From ac9373fd6f0db53c983d87c4790cb627e82759e9 Mon Sep 17 00:00:00 2001 From: zhaoqingang <zhaoqg0118@163.com> Date: 星期二, 25 二月 2025 17:25:39 +0800 Subject: [PATCH] merge --- app/service/v2/app_driver/chat_data.py | 64 ++++++++++++++++++++++++++++++- 1 files changed, 61 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..56c1785 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,55 @@ else: return {} + 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_ping(self, url, params, headers): + res = await self.http_get(url, params, headers) + # print(res.text) + 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_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 {} + + async def chat_upload(self, url, files, data, headers): + + res = await self.http_upload_file(url, headers=headers, files=files, data=data) + if res.status_code == 200 or res.status_code == 201: + 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 +87,18 @@ '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://smartai.com:8294/v1/llm/list" + # ping_url = "http://192.168.20.119:13002/console/api/workspaces" + user_token = "eyJhbG|ciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VyX2lkIjoiNjEzNzdiYzctZTViYy00YjhiLTgxYTYtNWZkOTVhODVlMmE4IiwiZXhwIjoxNzM5MjU3Njk1LCJpc3MiOiJTRUxGX0hPU1RFRCIsInN1YiI6IkNvbnNvbGUgQVBJIFBhc3Nwb3J0In0.w7xQrepd1dYR4iPXcbuthIZjdm45bTJFbolOM_SE9aQ" + user_token = "IjNmZTA4NmM2ZjJjMjExZWY4ZTc2MDI0MmFjMTIwMDA2Ig.Z7yNLg.XooARY7YHv-Zo1qLoXwCuDe8J0k" + # 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