You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
			
				
					339 lines
				
				11 KiB
			
		
		
			
		
	
	
					339 lines
				
				11 KiB
			| 
								 
											1 year ago
										 
									 | 
							
								from datetime import datetime, time
							 | 
						||
| 
								 | 
							
								from sqlalchemy import and_, delete, desc, func, or_, select, update  # noqa: F401
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								from sqlalchemy.ext.asyncio import AsyncSession
							 | 
						||
| 
								 
											2 years ago
										 
									 | 
							
								from module_admin.entity.do.dept_do import SysDept
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								from module_admin.entity.do.menu_do import SysMenu
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								from module_admin.entity.do.role_do import SysRole, SysRoleMenu, SysRoleDept
							 | 
						||
| 
								 | 
							
								from module_admin.entity.do.user_do import SysUser, SysUserRole
							 | 
						||
| 
								 | 
							
								from module_admin.entity.vo.role_vo import RoleDeptModel, RoleMenuModel, RoleModel, RolePageQueryModel
							 | 
						||
| 
								 
											2 years ago
										 
									 | 
							
								from utils.page_util import PageUtil
							 | 
						||
| 
								 
											2 years ago
										 
									 | 
							
								
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								class RoleDao:
							 | 
						||
| 
								 | 
							
								    """
							 | 
						||
| 
								 | 
							
								    角色管理模块数据库操作层
							 | 
						||
| 
								 | 
							
								    """
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    @classmethod
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								    async def get_role_by_name(cls, db: AsyncSession, role_name: str):
							 | 
						||
| 
								 
											2 years ago
										 
									 | 
							
								        """
							 | 
						||
| 
								 | 
							
								        根据角色名获取在用角色信息
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								
							 | 
						||
| 
								 
											2 years ago
										 
									 | 
							
								        :param db: orm对象
							 | 
						||
| 
								 | 
							
								        :param role_name: 角色名
							 | 
						||
| 
								 | 
							
								        :return: 当前角色名的角色信息对象
							 | 
						||
| 
								 | 
							
								        """
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								        query_role_info = (
							 | 
						||
| 
								 | 
							
								            (
							 | 
						||
| 
								 | 
							
								                await db.execute(
							 | 
						||
| 
								 | 
							
								                    select(SysRole)
							 | 
						||
| 
								 | 
							
								                    .where(SysRole.status == '0', SysRole.del_flag == '0', SysRole.role_name == role_name)
							 | 
						||
| 
								 | 
							
								                    .order_by(desc(SysRole.create_time))
							 | 
						||
| 
								 | 
							
								                    .distinct()
							 | 
						||
| 
								 | 
							
								                )
							 | 
						||
| 
								 | 
							
								            )
							 | 
						||
| 
								 | 
							
								            .scalars()
							 | 
						||
| 
								 | 
							
								            .first()
							 | 
						||
| 
								 | 
							
								        )
							 | 
						||
| 
								 
											2 years ago
										 
									 | 
							
								
							 | 
						||
| 
								 | 
							
								        return query_role_info
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    @classmethod
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								    async def get_role_by_info(cls, db: AsyncSession, role: RoleModel):
							 | 
						||
| 
								 
											2 years ago
										 
									 | 
							
								        """
							 | 
						||
| 
								 | 
							
								        根据角色参数获取角色信息
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								
							 | 
						||
| 
								 
											2 years ago
										 
									 | 
							
								        :param db: orm对象
							 | 
						||
| 
								 | 
							
								        :param role: 角色参数
							 | 
						||
| 
								 | 
							
								        :return: 当前角色参数的角色信息对象
							 | 
						||
| 
								 | 
							
								        """
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								        query_role_info = (
							 | 
						||
| 
								 | 
							
								            (
							 | 
						||
| 
								 | 
							
								                await db.execute(
							 | 
						||
| 
								 | 
							
								                    select(SysRole)
							 | 
						||
| 
								 | 
							
								                    .where(
							 | 
						||
| 
								 | 
							
								                        SysRole.del_flag == '0',
							 | 
						||
| 
								 | 
							
								                        SysRole.role_name == role.role_name if role.role_name else True,
							 | 
						||
| 
								 | 
							
								                        SysRole.role_key == role.role_key if role.role_key else True,
							 | 
						||
| 
								 | 
							
								                    )
							 | 
						||
| 
								 | 
							
								                    .order_by(desc(SysRole.create_time))
							 | 
						||
| 
								 | 
							
								                    .distinct()
							 | 
						||
| 
								 | 
							
								                )
							 | 
						||
| 
								 | 
							
								            )
							 | 
						||
| 
								 | 
							
								            .scalars()
							 | 
						||
| 
								 | 
							
								            .first()
							 | 
						||
| 
								 | 
							
								        )
							 | 
						||
