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

info_tech_router = APIRouter()

@info_tech_router.post("/info_tech", response_model_exclude_none=True)
async def create_info_tech(request:List[InfoTechCreate], db:Session = Depends(get_db),token: JWTPayloadSchema = Depends(get_current_student)):
    return await InfoTechService(db,token).create_info_tech(request)

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

@info_tech_router.get("/get_sum_of_total_info_tech", response_model_exclude_none=True)
async def get_sum_of_total(group_id:int, db:Session = Depends(get_db),token: JWTPayloadSchema = Depends(get_current_student)):
    return await service.InfoTechService(db,token).get_and_sum_info_tech(group_id)

@info_tech_router.put("/update_info_tech", response_model_exclude_none=True)
async def update_info_tech(request:List[InfoTechUpdate], db:Session = Depends(get_db), token: JWTPayloadSchema = Depends(get_current_student)):
    return await service.InfoTechService(db,token).update_info_tech(request)

@info_tech_router.delete("/delete_info_tech", response_model_exclude_none=True)
async def delete_info_tech(info_tech_delete_id:int ,db:Session = Depends(get_db), token: JWTPayloadSchema = Depends(get_current_student)):
    return await service.InfoTechService(db,token).delete_info_tech(info_tech_delete_id)