fediversion/backend/routers/tours.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

65 lines
1.9 KiB
Python

from typing import List
from fastapi import APIRouter, Depends, HTTPException, Query
from sqlmodel import Session, select, func
from database import get_session
from models import Tour, Show, User
from schemas import TourCreate, TourRead, TourUpdate
from auth import get_current_user
router = APIRouter(prefix="/tours", tags=["tours"])
@router.post("/", response_model=TourRead)
def create_tour(
tour: TourCreate,
session: Session = Depends(get_session),
current_user: User = Depends(get_current_user)
):
db_tour = Tour.model_validate(tour)
session.add(db_tour)
session.commit()
session.refresh(db_tour)
return db_tour
@router.get("/")
def read_tours(
offset: int = 0,
limit: int = Query(default=100, le=500),
session: Session = Depends(get_session)
):
"""Get all tours with show counts"""
tours = session.exec(select(Tour).offset(offset).limit(limit)).all()
# Get show counts per tour
result = []
for tour in tours:
show_count = session.exec(
select(func.count(Show.id)).where(Show.tour_id == tour.id)
).one()
tour_dict = tour.model_dump()
tour_dict["show_count"] = show_count
result.append(tour_dict)
return result
@router.get("/{slug}")
def read_tour(slug: str, session: Session = Depends(get_session)):
"""Get tour by slug or ID"""
# Try as ID first (for backwards compatibility)
try:
tour_id = int(slug)
tour = session.get(Tour, tour_id)
except ValueError:
tour = session.exec(select(Tour).where(Tour.slug == slug)).first()
if not tour:
raise HTTPException(status_code=404, detail="Tour not found")
# Add show count
show_count = session.exec(
select(func.count(Show.id)).where(Show.tour_id == tour.id)
).one()
tour_dict = tour.model_dump()
tour_dict["show_count"] = show_count
return tour_dict