SysUserService.cs 9.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267
  1. using Furion.DataEncryption;
  2. using Furion.DependencyInjection;
  3. using Furion.DynamicApiController;
  4. using Furion.FriendlyException;
  5. using Mapster;
  6. using Microsoft.AspNetCore.Mvc;
  7. using System;
  8. using System.Collections.Generic;
  9. using System.Linq;
  10. using System.Threading.Tasks;
  11. namespace Admin.NET.Core.Service
  12. {
  13. /// <summary>
  14. /// 系统用户服务
  15. /// </summary>
  16. [ApiDescriptionSettings(Name = "系统用户", Order = 199)]
  17. public class SysUserService : IDynamicApiController, ITransient
  18. {
  19. private readonly SqlSugarRepository<SysUser> _sysUserRep;
  20. private readonly IUserManager _userManager;
  21. private readonly ISysCacheService _sysCacheService;
  22. private readonly SysOrgService _sysOrgService;
  23. private readonly SysUserOrgService _sysUserOrgService;
  24. private readonly SysUserRoleService _sysUserRoleService;
  25. public SysUserService(SqlSugarRepository<SysUser> sysUserRep,
  26. IUserManager userManager,
  27. ISysCacheService sysCacheService,
  28. SysOrgService sysOrgService,
  29. SysUserOrgService sysUserOrgService,
  30. SysUserRoleService sysUserRoleService)
  31. {
  32. _sysUserRep = sysUserRep;
  33. _userManager = userManager;
  34. _sysOrgService = sysOrgService;
  35. _sysUserOrgService = sysUserOrgService;
  36. _sysUserRoleService = sysUserRoleService;
  37. _sysCacheService = sysCacheService;
  38. }
  39. /// <summary>
  40. /// 获取用户分页列表
  41. /// </summary>
  42. /// <param name="input"></param>
  43. /// <returns></returns>
  44. [HttpGet("/sysUser/pageList")]
  45. public async Task<SqlSugarPagedList<SysUser>> GetUserPageList([FromQuery] PageUserInput input)
  46. {
  47. var orgList = input.OrgId > 0 ? await _sysOrgService.GetChildIdListWithSelfById(input.OrgId) : null;
  48. return await _sysUserRep.AsQueryable()
  49. .WhereIF(!string.IsNullOrWhiteSpace(input.UserName), u => u.UserName.Contains(input.UserName))
  50. .WhereIF(!string.IsNullOrWhiteSpace(input.Phone), u => u.Phone.Contains(input.Phone))
  51. .WhereIF(input.OrgId > 0, u => orgList.Contains(u.OrgId))
  52. .WhereIF(!_userManager.SuperAdmin, u => u.UserType != UserTypeEnum.SuperAdmin)
  53. .ToPagedListAsync(input.Page, input.PageSize);
  54. }
  55. /// <summary>
  56. /// 增加用户
  57. /// </summary>
  58. /// <param name="input"></param>
  59. /// <returns></returns>
  60. [HttpPost("/sysUser/add")]
  61. public async Task AddUser(AddUserInput input)
  62. {
  63. CheckDataScope(input.OrgId); // 数据范围检查
  64. var isExist = await _sysUserRep.IsAnyAsync(u => u.UserName == input.UserName);
  65. if (isExist) throw Oops.Oh(ErrorCodeEnum.D1003);
  66. var user = input.Adapt<SysUser>();
  67. user.Password = MD5Encryption.Encrypt(CommonConst.SysPassword);
  68. await _sysUserRep.InsertAsync(user);
  69. }
  70. /// <summary>
  71. /// 更新用户
  72. /// </summary>
  73. /// <param name="input"></param>
  74. /// <returns></returns>
  75. [HttpPost("/sysUser/update")]
  76. public async Task UpdateUser(UpdateUserInput input)
  77. {
  78. CheckDataScope(input.OrgId); // 数据范围检查
  79. var isExist = await _sysUserRep.IsAnyAsync(u => u.UserName == input.UserName && u.Id != input.Id);
  80. if (isExist) throw Oops.Oh(ErrorCodeEnum.D1003);
  81. var user = input.Adapt<SysUser>();
  82. await _sysUserRep.AsUpdateable(user).IgnoreColumns(true)
  83. .IgnoreColumns(u => new { u.UserType }).ExecuteCommandAsync();
  84. }
  85. /// <summary>
  86. /// 删除用户
  87. /// </summary>
  88. /// <param name="input"></param>
  89. /// <returns></returns>
  90. [HttpPost("/sysUser/delete")]
  91. public async Task DeleteUser(DeleteUserInput input)
  92. {
  93. CheckDataScope(input.OrgId); // 数据范围检查
  94. var user = await _sysUserRep.GetFirstAsync(u => u.Id == input.Id);
  95. if (user == null)
  96. throw Oops.Oh(ErrorCodeEnum.D1002);
  97. if (user.UserType == UserTypeEnum.SuperAdmin)
  98. throw Oops.Oh(ErrorCodeEnum.D1014);
  99. //if (user.UserType == UserTypeEnum.Admin)
  100. // throw Oops.Oh(ErrorCodeEnum.D1018);
  101. if (user.Id == _userManager.UserId)
  102. throw Oops.Oh(ErrorCodeEnum.D1001);
  103. await _sysUserRep.DeleteAsync(user);
  104. //// 删除用户及附属机构职位信息
  105. //await _sysEmpService.DeleteEmpInfoByUserId(input.Id);
  106. //删除用户-角色关联信息
  107. await _sysUserRoleService.DeleteUserRoleByUserId(input.Id);
  108. //删除用户-机构关联信息
  109. await _sysUserOrgService.DeleteUserOrgByUserId(input.Id);
  110. }
  111. /// <summary>
  112. /// 查看用户
  113. /// </summary>
  114. /// <returns></returns>
  115. [HttpGet("/sysUser/detail")]
  116. public async Task<SysUser> GetUser(long id)
  117. {
  118. return await _sysUserRep.GetFirstAsync(u => u.Id == id);
  119. }
  120. /// <summary>
  121. /// 设置用户状态
  122. /// </summary>
  123. /// <param name="input"></param>
  124. /// <returns></returns>
  125. [HttpPost("/sysUser/setStatus")]
  126. public async Task<int> SetUserStatus(UserInput input)
  127. {
  128. var user = await _sysUserRep.GetFirstAsync(u => u.Id == input.Id);
  129. if (user.UserType == UserTypeEnum.SuperAdmin)
  130. throw Oops.Oh(ErrorCodeEnum.D1015);
  131. if (!Enum.IsDefined(typeof(StatusEnum), input.Status))
  132. throw Oops.Oh(ErrorCodeEnum.D3005);
  133. user.Status = (StatusEnum)input.Status;
  134. return await _sysUserRep.AsUpdateable(user)
  135. .UpdateColumns(u => new { u.Status }).ExecuteCommandAsync();
  136. }
  137. /// <summary>
  138. /// 授权用户角色
  139. /// </summary>
  140. /// <param name="input"></param>
  141. /// <returns></returns>
  142. [HttpPost("/sysUser/grantRole")]
  143. public async Task GrantUserRole(UserRoleInput input)
  144. {
  145. var user = await _sysUserRep.GetFirstAsync(u => u.Id == input.Id);
  146. if (user.UserType == UserTypeEnum.SuperAdmin)
  147. throw Oops.Oh(ErrorCodeEnum.D1022);
  148. //if (user.UserType == UserTypeEnum.Admin)
  149. // throw Oops.Oh(ErrorCodeEnum.D1008);
  150. CheckDataScope(input.OrgId); // 数据范围检查
  151. await _sysUserRoleService.GrantUserRole(input);
  152. }
  153. /// <summary>
  154. /// 授权用户机构
  155. /// </summary>
  156. /// <param name="input"></param>
  157. /// <returns></returns>
  158. [HttpPost("/sysUser/grantOrg")]
  159. public async Task GrantUserOrg(UserOrgInput input)
  160. {
  161. await _sysCacheService.RemoveAsync(CacheConst.KeyOrgIdList + $"{input.Id}"); // 清除缓存
  162. CheckDataScope(input.OrgId); // 数据范围检查
  163. await _sysUserOrgService.GrantUserOrg(input);
  164. }
  165. /// <summary>
  166. /// 修改用户密码
  167. /// </summary>
  168. /// <param name="input"></param>
  169. /// <returns></returns>
  170. [HttpPost("/sysUser/updatePwd")]
  171. public async Task<int> UpdateUserPwd(UpdatePwdUserInput input)
  172. {
  173. var user = await _sysUserRep.GetFirstAsync(u => u.Id == input.Id);
  174. if (MD5Encryption.Encrypt(input.OldPassword) != user.Password)
  175. throw Oops.Oh(ErrorCodeEnum.D1004);
  176. user.Password = MD5Encryption.Encrypt(input.NewPassword);
  177. return await _sysUserRep.AsUpdateable(user).UpdateColumns(u => u.Password).ExecuteCommandAsync();
  178. }
  179. /// <summary>
  180. /// 重置用户密码
  181. /// </summary>
  182. /// <param name="input"></param>
  183. /// <returns></returns>
  184. [HttpPost("/sysUser/resetPwd")]
  185. public async Task<int> ResetUserPwd(ResetPwdUserInput input)
  186. {
  187. var user = await _sysUserRep.GetFirstAsync(u => u.Id == input.Id);
  188. user.Password = MD5Encryption.Encrypt(CommonConst.SysPassword);
  189. return await _sysUserRep.AsUpdateable(user).UpdateColumns(u => u.Password).ExecuteCommandAsync();
  190. }
  191. /// <summary>
  192. /// 获取用户拥有角色
  193. /// </summary>
  194. /// <param name="input"></param>
  195. /// <returns></returns>
  196. [HttpGet("/sysUser/ownRole")]
  197. public async Task<List<long>> GetUserOwnRole([FromQuery] UserInput input)
  198. {
  199. return await _sysUserRoleService.GetUserRoleIdList(input.Id);
  200. }
  201. /// <summary>
  202. /// 获取用户拥有机构
  203. /// </summary>
  204. /// <param name="input"></param>
  205. /// <returns></returns>
  206. [HttpGet("/sysUser/ownOrg")]
  207. public async Task<List<long>> GetUserOwnOrg([FromQuery] UserInput input)
  208. {
  209. return await _sysUserOrgService.GetUserOrgIdList(input.Id);
  210. }
  211. /// <summary>
  212. /// 获取当前用户机构列表权限
  213. /// </summary>
  214. /// <returns></returns>
  215. [NonAction]
  216. public async Task<List<long>> GetUserOrgIdList()
  217. {
  218. return await _sysOrgService.GetUserOrgIdList();
  219. }
  220. /// <summary>
  221. /// 检查用户数据范围
  222. /// 当有多个机构时,在登录时选择一个组织,所以组织Id/OrgId从前端传过来
  223. /// </summary>
  224. /// <param name="orgId"></param>
  225. /// <returns></returns>
  226. private async void CheckDataScope(long orgId)
  227. {
  228. if (!_userManager.SuperAdmin)
  229. {
  230. var dataScopes = await GetUserOrgIdList();
  231. if (!dataScopes.Any(u => u == orgId))
  232. throw Oops.Oh(ErrorCodeEnum.D1013);
  233. }
  234. }
  235. }
  236. }