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

categories_under_promotions_router = APIRouter()

@categories_under_promotions_router.post("/create_categories_under_promotions", response_model_exclude_none=True)
async def create_categories_under_promotions(request:schema.CategoriesUnderPromotionsCreate, db:Session = Depends(get_db), token:JWTPayloadSchema = Depends(get_current_student)):
    return await service.CategoriesUnderPromotionsService(db,token).created(request)

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

@categories_under_promotions_router.put("/update_categories_under_promotions", response_model_exclude_none=True)
async def update_categories_under_promotions(request:List[schema.CategoriesUnderPromotionsUpdate], db:Session = Depends(get_db), token:JWTPayloadSchema = Depends(get_current_student)):
    return await service.CategoriesUnderPromotionsService(db,token).updated(request)

@categories_under_promotions_router.delete("/delete_categories_under_promotions", response_model_exclude_none=True)
async def delete_categories_under_promotions(categories_id:int, db:Session = Depends(get_db), token:JWTPayloadSchema = Depends(get_current_student)):
    return await service.CategoriesUnderPromotionsService(db,token).deleted(categories_id)
