from fastapi import APIRouter, Depends, Query, status
from sqlalchemy.orm import Session
from uuid import UUID

from src.apps.base.schemas.response_model import ResponseModel
from src.utils import constants
from src.core.dependencies import get_db
from src.utils.constants import MAX_PER_PAGE
from typing import Optional
from src.apps.wine.word_reserved.schemas.word_reserved import WordReservedFilterSchema
from src.apps.wine.word_reserved.services.word_reserved import get_all_word_reserved

router = APIRouter(prefix="", tags=["Reserved Words"])

@router.get("", response_model=ResponseModel, summary="Get all Reserved Words")
async def list_reserved_words(
    db: Session = Depends(get_db),
    payload: WordReservedFilterSchema = Depends(),
    page: int = Query(default=1, ge=1, description="Page number"),
    per_page: int = Query(
        default=constants.DEFAULT_PER_PAGE,
        ge=1,
        le=constants.MAX_PER_PAGE,
        description="Items per page",
    ),
):
    data = await get_all_word_reserved(db=db,payload=payload, page=page, per_page=per_page)
    return ResponseModel(
        data=data,
        status_code=status.HTTP_200_OK,
        success=True,
        message="Reserved Words fetched successfully"
    )