From 0650b889a36d9b9fd42415b9b9819676f839ae9b Mon Sep 17 00:00:00 2001 From: zhaoqingang <zhaoqg0118@163.com> Date: 星期二, 08 四月 2025 09:54:09 +0800 Subject: [PATCH] 首页会话-模型修改 --- app/models/v2/chat.py | 62 ++++++++++++++++++++----------- 1 files changed, 40 insertions(+), 22 deletions(-) diff --git a/app/models/v2/chat.py b/app/models/v2/chat.py index 7aed562..2f3a484 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 @@ -46,6 +46,13 @@ +class SetModelRequest(BaseModel): + chatType: int + modelType: int + modelName: str + modelProvider: str + + class ComplexChatModel(Base): __tablename__ = 'complex_chat' @@ -64,6 +71,9 @@ mode = Column(String(36)) parameters = Column(Text) chat_mode = Column(Integer) #1= 鏅�氬璇濓紝2=鑱旂綉锛�3=鐭ヨ瘑搴�,4=娣卞害 + chat_model = Column(String(255)) # 妯″瀷 + chat_model_ds = Column(String(255)) # 妯″瀷 + chat_provider = Column(String(255)) # 妯″瀷鎻愪緵鍟� def to_json(self): return { @@ -99,24 +109,20 @@ session = self.db.query(ComplexChatModel).filter_by(id=chat_id).first() return session - async def update_complex_chat_by_id(self, chat_id: str, session, message: dict, conversation_id=None) -> ComplexChatModel | None: - if not session: - session = await self.get_complex_chat_by_id(chat_id) - if session: - try: - # TODO - session.update_date = current_time() - self.db.commit() - self.db.refresh(session) - except Exception as e: - # logger.error(e) - self.db.rollback() - return session + async def update_complex_chat_by_id(self, chat_id: str, kwargs:dict) -> None: + + try: + self.db.query(ComplexChatModel).filter_by(id=chat_id).update(kwargs) + self.db.commit() + except Exception as e: + # logger.error(e) + self.db.rollback() + async def update_or_insert_by_id(self, chat_id: str, **kwargs) -> ComplexChatModel: existing_session = await self.get_complex_chat_by_id(chat_id) if existing_session: - return await self.update_complex_chat_by_id(chat_id, existing_session, kwargs.get("message")) + return await self.update_complex_chat_by_id(chat_id, kwargs) existing_session = await self.create_complex_chat(chat_id, **kwargs) return existing_session @@ -138,8 +144,12 @@ 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 + + + async def aget_complex_chat(self) -> List: + return self.db.query(ComplexChatModel).filter(ComplexChatModel.status!=Dialog_STATSU_DELETE).all() @@ -177,24 +187,32 @@ } def log_to_json(self): + 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: - query = {} - if self.query: - query = json.loads(self.query) - return { + + res = { 'id': self.id, 'role': "assistant", 'answer': self.content, 'chat_mode': self.chat_mode, - 'node_list': json.loads(self.node_data) if self.node_data else [], - "parentId": query.get("parentId") + "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: -- Gitblit v1.8.0