| 
								 
											2 years ago
										 
									 | 
							
								
							 | 
						||
| 
								 | 
							
								        return query_role_info
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    @classmethod
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								    async def get_role_by_id(cls, db: AsyncSession, role_id: int):
							 | 
						||
| 
								 
											2 years ago
										 
									 | 
							
								        """
							 | 
						||
| 
								 | 
							
								        根据角色id获取在用角色信息
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								
							 | 
						||
| 
								 
											2 years ago
										 
									 | 
							
								        :param db: orm对象
							 | 
						||
| 
								 | 
							
								        :param role_id: 角色id
							 | 
						||
| 
								 | 
							
								        :return: 当前角色id的角色信息对象
							 | 
						||
| 
								 | 
							
								        """
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								        role_info = (
							 | 
						||
| 
								 | 
							
								            (
							 | 
						||
| 
								 | 
							
								                await db.execute(
							 | 
						||
| 
								 | 
							
								                    select(SysRole).where(SysRole.role_id == role_id, SysRole.status == '0', SysRole.del_flag == '0')
							 | 
						||
| 
								 | 
							
								                )
							 | 
						||
| 
								 | 
							
								            )
							 | 
						||
| 
								 | 
							
								            .scalars()
							 | 
						||
| 
								 | 
							
								            .first()
							 | 
						||
| 
								 | 
							
								        )
							 | 
						||
| 
								 
											2 years ago
										 
									 | 
							
								
							 | 
						||
| 
								 | 
							
								        return role_info
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    @classmethod
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								    async def get_role_detail_by_id(cls, db: AsyncSession, role_id: int):
							 | 
						||
| 
								 
											2 years ago
										 
									 | 
							
								        """
							 | 
						||
| 
								 | 
							
								        根据role_id获取角色详细信息
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								
							 | 
						||
| 
								 
											2 years ago
										 
									 | 
							
								        :param db: orm对象
							 | 
						||
| 
								 | 
							
								        :param role_id: 角色id
							 | 
						||
| 
								 | 
							
								        :return: 当前role_id的角色信息对象
							 | 
						||
| 
								 | 
							
								        """
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								        query_role_info = (
							 | 
						||
| 
								 | 
							
								            (await db.execute(select(SysRole).where(SysRole.del_flag == '0', SysRole.role_id == role_id).distinct()))
							 | 
						||
| 
								 | 
							
								            .scalars()
							 | 
						||
| 
								 | 
							
								            .first()
							 | 
						||
| 
								 | 
							
								        )
							 | 
						||
| 
								 
											2 years ago
										 
									 | 
							
								
							 | 
						||
| 
								 | 
							
								        return query_role_info
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    @classmethod
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								    async def get_role_select_option_dao(cls, db: AsyncSession):
							 | 
						||
| 
								 
											2 years ago
										 
									 | 
							
								        """
							 | 
						||
| 
								 | 
							
								        获取编辑页面对应的在用角色列表信息
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								
							 | 
						||
| 
								 
											2 years ago
										 
									 | 
							
								        :param db: orm对象
							 | 
						||
| 
								 | 
							
								        :return: 角色列表信息
							 | 
						||
| 
								 | 
							
								        """
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								        role_info = (
							 | 
						||
| 
								 | 
							
								            (
							 | 
						||
| 
								 | 
							
								                await db.execute(
							 | 
						||
| 
								 | 
							
								                    select(SysRole).where(SysRole.role_id != 1, SysRole.status == '0', SysRole.del_flag == '0')
							 | 
						||
| 
								 | 
							
								                )
							 | 
						||
| 
								 | 
							
								            )
							 | 
						||
| 
								 | 
							
								            .scalars()
							 | 
						||
| 
								 | 
							
								            .all()
							 | 
						||
| 
								 | 
							
								        )
							 | 
						||
