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