Files
fast_api_template/backend/app/api/routes/items.py
T

98 lines
2.8 KiB
Python
Raw Normal View History

from typing import Any
from fastapi import APIRouter, HTTPException
2024-02-25 19:39:33 +01:00
from sqlmodel import func, select
2023-11-29 12:13:15 -05:00
from app.api.deps import CurrentUser, SessionDep
2024-02-25 19:39:33 +01:00
from app.models import Item, ItemCreate, ItemOut, ItemsOut, ItemUpdate, Message
router = APIRouter()
@router.get("/", response_model=ItemsOut)
def read_items(
session: SessionDep, current_user: CurrentUser, skip: int = 0, limit: int = 100
2023-12-27 13:37:05 -05:00
) -> Any:
"""
Retrieve items.
"""
statment = select(func.count()).select_from(Item)
count = session.exec(statment).one()
if current_user.is_superuser:
statement = select(Item).offset(skip).limit(limit)
2024-02-25 19:39:33 +01:00
items = session.exec(statement).all()
else:
statement = (
select(Item)
.where(Item.owner_id == current_user.id)
.offset(skip)
.limit(limit)
)
items = session.exec(statement).all()
return ItemsOut(data=items, count=count)
2023-12-27 13:37:05 -05:00
@router.get("/{id}", response_model=ItemOut)
def read_item(session: SessionDep, current_user: CurrentUser, id: int) -> Any:
"""
Get item by ID.
"""
item = session.get(Item, id)
if not item:
raise HTTPException(status_code=404, detail="Item not found")
if not current_user.is_superuser and (item.owner_id != current_user.id):
raise HTTPException(status_code=400, detail="Not enough permissions")
2023-12-27 13:37:05 -05:00
return item
2023-12-27 13:37:05 -05:00
@router.post("/", response_model=ItemOut)
def create_item(
*, session: SessionDep, current_user: CurrentUser, item_in: ItemCreate
2023-12-27 13:37:05 -05:00
) -> Any:
"""
Create new item.
"""
item = Item.model_validate(item_in, update={"owner_id": current_user.id})
session.add(item)
session.commit()
session.refresh(item)
2023-12-27 13:37:05 -05:00
return item
2023-12-27 13:37:05 -05:00
@router.put("/{id}", response_model=ItemOut)
def update_item(
*, session: SessionDep, current_user: CurrentUser, id: int, item_in: ItemUpdate
2023-12-27 13:37:05 -05:00
) -> Any:
"""
Update an item.
"""
item = session.get(Item, id)
if not item:
2020-02-07 17:28:45 -03:00
raise HTTPException(status_code=404, detail="Item not found")
if not current_user.is_superuser and (item.owner_id != current_user.id):
raise HTTPException(status_code=400, detail="Not enough permissions")
update_dict = item_in.model_dump(exclude_unset=True)
item.sqlmodel_update(update_dict)
session.add(item)
session.commit()
session.refresh(item)
2023-12-27 13:37:05 -05:00
return item
2024-02-13 09:25:58 -05:00
@router.delete("/{id}")
def delete_item(session: SessionDep, current_user: CurrentUser, id: int) -> Message:
"""
Delete an item.
"""
item = session.get(Item, id)
if not item:
raise HTTPException(status_code=404, detail="Item not found")
if not current_user.is_superuser and (item.owner_id != current_user.id):
raise HTTPException(status_code=400, detail="Not enough permissions")
session.delete(item)
session.commit()
2024-02-13 09:25:58 -05:00
return Message(message="Item deleted successfully")