from typing import List
from fastapi import APIRouter, Depends
from sqlalchemy.orm import Session
from app.api.electrical_cabling import schema, service
from app.database.main.mysql import get_db
from app.dependency.authantication import JWTPayloadSchema, get_current_student

electrical_cabling_router = APIRouter()

@electrical_cabling_router.post("/create_electrical_cabling", response_model_exclude_none=True)
async def create_electrical_cabling(request:List[schema.ElectricalCablingCreate], db:Session = Depends(get_db),token: JWTPayloadSchema = Depends(get_current_student)):
    return await service.ElectricalCablingService(db,token).create_electrical_cabling(request)

@electrical_cabling_router.get("/get_electrical_cabling/{group_id}", response_model_exclude_none=True)
async def get_electrical_cabling(group_id:int, db:Session = Depends(get_db),token: JWTPayloadSchema = Depends(get_current_student)):
    return await service.ElectricalCablingService(db,token).get_electrical_cabling1(group_id)

@electrical_cabling_router.get("/get_sum_electrical_cabling", response_model_exclude_none=True)
async def get_sum_electrical_cabling(group_id:int, db:Session = Depends(get_db),token: JWTPayloadSchema = Depends(get_current_student)):
    return await service.ElectricalCablingService(db,token).get_sum_electrical(group_id)

@electrical_cabling_router.put("/update_electrical_cabling", response_model_exclude_none=True)
async def update_electrical_cabling(request:List[schema.ElectricalCablingUpdate], db:Session = Depends(get_db),token: JWTPayloadSchema = Depends(get_current_student)):
    return await service.ElectricalCablingService(db,token).update_elecctrical_cabling(request)

@electrical_cabling_router.delete("/delete_electrical_cabling", response_model_exclude_none=True)
async def delete_electrical_cabling(electrical_id:int, db:Session = Depends(get_db),token: JWTPayloadSchema = Depends(get_current_student)):
    return await service.ElectricalCablingService(db,token).delete_elecctrical_cabling(electrical_id)