fediversion/backend/routers/attendance.py
fullsizemalt b4cddf41ea feat: Initialize Fediversion multi-band platform
- Fork elmeg-demo codebase for multi-band support
- Add data importer infrastructure with base class
- Create band-specific importers:
  - phish.py: Phish.net API v5
  - grateful_dead.py: Grateful Stats API
  - setlistfm.py: Dead & Company, Billy Strings (Setlist.fm)
- Add spec-kit configuration for Gemini
- Update README with supported bands and architecture
2025-12-28 12:39:28 -08:00

84 lines
2.7 KiB
Python

from typing import List, Optional
from fastapi import APIRouter, Depends, HTTPException, Query
from sqlmodel import Session, select
from database import get_session
from models import Attendance, User, Show
from schemas import AttendanceCreate, AttendanceRead
from auth import get_current_user
from services.gamification import award_xp, check_and_award_badges, update_streak, XP_REWARDS
router = APIRouter(prefix="/attendance", tags=["attendance"])
@router.post("/", response_model=AttendanceRead)
def mark_attendance(
attendance: AttendanceCreate,
session: Session = Depends(get_session),
current_user: User = Depends(get_current_user)
):
# Check if already attended
existing = session.exec(
select(Attendance)
.where(Attendance.user_id == current_user.id)
.where(Attendance.show_id == attendance.show_id)
).first()
if existing:
# Update notes if provided, or just return existing
if attendance.notes:
existing.notes = attendance.notes
session.add(existing)
session.commit()
session.refresh(existing)
return existing
db_attendance = Attendance(**attendance.model_dump(), user_id=current_user.id)
session.add(db_attendance)
# Award XP for marking attendance
new_xp, level_up = award_xp(session, current_user, XP_REWARDS["attendance_add"], "attendance")
update_streak(session, current_user)
new_badges = check_and_award_badges(session, current_user)
session.commit()
session.refresh(db_attendance)
return db_attendance
@router.delete("/{show_id}")
def remove_attendance(
show_id: int,
session: Session = Depends(get_session),
current_user: User = Depends(get_current_user)
):
attendance = session.exec(
select(Attendance)
.where(Attendance.user_id == current_user.id)
.where(Attendance.show_id == show_id)
).first()
if not attendance:
raise HTTPException(status_code=404, detail="Attendance not found")
session.delete(attendance)
session.commit()
return {"ok": True}
@router.get("/me", response_model=List[AttendanceRead])
def get_my_attendance(
session: Session = Depends(get_session),
current_user: User = Depends(get_current_user)
):
return session.exec(select(Attendance).where(Attendance.user_id == current_user.id)).all()
@router.get("/show/{show_id}", response_model=List[AttendanceRead])
def get_show_attendance(
show_id: int,
session: Session = Depends(get_session),
offset: int = 0,
limit: int = 100
):
return session.exec(
select(Attendance)
.where(Attendance.show_id == show_id)
.offset(offset)
.limit(limit)
).all()