SysUserRoleService.cs 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081
  1. using Furion.DependencyInjection;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using System.Threading.Tasks;
  5. namespace Admin.NET.Core.Service
  6. {
  7. /// <summary>
  8. /// 系统用户角色服务
  9. /// </summary>
  10. public class SysUserRoleService : ITransient
  11. {
  12. private readonly SqlSugarRepository<SysUserRole> _sysUserRoleRep;
  13. public SysUserRoleService(SqlSugarRepository<SysUserRole> sysUserRoleRep)
  14. {
  15. _sysUserRoleRep = sysUserRoleRep;
  16. }
  17. /// <summary>
  18. /// 授权用户角色
  19. /// </summary>
  20. /// <param name="input"></param>
  21. /// <returns></returns>
  22. [SqlSugarUnitOfWork]
  23. public async Task GrantUserRole(UserRoleInput input)
  24. {
  25. await _sysUserRoleRep.DeleteAsync(u => u.UserId == input.Id);
  26. var roles = input.RoleIdList.Select(u => new SysUserRole
  27. {
  28. UserId = input.Id,
  29. RoleId = u
  30. }).ToList();
  31. await _sysUserRoleRep.InsertRangeAsync(roles);
  32. }
  33. /// <summary>
  34. /// 根据角色Id删除用户角色
  35. /// </summary>
  36. /// <param name="roleId"></param>
  37. /// <returns></returns>
  38. public async Task DeleteUserRoleByRoleId(long roleId)
  39. {
  40. await _sysUserRoleRep.DeleteAsync(u => u.RoleId == roleId);
  41. }
  42. /// <summary>
  43. /// 根据用户Id删除用户角色
  44. /// </summary>
  45. /// <param name="userId"></param>
  46. /// <returns></returns>
  47. public async Task DeleteUserRoleByUserId(long userId)
  48. {
  49. await _sysUserRoleRep.DeleteAsync(u => u.UserId == userId);
  50. }
  51. /// <summary>
  52. /// 根据用户Id获取角色集合
  53. /// </summary>
  54. /// <param name="userId"></param>
  55. /// <returns></returns>
  56. public async Task<List<SysRole>> GetUserRoleList(long userId)
  57. {
  58. var sysUserRoleList = await _sysUserRoleRep.AsQueryable()
  59. .Mapper(u => u.SysRole, u => u.RoleId)
  60. .Where(u => u.UserId == userId).ToListAsync();
  61. return sysUserRoleList.Select(u => u.SysRole).ToList();
  62. }
  63. /// <summary>
  64. /// 根据用户Id获取角色Id集合
  65. /// </summary>
  66. /// <param name="userId"></param>
  67. /// <returns></returns>
  68. public async Task<List<long>> GetUserRoleIdList(long userId)
  69. {
  70. return await _sysUserRoleRep.AsQueryable()
  71. .Where(u => u.UserId == userId).Select(u => u.RoleId).ToListAsync();
  72. }
  73. }
  74. }