feat: add GET /shows/by-episode/{episode_number} endpoint
Allows looking up shows by episode number instead of internal DB ID, enabling IRC bot commands like !playlist 530 to resolve directly. Made-with: Cursor
This commit is contained in:
@@ -89,6 +89,20 @@ def create_app(
|
||||
for s in shows
|
||||
]
|
||||
|
||||
@app.get("/shows/by-episode/{episode_number}")
|
||||
def show_by_episode(episode_number: int):
|
||||
show = db.get_show_by_episode_number(episode_number)
|
||||
if show is None:
|
||||
raise HTTPException(status_code=404, detail=f"No show with episode number {episode_number}")
|
||||
tracks = db.get_show_tracks(show.id)
|
||||
return {
|
||||
"show_id": show.id,
|
||||
"episode_number": show.episode_number,
|
||||
"week_start": show.week_start.isoformat(),
|
||||
"week_end": show.week_end.isoformat(),
|
||||
"tracks": tracks,
|
||||
}
|
||||
|
||||
@app.get("/shows/{show_id}")
|
||||
def show_detail(show_id: int):
|
||||
shows = db.list_shows(limit=1000, offset=0)
|
||||
|
||||
@@ -239,6 +239,24 @@ class Database:
|
||||
for row in rows
|
||||
]
|
||||
|
||||
def get_show_by_episode_number(self, episode_number: int) -> Show | None:
|
||||
conn = self._connect()
|
||||
row = conn.execute(
|
||||
"SELECT id, week_start, week_end, created_at, episode_number "
|
||||
"FROM shows WHERE episode_number = ? LIMIT 1",
|
||||
(episode_number,),
|
||||
).fetchone()
|
||||
conn.close()
|
||||
if row is None:
|
||||
return None
|
||||
return Show(
|
||||
id=row["id"],
|
||||
week_start=datetime.fromisoformat(row["week_start"]),
|
||||
week_end=datetime.fromisoformat(row["week_end"]),
|
||||
created_at=datetime.fromisoformat(row["created_at"]),
|
||||
episode_number=row["episode_number"],
|
||||
)
|
||||
|
||||
def get_latest_episode_number(self) -> int | None:
|
||||
conn = self._connect()
|
||||
row = conn.execute(
|
||||
|
||||
Reference in New Issue
Block a user