SysRoleService.cs 9.5 KB

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