From 56d8dce48022692c5a7541114ef84f4fa395ff9d Mon Sep 17 00:00:00 2001
From: zhaoqingang <zhaoqg0118@163.com>
Date: 星期二, 26 十一月 2024 11:22:49 +0800
Subject: [PATCH] dify images 问题

---
 app/service/difyService.py |   70 ++++++++++++++++++----------------
 1 files changed, 37 insertions(+), 33 deletions(-)

diff --git a/app/service/difyService.py b/app/service/difyService.py
index 6b6a59a..9aee918 100644
--- a/app/service/difyService.py
+++ b/app/service/difyService.py
@@ -5,9 +5,8 @@
 from typing import Union, Dict, List
 from fastapi import HTTPException
 from starlette import status
-from watchdog.observers.fsevents2 import message
 
-# from Log import logger
+from Log import logger
 from app.config.config import settings
 from app.utils.rsa_crypto import RagflowCrypto
 
@@ -18,6 +17,8 @@
 
     def _handle_response(self, response: httpx.Response) -> Union[Dict, List]:
         if response.status_code != 200:
+            if response.status_code == 201:
+                return response.json()
             return {}
 
         data = response.json()
@@ -27,8 +28,8 @@
                 status_code=status.HTTP_401_UNAUTHORIZED,
                 detail="鐧诲綍杩囨湡",
             )
-        if ret_code != 0:
-            return {}
+        # if ret_code != 0:
+        #     return {}
 
         # 妫�鏌ヨ繑鍥炵殑鏁版嵁绫诲瀷
         if isinstance(data.get("data"), dict):
@@ -36,7 +37,7 @@
         elif isinstance(data.get("data"), list):
             return data.get("data", [])
         else:
-            return {}
+            return data
 
     async def register(self, username: str, password: str):
         password = RagflowCrypto(settings.PUBLIC_KEY, settings.PRIVATE_KEY).encrypt(password)
@@ -65,26 +66,25 @@
                 raise Exception("Authorization header not found in response")
             return authorization
 
-    async def chat(self, token: str, chat_id: str,  message: str, upload_file_id: str, conversation_id: str):
+    async def chat(self, token: str, user_id: int,  message: str, upload_file_id: str, conversation_id: str):
 
         target_url = f"{self.base_url}/v1/chat-messages"
-        files = [
+        files = []
+        if upload_file_id:
+            files = [
                 {
                     "type": "image",
-                    "transfer_method": "remote_url",
-                    "url": "https://cloud.dify.ai/logo/logo-site.png",
-                    "upload_file_id":""
+                    "transfer_method": "local_file",
+                    "url": "",
+                    "upload_file_id": upload_file_id
                 }
             ]
-        if upload_file_id:
-            files[0]["transfer_method"] = "local_file"
-            files[0]["upload_file_id"] = upload_file_id
         data = {
             "inputs": {},
             "query": message,
             "response_mode": "streaming",
-            "conversation_id": conversation_id,
-            "user": chat_id,
+            "conversation_id": "",
+            "user": str(user_id),
             "files": files
         }
 
@@ -97,7 +97,7 @@
                 if response.status_code == 200:
                     try:
                         async for answer in response.aiter_text():
-                            print(f"response of ragflow chat: {answer}")
+                            # print(f"response of ragflow chat: {answer}")
                             yield answer
                     except GeneratorExit as e:
                         print(e)
@@ -107,35 +107,39 @@
 
 
 
-    async def get_session_history(self, token: str, chat_id: str, is_all: int=0):
-        url = f"{self.base_url}/v1/conversation/get?conversation_id={chat_id}"
-        headers = {"Authorization": token}
+    async def get_session_history(self, token: str, conversation_id: str, user: str):
+        url = f"{self.base_url}/v1/messages"
+        params = {
+            'user': user,
+            'conversation_id': conversation_id
+        }
+        headers = {"Authorization": f'Bearer {token}'}
         async with httpx.AsyncClient() as client:
-            response = await client.get(url, headers=headers)
+            response = await client.get(url, params=params, headers=headers)
+            # print(response.text)
+            # print(response.status_code)
+            # print(response.res)
             data = self._handle_response(response)
             # print("----------------data----------------------:", data)
-            if is_all:
-                return data
-            return data.get("message", [])
 
-    async def upload(self, token: str, filename: str, file: bytes) -> dict:
-        url = f"{self.base_url}/console/api/files/upload"
+            return data
+
+    async def upload(self, token: str, filename: str, file: bytes, user_id) -> dict:
+        url = f"{self.base_url}/v1/files/upload"
         headers = {
-            'Content-Type': 'application/json',
+            # 'Content-Type': 'application/json',
             'Authorization': f'Bearer {token}'
         }
-
+        data = {
+            'user': str(user_id)
+        }
         # 鍒涘缓琛ㄥ崟鏁版嵁锛屽寘鍚枃浠�
         files = {"file": (filename, file)}
         async with httpx.AsyncClient() as client:
-            response = await client.post(url, headers=headers, files=files)
+            response = await client.post(url, headers=headers, files=files, data=data)
             data = self._handle_response(response)
-            # file_path = data.get("file_path", "")
-            result = {
-                "file_path": data
-            }
 
-            return result
+            return data
 
 
 

--
Gitblit v1.8.0