From 3eabd0961bc63f08f10b4c582ed1c471df43a8c7 Mon Sep 17 00:00:00 2001
From: zhaoqingang <zhaoqg0118@163.com>
Date: 星期一, 10 二月 2025 15:40:26 +0800
Subject: [PATCH] 獲取配置信息增加api

---
 app/service/v2/app_driver/chat_data.py |   54 +++++++++++++++++++++++++++++++++++++++++++++++++++---
 1 files changed, 51 insertions(+), 3 deletions(-)

diff --git a/app/service/v2/app_driver/chat_data.py b/app/service/v2/app_driver/chat_data.py
index ebfa63d..52e6883 100644
--- a/app/service/v2/app_driver/chat_data.py
+++ b/app/service/v2/app_driver/chat_data.py
@@ -1,12 +1,14 @@
 import json
 
+from app.config.config import settings
 # from Log import logger
 from app.service.v2.app_driver.chat_base import ChatBase
+from app.utils.rsa_crypto import RagflowCrypto
 
 
 class ChatBaseApply(ChatBase):
 
-    async def chat_parameters(self, url, params, headers):
+    async def chat_get(self, url, params, headers):
 
         res = await self.http_get(url, params, headers)
         if res.status_code == 200:
@@ -14,8 +16,47 @@
         else:
             return {}
 
+    async def chat_ping(self, url, params, headers):
+        res = await self.http_get(url, params, headers)
+        if res.status_code != 200:
+            return 0
+        if res.json().get("code") == "unauthorized" or res.json().get("code") == 401:
+            return 0
+        return 200
 
 
+    async def chat_post(self, url, data, headers):
+
+        res = await self.http_post(url, data, headers)
+        if res.status_code == 200 or res.status_code == 201:
+            return res.json()
+        else:
+            return {}
+
+    async def chat_login(self, url, data, headers):
+
+        res = await self.http_post(url, data, headers)
+        if res.status_code == 200:
+            res_json = res.json()
+            authorization = res.headers.get('Authorization')
+            if authorization:
+                res_json["data"]["access_token"] = authorization
+            return res_json
+        else:
+            return {}
+
+
+    @staticmethod
+    async def password_encrypt(password):
+        password = RagflowCrypto(settings.PUBLIC_KEY, settings.PRIVATE_KEY).encrypt(password)
+        return password
+
+    @staticmethod
+    async def get_chat_headers(token):
+        return {
+            'Content-Type': 'application/json',
+            'Authorization': token
+        }
 
 
 
@@ -38,9 +79,16 @@
             'Content-Type': 'application/json',
             'Authorization': f"Bearer {token}"
         }
-        ans = await chat.chat_parameters(url, params, headers)
-        print(ans)
+        # ans = await chat.chat_parameters(url, params, headers)
+        # print(ans)
 
+        ping_url = "http://192.168.20.116:11080/v1/system/version"
+        # ping_url = "http://192.168.20.119:13002/console/api/workspaces"
+        user_token = "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VyX2lkIjoiNjEzNzdiYzctZTViYy00YjhiLTgxYTYtNWZkOTVhODVlMmE4IiwiZXhwIjoxNzM5MjU3Njk1LCJpc3MiOiJTRUxGX0hPU1RFRCIsInN1YiI6IkNvbnNvbGUgQVBJIFBhc3Nwb3J0In0.w7xQrepd1dYR4iPXcbuthIZjdm45bTJFbolOM_SE9aQ"
+        # token = "Bearer {}"
+        token = "{}"
+        res = await chat.chat_ping(ping_url, {}, await chat.get_chat_headers(token.format(user_token)))
+        print(res)
 
     import asyncio
 

--
Gitblit v1.8.0