41 lines
1.5 KiB
Python
41 lines
1.5 KiB
Python
from fastapi import APIRouter, Depends, HTTPException
|
|
from sqlalchemy.orm import Session
|
|
from app.database import get_db
|
|
from app.schemas.category import CategoryCreate, CategoryUpdate, CategoryResponse
|
|
from app.services import category_service
|
|
|
|
router = APIRouter()
|
|
|
|
|
|
@router.post("", response_model=CategoryResponse, status_code=201)
|
|
def create(data: CategoryCreate, db: Session = Depends(get_db)):
|
|
return category_service.create_category(db, data)
|
|
|
|
|
|
@router.get("", response_model=list[CategoryResponse])
|
|
def listar(db: Session = Depends(get_db)):
|
|
return category_service.get_categories(db)
|
|
|
|
|
|
@router.get("/{category_id}", response_model=CategoryResponse)
|
|
def obtener(category_id: str, db: Session = Depends(get_db)):
|
|
cat = category_service.get_category(db, category_id)
|
|
if not cat:
|
|
raise HTTPException(status_code=404, detail="Categoría no encontrada")
|
|
return cat
|
|
|
|
|
|
@router.put("/{category_id}", response_model=CategoryResponse)
|
|
def actualizar(category_id: str, data: CategoryUpdate, db: Session = Depends(get_db)):
|
|
cat = category_service.update_category(db, category_id, data)
|
|
if not cat:
|
|
raise HTTPException(status_code=404, detail="Categoría no encontrada")
|
|
return cat
|
|
|
|
|
|
@router.delete("/{category_id}", status_code=204)
|
|
def eliminar(category_id: str, db: Session = Depends(get_db)):
|
|
ok = category_service.delete_category(db, category_id)
|
|
if not ok:
|
|
raise HTTPException(status_code=404, detail="Categoría no encontrada")
|