Add Hearthkeeper preview endpoint

This commit is contained in:
2026-05-12 20:30:00 -05:00
parent 5c920fa309
commit 02fe426c94
2 changed files with 64 additions and 0 deletions

View File

@@ -398,6 +398,38 @@ class AgentOrchestrator:
"third_tick_after_interval": third_tick,
}
async def preview_hearthkeeper_prompt(self, session_id: str) -> dict:
"""Generate a Hearthkeeper prompt preview without sending or recording it."""
session_info = self.active_sessions.get(session_id)
if not session_info:
return {"generated": False, "reason": "session_not_found"}
recent_discussion_messages = []
async for db_session in get_session():
repo = Repository(db_session)
recent_discussion_messages = await repo.get_recent_human_messages(
session_id=session_id,
limit=5,
)
recent_discussion = [
message.content for message in recent_discussion_messages[:5]
]
agent_response = await self.hearthkeeper.generate_prompt(
theme=session_info.get("theme"),
dashboard=session_info.get("dashboard"),
recent_discussion=recent_discussion,
)
return {
"generated": True,
"session_id": session_id,
"agent_response": agent_response,
"theme": session_info.get("theme"),
"dashboard": session_info.get("dashboard"),
"recent_discussion": recent_discussion,
}
async def _count_response_actions(self, session_id: str, mode: str) -> int:
"""Count response actions for a mode in a session."""
async for db_session in get_session():

View File

@@ -302,6 +302,38 @@ async def test_loop_inactivity(
}
@app.post("/admin/hearthkeeper/preview", dependencies=[Depends(require_admin)])
async def preview_hearthkeeper_prompt(session_id: str | None = Form(None)) -> dict:
"""Generate a Hearthkeeper prompt preview without posting to Twitch."""
if not orchestrator:
raise HTTPException(status_code=503, detail="Orchestrator not initialized")
resolved_session_id = session_id or get_current_stream_session_id()
if not resolved_session_id:
raise HTTPException(status_code=404, detail="No active stream session found")
result = await orchestrator.preview_hearthkeeper_prompt(resolved_session_id)
if result.get("reason") == "session_not_found":
raise HTTPException(status_code=404, detail="Active session not found")
live_status = None
session_info = orchestrator.active_sessions.get(resolved_session_id)
if twitch_live_status and session_info:
live_status = (
await twitch_live_status.get_status(session_info["channel_name"])
).to_dict()
return {
"status": "preview_generated" if result.get("generated") else "failed",
"preview": result,
"would_post_now": await orchestrator.can_interact_with_chat(
session_info["channel_name"]
) if session_info else False,
"live_status": live_status,
"timestamp": datetime.utcnow().isoformat(),
}
def serialize_dashboard(dashboard) -> dict:
"""Serialize a dashboard database model into an API response."""
return Repository.serialize_dashboard(dashboard)