| | |
| | | import json |
| | | import re |
| | | import uuid |
| | | |
| | | from fastapi import WebSocket, WebSocketDisconnect, APIRouter, Depends |
| | |
| | | await websocket.send_json(result) |
| | | |
| | | else: |
| | | logger.error("---------------------excel_talk-----------------------------") |
| | | async for data in service.excel_talk(question, chat_id): |
| | | logger.error(data) |
| | | output = data.get("output", "") |
| | | excel_name = data.get("excel_name", "") |
| | | image_name = data.get("image_name", "") |
| | |
| | | token = settings.dify_api_token |
| | | try: |
| | | async def forward_to_dify(): |
| | | |
| | | |
| | | while True: |
| | | image_list = [] |
| | | is_image = False |
| | | conversation_id = "" |
| | | receive_message = await websocket.receive_json() |
| | | print(f"Received from client {chat_id}: {receive_message}") |
| | | upload_file_id = receive_message.get('upload_file_id', []) |
| | | upload_file_id = receive_message.get('upload_file_id', "") |
| | | question = receive_message.get('message', "") |
| | | if not question and not image_url: |
| | | await websocket.send_json({"message": "Invalid request", "type": "error"}) |
| | |
| | | conversation_id = session.conversation_id |
| | | except Exception as e: |
| | | logger.error(e) |
| | | complete_response = "" |
| | | # complete_response = "" |
| | | answer_str = "" |
| | | async for rag_response in dify_service.chat(token, current_user.id, question, upload_file_id, conversation_id): |
| | | # print("=============================================") |
| | | # print(rag_response) |
| | | try: |
| | | if rag_response[:5] == "data:": |
| | | # 如果是,则截取掉前5个字符,并去除首尾空白符 |
| | | text = rag_response[5:].strip() |
| | | complete_response = rag_response[5:].strip() |
| | | else: |
| | | # 否则,保持原样 |
| | | text = rag_response |
| | | complete_response += text |
| | | complete_response = rag_response |
| | | # complete_response += text |
| | | try: |
| | | data = json.loads(complete_response) |
| | | complete_response = "" |
| | | # data = json_data.get("data") |
| | | if "answer" not in data or not isinstance(data["answer"], dict): # 信息过滤 |
| | | continue |
| | | else: # 正常输出 |
| | | answer = data.get("answer", "") |
| | | if data.get("event") == "agent_message":# "event": "message_end" |
| | | if "answer" not in data or not data["answer"]: # 信息过滤 |
| | | logger.error("非法数据--------------------") |
| | | # logger.error(data) |
| | | |
| | | result = {"message": answer, "type": "message"} |
| | | continue |
| | | else: # 正常输出 |
| | | answer = data.get("answer", "") |
| | | if isinstance(answer, str): |
| | | if "]+\)' |
| | | url_image = image_list.pop() |
| | | new_answer = re.sub(pattern, url_image, answer) |
| | | answer_str += new_answer |
| | | else: |
| | | answer_str += answer |
| | | |
| | | elif isinstance(answer, dict): |
| | | logger.error("未知数据体:0---------------------------------") |
| | | logger.error(answer) |
| | | answer_str += answer.get("action_input", "") |
| | | |
| | | result = {"message": answer_str, "type": "message"} |
| | | elif data.get("event") == "message_end": |
| | | images_url = [] |
| | | # res_msg = await dify_service.get_session_history(token, data.get("conversation_id"), str(current_user.id)) |
| | | # if len(res_msg) > 0: |
| | | # message_files = res_msg[-1].get("message_files") |
| | | # for msg_file in message_files: |
| | | # await dify_service.save_images(msg_file.get("url"), msg_file.get("id")+".png") |
| | | # images_url.append(msg_file.get("id")) |
| | | # result = {"message": answer_str, "type": "close"} # , "message_files": images_url |
| | | if image_list and not is_image: |
| | | answer_str += image_list[-1] |
| | | result = {"message": answer_str, |
| | | "type": "close"} # , "message_files": images_url |
| | | try: |
| | | SessionService(db).update_session(chat_id, |
| | | message={"role": "assistant", "content": data, "conversation_id": data.get("conversation_id")}) |
| | | message={"role": "assistant", "content": {"answer":answer_str, "images":images_url}},conversation_id=data.get("conversation_id")) |
| | | except Exception as e: |
| | | logger.error("保存dify的会话异常!") |
| | | logger.error(e) |
| | | elif data.get("event") == "message_file": |
| | | await dify_service.save_images(data.get("url"), data.get("id") + ".png") |
| | | image_list.append(f"})") |
| | | # result = {"message": answer_str, "type": "message"} |
| | | continue |
| | | else: |
| | | continue |
| | | await websocket.send_json(result) |
| | | complete_response = "" |
| | | except json.JSONDecodeError as e: |
| | |
| | | result = {"message": f"内部错误: {e2}", "type": "close"} |
| | | await websocket.send_json(result) |
| | | print(f"Error process message of ragflow: {e2}") |
| | | try: |
| | | dialog_chat_history = await ragflow_service.get_session_history(token, chat_id, 1) |
| | | await update_session_history(db, dialog_chat_history, current_user.id) |
| | | except Exception as e: |
| | | logger.error(e) |
| | | logger.error("-----------------保存ragflow的历史会话异常-----------------") |
| | | |
| | | |
| | | # 启动任务处理客户端消息 |
| | | tasks = [ |