From c0d11dac469251c71b036c757c788615285c9683 Mon Sep 17 00:00:00 2001 From: zhangqian <zhangqian@123.com> Date: 星期五, 15 十一月 2024 10:57:10 +0800 Subject: [PATCH] 毕昇对话历史只返回了一条修正,按时间正序排列吧,json乱码修正 --- app/api/report.py | 23 ++++++++++++++++++----- 1 files changed, 18 insertions(+), 5 deletions(-) diff --git a/app/api/report.py b/app/api/report.py index 254695d..b2bac8a 100644 --- a/app/api/report.py +++ b/app/api/report.py @@ -65,24 +65,37 @@ files = data.get("files", []) steps = data.get("intermediate_steps", "") msg = data.get("message", "") + category = data.get("category", "") - if len(files) != 0 or (steps and last_message == "step") or msg or data["type"] == "close": + if len(files) != 0 or (msg and category != "answer") or data["type"] == "close": if data["type"] == "close": t = "close" else: t = "stream" process_files(files, agent_id) - result = {"step_message": steps, "message": msg, "type": t, "files": files} + result = {"message": msg, "type": t, "files": files} await websocket.send_json(result) - print(f"Forwarded to client, {chat_id}: {result}") + elif steps and last_message == "step": + result = {"step_message": steps, "type": "stream", "files": files} + await websocket.send_json(result) - last_message = "step" if steps else "message" + last_message = "message" if msg else "step" # 鍚姩涓や釜浠诲姟锛屽垎鍒鐞嗗鎴风鍜屾湇鍔$鐨勬秷鎭� tasks = [ asyncio.create_task(forward_to_service()), asyncio.create_task(forward_to_client()) ] + done, pending = await asyncio.wait(tasks, return_when=asyncio.FIRST_COMPLETED) + + # 鍙栨秷鏈畬鎴愮殑浠诲姟 + for task in pending: + task.cancel() + try: + await task + except asyncio.CancelledError as e: + print(f"asyncio CancelledError: {e}") + pass except WebSocketDisconnect as e: print(f"WebSocket connection closed with code {e.code}: {e.reason}") @@ -91,7 +104,7 @@ except Exception as e: print(f"Exception occurred: {e}") finally: - print("Cleaning up resources") + print("Cleaning up resources of bisheng report") # 鍙栨秷鎵�鏈変换鍔� for task in tasks: if not task.done(): -- Gitblit v1.8.0