| 
								 
											2 years ago
										 
									 | 
							
								
							 | 
						||
| 
								 | 
							
								        return role_info
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    @classmethod
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								    async def get_role_list(
							 | 
						||
| 
								 | 
							
								        cls, db: AsyncSession, query_object: RolePageQueryModel, data_scope_sql: str, is_page: bool = False
							 | 
						||
| 
								 | 
							
								    ):
							 | 
						||
| 
								 
											2 years ago
										 
									 | 
							
								        """
							 | 
						||
| 
								 | 
							
								        根据查询参数获取角色列表信息
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								
							 | 
						||
| 
								 
											2 years ago
										 
									 | 
							
								        :param db: orm对象
							 | 
						||
| 
								 | 
							
								        :param query_object: 查询参数对象
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								        :param data_scope_sql: 数据权限对应的查询sql语句
							 | 
						||
| 
								 
											2 years ago
										 
									 | 
							
								        :param is_page: 是否开启分页
							 | 
						||
| 
								 
											2 years ago
										 
									 | 
							
								        :return: 角色列表信息对象
							 | 
						||
| 
								 | 
							
								        """
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								        query = (
							 | 
						||
| 
								 | 
							
								            select(SysRole)
							 | 
						||
| 
								 | 
							
								            .join(SysUserRole, SysUserRole.role_id == SysRole.role_id, isouter=True)
							 | 
						||
| 
								 | 
							
								            .join(SysUser, SysUser.user_id == SysUserRole.user_id, isouter=True)
							 | 
						||
| 
								 | 
							
								            .join(SysDept, SysDept.dept_id == SysUser.dept_id, isouter=True)
							 | 
						||
| 
								 | 
							
								            .where(
							 | 
						||
| 
								 | 
							
								                SysRole.del_flag == '0',
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								                SysRole.role_id == query_object.role_id if query_object.role_id is not None else True,
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								                SysRole.role_name.like(f'%{query_object.role_name}%') if query_object.role_name else True,
							 | 
						||
| 
								 | 
							
								                SysRole.role_key.like(f'%{query_object.role_key}%') if query_object.role_key else True,
							 | 
						||
| 
								 | 
							
								                SysRole.status == query_object.status if query_object.status else True,
							 | 
						||
| 
								 | 
							
								                SysRole.create_time.between(
							 | 
						||
| 
								 | 
							
								                    datetime.combine(datetime.strptime(query_object.begin_time, '%Y-%m-%d'), time(00, 00, 00)),
							 | 
						||
| 
								 | 
							
								                    datetime.combine(datetime.strptime(query_object.end_time, '%Y-%m-%d'), time(23, 59, 59)),
							 | 
						||
| 
								 | 
							
								                )
							 | 
						||
| 
								 | 
							
								                if query_object.begin_time and query_object.end_time
							 | 
						||
| 
								 | 
							
								                else True,
							 | 
						||
| 
								 | 
							
								                eval(data_scope_sql),
							 | 
						||
| 
								 | 
							
								            )
							 | 
						||
| 
								 | 
							
								            .order_by(SysRole.role_sort)
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								            .distinct()
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								        )
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								        role_list = await PageUtil.paginate(db, query, query_object.page_num, query_object.page_size, is_page)
							 | 
						||
| 
								 
											2 years ago
										 
									 | 
							
								
							 | 
						||
| 
								 | 
							
								        return role_list
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    @classmethod
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								    async def add_role_dao(cls, db: AsyncSession, role: RoleModel):
							 | 
						||
