SysUserRoleService.cs 2.2 KB

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