|  |  | @ -1,4 +1,5 @@ | 
			
		
	
		
			
				
					|  |  |  | from fastapi import Depends | 
			
		
	
		
			
				
					|  |  |  | from typing import Union, List | 
			
		
	
		
			
				
					|  |  |  | from module_admin.entity.vo.user_vo import CurrentUserModel | 
			
		
	
		
			
				
					|  |  |  | from module_admin.service.login_service import LoginService | 
			
		
	
		
			
				
					|  |  |  | from exceptions.exception import PermissionException | 
			
		
	
	
		
			
				
					|  |  | @ -7,13 +8,52 @@ from exceptions.exception import PermissionException | 
			
		
	
		
			
				
					|  |  |  | class CheckUserInterfaceAuth: | 
			
		
	
		
			
				
					|  |  |  |     """ | 
			
		
	
		
			
				
					|  |  |  |     校验当前用户是否具有相应的接口权限 | 
			
		
	
		
			
				
					|  |  |  |     :param perm: 权限标识 | 
			
		
	
		
			
				
					|  |  |  |     :param is_strict: 当传入的权限标识是list类型时,是否开启严格模式,开启表示会校验列表中的每一个权限标识,所有的校验结果都需要为True才会通过 | 
			
		
	
		
			
				
					|  |  |  |     """ | 
			
		
	
		
			
				
					|  |  |  |     def __init__(self, perm_str: str = 'common'): | 
			
		
	
		
			
				
					|  |  |  |         self.perm_str = perm_str | 
			
		
	
		
			
				
					|  |  |  |     def __init__(self, perm: Union[str, List], is_strict: bool = False): | 
			
		
	
		
			
				
					|  |  |  |         self.perm = perm | 
			
		
	
		
			
				
					|  |  |  |         self.is_strict = is_strict | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |     def __call__(self, current_user: CurrentUserModel = Depends(LoginService.get_current_user)): | 
			
		
	
		
			
				
					|  |  |  |         user_auth_list = current_user.permissions | 
			
		
	
		
			
				
					|  |  |  |         user_auth_list.append('common') | 
			
		
	
		
			
				
					|  |  |  |         if '*:*:*' in user_auth_list or self.perm_str in user_auth_list: | 
			
		
	
		
			
				
					|  |  |  |         if '*:*:*' in user_auth_list: | 
			
		
	
		
			
				
					|  |  |  |             return True | 
			
		
	
		
			
				
					|  |  |  |         if isinstance(self.perm, str): | 
			
		
	
		
			
				
					|  |  |  |             if self.perm in user_auth_list: | 
			
		
	
		
			
				
					|  |  |  |                 return True | 
			
		
	
		
			
				
					|  |  |  |         if isinstance(self.perm, list): | 
			
		
	
		
			
				
					|  |  |  |             if self.is_strict: | 
			
		
	
		
			
				
					|  |  |  |                 if all([perm_str in user_auth_list for perm_str in self.perm]): | 
			
		
	
		
			
				
					|  |  |  |                     return True | 
			
		
	
		
			
				
					|  |  |  |             else: | 
			
		
	
		
			
				
					|  |  |  |                 if any([perm_str in user_auth_list for perm_str in self.perm]): | 
			
		
	
		
			
				
					|  |  |  |                     return True | 
			
		
	
		
			
				
					|  |  |  |         raise PermissionException(data="", message="该用户无此接口权限") | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  | class CheckRoleInterfaceAuth: | 
			
		
	
		
			
				
					|  |  |  |     """ | 
			
		
	
		
			
				
					|  |  |  |     根据角色校验当前用户是否具有相应的接口权限 | 
			
		
	
		
			
				
					|  |  |  |     :param role_key: 角色标识 | 
			
		
	
		
			
				
					|  |  |  |     :param is_strict: 当传入的角色标识是list类型时,是否开启严格模式,开启表示会校验列表中的每一个角色标识,所有的校验结果都需要为True才会通过 | 
			
		
	
		
			
				
					|  |  |  |     """ | 
			
		
	
		
			
				
					|  |  |  |     def __init__(self, role_key: Union[str, List], is_strict: bool = False): | 
			
		
	
		
			
				
					|  |  |  |         self.role_key = role_key | 
			
		
	
		
			
				
					|  |  |  |         self.is_strict = is_strict | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |     def __call__(self, current_user: CurrentUserModel = Depends(LoginService.get_current_user)): | 
			
		
	
		
			
				
					|  |  |  |         user_role_list = current_user.user.role | 
			
		
	
		
			
				
					|  |  |  |         user_role_key_list = [role.role_key for role in user_role_list] | 
			
		
	
		
			
				
					|  |  |  |         if isinstance(self.role_key, str): | 
			
		
	
		
			
				
					|  |  |  |             if self.role_key in user_role_key_list: | 
			
		
	
		
			
				
					|  |  |  |                 return True | 
			
		
	
		
			
				
					|  |  |  |         if isinstance(self.role_key, list): | 
			
		
	
		
			
				
					|  |  |  |             if self.is_strict: | 
			
		
	
		
			
				
					|  |  |  |                 if all([role_key_str in user_role_key_list for role_key_str in self.role_key]): | 
			
		
	
		
			
				
					|  |  |  |                     return True | 
			
		
	
		
			
				
					|  |  |  |             else: | 
			
		
	
		
			
				
					|  |  |  |                 if any([role_key_str in user_role_key_list for role_key_str in self.role_key]): | 
			
		
	
		
			
				
					|  |  |  |                     return True | 
			
		
	
		
			
				
					|  |  |  |         raise PermissionException(data="", message="该用户无此接口权限") | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
	
		
			
				
					|  |  | 
 |