Files

85 lines
2.6 KiB
Python
Raw Permalink Normal View History

2026-03-11 16:28:04 +08:00
from uuid import UUID
2026-03-13 23:53:26 +08:00
from datetime import datetime, timezone
2026-03-11 16:28:04 +08:00
from fastapi import APIRouter, Depends, Query
2026-03-13 23:53:26 +08:00
from sqlalchemy import select
2026-03-11 16:28:04 +08:00
from sqlalchemy.ext.asyncio import AsyncSession
from app.core.database import get_db
from app.models.case import Case, CaseStatus
from app.repositories.case_repo import CaseRepository
2026-03-13 23:53:26 +08:00
from app.schemas.case import (
CaseCreate,
CaseUpdate,
CaseOut,
CaseListOut,
CaseDeleteIn,
CaseDeleteOut,
)
2026-03-11 16:28:04 +08:00
router = APIRouter()
@router.post("", response_model=CaseOut, status_code=201)
async def create_case(body: CaseCreate, db: AsyncSession = Depends(get_db)):
repo = CaseRepository(db)
case = Case(
case_no=body.case_no,
title=body.title,
victim_name=body.victim_name,
handler=body.handler,
)
case = await repo.create(case)
return case
@router.get("", response_model=CaseListOut)
async def list_cases(
offset: int = Query(0, ge=0),
limit: int = Query(50, ge=1, le=200),
status: CaseStatus | None = None,
search: str | None = None,
db: AsyncSession = Depends(get_db),
):
repo = CaseRepository(db)
items, total = await repo.list_cases(offset=offset, limit=limit, status=status, search=search)
return CaseListOut(items=items, total=total)
@router.get("/{case_id}", response_model=CaseOut)
async def get_case(case_id: UUID, db: AsyncSession = Depends(get_db)):
repo = CaseRepository(db)
case = await repo.get(case_id)
2026-03-13 23:53:26 +08:00
if not case or case.deleted_at is not None:
2026-03-11 16:28:04 +08:00
from fastapi import HTTPException
raise HTTPException(status_code=404, detail="案件不存在")
return case
@router.patch("/{case_id}", response_model=CaseOut)
async def update_case(case_id: UUID, body: CaseUpdate, db: AsyncSession = Depends(get_db)):
repo = CaseRepository(db)
case = await repo.get(case_id)
2026-03-13 23:53:26 +08:00
if not case or case.deleted_at is not None:
2026-03-11 16:28:04 +08:00
from fastapi import HTTPException
raise HTTPException(status_code=404, detail="案件不存在")
case = await repo.update(case, body.model_dump(exclude_unset=True))
return case
2026-03-13 23:53:26 +08:00
@router.delete("", response_model=CaseDeleteOut)
async def delete_cases(body: CaseDeleteIn, db: AsyncSession = Depends(get_db)):
if not body.case_ids:
return CaseDeleteOut(deleted=0, message="未选择需要删除的案件")
result = await db.execute(
select(Case).where(Case.id.in_(body.case_ids), Case.deleted_at.is_(None))
)
cases = list(result.scalars().all())
now = datetime.now(timezone.utc)
for c in cases:
c.deleted_at = now
await db.flush()
return CaseDeleteOut(deleted=len(cases), message=f"已删除 {len(cases)} 个案件")