| 
								 
											2 years ago
										 
									 | 
							
								        """
							 | 
						||
| 
								 | 
							
								        新增角色数据库操作
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								
							 | 
						||
| 
								 
											2 years ago
										 
									 | 
							
								        :param db: orm对象
							 | 
						||
| 
								 | 
							
								        :param role: 角色对象
							 | 
						||
| 
								 | 
							
								        :return:
							 | 
						||
| 
								 | 
							
								        """
							 | 
						||
| 
								 
											2 years ago
										 
									 | 
							
								        db_role = SysRole(**role.model_dump(exclude={'admin'}))
							 | 
						||
| 
								 
											2 years ago
										 
									 | 
							
								        db.add(db_role)
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								        await db.flush()
							 | 
						||
| 
								 
											2 years ago
										 
									 | 
							
								
							 | 
						||
| 
								 | 
							
								        return db_role
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    @classmethod
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								    async def edit_role_dao(cls, db: AsyncSession, role: dict):
							 | 
						||
| 
								 
											2 years ago
										 
									 | 
							
								        """
							 | 
						||
| 
								 | 
							
								        编辑角色数据库操作
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								
							 | 
						||
| 
								 
											2 years ago
										 
									 | 
							
								        :param db: orm对象
							 | 
						||
| 
								 | 
							
								        :param role: 需要更新的角色字典
							 | 
						||
| 
								 | 
							
								        :return:
							 | 
						||
| 
								 | 
							
								        """
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								        await db.execute(update(SysRole), [role])
							 | 
						||
| 
								 
											2 years ago
										 
									 | 
							
								
							 | 
						||
| 
								 | 
							
								    @classmethod
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								    async def delete_role_dao(cls, db: AsyncSession, role: RoleModel):
							 | 
						||
| 
								 
											2 years ago
										 
									 | 
							
								        """
							 | 
						||
| 
								 | 
							
								        删除角色数据库操作
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								
							 | 
						||
| 
								 
											2 years ago
										 
									 | 
							
								        :param db: orm对象
							 | 
						||
| 
								 | 
							
								        :param role: 角色对象
							 | 
						||
| 
								 | 
							
								        :return:
							 | 
						||
| 
								 | 
							
								        """
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								        await db.execute(
							 | 
						||
| 
								 | 
							
								            update(SysRole)
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								            .where(SysRole.role_id == role.role_id)
							 | 
						||
| 
								 | 
							
								            .values(del_flag='2', update_by=role.update_by, update_time=role.update_time)
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								        )
							 | 
						||
| 
								 
											2 years ago
										 
									 | 
							
								
							 | 
						||
| 
								 | 
							
								    @classmethod
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								    async def get_role_menu_dao(cls, db: AsyncSession, role: RoleModel):
							 | 
						||
| 
								 
											2 years ago
										 
									 | 
							
								        """
							 | 
						||
| 
								 | 
							
								        根据角色id获取角色菜单关联列表信息
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								
							 | 
						||
| 
								 
											2 years ago
										 
									 | 
							
								        :param db: orm对象
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								        :param role: 角色对象
							 | 
						||
| 
								 
											2 years ago
										 
									 | 
							
								        :return: 角色菜单关联列表信息
							 | 
						||
| 
								 | 
							
								        """
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								        role_menu_query_all = (
							 | 
						||
| 
								 | 
							
								            (
							 | 
						||
| 
								 | 
							
								                await db.execute(
							 | 
						||
| 
								 | 
							
								                    select(SysMenu)
							 | 
						||
| 
								 | 
							
								                    .join(SysRoleMenu, SysRoleMenu.menu_id == SysMenu.menu_id)
							 | 
						||
| 
								 | 
							
								                    .where(
							 | 
						||
| 
								 | 
							
								                        SysRoleMenu.role_id == role.role_id,
							 | 
						||
| 
								 | 
							
								                        ~SysMenu.menu_id.in_(
							 | 
						||
| 
								 | 
							
								                            select(SysMenu.parent_id)
							 | 
						||
| 
								 | 
							
								                            .select_from(SysMenu)
							 | 
						||
| 
								 | 
							
								                            .join(
							 | 
						||
| 
								 | 
							
								                                SysRoleMenu,
							 | 
						||
| 
								 | 
							
								                                and_(SysRoleMenu.menu_id == SysMenu.menu_id, SysRoleMenu.role_id == role.role_id),
							 | 
						||
| 
								 | 
							
								                            )
							 | 
						||
| 
								 | 
							
								                        )
							 | 
						||
| 
								 | 
							
								                        if role.menu_check_strictly
							 | 
						||
| 
								 | 
							
								                        else True,
							 | 
						||
| 
								 | 
							
								                    )
							 | 
						||
| 
								 | 
							
								                    .order_by(SysMenu.parent_id, SysMenu.order_num)
							 | 
						||
| 
								 | 
							
								                )
							 | 
						||
| 
								 | 
							
								            )
							 | 
						||
| 
								 | 
							
								            .scalars()
							 | 
						||
| 
								 | 
							
								            .all()
							 | 
						||
| 
								 | 
							
								        )
							 | 
						||
