flare / chat_handler.py
ciyidogan's picture
Update chat_handler.py
fdebccf verified
raw
history blame
2.59 kB
from fastapi import Request
from fastapi.responses import JSONResponse
import traceback
from llm_model import Message, LLMModel
from intent_api import execute_intent
from parse_llm_blocks import parse_llm_blocks
from log import log
async def handle_chat(msg: Message, request: Request, app, service_config, session, llm_model: LLMModel):
try:
user_input = msg.user_input.strip()
log(f"💬 Kullanıcı input'u: '{user_input}'")
project_name = session.project_name
project_config = service_config.get_project_llm_config(project_name)
system_prompt = service_config.system_prompt
# Chat history'ye user mesajını ekle
session.chat_history.append({"role": "user", "content": user_input})
# === LLM çağrısı
llm_response = await llm_model.generate_response_with_messages(session.chat_history, project_config, system_prompt)
log(f"🤖 LLM cevabı: {llm_response}")
# === LLM cevabını parse et
parsed = parse_llm_blocks(llm_response)
intent = parsed["intent"]
params = parsed["params"]
missing = parsed["missing"]
action_json = parsed["action_json"]
answer = parsed.get("answer")
# Chat history'ye assistant cevabını ekle
session.chat_history.append({"role": "assistant", "content": llm_response})
# === INTENT yok → direkt cevap
if intent == "NONE":
session.awaiting_variable = None
session.last_intent = None
session.variables.clear()
return {"response": answer}
# === INTENT varsa → parametreleri güncelle
session.last_intent = intent
session.variables.update(params)
# Eksik parametre varsa → kullanıcıdan istenecek
if missing:
session.awaiting_variable = missing[0]
return {"response": f"Lütfen {', '.join(missing)} bilgisini belirtir misin?"}
# === API çağrısı yap
log("🚀 execute_intent() çağrılıyor...")
result = execute_intent(
intent,
user_input,
session.__dict__,
project_name,
service_config
)
if "reply" in result:
return {"response": result["reply"]}
elif "fallback" in result:
return {"response": result["fallback"]}
else:
return {"response": "Beklenmeyen bir hata oluştu."}
except Exception as e:
traceback.print_exc()
return JSONResponse(content={"error": str(e)}, status_code=500)