| | |
| | | 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"}) |
| | |
| | | # 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) |
| | | # print("=============================================") |
| | | # print(rag_response) |
| | | try: |
| | | if rag_response[:5] == "data:": |
| | | # 如果是,则截取掉前5个字符,并去除首尾空白符 |
| | |
| | | if data.get("event") == "agent_message":# "event": "message_end" |
| | | if "answer" not in data or not data["answer"]: # 信息过滤 |
| | | logger.error("非法数据--------------------") |
| | | logger.error(data) |
| | | # logger.error(data) |
| | | |
| | | continue |
| | | else: # 正常输出 |
| | |
| | | logger.error("未知数据体:0---------------------------------") |
| | | logger.error(answer) |
| | | answer_str += answer.get("action_input", "") |
| | | continue |
| | | |
| | | result = {"message": answer_str, "type": "message"} |
| | | elif data.get("event") == "message_end": |
| | | result = {"message": answer_str, "type": "close"} |
| | | try: |
| | |
| | | except Exception as e: |
| | | logger.error("保存dify的会话异常!") |
| | | logger.error(e) |
| | | elif data.get("event") == "message_file": |
| | | url = data.get("url", "") |
| | | result = {"message": url, "type": "image"} |
| | | else: |
| | | continue |
| | | await websocket.send_json(result) |