SysRoleService.cs 9.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246
  1. // 此源代码遵循位于源代码树根目录中的 LICENSE 文件的许可证。
  2. //
  3. // 必须在法律法规允许的范围内正确使用,严禁将其用于非法、欺诈、恶意或侵犯他人合法权益的目的。
  4. namespace Admin.NET.Core.Service;
  5. /// <summary>
  6. /// 系统角色服务 💥
  7. /// </summary>
  8. [ApiDescriptionSettings(Order = 480)]
  9. public class SysRoleService : IDynamicApiController, ITransient
  10. {
  11. private readonly UserManager _userManager;
  12. private readonly SqlSugarRepository<SysRole> _sysRoleRep;
  13. private readonly SysRoleOrgService _sysRoleOrgService;
  14. private readonly SysRoleMenuService _sysRoleMenuService;
  15. private readonly SysOrgService _sysOrgService;
  16. private readonly SysUserRoleService _sysUserRoleService;
  17. public SysRoleService(UserManager userManager,
  18. SqlSugarRepository<SysRole> sysRoleRep,
  19. SysRoleOrgService sysRoleOrgService,
  20. SysRoleMenuService sysRoleMenuService,
  21. SysOrgService sysOrgService,
  22. SysUserRoleService sysUserRoleService)
  23. {
  24. _userManager = userManager;
  25. _sysRoleRep = sysRoleRep;
  26. _sysRoleOrgService = sysRoleOrgService;
  27. _sysRoleMenuService = sysRoleMenuService;
  28. _sysOrgService = sysOrgService;
  29. _sysUserRoleService = sysUserRoleService;
  30. }
  31. /// <summary>
  32. /// 获取角色分页列表 🔖
  33. /// </summary>
  34. /// <param name="input"></param>
  35. /// <returns></returns>
  36. [DisplayName("获取角色分页列表")]
  37. public async Task<SqlSugarPagedList<SysRole>> Page(PageRoleInput input)
  38. {
  39. return await _sysRoleRep.AsQueryable()
  40. .WhereIF(!_userManager.SuperAdmin, u => u.CreateUserId == _userManager.UserId) // 若非超管,则只能操作自己创建的角色
  41. .WhereIF(!string.IsNullOrWhiteSpace(input.Name), u => u.Name.Contains(input.Name))
  42. .WhereIF(!string.IsNullOrWhiteSpace(input.Code), u => u.Code.Contains(input.Code))
  43. .OrderBy(u => u.OrderNo)
  44. .ToPagedListAsync(input.Page, input.PageSize);
  45. }
  46. /// <summary>
  47. /// 获取角色列表 🔖
  48. /// </summary>
  49. /// <returns></returns>
  50. [DisplayName("获取角色列表")]
  51. public async Task<List<RoleOutput>> GetList()
  52. {
  53. // 当前用户已拥有的角色集合
  54. var roleIdList = _userManager.SuperAdmin ? null : await _sysUserRoleService.GetUserRoleIdList(_userManager.UserId);
  55. return await _sysRoleRep.AsQueryable()
  56. .WhereIF(roleIdList != null, u => u.CreateUserId == _userManager.UserId || roleIdList.Contains(u.Id)) // 若非超管,则只显示自己创建和已拥有的角色
  57. .OrderBy(u => u.OrderNo).Select<RoleOutput>().ToListAsync();
  58. }
  59. /// <summary>
  60. /// 增加角色 🔖
  61. /// </summary>
  62. /// <param name="input"></param>
  63. /// <returns></returns>
  64. [ApiDescriptionSettings(Name = "Add"), HttpPost]
  65. [DisplayName("增加角色")]
  66. public async Task AddRole(AddRoleInput input)
  67. {
  68. if (await _sysRoleRep.IsAnyAsync(u => u.Name == input.Name && u.Code == input.Code))
  69. throw Oops.Oh(ErrorCodeEnum.D1006);
  70. var newRole = await _sysRoleRep.AsInsertable(input.Adapt<SysRole>()).ExecuteReturnEntityAsync();
  71. input.Id = newRole.Id;
  72. await UpdateRoleMenu(input);
  73. }
  74. /// <summary>
  75. /// 更新角色菜单权限
  76. /// </summary>
  77. /// <param name="input"></param>
  78. /// <returns></returns>
  79. private async Task UpdateRoleMenu(AddRoleInput input)
  80. {
  81. if (input.MenuIdList == null || input.MenuIdList.Count < 1)
  82. return;
  83. // 将父节点为0的菜单排除,防止前端全选异常
  84. var pMenuIds = await _sysRoleRep.ChangeRepository<SqlSugarRepository<SysMenu>>().AsQueryable().Where(u => input.MenuIdList.Contains(u.Id) && u.Pid == 0).ToListAsync(u => u.Id);
  85. var menuIds = input.MenuIdList.Except(pMenuIds); // 差集
  86. await GrantMenu(new RoleMenuInput()
  87. {
  88. Id = input.Id,
  89. MenuIdList = menuIds.ToList()
  90. });
  91. }
  92. /// <summary>
  93. /// 更新角色 🔖
  94. /// </summary>
  95. /// <param name="input"></param>
  96. /// <returns></returns>
  97. [ApiDescriptionSettings(Name = "Update"), HttpPost]
  98. [DisplayName("更新角色")]
  99. public async Task UpdateRole(UpdateRoleInput input)
  100. {
  101. if (await _sysRoleRep.IsAnyAsync(u => u.Name == input.Name && u.Code == input.Code && u.Id != input.Id))
  102. throw Oops.Oh(ErrorCodeEnum.D1006);
  103. await _sysRoleRep.AsUpdateable(input.Adapt<SysRole>()).IgnoreColumns(true)
  104. .IgnoreColumns(u => new { u.DataScope }).ExecuteCommandAsync();
  105. await UpdateRoleMenu(input);
  106. }
  107. /// <summary>
  108. /// 删除角色 🔖
  109. /// </summary>
  110. /// <param name="input"></param>
  111. /// <returns></returns>
  112. [UnitOfWork]
  113. [ApiDescriptionSettings(Name = "Delete"), HttpPost]
  114. [DisplayName("删除角色")]
  115. public async Task DeleteRole(DeleteRoleInput input)
  116. {
  117. // 禁止删除系统管理员角色
  118. var sysRole = await _sysRoleRep.GetFirstAsync(u => u.Id == input.Id) ?? throw Oops.Oh(ErrorCodeEnum.D1002);
  119. if (sysRole.Code == CommonConst.SysAdminRole)
  120. throw Oops.Oh(ErrorCodeEnum.D1019);
  121. // 若角色有用户则禁止删除
  122. var userIds = await _sysUserRoleService.GetUserIdList(input.Id);
  123. if (userIds != null && userIds.Count > 0)
  124. throw Oops.Oh(ErrorCodeEnum.D1025);
  125. await _sysRoleRep.DeleteAsync(sysRole);
  126. // 级联删除角色机构数据
  127. await _sysRoleOrgService.DeleteRoleOrgByRoleId(sysRole.Id);
  128. // 级联删除用户角色数据
  129. await _sysUserRoleService.DeleteUserRoleByRoleId(sysRole.Id);
  130. // 级联删除角色菜单数据
  131. await _sysRoleMenuService.DeleteRoleMenuByRoleId(sysRole.Id);
  132. }
  133. /// <summary>
  134. /// 授权角色菜单 🔖
  135. /// </summary>
  136. /// <param name="input"></param>
  137. /// <returns></returns>
  138. [UnitOfWork]
  139. [DisplayName("授权角色菜单")]
  140. public async Task GrantMenu(RoleMenuInput input)
  141. {
  142. await _sysRoleMenuService.GrantRoleMenu(input);
  143. }
  144. /// <summary>
  145. /// 授权角色数据范围 🔖
  146. /// </summary>
  147. /// <param name="input"></param>
  148. /// <returns></returns>
  149. [UnitOfWork]
  150. [DisplayName("授权角色数据范围")]
  151. public async Task GrantDataScope(RoleOrgInput input)
  152. {
  153. // 删除与该角色相关的用户机构缓存
  154. var userIdList = await _sysUserRoleService.GetUserIdList(input.Id);
  155. foreach (var userId in userIdList)
  156. {
  157. SqlSugarFilter.DeleteUserOrgCache(userId, _sysRoleRep.Context.CurrentConnectionConfig.ConfigId.ToString());
  158. }
  159. var role = await _sysRoleRep.GetFirstAsync(u => u.Id == input.Id);
  160. var dataScope = input.DataScope;
  161. if (!_userManager.SuperAdmin)
  162. {
  163. // 非超级管理员没有全部数据范围权限
  164. if (dataScope == (int)DataScopeEnum.All)
  165. throw Oops.Oh(ErrorCodeEnum.D1016);
  166. // 若数据范围自定义,则判断授权数据范围是否有权限
  167. if (dataScope == (int)DataScopeEnum.Define)
  168. {
  169. var grantOrgIdList = input.OrgIdList;
  170. if (grantOrgIdList.Count > 0)
  171. {
  172. var orgIdList = await _sysOrgService.GetUserOrgIdList();
  173. if (orgIdList.Count < 1)
  174. throw Oops.Oh(ErrorCodeEnum.D1016);
  175. else if (!grantOrgIdList.All(u => orgIdList.Any(c => c == u)))
  176. throw Oops.Oh(ErrorCodeEnum.D1016);
  177. }
  178. }
  179. }
  180. role.DataScope = (DataScopeEnum)dataScope;
  181. await _sysRoleRep.AsUpdateable(role).UpdateColumns(u => new { u.DataScope }).ExecuteCommandAsync();
  182. await _sysRoleOrgService.GrantRoleOrg(input);
  183. }
  184. /// <summary>
  185. /// 根据角色Id获取菜单Id集合 🔖
  186. /// </summary>
  187. /// <param name="input"></param>
  188. /// <returns></returns>
  189. [DisplayName("根据角色Id获取菜单Id集合")]
  190. public async Task<List<long>> GetOwnMenuList([FromQuery] RoleInput input)
  191. {
  192. return await _sysRoleMenuService.GetRoleMenuIdList(new List<long> { input.Id });
  193. }
  194. /// <summary>
  195. /// 根据角色Id获取机构Id集合 🔖
  196. /// </summary>
  197. /// <param name="input"></param>
  198. /// <returns></returns>
  199. [DisplayName("根据角色Id获取机构Id集合")]
  200. public async Task<List<long>> GetOwnOrgList([FromQuery] RoleInput input)
  201. {
  202. return await _sysRoleOrgService.GetRoleOrgIdList(new List<long> { input.Id });
  203. }
  204. /// <summary>
  205. /// 设置角色状态 🔖
  206. /// </summary>
  207. /// <param name="input"></param>
  208. /// <returns></returns>
  209. [DisplayName("设置角色状态")]
  210. public async Task<int> SetStatus(RoleInput input)
  211. {
  212. if (!Enum.IsDefined(typeof(StatusEnum), input.Status))
  213. throw Oops.Oh(ErrorCodeEnum.D3005);
  214. return await _sysRoleRep.AsUpdateable()
  215. .SetColumns(u => u.Status == input.Status)
  216. .Where(u => u.Id == input.Id)
  217. .ExecuteCommandAsync();
  218. }
  219. }