From b272fec78e30d1a10f3ab761684a119193391296 Mon Sep 17 00:00:00 2001 From: zhangqian <zhangqian@123.com> Date: 星期二, 19 十一月 2024 17:08:57 +0800 Subject: [PATCH] 解决冲突 --- app/api/chat.py | 40 ++++++++++++++++++++++++++++++++++++++++ 1 files changed, 40 insertions(+), 0 deletions(-) diff --git a/app/api/chat.py b/app/api/chat.py index ea1be48..b5bfd6a 100644 --- a/app/api/chat.py +++ b/app/api/chat.py @@ -11,6 +11,7 @@ from app.models.base_model import get_db from app.models.user_model import UserModel from app.service.dialog import update_session_history +from app.service.basic import BasicService from app.service.ragflow import RagflowService from app.service.service_token import get_bisheng_token, get_ragflow_token @@ -196,6 +197,45 @@ await task except asyncio.CancelledError: pass + elif agent_type == AgentType.BASIC: + try: + while True: + # 鎺ユ敹鍓嶇娑堟伅 + message = await websocket.receive_json() + question = message.get("message") + if not question: + await websocket.send_json({"message": "Invalid request", "type": "error"}) + continue + + service = BasicService(base_url=settings.basic_base_url) + complete_response = "" + async for result in service.excel_talk(question, chat_id): + try: + if result[:5] == "data:": + # 濡傛灉鏄紝鍒欐埅鍙栨帀鍓�5涓瓧绗︼紝骞跺幓闄ら灏剧┖鐧界 + text = result[5:].strip() + else: + # 鍚﹀垯锛屼繚鎸佸師鏍� + text = result + complete_response += text + try: + json_data = json.loads(complete_response) + output = json_data.get("output", "") + result = {"message": output, "type": "message"} + await websocket.send_json(result | json_data) + complete_response = "" + except json.JSONDecodeError as e: + print(f"Error decoding JSON: {e}") + print(f"Response text: {text}") + except Exception as e2: + result = {"message": f"鍐呴儴閿欒锛� {e2}", "type": "close"} + await websocket.send_json(result) + print(f"Error process message of basic agent: {e2}") + except Exception as e: + await websocket.send_json({"message": str(e), "type": "error"}) + finally: + await websocket.close() + print(f"Client {agent_id} disconnected") else: ret = {"message": "Agent not found", "type": "close"} await websocket.send_json(ret) -- Gitblit v1.8.0