From e6c5e89f09637b8d9ebca6895d781663f12646d6 Mon Sep 17 00:00:00 2001 From: zhaoqingang <zhaoqg0118@163.com> Date: 星期二, 17 十二月 2024 16:43:55 +0800 Subject: [PATCH] dify 文档智能 --- app/service/v2/initialize_data.py | 73 +++++++++++++++++++++++++++++++++--- 1 files changed, 66 insertions(+), 7 deletions(-) diff --git a/app/service/v2/initialize_data.py b/app/service/v2/initialize_data.py index bf05dcf..b5f2002 100644 --- a/app/service/v2/initialize_data.py +++ b/app/service/v2/initialize_data.py @@ -1,7 +1,8 @@ import json from Log import logger -from app.models import MenuCapacityModel, WebMenuModel, GroupModel +from app.models import MenuCapacityModel, WebMenuModel, GroupModel, RoleModel, DialogModel, UserModel +from app.service.v2.app_register import AppRegisterDao async def dialog_menu_sync(db): @@ -17,13 +18,9 @@ for menu in menu_list: # print(menu) - agent = menu.pop("agent", []) - for i in agent: - capacity = MenuCapacityModel(menu_id=menu["id"], capacity_id=i, capacity_type=2) - db.add(capacity) dialog = menu.pop("dialog", []) for i in dialog: - capacity = MenuCapacityModel(menu_id=menu["id"], capacity_id=i, capacity_type=1) + capacity = MenuCapacityModel(menu_id=menu["id"], capacity_id=i["id"], capacity_type=i["agentType"], chat_id=i["id"] if not i["chat_id"] else i["chat_id"], chat_type=i["chat_type"]) db.add(capacity) menu_obj = WebMenuModel(**menu) db.add(menu_obj) @@ -33,4 +30,66 @@ async def default_group_sync(db): group = db.query(GroupModel).filter_by(group_type=2).first() if not group: - logger.error("鏈垵濮嬪寲") \ No newline at end of file + logger.error("鏈垵濮嬮粯璁ょ粍锛� 寮�濮嬪垵濮嬪寲锛�") + + try: + group = GroupModel(group_name="榛樿鐢ㄦ埛缁�", group_description="榛樿缁�", group_type=2) + db.add(group) + db.commit() + except Exception as e: + logger.error(e) + + +async def default_role_sync(db): + role = db.query(RoleModel).filter_by(role_type=2).first() + if not role: + logger.error("鏈垵濮嬮粯璁よ鑹诧紝 寮�濮嬪垵濮嬪寲锛�") + + try: + group = RoleModel(id="morenjuese1234567890", name="榛樿瑙掕壊", description="榛樿瑙掕壊", role_type=2) + db.add(group) + db.commit() + except Exception as e: + logger.error(e) + + +async def app_register_sync(db): + app_dict = {} + with open("env_conf/app_register_conf.json", 'r', encoding='utf-8') as file: + # 鍔犺浇JSON鏁版嵁 + app_dict = json.load(file) + try: + for app_id, status in app_dict.items(): + AppRegisterDao(db).update_and_insert_app(app_id, status) + except Exception as e: + logger.error(e) + + +async def basic_agent_sync(db): + agent_list = [] + with open("env_conf/default_agent_conf.json", 'r', encoding='utf-8') as file: + # 鍔犺浇JSON鏁版嵁 + agent_dict = json.load(file) + agent_list = agent_dict.get("basic", []) + user = db.query(UserModel).filter_by(permission="admin").first() + for agent in agent_list: + dialog = db.query(DialogModel).filter(DialogModel.id==agent["id"]).first() + if dialog: + try: + dialog.name = agent["name"] + dialog.description = agent["description"] + dialog.icon = agent["icon"] + db.commit() + except Exception as e: + logger.error(e) + else: + try: + dialog = DialogModel(id=agent["id"], name=agent["name"], description=agent["description"], + icon=agent["icon"], tenant_id=user.id if user else "", dialog_type="3", + agent_id=agent["id"]) + db.add(dialog) + db.commit() + db.refresh(dialog) + except Exception as e: + print(e) + db.rollback() \ No newline at end of file -- Gitblit v1.8.0