SysUserService.cs 3.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788
  1. using Furion.DatabaseAccessor.Extensions;
  2. using Microsoft.Extensions.Options;
  3. using YBEE.EQM.Core;
  4. namespace YBEE.EQM.Application;
  5. /// <summary>
  6. /// 系统用户服务
  7. /// </summary>
  8. public class SysUserService : ISysUserService, ITransient
  9. {
  10. private readonly IRepository<SysUser> _userRep;
  11. private readonly AuthOptions _authOptions;
  12. public SysUserService(IRepository<SysUser> userRep, IOptions<AuthOptions> options)
  13. {
  14. _userRep = userRep;
  15. _authOptions = options.Value;
  16. }
  17. /// <summary>
  18. /// 获取所有用户列表
  19. /// </summary>
  20. /// <returns></returns>
  21. public async Task<List<SysUserLiteOutput>> GetAllList()
  22. {
  23. var items = await _userRep.DetachedEntities.Where(u => u.Status == CommonStatus.ENABLE)
  24. .ProjectToType<SysUserLiteOutput>()
  25. .ToListAsync();
  26. return items;
  27. }
  28. /// <summary>
  29. /// 修改密码
  30. /// </summary>
  31. /// <param name="input"></param>
  32. /// <returns></returns>
  33. public async Task ChangePassword(ChangeSysUserPasswordInput input)
  34. {
  35. string oldPwd = RSAEncryption.Decrypt(input.OldPassword, _authOptions.RsaPrivateKey);
  36. string newPwd = RSAEncryption.Decrypt(input.NewPassword, _authOptions.RsaPrivateKey);
  37. if (newPwd.Length < 6 || newPwd.Length > 32)
  38. {
  39. throw Oops.Oh(ErrorCode.E1006);
  40. }
  41. if ((await _userRep.DetachedEntities.AsQueryable().ToListAsync()).Any(t => t.Id == CurrentSysUserInfo.SysUserId && AESEncryption.Decrypt(t.Password, _authOptions.AesPassword).Equals(oldPwd)))
  42. {
  43. var user = await _userRep.FirstOrDefaultAsync(t => t.Id == CurrentSysUserInfo.SysUserId);
  44. user.Password = AESEncryption.Encrypt(newPwd, _authOptions.AesPassword);
  45. await user.UpdateIncludeNowAsync(new[] { "Password" });
  46. }
  47. else
  48. {
  49. throw Oops.Oh(ErrorCode.E1005);
  50. }
  51. }
  52. /// <summary>
  53. /// 查询简要用户列表
  54. /// </summary>
  55. /// <param name="input"></param>
  56. /// <returns></returns>
  57. public async Task<PageResult<SysUserSimpleOutput>> QueryUserSimplePageList(SysUserPageInput input)
  58. {
  59. var query = GetQueryBase(input);
  60. var ret = await query.OrderBy(t => t.Name).ProjectToType<SysUserSimpleOutput>().ToADPagedListAsync(input.PageIndex, input.PageSize);
  61. return ret;
  62. }
  63. #region 私有方法
  64. private IQueryable<SysUser> GetQueryBase(SysUserPageInput input)
  65. {
  66. var name = !string.IsNullOrEmpty(input.Name?.Trim());
  67. var mobile = !string.IsNullOrEmpty(input.Mobile?.Trim());
  68. var account = !string.IsNullOrEmpty(input.Account?.Trim());
  69. var email = !string.IsNullOrEmpty(input.Email?.Trim());
  70. var searchValue = !string.IsNullOrEmpty(input.SearchValue?.Trim());
  71. var query = _userRep.DetachedEntities.Where(t => t.IsDeleted == false)
  72. .Where((searchValue, u => EF.Functions.Like(u.Name, $"%{input.SearchValue.Trim()}%") || EF.Functions.Like(u.Account, $"%{input.SearchValue.Trim()}%")))
  73. .Where(name, u => EF.Functions.Like(u.Name, $"%{input.Name.Trim()}%"))
  74. .Where(mobile, u => EF.Functions.Like(u.Mobile, $"%{input.Mobile.Trim()}%"))
  75. .Where(account, u => EF.Functions.Like(u.Account, $"%{input.Account.Trim()}%"))
  76. .Where(email, u => EF.Functions.Like(u.Email, $"%{input.Email.Trim()}%"))
  77. .Where(input.SysOrgId.HasValue, t => t.SysOrgId == input.SysOrgId);
  78. return query;
  79. }
  80. #endregion
  81. }