UserService.cs 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429
  1. using System.Collections.Generic;
  2. using System.Linq;
  3. using System.Threading.Tasks;
  4. using Microsoft.AspNetCore.Mvc;
  5. using Microsoft.AspNetCore.Http;
  6. using Microsoft.Extensions.Options;
  7. using ZhonTai.Admin.Core.Attributes;
  8. using ZhonTai.Admin.Core.Configs;
  9. using ZhonTai.Admin.Core.Repositories;
  10. using ZhonTai.Common.Helpers;
  11. using ZhonTai.Admin.Core.Dto;
  12. using ZhonTai.Admin.Domain.Api;
  13. using ZhonTai.Admin.Domain.PermissionApi;
  14. using ZhonTai.Admin.Domain.Role;
  15. using ZhonTai.Admin.Domain.RolePermission;
  16. using ZhonTai.Admin.Domain.Tenant;
  17. using ZhonTai.Admin.Domain.User;
  18. using ZhonTai.Admin.Domain.UserRole;
  19. using ZhonTai.Admin.Services.Auth.Dto;
  20. using ZhonTai.Admin.Services.User.Dto;
  21. using ZhonTai.DynamicApi;
  22. using ZhonTai.DynamicApi.Attributes;
  23. using ZhonTai.Admin.Core.Helpers;
  24. using ZhonTai.Admin.Core.Consts;
  25. using ZhonTai.Admin.Domain.Employee;
  26. using ZhonTai.Admin.Domain;
  27. using ZhonTai.Admin.Domain.Organization;
  28. namespace ZhonTai.Admin.Services.User;
  29. /// <summary>
  30. /// 用户服务
  31. /// </summary>
  32. [DynamicApi(Area = AdminConsts.AreaName)]
  33. public class UserService : BaseService, IUserService, IDynamicApi
  34. {
  35. private AppConfig _appConfig => LazyGetRequiredService<AppConfig>();
  36. private IUserRepository _userRepository => LazyGetRequiredService<IUserRepository>();
  37. private IRepositoryBase<UserRoleEntity> _userRoleRepository => LazyGetRequiredService<IRepositoryBase<UserRoleEntity>>();
  38. private ITenantRepository _tenantRepository => LazyGetRequiredService<ITenantRepository>();
  39. private IApiRepository _apiRepository => LazyGetRequiredService<IApiRepository>();
  40. private IRoleRepository _roleRepository => LazyGetRequiredService<IRoleRepository>();
  41. private IEmployeeRepository _employeeRepository => LazyGetRequiredService<IEmployeeRepository>();
  42. private IRepositoryBase<EmployeeOrganizationEntity> _employeeOrganizationRepository => LazyGetRequiredService<IRepositoryBase<EmployeeOrganizationEntity>>();
  43. public UserService()
  44. {
  45. }
  46. /// <summary>
  47. /// 查询用户
  48. /// </summary>
  49. /// <param name="id"></param>
  50. /// <returns></returns>
  51. public async Task<IResultOutput> GetAsync(long id)
  52. {
  53. var output = await _userRepository.Select
  54. .WhereDynamic(id)
  55. .IncludeMany(a => a.Roles.Select(b => new RoleEntity { Id = b.Id, Name = b.Name }))
  56. .IncludeMany(a => a.Emp.Orgs.Select(b => new OrganizationEntity { Id = b.Id, Name = b.Name }))
  57. .ToOneAsync(a=>new
  58. {
  59. a.Id,
  60. a.Version,
  61. a.UserName,
  62. a.Name,
  63. a.Mobile,
  64. a.Email,
  65. a.Roles,
  66. Emp = new
  67. {
  68. a.Emp.Version,
  69. a.Emp.MainOrgId,
  70. a.Emp.Orgs
  71. }
  72. });
  73. return ResultOutput.Ok(output);
  74. }
  75. /// <summary>
  76. /// 查询分页
  77. /// </summary>
  78. /// <param name="input"></param>
  79. /// <returns></returns>
  80. [HttpPost]
  81. public async Task<IResultOutput> GetPageAsync(PageInput<long?> input)
  82. {
  83. var list = await _userRepository.Select
  84. .WhereIf(input.Filter.HasValue && input.Filter > 0, a=>a.Emp.MainOrgId == input.Filter)
  85. .WhereDynamicFilter(input.DynamicFilter)
  86. .Count(out var total)
  87. .OrderByDescending(true, a => a.Id)
  88. .IncludeMany(a => a.Roles.Select(b => new RoleEntity { Name = b.Name }))
  89. .Page(input.CurrentPage, input.PageSize)
  90. .ToListAsync();
  91. var data = new PageOutput<UserGetPageOutput>()
  92. {
  93. List = Mapper.Map<List<UserGetPageOutput>>(list),
  94. Total = total
  95. };
  96. return ResultOutput.Ok(data);
  97. }
  98. /// <summary>
  99. /// 查询登录用户信息
  100. /// </summary>
  101. /// <param name="id"></param>
  102. /// <returns></returns>
  103. public async Task<ResultOutput<AuthLoginOutput>> GetLoginUserAsync(long id)
  104. {
  105. var output = new ResultOutput<AuthLoginOutput>();
  106. var entityDto = await _userRepository.Select.DisableGlobalFilter("Tenant").WhereDynamic(id).ToOneAsync<AuthLoginOutput>();
  107. if (_appConfig.Tenant && entityDto?.TenantId.Value > 0)
  108. {
  109. var tenant = await _tenantRepository.Select.DisableGlobalFilter("Tenant").WhereDynamic(entityDto.TenantId).ToOneAsync(a => new { a.TenantType, a.DataIsolationType });
  110. if (null != tenant)
  111. {
  112. entityDto.TenantType = tenant.TenantType;
  113. entityDto.DataIsolationType = tenant.DataIsolationType;
  114. }
  115. }
  116. return output.Ok(entityDto);
  117. }
  118. /// <summary>
  119. /// 查询用户基本信息
  120. /// </summary>
  121. /// <returns></returns>
  122. public async Task<IResultOutput> GetBasicAsync()
  123. {
  124. if (!(User?.Id > 0))
  125. {
  126. return ResultOutput.NotOk("未登录!");
  127. }
  128. var data = await _userRepository.GetAsync<UserUpdateBasicInput>(User.Id);
  129. return ResultOutput.Ok(data);
  130. }
  131. /// <summary>
  132. /// 查询用户权限信息
  133. /// </summary>
  134. /// <returns></returns>
  135. public async Task<IList<UserPermissionsOutput>> GetPermissionsAsync()
  136. {
  137. var key = string.Format(CacheKeys.UserPermissions, User.Id);
  138. var result = await Cache.GetOrSetAsync(key, async () =>
  139. {
  140. return await _apiRepository
  141. .Where(a => _userRoleRepository.Orm.Select<UserRoleEntity, RolePermissionEntity, PermissionApiEntity>()
  142. .InnerJoin((b, c, d) => b.RoleId == c.RoleId && b.UserId == User.Id)
  143. .InnerJoin((b, c, d) => c.PermissionId == d.PermissionId)
  144. .Where((b, c, d) => d.ApiId == a.Id).Any())
  145. .ToListAsync<UserPermissionsOutput>();
  146. });
  147. return result;
  148. }
  149. /// <summary>
  150. /// 新增用户
  151. /// </summary>
  152. /// <param name="input"></param>
  153. /// <returns></returns>
  154. [Transaction]
  155. public async Task<IResultOutput> AddAsync(UserAddInput input)
  156. {
  157. if (await _userRepository.Select.AnyAsync(a => a.UserName == input.UserName))
  158. {
  159. return ResultOutput.NotOk($"账号已存在");
  160. }
  161. if (input.Mobile.NotNull() && await _userRepository.Select.AnyAsync(a => a.Mobile == input.Mobile))
  162. {
  163. return ResultOutput.NotOk($"手机号已存在");
  164. }
  165. if (input.Email.NotNull() && await _userRepository.Select.AnyAsync(a => a.Email == input.Email))
  166. {
  167. return ResultOutput.NotOk($"邮箱已存在");
  168. }
  169. // 用户信息
  170. if (input.Password.IsNull())
  171. {
  172. input.Password = _appConfig.DefaultPassword;
  173. }
  174. input.Password = MD5Encrypt.Encrypt32(input.Password);
  175. var entity = Mapper.Map<UserEntity>(input);
  176. var user = await _userRepository.InsertAsync(entity);
  177. if (!(user?.Id > 0))
  178. {
  179. return ResultOutput.NotOk("新增用户失败");
  180. }
  181. //用户角色
  182. if (input.RoleIds != null && input.RoleIds.Any())
  183. {
  184. var roles = input.RoleIds.Select(a => new UserRoleEntity { UserId = user.Id, RoleId = a });
  185. await _userRoleRepository.InsertAsync(roles);
  186. }
  187. // 员工信息
  188. var emp = Mapper.Map<EmployeeEntity>(input.Emp);
  189. emp.Id = user.Id;
  190. await _employeeRepository.InsertAsync(emp);
  191. //所属部门
  192. if (input.Emp.OrgIds != null && input.Emp.OrgIds.Any())
  193. {
  194. var organizations = input.Emp.OrgIds.Select(organizationId => new EmployeeOrganizationEntity
  195. {
  196. EmployeeId = emp.Id,
  197. OrganizationId = organizationId
  198. });
  199. await _employeeOrganizationRepository.InsertAsync(organizations);
  200. }
  201. return ResultOutput.Ok();
  202. }
  203. /// <summary>
  204. /// 修改用户
  205. /// </summary>
  206. /// <param name="input"></param>
  207. /// <returns></returns>
  208. [Transaction]
  209. public async Task<IResultOutput> UpdateAsync(UserUpdateInput input)
  210. {
  211. var user = await _userRepository.GetAsync(input.Id);
  212. if (!(user?.Id > 0))
  213. {
  214. return ResultOutput.NotOk("用户不存在");
  215. }
  216. if (await _userRepository.Select.AnyAsync(a => a.Id != input.Id && a.UserName == input.UserName))
  217. {
  218. return ResultOutput.NotOk($"账号已存在");
  219. }
  220. if (input.Mobile.NotNull() && await _userRepository.Select.AnyAsync(a => a.Id != input.Id && a.Mobile == input.Mobile))
  221. {
  222. return ResultOutput.NotOk($"手机号已存在");
  223. }
  224. if (input.Email.NotNull() && await _userRepository.Select.AnyAsync(a => a.Id != input.Id && a.Email == input.Email))
  225. {
  226. return ResultOutput.NotOk($"邮箱已存在");
  227. }
  228. Mapper.Map(input, user);
  229. await _userRepository.UpdateAsync(user);
  230. // 用户角色
  231. await _userRoleRepository.DeleteAsync(a => a.UserId == user.Id);
  232. if (input.RoleIds != null && input.RoleIds.Any())
  233. {
  234. var roles = input.RoleIds.Select(a => new UserRoleEntity { UserId = user.Id, RoleId = a });
  235. await _userRoleRepository.InsertAsync(roles);
  236. }
  237. // 员工信息
  238. var emp = await _employeeRepository.GetAsync(user.Id);
  239. if(emp == null)
  240. {
  241. emp = new EmployeeEntity();
  242. }
  243. Mapper.Map(input.Emp, emp);
  244. emp.Id = user.Id;
  245. await _employeeRepository.InsertOrUpdateAsync(emp);
  246. //所属部门
  247. await _employeeOrganizationRepository.DeleteAsync(a => a.EmployeeId == emp.Id);
  248. if (input.Emp.OrgIds != null && input.Emp.OrgIds.Any())
  249. {
  250. var organizations = input.Emp.OrgIds.Select(organizationId => new EmployeeOrganizationEntity
  251. {
  252. EmployeeId = emp.Id,
  253. OrganizationId = organizationId
  254. });
  255. await _employeeOrganizationRepository.InsertAsync(organizations);
  256. }
  257. return ResultOutput.Ok();
  258. }
  259. /// <summary>
  260. /// 更新用户基本信息
  261. /// </summary>
  262. /// <param name="input"></param>
  263. /// <returns></returns>
  264. public async Task<IResultOutput> UpdateBasicAsync(UserUpdateBasicInput input)
  265. {
  266. var entity = await _userRepository.GetAsync(input.Id);
  267. entity = Mapper.Map(input, entity);
  268. var result = (await _userRepository.UpdateAsync(entity)) > 0;
  269. //清除用户缓存
  270. await Cache.DelAsync(string.Format(CacheKeys.UserInfo, input.Id));
  271. return ResultOutput.Result(result);
  272. }
  273. /// <summary>
  274. /// 修改用户密码
  275. /// </summary>
  276. /// <param name="input"></param>
  277. /// <returns></returns>
  278. public async Task<IResultOutput> ChangePasswordAsync(UserChangePasswordInput input)
  279. {
  280. if (input.ConfirmPassword != input.NewPassword)
  281. {
  282. return ResultOutput.NotOk("新密码和确认密码不一致!");
  283. }
  284. var entity = await _userRepository.GetAsync(input.Id);
  285. var oldPassword = MD5Encrypt.Encrypt32(input.OldPassword);
  286. if (oldPassword != entity.Password)
  287. {
  288. return ResultOutput.NotOk("旧密码不正确!");
  289. }
  290. input.Password = MD5Encrypt.Encrypt32(input.NewPassword);
  291. entity = Mapper.Map(input, entity);
  292. var result = (await _userRepository.UpdateAsync(entity)) > 0;
  293. return ResultOutput.Result(result);
  294. }
  295. /// <summary>
  296. /// 彻底删除用户
  297. /// </summary>
  298. /// <param name="id"></param>
  299. /// <returns></returns>
  300. [Transaction]
  301. public async Task<IResultOutput> DeleteAsync(long id)
  302. {
  303. //删除员工所属部门
  304. await _employeeOrganizationRepository.DeleteAsync(a => a.EmployeeId == id);
  305. //删除员工
  306. await _employeeRepository.DeleteAsync(a => a.Id == id);
  307. //删除用户角色
  308. await _userRoleRepository.DeleteAsync(a => a.UserId == id);
  309. //删除用户
  310. await _userRepository.DeleteAsync(a => a.Id == id);
  311. return ResultOutput.Ok();
  312. }
  313. /// <summary>
  314. /// 批量彻底删除用户
  315. /// </summary>
  316. /// <param name="ids"></param>
  317. /// <returns></returns>
  318. [Transaction]
  319. public async Task<IResultOutput> BatchDeleteAsync(long[] ids)
  320. {
  321. //删除员工所属部门
  322. await _employeeOrganizationRepository.DeleteAsync(a => ids.Contains(a.EmployeeId));
  323. //删除员工
  324. await _employeeRepository.DeleteAsync(a => ids.Contains(a.Id));
  325. //删除用户角色
  326. await _userRoleRepository.DeleteAsync(a => ids.Contains(a.UserId));
  327. //删除用户
  328. await _userRepository.DeleteAsync(a => ids.Contains(a.Id));
  329. return ResultOutput.Ok();
  330. }
  331. /// <summary>
  332. /// 删除用户
  333. /// </summary>
  334. /// <param name="id"></param>
  335. /// <returns></returns>
  336. [Transaction]
  337. public async Task<IResultOutput> SoftDeleteAsync(long id)
  338. {
  339. await _employeeOrganizationRepository.DeleteAsync(a => a.EmployeeId == id);
  340. await _employeeRepository.SoftDeleteAsync(a => a.Id == id);
  341. await _userRoleRepository.DeleteAsync(a => a.UserId == id);
  342. await _userRepository.SoftDeleteAsync(id);
  343. return ResultOutput.Ok();
  344. }
  345. /// <summary>
  346. /// 批量删除用户
  347. /// </summary>
  348. /// <param name="ids"></param>
  349. /// <returns></returns>
  350. [Transaction]
  351. public async Task<IResultOutput> BatchSoftDeleteAsync(long[] ids)
  352. {
  353. await _employeeOrganizationRepository.DeleteAsync(a => ids.Contains(a.EmployeeId));
  354. await _employeeRepository.SoftDeleteAsync(a => ids.Contains(a.Id));
  355. await _userRoleRepository.DeleteAsync(a => ids.Contains(a.UserId));
  356. await _userRepository.SoftDeleteAsync(ids);
  357. return ResultOutput.Ok();
  358. }
  359. /// <summary>
  360. /// 上传头像
  361. /// </summary>
  362. /// <param name="file"></param>
  363. /// <returns></returns>
  364. [HttpPost]
  365. [Login]
  366. public async Task<IResultOutput> AvatarUpload([FromForm] IFormFile file)
  367. {
  368. var uploadConfig = LazyGetRequiredService<IOptionsMonitor<UploadConfig>>().CurrentValue;
  369. var uploadHelper = LazyGetRequiredService<UploadHelper>();
  370. var config = uploadConfig.Avatar;
  371. var res = await uploadHelper.UploadAsync(file, config, new { User.Id });
  372. if (res.Success)
  373. {
  374. return ResultOutput.Ok(res.Data.FileRelativePath);
  375. }
  376. return ResultOutput.NotOk(res.Msg ?? "上传失败!");
  377. }
  378. }