import json from Log import logger from app.models import MenuCapacityModel, WebMenuModel, GroupModel, RoleModel, DialogModel, UserModel from app.service.v2.app_register import AppRegisterDao async def dialog_menu_sync(db): menu_list = [] with open("env_conf/menu_conf.json", 'r', encoding='utf-8') as file: # 加载JSON数据 data = json.load(file) menu_list = data.get("data", []) db.query(WebMenuModel).delete() db.query(MenuCapacityModel).delete() db.commit() for menu in menu_list: # print(menu) dialog = menu.pop("dialog", []) for i in dialog: 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) db.commit() async def default_group_sync(db): group = db.query(GroupModel).filter_by(group_type=2).first() if not group: 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()