File size: 1,954 Bytes
04f25f0
 
 
 
ad3d8b0
 
 
 
 
04f25f0
 
 
 
f148dc8
04f25f0
 
 
 
 
 
 
 
 
 
 
 
 
 
 
ad3d8b0
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
c951f9c
ad3d8b0
 
 
 
 
04f25f0
 
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
from fastapi import APIRouter, HTTPException
from openai import OpenAI

from ..models.chat import ChatRequest, ChatResponse, ChatMessage
from ..services.metrics_logger import (
    log_chat_answer,
    save_chat_answer_to_supabase,
    metrics_enabled,
)

router = APIRouter()


@router.post("", response_model=ChatResponse, summary="Chat using generated system prompt")
async def chat(req: ChatRequest):
    if not req.system_prompt:
        raise HTTPException(status_code=400, detail="system_prompt is required")

    messages = [{"role": "system", "content": req.system_prompt}]
    for m in req.messages:
        messages.append({"role": m.role, "content": m.content})

    try:
        client = OpenAI()
        resp = client.chat.completions.create(
            model="gpt-4o-mini",
            messages=messages,
        )
        answer = resp.choices[0].message.content or ""

        if metrics_enabled():
            provenance = "primary_plus_secondary" if "SECONDARY SOURCE" in req.system_prompt else "primary_only"
            try:
                # Best-effort file log
                log_chat_answer(
                    question=req.messages[-1].content if req.messages else "",
                    answer=answer,
                    provenance=provenance,
                    user=None,
                )
                # Best-effort Supabase log
                save_chat_answer_to_supabase(
                    question=req.messages[-1].content if req.messages else "",
                    answer=answer,
                    system_prompt=req.system_prompt,
                    user_id=req.user_id,
                    url=None,
                )
            except Exception as log_exc:
                print(f"⚠️ Metrics logging skipped: {log_exc}")

        return ChatResponse(message=ChatMessage(role="assistant", content=answer))
    except Exception as exc:
        raise HTTPException(status_code=500, detail=str(exc))