|
| 1 | +from datetime import date, datetime |
| 2 | + |
| 3 | +from fastapi import APIRouter, Depends, HTTPException, status |
| 4 | +from fastapi.encoders import jsonable_encoder |
| 5 | +from fastapi.responses import JSONResponse |
| 6 | +from pydantic import ValidationError |
| 7 | + |
| 8 | +import database |
| 9 | +import event.crud |
| 10 | +from dependencies import perm_admin |
| 11 | +from event.models import Event, EventCreate, EventDelete, EventUpdate |
| 12 | +from event.tables import EventDB |
| 13 | +from utils.shared_models import DetailModel, SuccessResponse |
| 14 | + |
| 15 | +router = APIRouter( |
| 16 | + prefix="/event", |
| 17 | + tags=["event"], |
| 18 | +) |
| 19 | + |
| 20 | + |
| 21 | +@router.get( |
| 22 | + "", |
| 23 | + description="Get all events", |
| 24 | + response_model=list[Event], |
| 25 | + operation_id="get_all_events", |
| 26 | +) |
| 27 | +async def get_all_events( |
| 28 | + db_session: database.DBSession, |
| 29 | +): |
| 30 | + events_list = await event.crud.get_all_events(db_session) |
| 31 | + |
| 32 | + return events_list |
| 33 | + |
| 34 | + |
| 35 | +@router.get( |
| 36 | + "/{year}", |
| 37 | + description="Get events that start OR end in this year", |
| 38 | + response_model=list[Event], |
| 39 | + operation_id="get_events_for_this_year", |
| 40 | +) |
| 41 | +async def get_events_for_this_year( |
| 42 | + db_session: database.DBSession, |
| 43 | + year: int, |
| 44 | +): |
| 45 | + events_list = await event.crud.get_events_for_this_year(db_session, year) |
| 46 | + |
| 47 | + return events_list |
| 48 | + |
| 49 | + |
| 50 | +@router.get( |
| 51 | + "/{year}/{month}", |
| 52 | + description="Get events that start OR end in the given year and month", |
| 53 | + response_model=list[Event], |
| 54 | + operation_id="get_events_for_this_year_month", |
| 55 | +) |
| 56 | +async def get_events_for_this_year_month(db_session: database.DBSession, year: int, month: int): |
| 57 | + events_list = await event.crud.get_events_for_this_year_month(db_session, year, month) |
| 58 | + |
| 59 | + return events_list |
| 60 | + |
| 61 | + |
| 62 | +@router.post( |
| 63 | + "", |
| 64 | + description="Create a new event", |
| 65 | + response_model=Event, |
| 66 | + status_code=status.HTTP_201_CREATED, |
| 67 | + responses={ |
| 68 | + 500: {"description": "failed to fetch new event", "model": DetailModel}, |
| 69 | + }, |
| 70 | + operation_id="create_event", |
| 71 | + dependencies=[Depends(perm_admin)], |
| 72 | +) |
| 73 | +async def create_event(db_session: database.DBSession, body: EventCreate): |
| 74 | + new_event = EventDB(**body.model_dump()) |
| 75 | + await event.crud.create_event( |
| 76 | + db_session, |
| 77 | + new_event, |
| 78 | + ) |
| 79 | + |
| 80 | + await db_session.commit() |
| 81 | + await db_session.refresh(new_event) |
| 82 | + |
| 83 | + return new_event |
| 84 | + |
| 85 | + |
| 86 | +@router.patch( |
| 87 | + "/{eid}", |
| 88 | + description="Update an Event detail", |
| 89 | + response_model=Event, |
| 90 | + responses={404: {"description": "Event doesn't exist."}}, |
| 91 | + operation_id="update_event", |
| 92 | + dependencies=[Depends(perm_admin)], |
| 93 | +) |
| 94 | +async def update_event(db_session: database.DBSession, eid: int, body: EventUpdate): |
| 95 | + db_event = await event.crud.get_event_by_eid(db_session, eid) |
| 96 | + if db_event is None: |
| 97 | + raise HTTPException(status_code=status.HTTP_404_NOT_FOUND, detail="Event doesn't exist.") |
| 98 | + |
| 99 | + db_data = Event.model_validate(db_event).model_dump() |
| 100 | + patch_data = body.model_dump(exclude_unset=True) |
| 101 | + |
| 102 | + merged_data = {**db_data, **patch_data} |
| 103 | + try: |
| 104 | + Event.model_validate(merged_data) |
| 105 | + except ValidationError as e: |
| 106 | + raise HTTPException( |
| 107 | + status_code=status.HTTP_422_UNPROCESSABLE_ENTITY, detail=jsonable_encoder(e.errors()) |
| 108 | + ) from e |
| 109 | + |
| 110 | + for key, value in patch_data.items(): |
| 111 | + setattr(db_event, key, value) |
| 112 | + |
| 113 | + await db_session.commit() |
| 114 | + await db_session.refresh(db_event) |
| 115 | + |
| 116 | + return db_event |
| 117 | + |
| 118 | + |
| 119 | +@router.delete( |
| 120 | + "/{eid}", |
| 121 | + description="Delete an event", |
| 122 | + response_model=EventDelete, |
| 123 | + responses={404: {"description": "Event doesn't exist."}}, |
| 124 | + operation_id="delete_event", |
| 125 | + dependencies=[Depends(perm_admin)], |
| 126 | +) |
| 127 | +async def delete_event(db_session: database.DBSession, eid: int): |
| 128 | + rows_deleted = await event.crud.delete_event(db_session, eid) |
| 129 | + |
| 130 | + if rows_deleted == 0: |
| 131 | + raise HTTPException(status_code=status.HTTP_404_NOT_FOUND, detail="Event doesn't exist.") |
| 132 | + |
| 133 | + await db_session.commit() |
| 134 | + return EventDelete(result=True, eid=eid) |
0 commit comments