| 
								 
											2 years ago
										 
									 | 
							
								
							 | 
						||
| 
								 | 
							
								        return role_menu_query_all
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    @classmethod
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								    async def add_role_menu_dao(cls, db: AsyncSession, role_menu: RoleMenuModel):
							 | 
						||
| 
								 
											2 years ago
										 
									 | 
							
								        """
							 | 
						||
| 
								 | 
							
								        新增角色菜单关联信息数据库操作
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								
							 | 
						||
| 
								 
											2 years ago
										 
									 | 
							
								        :param db: orm对象
							 | 
						||
| 
								 | 
							
								        :param role_menu: 用户角色菜单关联对象
							 | 
						||
| 
								 | 
							
								        :return:
							 | 
						||
| 
								 | 
							
								        """
							 | 
						||
| 
								 | 
							
								        db_role_menu = SysRoleMenu(**role_menu.model_dump())
							 | 
						||
| 
								 | 
							
								        db.add(db_role_menu)
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    @classmethod
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								    async def delete_role_menu_dao(cls, db: AsyncSession, role_menu: RoleMenuModel):
							 | 
						||
| 
								 
											2 years ago
										 
									 | 
							
								        """
							 | 
						||
| 
								 | 
							
								        删除角色菜单关联信息数据库操作
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								
							 | 
						||
| 
								 
											2 years ago
										 
									 | 
							
								        :param db: orm对象
							 | 
						||
| 
								 | 
							
								        :param role_menu: 角色菜单关联对象
							 | 
						||
| 
								 | 
							
								        :return:
							 | 
						||
| 
								 | 
							
								        """
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								        await db.execute(delete(SysRoleMenu).where(SysRoleMenu.role_id.in_([role_menu.role_id])))
							 | 
						||
| 
								 
											2 years ago
										 
									 | 
							
								
							 | 
						||
| 
								 | 
							
								    @classmethod
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								    async def get_role_dept_dao(cls, db: AsyncSession, role: RoleModel):
							 | 
						||
