Files
PYTV/api/routers/schedule.py
2026-03-08 16:48:58 -04:00

95 lines
3.4 KiB
Python

from ninja import Router, Schema
from typing import List, Optional
from core.models import ScheduleTemplate, Channel, ScheduleBlock
from django.shortcuts import get_object_or_404
from datetime import date
router = Router(tags=["schedule"])
class ScheduleTemplateSchema(Schema):
id: int
name: str
description: Optional[str] = None
timezone_name: str
valid_from_date: Optional[date] = None
valid_to_date: Optional[date] = None
priority: int
is_active: bool
channel_id: int
class ScheduleTemplateCreateSchema(Schema):
name: str
description: Optional[str] = None
timezone_name: str
valid_from_date: Optional[date] = None
valid_to_date: Optional[date] = None
priority: int = 0
is_active: bool = True
channel_id: int
@router.get("/template/", response=List[ScheduleTemplateSchema])
def list_schedule_templates(request):
return ScheduleTemplate.objects.all()
@router.get("/template/{template_id}", response=ScheduleTemplateSchema)
def get_schedule_template(request, template_id: int):
return get_object_or_404(ScheduleTemplate, id=template_id)
@router.post("/template/", response={201: ScheduleTemplateSchema})
def create_schedule_template(request, payload: ScheduleTemplateCreateSchema):
channel = get_object_or_404(Channel, id=payload.channel_id)
template = ScheduleTemplate.objects.create(
channel=channel,
name=payload.name,
description=payload.description,
timezone_name=payload.timezone_name,
valid_from_date=payload.valid_from_date,
valid_to_date=payload.valid_to_date,
priority=payload.priority,
is_active=payload.is_active
)
# Create a default 24/7 programming block automatically to avoid
# complex block management in the UI
from datetime import time
ScheduleBlock.objects.create(
schedule_template=template,
name="Default 24/7 Block",
block_type=ScheduleBlock.BlockType.PROGRAMMING,
start_local_time=time(0, 0, 0),
end_local_time=time(23, 59, 59),
day_of_week_mask=127,
)
return 201, template
class GenerateScheduleSchema(Schema):
target_date: date
@router.post("/generate/{channel_id}")
def generate_schedule(request, channel_id: int, payload: GenerateScheduleSchema):
channel = get_object_or_404(Channel, id=channel_id)
# Inline import to prevent circular dependency issues during initialization
from core.services.scheduler import ScheduleGenerator
generator = ScheduleGenerator(channel=channel)
airings_created = generator.generate_for_date(payload.target_date)
return {"status": "success", "airings_created": airings_created}
@router.delete("/template/{template_id}", response={204: None})
def delete_schedule_template(request, template_id: int):
template = get_object_or_404(ScheduleTemplate, id=template_id)
template.delete()
return 204, None
@router.post("/generate-today/{channel_id}")
def generate_schedule_today(request, channel_id: int):
"""Convenience endpoint: generates today's schedule for a channel."""
from datetime import date
from core.services.scheduler import ScheduleGenerator
channel = get_object_or_404(Channel, id=channel_id)
generator = ScheduleGenerator(channel=channel)
airings_created = generator.generate_for_date(date.today())
return {"status": "success", "airings_created": airings_created}