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

operating_expenses_router = APIRouter()

@operating_expenses_router.post("/create_operating_expense", response_model_exclude_none=True)
async def create_operating_expense(request:schema.OperatingExpensesCreate, db:Session = Depends(get_db),token: JWTPayloadSchema = Depends(get_current_student)):
    return await OperatingExpensesService(db,token).create_operating_Expenses(request)

@operating_expenses_router.get("/get_operating_expenses{group_id}", response_model_exclude_none=True)
async def get_operating_expenses(group_id:int, db:Session = Depends(get_db),token: JWTPayloadSchema = Depends(get_current_student)):
    return await OperatingExpensesService(db,token).get_operating_Expenses(group_id)

@operating_expenses_router.put("/update_operating_expenses", response_model_exclude_none=True)
async def update_operating_expenses(request:List[schema.OperatingExpensesUpdate], db:Session = Depends(get_db),token: JWTPayloadSchema = Depends(get_current_student)):
    return await OperatingExpensesService(db,token).update_operating_expenses(request)

@operating_expenses_router.delete("/delete_operating_expenses", response_model_exclude_none=True)
async def delete_operating_expenses(operating_id:int, db:Session = Depends(get_db),token: JWTPayloadSchema = Depends(get_current_student)):
    return await OperatingExpensesService(db,token).delete_operating_expenses(operating_id)