| | |
| | | import json |
| | | import re |
| | | import uuid |
| | | from copy import deepcopy |
| | | |
| | | from fastapi import WebSocket, WebSocketDisconnect, APIRouter, Depends |
| | | import asyncio |
| | |
| | | print(f"Error process message of ragflow: {e2}") |
| | | elif agent.type == "reportWorkflow": |
| | | |
| | | token = DfTokenDao(db).get_token_by_id(DOCUMENT_TO_CLEANING) |
| | | if not token: |
| | | await websocket.send_json({"message": "Invalid token document_to_cleaning", "type": "error"}) |
| | | |
| | | while True: |
| | | receive_message = await websocket.receive_json() |
| | | print(f"Received from client {chat_id}: {receive_message}") |
| | |
| | | inputs_list = [] |
| | | is_next = 0 |
| | | if workflow_type == 1: |
| | | token = DfTokenDao(db).get_token_by_id(DOCUMENT_TO_CLEANING) |
| | | if not token: |
| | | await websocket.send_json( |
| | | {"message": "Invalid token document_to_cleaning", "type": "error"}) |
| | | inputs["input_files"] = files |
| | | inputs["Completion_of_main_indicators"] = title |
| | | inputs_list.append({"inputs": inputs, "token": token, "workflow_type": workflow_type}) |
| | |
| | | {"message": "Invalid token document_to_title", "type": "error"}) |
| | | inputs_list.append({"inputs": inputs, "token": token, "workflow_type": workflow_type}) |
| | | elif workflow_type == 3 and is_clean == 1 or tokens >= max_token: |
| | | token = DfTokenDao(db).get_token_by_id(DOCUMENT_TO_CLEANING) |
| | | if not token: |
| | | await websocket.send_json( |
| | | {"message": "Invalid token document_to_cleaning", "type": "error"}) |
| | | inputs["input_files"] = files |
| | | inputs["Completion_of_main_indicators"] = title |
| | | inputs_list.append({"inputs": inputs, "token": token, "workflow_type": 1}) |
| | |
| | | try: |
| | | data = json.loads(complete_response) |
| | | # print(data) |
| | | node_list.append(data) |
| | | node_data = deepcopy(data) |
| | | if "data" in node_data: |
| | | if "outputs" in node_data["data"]: |
| | | node_data["data"]["outputs"] = {} |
| | | if "inputs" in node_data["data"]: |
| | | node_data["data"]["inputs"] = {} |
| | | # print(node_data) |
| | | node_list.append(node_data) |
| | | |
| | | complete_response = "" |
| | | if data.get("event") == "node_started": # "event": "message_end" |
| | | |
| | |
| | | |
| | | message = answer.get("title", "") |
| | | |
| | | |
| | | result = {"message": message, "type": "system"} |
| | | elif data.get("event") == "node_finished": |
| | | workflow_list.append({ |
| | |
| | | "elapsed_time":data.get("data", {}).get("elapsed_time", 0), |
| | | "error":data.get("data", {}).get("error", ""), |
| | | }) |
| | | answer = data.get("data", "") |
| | | if isinstance(answer, str): |
| | | logger.error("----------------未知数据--------------------") |
| | | logger.error(data) |
| | | continue |
| | | elif isinstance(answer, dict): |
| | | |
| | | message = answer.get("title", "") |
| | | if answer.get("status") == "failed": |
| | | message = answer.get("error", "") |
| | | result = {"message": message, "type": "system"} |
| | | |
| | | elif data.get("event") == "workflow_finished": |
| | | answer = data.get("data", "") |
| | | if isinstance(answer, str): |
| | |
| | | logger.error(e) |
| | | logger.error("返回客户端消息异常!") |
| | | |
| | | result = {"message": "", "type": "close", "workflow": workflow_dict, "is_next": is_next} |
| | | result = {"message": "", "type": "close", "workflow": workflow_dict, "is_next": is_next, "download_url": download_url} |
| | | |
| | | |
| | | else: |
| | |
| | | logger.error(e) |
| | | logger.error("返回客户端消息异常!") |
| | | complete_response = "" |
| | | |
| | | except json.JSONDecodeError as e: |
| | | print(f"Error decoding JSON: {e}") |
| | | # print(f"Response text: {text}") |
| | |
| | | complete_response += rag_response |
| | | try: |
| | | data = json.loads(complete_response) |
| | | node_list.append(data) |
| | | # print(data) |
| | | node_data = deepcopy(data) |
| | | if "data" in node_data: |
| | | if "outputs" in node_data["data"]: |
| | | node_data["data"]["outputs"] = {} |
| | | if "inputs" in node_data["data"]: |
| | | node_data["data"]["inputs"] = {} |
| | | # print(node_data) |
| | | node_list.append(node_data) |
| | | complete_response = "" |
| | | if data.get("event") == "node_started": # "event": "message_end" |
| | | if "data" not in data or not data["data"]: # 信息过滤 |
| | |
| | | "elapsed_time":data.get("data", {}).get("elapsed_time", 0), |
| | | "error":data.get("data", {}).get("error", ""), |
| | | }) |
| | | |
| | | answer = data.get("data", "") |
| | | if isinstance(answer, str): |
| | | logger.error("----------------未知数据--------------------") |
| | | logger.error(data) |
| | | continue |
| | | elif isinstance(answer, dict): |
| | | |
| | | message = answer.get("title", "") |
| | | if answer.get("status") == "failed": |
| | | message = answer.get("error", "") |
| | | result = {"message": message, "type": "system"} |
| | | elif data.get("event") == "message": |
| | | answer_str = data.get("answer", "") |
| | | # try: |