From 498ea113e09d7781a79ca67078de6bbc13bdf2f6 Mon Sep 17 00:00:00 2001 From: zhaoqingang <zhaoqg0118@163.com> Date: 星期二, 08 四月 2025 09:56:42 +0800 Subject: [PATCH] license同步任务 --- app/service/v2/chat.py | 13 ++++++++----- 1 files changed, 8 insertions(+), 5 deletions(-) diff --git a/app/service/v2/chat.py b/app/service/v2/chat.py index 3982bdc..9f83c63 100644 --- a/app/service/v2/chat.py +++ b/app/service/v2/chat.py @@ -14,7 +14,7 @@ from app.config.config import settings from app.config.const import * from app.models import DialogModel, ApiTokenModel, UserTokenModel, ComplexChatSessionDao, ChatDataRequest, \ - ComplexChatDao, KnowledgeModel, UserModel + ComplexChatDao, KnowledgeModel, UserModel, KnowledgeUserModel from app.models.v2.session_model import ChatSessionDao, ChatData from app.service.v2.app_driver.chat_agent import ChatAgent from app.service.v2.app_driver.chat_data import ChatBaseApply @@ -34,7 +34,7 @@ async def add_session_log(db, session_id: str, question: str, chat_id: str, user_id, event_type: str, - conversation_id: str, agent_type): + conversation_id: str, agent_type, query: dict=None): try: session = await ChatSessionDao(db).update_or_insert_by_id( session_id=session_id, @@ -42,7 +42,7 @@ agent_id=chat_id, agent_type=agent_type, tenant_id=user_id, - message={"role": "user", "content": question}, + message={"role": "user", "content": question, "query": query}, conversation_id=conversation_id, event_type=event_type ) @@ -97,6 +97,9 @@ query = db.query(KnowledgeModel) if user.permission != "admin": klg_list = [j.id for i in user.groups for j in i.knowledges] + for i in db.query(KnowledgeUserModel).filter(KnowledgeUserModel.user_id == user_id, KnowledgeUserModel.status == 1).all(): + if i.kb_id not in klg_list: + klg_list.append(i.kb_id) query = query.filter(or_(KnowledgeModel.id.in_(klg_list), KnowledgeModel.tenant_id == str(user_id))) kb_list= query.all() for kb in kb_list: @@ -204,7 +207,7 @@ else: query = "start new conversation" session = await add_session_log(db, session_id, query if query else "start new conversation", chat_id, user_id, - mode, conversation_id, DF_TYPE) + mode, conversation_id, DF_TYPE, chat_data.to_dict()) if session: conversation_id = session.conversation_id try: @@ -547,7 +550,7 @@ query_data["parentId"] = new_message_id try: - if chat_request.chatMode == complex_knowledge_chat: + if chat_request.chatMode == complex_knowledge_chat or chat_request.chatMode == complex_knowledge_chat_deep: if not conversation_id: session = await service_chat_sessions(db, chat_id, chat_request.query) # print(session) -- Gitblit v1.8.0