| 
								 
											2 years ago
										 
									 | 
							
								        """
							 | 
						||
| 
								 | 
							
								        根据角色id获取角色部门关联列表信息
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								
							 | 
						||
| 
								 
											2 years ago
										 
									 | 
							
								        :param db: orm对象
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								        :param role: 角色对象
							 | 
						||
| 
								 
											2 years ago
										 
									 | 
							
								        :return: 角色部门关联列表信息
							 | 
						||
| 
								 | 
							
								        """
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								        role_dept_query_all = (
							 | 
						||
| 
								 | 
							
								            (
							 | 
						||
| 
								 | 
							
								                await db.execute(
							 | 
						||
| 
								 | 
							
								                    select(SysDept)
							 | 
						||
| 
								 | 
							
								                    .join(SysRoleDept, SysRoleDept.dept_id == SysDept.dept_id)
							 | 
						||
| 
								 | 
							
								                    .where(
							 | 
						||
| 
								 | 
							
								                        SysRoleDept.role_id == role.role_id,
							 | 
						||
| 
								 | 
							
								                        ~SysDept.dept_id.in_(
							 | 
						||
| 
								 | 
							
								                            select(SysDept.parent_id)
							 | 
						||
| 
								 | 
							
								                            .select_from(SysDept)
							 | 
						||
| 
								 | 
							
								                            .join(
							 | 
						||
| 
								 | 
							
								                                SysRoleDept,
							 | 
						||
| 
								 | 
							
								                                and_(SysRoleDept.dept_id == SysDept.dept_id, SysRoleDept.role_id == role.role_id),
							 | 
						||
| 
								 | 
							
								                            )
							 | 
						||
| 
								 | 
							
								                        )
							 | 
						||
| 
								 | 
							
								                        if role.dept_check_strictly
							 | 
						||
| 
								 | 
							
								                        else True,
							 | 
						||
| 
								 | 
							
								                    )
							 | 
						||
| 
								 | 
							
								                    .order_by(SysDept.parent_id, SysDept.order_num)
							 | 
						||
| 
								 | 
							
								                )
							 | 
						||
| 
								 | 
							
								            )
							 | 
						||
| 
								 | 
							
								            .scalars()
							 | 
						||
| 
								 | 
							
								            .all()
							 | 
						||
| 
								 | 
							
								        )
							 | 
						||
| 
								 
											2 years ago
										 
									 | 
							
								
							 | 
						||
| 
								 | 
							
								        return role_dept_query_all
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    @classmethod
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								    async def add_role_dept_dao(cls, db: AsyncSession, role_dept: RoleDeptModel):
							 | 
						||
| 
								 
											2 years ago
										 
									 | 
							
								        """
							 | 
						||
| 
								 | 
							
								        新增角色部门关联信息数据库操作
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								
							 | 
						||
| 
								 
											2 years ago
										 
									 | 
							
								        :param db: orm对象
							 | 
						||
| 
								 | 
							
								        :param role_dept: 用户角色部门关联对象
							 | 
						||
| 
								 | 
							
								        :return:
							 | 
						||
| 
								 | 
							
								        """
							 | 
						||
| 
								 | 
							
								        db_role_dept = SysRoleDept(**role_dept.dict())
							 | 
						||
| 
								 | 
							
								        db.add(db_role_dept)
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    @classmethod
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								    async def delete_role_dept_dao(cls, db: AsyncSession, role_dept: RoleDeptModel):
							 | 
						||
| 
								 
											2 years ago
										 
									 | 
							
								        """
							 | 
						||
| 
								 | 
							
								        删除角色部门关联信息数据库操作
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								
							 | 
						||
| 
								 
											2 years ago
										 
									 | 
							
								        :param db: orm对象
							 | 
						||
| 
								 | 
							
								        :param role_dept: 角色部门关联对象
							 | 
						||
| 
								 | 
							
								        :return:
							 | 
						||
| 
								 | 
							
								        """
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								        await db.execute(delete(SysRoleDept).where(SysRoleDept.role_id.in_([role_dept.role_id])))
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								
							 | 
						||
| 
								 | 
							
								    @classmethod
							 | 
						||
| 
								 | 
							
								    async def count_user_role_dao(cls, db: AsyncSession, role_id: int):
							 | 
						||
| 
								 | 
							
								        """
							 | 
						||
| 
								 | 
							
								        根据角色id查询角色关联用户数量
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								        :param db: orm对象
							 | 
						||
| 
								 | 
							
								        :param role_id: 角色id
							 | 
						||
| 
								 | 
							
								        :return: 角色关联用户数量
							 | 
						||
| 
								 | 
							
								        """
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								        user_count = (
							 | 
						||
| 
								 | 
							
								            await db.execute(select(func.count('*')).select_from(SysUserRole).where(SysUserRole.role_id == role_id))
							 | 
						||
| 
								 | 
							
								        ).scalar()
							 | 
						||
| 
								 
											1 year ago
										 
									 | 
							
								
							 | 
						||
| 
								 | 
							
								        return user_count
							 |