From f9a307e86b771f20bd2dc043a875b2ee86cc5d50 Mon Sep 17 00:00:00 2001
From: zhaoqingang <zhaoqg0118@163.com>
Date: 星期二, 12 十一月 2024 18:42:12 +0800
Subject: [PATCH] Merge branch 'master' of http://192.168.5.5:10010/r/rag-gateway

---
 app/service/ragflow.py |   21 +++++++++++++++++++++
 app/api/chat.py        |   12 +++++++-----
 app/api/agent.py       |   12 ++++++++++++
 3 files changed, 40 insertions(+), 5 deletions(-)

diff --git a/app/api/agent.py b/app/api/agent.py
index 2879506..028bded 100644
--- a/app/api/agent.py
+++ b/app/api/agent.py
@@ -1,6 +1,7 @@
 import uuid
 
 from fastapi import Depends, APIRouter, Query, HTTPException
+from fastapi.responses import JSONResponse
 from pydantic import BaseModel
 from sqlalchemy.orm import Session
 
@@ -51,6 +52,17 @@
         return ResponseList(code=200, msg="Unsupported agent type")
 
 
+@router.get("/{conversation_id}/session_log")
+async def session_log(conversation_id: str, db: Session = Depends(get_db), current_user: UserModel = Depends(get_current_user)):
+    ragflow_service = RagflowService(base_url=settings.fwr_base_url)
+    try:
+        token = get_ragflow_token(db, current_user.id)
+        result = await ragflow_service.get_session_log(token, conversation_id)
+    except Exception as e:
+        raise HTTPException(status_code=500, detail=str(e))
+    return JSONResponse(status_code=200, content={"code": 200, "log": result})
+
+
 @router.get("/get-chat-id/{agent_id}", response_model=Response)
 async def get_chat_id(agent_id: str, db: Session = Depends(get_db)):
     agent = db.query(AgentModel).filter(AgentModel.id == agent_id).first()
diff --git a/app/api/chat.py b/app/api/chat.py
index b54db51..ae196ed 100644
--- a/app/api/chat.py
+++ b/app/api/chat.py
@@ -64,6 +64,7 @@
                                 "doc_ids": message.get("doc_ids", []),
                                 "role": "user"
                             })
+                    complete_response = ""
                     async for rag_response in ragflow_service.chat(token, chat_id, chat_history):
                         try:
                             if rag_response[:5] == "data:":
@@ -72,8 +73,9 @@
                             else:
                                 # 鍚﹀垯锛屼繚鎸佸師鏍�
                                 text = rag_response
+                            complete_response += text
                             try:
-                                json_data = json.loads(text)
+                                json_data = json.loads(complete_response)
                                 data = json_data.get("data")
                                 if data is True:  # 瀹屾垚杈撳嚭
                                     result = {"message": "", "type": "close"}
@@ -85,10 +87,10 @@
                                     reference = data.get("reference", {})
                                     result = {"message": answer, "type": "message", "reference": reference}
                                 await websocket.send_json(result)
-                            except json.JSONDecodeError:
-                                print(f"Error decode ragflow response: {text}")
-                                pass
-
+                                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)
diff --git a/app/service/ragflow.py b/app/service/ragflow.py
index d5d4726..969f3b0 100644
--- a/app/service/ragflow.py
+++ b/app/service/ragflow.py
@@ -102,6 +102,27 @@
             ]
             return result
 
+    async def get_session_log(self, token: str, conversation_id: str) -> dict:
+        url = f"{self.base_url}/v1/conversation/get?conversation_id={conversation_id}"
+        headers = {"Authorization": token}
+        async with httpx.AsyncClient() as client:
+            response = await client.get(url, headers=headers)
+            data = self._handle_response(response)
+            session_log = {
+                "dialog_id": data.get("dialog_id"),
+                "id": data.get("id"),
+                "message": [
+                    {
+                        "content": message.get("content"),
+                        "role": message.get("role"),
+                    }
+                    for message in data.get("message", [])
+                ],
+                "name": data.get("name"),
+                "reference": data.get("reference"),
+            }
+        return session_log
+
     async def set_session(self, token: str, dialog_id: str, message: dict, chat_id: str, is_new: bool) -> list:
         url = f"{self.base_url}/v1/conversation/set?dialog_id={dialog_id}"
         headers = {"Authorization": token}

--
Gitblit v1.8.0