Files
KinginfoGateway/src/Admin/ThingsGateway.Admin.Application/Services/Role/ISysRoleService.cs

106 lines
3.3 KiB
C#
Raw Normal View History

2025-01-24 22:42:26 +08:00
//------------------------------------------------------------------------------
// 此代码版权声明为全文件覆盖,如有原作者特别声明,会在下方手动补充
// 此代码版权除特别声明外的代码归作者本人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>
2025-07-24 19:46:30 +08:00
Task<bool> DeleteRoleAsync(HashSet<long> ids);
2025-01-24 22:42:26 +08:00
/// <summary>
/// 从缓存/数据库获取全部角色信息
/// </summary>
/// <returns>角色列表</returns>
Task<List<SysRole>> GetAllAsync();
/// <summary>
/// 根据角色id获取角色列表
/// </summary>
/// <param name="input">角色id列表</param>
/// <returns>角色列表</returns>
2025-07-24 19:46:30 +08:00
Task<IEnumerable<SysRole>> GetRoleListByIdListAsync(HashSet<long> input);
2025-01-24 22:42:26 +08:00
/// <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);
}