From fb37a87e565fe998becb322ff9d344d3b7aa8e14 Mon Sep 17 00:00:00 2001
From: zhangqian <zhangqian@123.com>
Date: 星期三, 16 十月 2024 14:40:44 +0800
Subject: [PATCH] 智能体获取会话id接口
---
app/service/bisheng.py | 21 +++++++++++++++++++++
1 files changed, 21 insertions(+), 0 deletions(-)
diff --git a/app/service/bisheng.py b/app/service/bisheng.py
index b71a932..3eb0dfd 100644
--- a/app/service/bisheng.py
+++ b/app/service/bisheng.py
@@ -1,3 +1,5 @@
+from datetime import datetime
+
import httpx
from app.config.config import settings
@@ -42,3 +44,22 @@
if response.status_code != 200:
raise Exception(f"Failed to get public key: {response.text}")
return response.json().get('data', {}).get('public_key')
+
+ async def get_chat_sessions(self, token: str) -> list:
+ url = f"{self.base_url}/api/v1/chat/list?page=1&limit=40"
+ headers = {'cookie': f"access_token_cookie={token};"}
+ async with httpx.AsyncClient() as client:
+ response = await client.get(url, headers=headers)
+ if response.status_code != 200:
+ raise Exception(f"Failed to fetch data from Bisheng API: {response.text}")
+
+ data = response.json().get("data", [])
+ result = [
+ {
+ "id": item["chat_id"],
+ "name": item["latest_message"]["message"],
+ "updated_time": int(datetime.strptime(item["update_time"], "%Y-%m-%dT%H:%M:%S").timestamp() * 1000)
+ }
+ for item in data
+ ]
+ return result
--
Gitblit v1.8.0