SysRoleService.cs 7.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216
  1. namespace Admin.NET.Core.Service;
  2. /// <summary>
  3. /// 系统角色服务
  4. /// </summary>
  5. [ApiDescriptionSettings(Order = 198)]
  6. public class SysRoleService : IDynamicApiController, ITransient
  7. {
  8. private readonly SqlSugarRepository<SysRole> _sysRoleRep;
  9. private readonly IUserManager _userManager;
  10. private readonly ISysCacheService _sysCacheService;
  11. private readonly SysRoleOrgService _sysRoleOrgService;
  12. private readonly SysRoleMenuService _sysRoleMenuService;
  13. private readonly SysOrgService _sysOrgService;
  14. private readonly SysUserRoleService _sysUserRoleService;
  15. public SysRoleService(SqlSugarRepository<SysRole> sysRoleRep,
  16. IUserManager userManager,
  17. ISysCacheService sysCacheService,
  18. SysRoleOrgService sysRoleOrgService,
  19. SysRoleMenuService sysRoleMenuService,
  20. SysOrgService sysOrgService,
  21. SysUserRoleService sysUserRoleService)
  22. {
  23. _sysRoleRep = sysRoleRep;
  24. _userManager = userManager;
  25. _sysCacheService = sysCacheService;
  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. [HttpGet("/sysRole/page")]
  37. public async Task<SqlSugarPagedList<SysRole>> GetRolePage([FromQuery] PageRoleInput input)
  38. {
  39. return await _sysRoleRep.AsQueryable()
  40. .WhereIF(input.Status > 0, u => u.Status == (StatusEnum)input.Status)
  41. .WhereIF(!string.IsNullOrWhiteSpace(input.Name), u => u.Name.Contains(input.Name))
  42. .OrderBy(u => u.Order)
  43. .ToPagedListAsync(input.Page, input.PageSize);
  44. }
  45. /// <summary>
  46. /// 获取角色列表
  47. /// </summary>
  48. /// <returns></returns>
  49. [HttpGet("/sysRole/list")]
  50. public async Task<List<RoleOutput>> GetRoleList()
  51. {
  52. //// 若非超级管理员则只取拥有角色Id集合
  53. //var roleIdList = _userManager.SuperAdmin ? new List<long>() :
  54. // await _sysUserRoleService.GetUserRoleIdList(_userManager.UserId);
  55. return await _sysRoleRep.AsQueryable()
  56. //.WhereIF(roleIdList.Count > 0, u => roleIdList.Contains(u.Id))
  57. .OrderBy(u => u.Order).Select<RoleOutput>().ToListAsync();
  58. }
  59. /// <summary>
  60. /// 增加角色
  61. /// </summary>
  62. /// <param name="input"></param>
  63. /// <returns></returns>
  64. [HttpPost("/sysRole/add")]
  65. public async Task AddRole(AddRoleInput input)
  66. {
  67. var isExist = await _sysRoleRep.IsAnyAsync(u => u.Code == input.Code || u.Name == input.Name);
  68. if (isExist)
  69. throw Oops.Oh(ErrorCodeEnum.D1006);
  70. await _sysRoleRep.InsertAsync(input.Adapt<SysRole>());
  71. }
  72. /// <summary>
  73. /// 更新角色
  74. /// </summary>
  75. /// <param name="input"></param>
  76. /// <returns></returns>
  77. [HttpPost("/sysRole/update")]
  78. public async Task UpdateRole(UpdateRoleInput input)
  79. {
  80. var adminRole = await _sysRoleRep.GetFirstAsync(u => u.Id == input.Id);
  81. if (adminRole.Code == CommonConst.SysAdminRoleCode)
  82. throw Oops.Oh(ErrorCodeEnum.D1020);
  83. var isExist = await _sysRoleRep.IsAnyAsync(u => (u.Name == input.Name || u.Code == input.Code) && u.Id != input.Id);
  84. if (isExist)
  85. throw Oops.Oh(ErrorCodeEnum.D1006);
  86. await _sysRoleRep.AsUpdateable(input.Adapt<SysRole>()).IgnoreColumns(true)
  87. .IgnoreColumns(u => new { u.DataScope }).ExecuteCommandAsync();
  88. }
  89. /// <summary>
  90. /// 删除角色
  91. /// </summary>
  92. /// <param name="input"></param>
  93. /// <returns></returns>
  94. [HttpPost("/sysRole/delete")]
  95. [UnitOfWork]
  96. public async Task DeleteRole(DeleteRoleInput input)
  97. {
  98. var sysRole = await _sysRoleRep.GetFirstAsync(u => u.Id == input.Id);
  99. if (sysRole.Code == CommonConst.SysAdminRoleCode)
  100. throw Oops.Oh(ErrorCodeEnum.D1019);
  101. await _sysRoleRep.DeleteAsync(sysRole);
  102. // 级联删除角色机构数据
  103. await _sysRoleOrgService.DeleteRoleOrgByRoleId(sysRole.Id);
  104. // 级联删除用户角色数据
  105. await _sysUserRoleService.DeleteUserRoleByRoleId(sysRole.Id);
  106. // 级联删除角色菜单数据
  107. await _sysRoleMenuService.DeleteRoleMenuByRoleId(sysRole.Id);
  108. }
  109. /// <summary>
  110. /// 授权角色菜单
  111. /// </summary>
  112. /// <param name="input"></param>
  113. /// <returns></returns>
  114. [HttpPost("/sysRole/grantMenu")]
  115. public async Task GrantRoleMenu(RoleMenuInput input)
  116. {
  117. var role = await _sysRoleRep.GetFirstAsync(u => u.Id == input.Id);
  118. if (!_userManager.SuperAdmin && role.Code == CommonConst.SysAdminRoleCode)
  119. throw Oops.Oh(ErrorCodeEnum.D1021);
  120. await _sysRoleMenuService.GrantRoleMenu(input);
  121. }
  122. /// <summary>
  123. /// 授权角色数据范围
  124. /// </summary>
  125. /// <param name="input"></param>
  126. /// <returns></returns>
  127. [HttpPost("/sysRole/grantData")]
  128. public async Task GrantRoleDataScope(RoleOrgInput input)
  129. {
  130. // 删除所有用户机构缓存
  131. await _sysCacheService.DelByPatternAsync(CacheConst.KeyOrgIdList);
  132. var role = await _sysRoleRep.GetFirstAsync(u => u.Id == input.Id);
  133. var dataScope = input.DataScope;
  134. if (!_userManager.SuperAdmin)
  135. {
  136. // 非超级管理员没有全部数据范围权限
  137. if (dataScope == (int)DataScopeEnum.All)
  138. throw Oops.Oh(ErrorCodeEnum.D1016);
  139. // 若数据范围自定义,则判断授权数据范围是否有权限
  140. if (dataScope == (int)DataScopeEnum.Define)
  141. {
  142. var grantOrgIdList = input.OrgIdList;
  143. if (grantOrgIdList.Count > 0)
  144. {
  145. var orgIdList = await _sysOrgService.GetUserOrgIdList();
  146. if (orgIdList.Count < 1)
  147. throw Oops.Oh(ErrorCodeEnum.D1016);
  148. else if (!grantOrgIdList.All(u => orgIdList.Any(c => c == u)))
  149. throw Oops.Oh(ErrorCodeEnum.D1016);
  150. }
  151. }
  152. }
  153. role.DataScope = (DataScopeEnum)dataScope;
  154. await _sysRoleRep.AsUpdateable(role).UpdateColumns(u => new { u.DataScope }).ExecuteCommandAsync();
  155. await _sysRoleOrgService.GrantRoleOrg(input);
  156. }
  157. /// <summary>
  158. /// 根据角色Id获取菜单树(前端区分父子节点)
  159. /// </summary>
  160. /// <param name="input"></param>
  161. /// <returns></returns>
  162. [HttpGet("/sysRole/ownMenu")]
  163. public async Task<List<SysMenu>> GetRoleOwnMenu([FromQuery] RoleInput input)
  164. {
  165. return await _sysRoleMenuService.GetRoleMenu(new List<long> { input.Id });
  166. }
  167. /// <summary>
  168. /// 根据角色Id获取机构Id集合
  169. /// </summary>
  170. /// <param name="input"></param>
  171. /// <returns></returns>
  172. [HttpGet("/sysRole/ownOrg")]
  173. public async Task<List<long>> GetRoleOwnOrg([FromQuery] RoleInput input)
  174. {
  175. return await _sysRoleOrgService.GetRoleOrgIdList(new List<long> { input.Id });
  176. }
  177. /// <summary>
  178. /// 设置角色状态
  179. /// </summary>
  180. /// <param name="input"></param>
  181. /// <returns></returns>
  182. [HttpPost("/sysRole/setStatus")]
  183. public async Task<int> SetRoleStatus(RoleInput input)
  184. {
  185. if (!Enum.IsDefined(typeof(StatusEnum), input.Status))
  186. throw Oops.Oh(ErrorCodeEnum.D3005);
  187. return await _sysRoleRep.AsUpdateable()
  188. .SetColumns(u => u.Status == (StatusEnum)input.Status)
  189. .Where(u => u.Id == input.Id)
  190. .ExecuteCommandAsync();
  191. }
  192. }