From 3b1bf7da6771bd1d6852d3dcc1f906d5ae5c95d1 Mon Sep 17 00:00:00 2001 From: zhaoqingang <zhaoqg0118@163.com> Date: 星期三, 12 三月 2025 13:49:12 +0800 Subject: [PATCH] 增加内容优化 --- app/models/v2/chat.py | 35 ++++++++++++++++++++--------------- 1 files changed, 20 insertions(+), 15 deletions(-) diff --git a/app/models/v2/chat.py b/app/models/v2/chat.py index 86d7ea4..e41edcf 100644 --- a/app/models/v2/chat.py +++ b/app/models/v2/chat.py @@ -26,6 +26,7 @@ query: str chatMode: Optional[int] = 1 # 1= 鏅�氬璇濓紝2=鑱旂綉锛�3=鐭ヨ瘑搴�,4=娣卞害 isDeep: Optional[int] = 1 # 1= 鏅��, 2=娣卞害 + optimizeType: Optional[str] = "" # 浼樺寲绫诲瀷锛氭鼎鑹诧紝鎵╁啓锛岀缉鍐欙紝璋冩暣璇皵锛岃嚜瀹氫箟 knowledgeId: Optional[list] = [] files: Optional[list] = [] @@ -38,6 +39,7 @@ "knowledgeId": self.knowledgeId, "files": self.files, "isDeep": self.isDeep, + "optimizeType": self.optimizeType, } @@ -173,15 +175,19 @@ } def log_to_json(self): - return { - 'id': self.id, - 'name': self.name, - 'agent_type': self.agent_type, - 'chat_id': self.agent_id, - 'create_date': self.create_date.strftime("%Y-%m-%d %H:%M:%S"), - 'update_date': self.update_date.strftime("%Y-%m-%d %H:%M:%S"), - 'message': json.loads(self.message) - } + if self.message_type == 1: + return { + 'id': self.id, + 'role': "user", + 'content': self.content, + } + else: + return { + 'id': self.id, + 'role': "assistant", + 'answer': self.content, + 'node_list': json.loads(self.node_data) if self.node_data else [], + } class ComplexChatSessionDao: @@ -238,12 +244,11 @@ self.db.delete(session) self.db.commit() - async def get_session_list(self, user_id: int, agent_id: str, keyword:str, page: int, page_size: int) -> any: - query = self.db.query(ComplexChatSessionModel).filter(ComplexChatSessionModel.tenant_id==user_id) - if agent_id: - query = query.filter(ComplexChatSessionModel.agent_id==agent_id) + async def get_session_list(self, session_id: int, keyword:str="", page: int=1, page_size: int=100) -> any: + query = self.db.query(ComplexChatSessionModel).filter(ComplexChatSessionModel.session_id==session_id) + if keyword: - query = query.filter(ComplexChatSessionModel.name.like('%{}%'.format(keyword))) + query = query.filter(ComplexChatSessionModel.content.like('%{}%'.format(keyword))) total = query.count() - session_list = query.order_by(ComplexChatSessionModel.update_date.desc()).offset((page-1)*page_size).limit(page_size).all() + session_list = query.order_by(ComplexChatSessionModel.create_date.desc()).offset((page-1)*page_size).limit(page_size).all() return total, session_list \ No newline at end of file -- Gitblit v1.8.0