mirror of
				https://gitee.com/ThingsGateway/ThingsGateway.git
				synced 2025-10-31 15:43:59 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			106 lines
		
	
	
		
			3.3 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
			
		
		
	
	
			106 lines
		
	
	
		
			3.3 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
| //------------------------------------------------------------------------------
 | ||
| //  此代码版权声明为全文件覆盖,如有原作者特别声明,会在下方手动补充
 | ||
| //  此代码版权(除特别声明外的代码)归作者本人Diego所有
 | ||
| //  源代码使用协议遵循本仓库的开源协议及附加协议
 | ||
| //  Gitee源代码仓库:https://gitee.com/diego2098/ThingsGateway
 | ||
| //  Github源代码仓库:https://github.com/kimdiego2098/ThingsGateway
 | ||
| //  使用文档:https://thingsgateway.cn/
 | ||
| //  QQ群:605534569
 | ||
| //------------------------------------------------------------------------------
 | ||
| 
 | ||
| namespace ThingsGateway.Admin.Application;
 | ||
| 
 | ||
| /// <summary>
 | ||
| /// 角色服务接口
 | ||
| /// </summary>
 | ||
| public interface ISysRoleService
 | ||
| {
 | ||
|     /// <summary>
 | ||
|     /// 获取角色拥有的OpenApi权限
 | ||
|     /// </summary>
 | ||
|     /// <param name="id">角色id</param>
 | ||
|     Task<GrantPermissionData> ApiOwnPermissionAsync(long id);
 | ||
| 
 | ||
|     /// <summary>
 | ||
|     /// 获取角色树
 | ||
|     /// </summary>
 | ||
|     Task<List<RoleTreeOutput>> TreeAsync();
 | ||
| 
 | ||
|     /// <summary>
 | ||
|     /// 删除角色
 | ||
|     /// </summary>
 | ||
|     /// <param name="ids">id列表</param>
 | ||
|     Task<bool> DeleteRoleAsync(HashSet<long> ids);
 | ||
| 
 | ||
|     /// <summary>
 | ||
|     /// 从缓存/数据库获取全部角色信息
 | ||
|     /// </summary>
 | ||
|     /// <returns>角色列表</returns>
 | ||
|     Task<List<SysRole>> GetAllAsync();
 | ||
| 
 | ||
|     /// <summary>
 | ||
|     /// 根据角色id获取角色列表
 | ||
|     /// </summary>
 | ||
|     /// <param name="input">角色id列表</param>
 | ||
|     /// <returns>角色列表</returns>
 | ||
|     Task<IEnumerable<SysRole>> GetRoleListByIdListAsync(HashSet<long> input);
 | ||
| 
 | ||
|     /// <summary>
 | ||
|     /// 根据用户id获取角色列表
 | ||
|     /// </summary>
 | ||
|     /// <param name="userId">用户id</param>
 | ||
|     /// <returns>角色列表</returns>
 | ||
|     Task<IEnumerable<SysRole>> GetRoleListByUserIdAsync(long userId);
 | ||
| 
 | ||
|     /// <summary>
 | ||
|     /// 授权OpenApi权限
 | ||
|     /// </summary>
 | ||
|     /// <param name="input">授权信息</param>
 | ||
|     Task GrantApiPermissionAsync(GrantPermissionData input);
 | ||
| 
 | ||
|     /// <summary>
 | ||
|     /// 授权资源
 | ||
|     /// </summary>
 | ||
|     /// <param name="input">授权信息</param>
 | ||
|     Task GrantResourceAsync(GrantResourceData input);
 | ||
| 
 | ||
|     /// <summary>
 | ||
|     /// 授权用户
 | ||
|     /// </summary>
 | ||
|     /// <param name="input">授权参数</param>
 | ||
|     Task GrantUserAsync(GrantUserOrRoleInput input);
 | ||
| 
 | ||
|     /// <summary>
 | ||
|     /// 获取拥有的资源
 | ||
|     /// </summary>
 | ||
|     /// <param name="id">id</param>
 | ||
|     /// <param name="category">类型</param>
 | ||
|     Task<GrantResourceData> OwnResourceAsync(long id, RelationCategoryEnum category = RelationCategoryEnum.RoleHasResource);
 | ||
| 
 | ||
|     /// <summary>
 | ||
|     /// 获取角色的用户id列表
 | ||
|     /// </summary>
 | ||
|     /// <param name="id">角色id</param>
 | ||
|     /// <returns></returns>
 | ||
|     Task<IEnumerable<long>> OwnUserAsync(long id);
 | ||
| 
 | ||
|     /// <summary>
 | ||
|     /// 报表查询
 | ||
|     /// </summary>
 | ||
|     /// <param name="option">查询条件</param>
 | ||
|     /// <param name="queryFunc">查询条件</param>
 | ||
|     Task<QueryData<SysRole>> PageAsync(QueryPageOptions option, Func<ISugarQueryable<SysRole>, ISugarQueryable<SysRole>>? queryFunc = null);
 | ||
| 
 | ||
|     /// <summary>
 | ||
|     /// 刷新缓存
 | ||
|     /// </summary>
 | ||
|     void RefreshCache();
 | ||
| 
 | ||
|     /// <summary>
 | ||
|     /// 保存角色
 | ||
|     /// </summary>
 | ||
|     /// <param name="input">角色</param>
 | ||
|     /// <param name="type">保存类型</param>
 | ||
|     Task<bool> SaveRoleAsync(SysRole input, ItemChangedType type);
 | ||
| }
 | 
