from app.api.adapting_supply_chain import schema
from app.dependency.authantication import JWTPayloadSchema
from sqlalchemy.orm import Session
from app.locale.messages import Messages
from fastapi import HTTPException
from app.utils.schemas_utils import CustomResponse
from typing import List

from app.models.main.adapting_supply_chain import AdaptingSupplyChainBase, TblAdaptingSupplyChain

class AdaptingSupplyChainService:
    def __init__(self, db:Session, token:JWTPayloadSchema):
        self.db = db
        self.token = token
        
    async def created(self, request:schema.AdaptingSupplyCreate):
        created_data = AdaptingSupplyChainBase.model_validate(request.model_dump())
        TblAdaptingSupplyChain.create(created_data, self.db)
        self.db.commit()
        return CustomResponse(status="1", message=Messages.ADAPTING_SUPPLY_CHAIN)
    
    async def geted(self, group_id:int):
        geted_data = TblAdaptingSupplyChain.get(group_id, self.db)
        if not geted_data:
            raise HTTPException(status_code=404, detail="Get group ID not found")
        return [schema.AdaptingSupplyResponse.model_validate(get_group) for get_group in geted_data]
    
    async def updated(self, request:List[schema.AdaptingSupplyUpdate]):
        for req in request:
            updated_data = AdaptingSupplyChainBase.model_validate(req.model_dump())
            if updated_data.adapting_id is None:
                return CustomResponse(status="-1", message=Messages.ADAPTING_SUPPLY_CHAIN_NOT)
            TblAdaptingSupplyChain.update(updated_data.adapting_id, updated_data, self.db)
        self.db.commit()
        return CustomResponse(status="1", message=Messages.ADAPTING_SUPPLY_CHAIN_UPDATE)
        
    async def deleted(self, adapting_id:int):
        deleted_data = TblAdaptingSupplyChain.delete(adapting_id, self.db)
        if not deleted_data:
            return CustomResponse(status="-1", message=Messages.ADAPTING_SUPPLY_CHAIN_NOT)
        return CustomResponse(status="1", message=Messages.ADAPTING_SUPPLY_CHAIN_DELETE)