SysRoleOrgService.cs 1.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566
  1. namespace Admin.NET.Core.Service;
  2. /// <summary>
  3. /// 系统角色机构服务
  4. /// </summary>
  5. public class SysRoleOrgService : ITransient
  6. {
  7. private readonly SqlSugarRepository<SysRoleOrg> _sysRoleOrgRep;
  8. public SysRoleOrgService(SqlSugarRepository<SysRoleOrg> sysRoleOrgRep)
  9. {
  10. _sysRoleOrgRep = sysRoleOrgRep;
  11. }
  12. /// <summary>
  13. /// 授权角色机构
  14. /// </summary>
  15. /// <param name="input"></param>
  16. /// <returns></returns>
  17. [UnitOfWork]
  18. public async Task GrantRoleOrg(RoleOrgInput input)
  19. {
  20. await _sysRoleOrgRep.DeleteAsync(u => u.RoleId == input.Id);
  21. if (input.DataScope == (int)DataScopeEnum.Define)
  22. {
  23. var roleOrgs = input.OrgIdList.Select(u => new SysRoleOrg
  24. {
  25. RoleId = input.Id,
  26. OrgId = u
  27. }).ToList();
  28. await _sysRoleOrgRep.InsertRangeAsync(roleOrgs);
  29. }
  30. }
  31. /// <summary>
  32. /// 根据角色Id集合获取角色机构Id集合
  33. /// </summary>
  34. /// <param name="roleIdList"></param>
  35. /// <returns></returns>
  36. public async Task<List<long>> GetRoleOrgIdList(List<long> roleIdList)
  37. {
  38. return await _sysRoleOrgRep.AsQueryable()
  39. .Where(u => roleIdList.Contains(u.RoleId))
  40. .Select(u => u.OrgId).ToListAsync();
  41. }
  42. /// <summary>
  43. /// 根据机构Id集合删除角色机构
  44. /// </summary>
  45. /// <param name="orgIdList"></param>
  46. /// <returns></returns>
  47. public async Task DeleteRoleOrgByOrgIdList(List<long> orgIdList)
  48. {
  49. await _sysRoleOrgRep.DeleteAsync(u => orgIdList.Contains(u.OrgId));
  50. }
  51. /// <summary>
  52. /// 根据角色Id删除角色机构
  53. /// </summary>
  54. /// <param name="roleId"></param>
  55. /// <returns></returns>
  56. public async Task DeleteRoleOrgByRoleId(long roleId)
  57. {
  58. await _sysRoleOrgRep.DeleteAsync(u => u.RoleId == roleId);
  59. }
  60. }