Files
Benjamin Boenisch 5a31f52310 Initial commit: breakpilot-lehrer - Lehrer KI Platform
Services: Admin-Lehrer, Backend-Lehrer, Studio v2, Website,
Klausur-Service, School-Service, Voice-Service, Geo-Service,
BreakPilot Drive, Agent-Core

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-02-11 23:47:26 +01:00

97 lines
2.5 KiB
Python

"""
Playbooks Route - System Prompt Verwaltung.
"""
import logging
from typing import Optional
from fastapi import APIRouter, HTTPException, Depends
from pydantic import BaseModel
from ..services.playbook_service import get_playbook_service, Playbook
from ..middleware.auth import verify_api_key
logger = logging.getLogger(__name__)
router = APIRouter(prefix="/playbooks", tags=["Playbooks"])
class PlaybookSummary(BaseModel):
"""Zusammenfassung eines Playbooks (ohne System Prompt)."""
id: str
name: str
description: str
prompt_version: str
recommended_models: list[str]
class PlaybookDetail(BaseModel):
"""Vollständige Playbook-Details."""
id: str
name: str
description: str
system_prompt: str
prompt_version: str
recommended_models: list[str]
tool_policy: dict
status: str
class PlaybookListResponse(BaseModel):
"""Response für Playbook-Liste."""
items: list[PlaybookSummary]
@router.get("", response_model=PlaybookListResponse)
async def list_playbooks(
status: Optional[str] = "published",
_: str = Depends(verify_api_key),
):
"""
Liste verfügbarer Playbooks.
Playbooks sind versionierte System-Prompt-Vorlagen für spezifische Schulkontexte.
"""
service = get_playbook_service()
playbooks = service.list_playbooks(status=status)
return PlaybookListResponse(
items=[
PlaybookSummary(
id=p.id,
name=p.name,
description=p.description,
prompt_version=p.prompt_version,
recommended_models=p.recommended_models,
)
for p in playbooks
]
)
@router.get("/{playbook_id}", response_model=PlaybookDetail)
async def get_playbook(
playbook_id: str,
_: str = Depends(verify_api_key),
):
"""
Details zu einem Playbook abrufen.
Enthält den vollständigen System Prompt und Tool-Policies.
"""
service = get_playbook_service()
playbook = service.get_playbook(playbook_id)
if not playbook:
raise HTTPException(status_code=404, detail=f"Playbook {playbook_id} not found")
return PlaybookDetail(
id=playbook.id,
name=playbook.name,
description=playbook.description,
system_prompt=playbook.system_prompt,
prompt_version=playbook.prompt_version,
recommended_models=playbook.recommended_models,
tool_policy=playbook.tool_policy,
status=playbook.status,
)