From 9ea07e00fc8b92e9b75849859c1ecce77c7096d1 Mon Sep 17 00:00:00 2001 From: zhaoqingang <zhaoqg0118@163.com> Date: 星期四, 10 四月 2025 13:31:23 +0800 Subject: [PATCH] 优化 --- app/models/v2/chat.py | 55 ++++++++++++++++++++++++++++++++++++++----------------- 1 files changed, 38 insertions(+), 17 deletions(-) diff --git a/app/models/v2/chat.py b/app/models/v2/chat.py index 1240c85..1ee30d2 100644 --- a/app/models/v2/chat.py +++ b/app/models/v2/chat.py @@ -6,7 +6,7 @@ from sqlalchemy import Column, Integer, String, BigInteger, ForeignKey, DateTime, Text, TEXT from sqlalchemy.orm import Session -from app.config.const import Dialog_STATSU_DELETE +from app.config.const import Dialog_STATSU_DELETE, Dialog_STATSU_ON, complex_knowledge_chat, complex_knowledge_chat_deep from app.models.base_model import Base from app.utils.common import current_time @@ -23,9 +23,11 @@ class ChatDataRequest(BaseModel): sessionId: str + parentId: Optional[str] = "" 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] = [] @@ -37,6 +39,9 @@ "chatMode": self.chatMode, "knowledgeId": self.knowledgeId, "files": self.files, + "isDeep": self.isDeep, + "optimizeType": self.optimizeType, + "parentId": self.parentId, } @@ -133,7 +138,7 @@ return [i.id for i in session_list] async def get_complex_chat_by_mode(self, chat_mode: int) -> ComplexChatModel | None: - session = self.db.query(ComplexChatModel).filter(ComplexChatModel.chat_mode==chat_mode, ComplexChatModel.status!=Dialog_STATSU_DELETE).first() + session = self.db.query(ComplexChatModel).filter(ComplexChatModel.chat_mode==chat_mode, ComplexChatModel.status==Dialog_STATSU_ON).first() return session @@ -172,15 +177,32 @@ } 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) - } + query = {} + if self.query: + query = json.loads(self.query) + if self.message_type == 1: + return { + 'id': self.id, + 'role': "user", + 'content': self.content, + 'files': query.get("files", []), + } + else: + + res = { + 'id': self.id, + 'role': "assistant", + 'answer': self.content, + 'chat_mode': self.chat_mode, + "parentId": query.get("parentId"), + "isDeep": query.get("isDeep", 1), + "mindmap": True if self.mindmap else False, + } + if self.chat_mode == complex_knowledge_chat or self.chat_mode == complex_knowledge_chat_deep: + res['reference'] = json.loads(self.node_data) if self.node_data else {} + else: + res['node_list'] = json.loads(self.node_data) if self.node_data else [] + return res class ComplexChatSessionDao: @@ -237,12 +259,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