SysPosService.cs 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105
  1. // Admin.NET 项目的版权、商标、专利和其他相关权利均受相应法律法规的保护。使用本项目应遵守相关法律法规和许可证的要求。
  2. //
  3. // 本项目主要遵循 MIT 许可证和 Apache 许可证(版本 2.0)进行分发和使用。许可证位于源代码树根目录中的 LICENSE-MIT 和 LICENSE-APACHE 文件。
  4. //
  5. // 不得利用本项目从事危害国家安全、扰乱社会秩序、侵犯他人合法权益等法律法规禁止的活动!任何基于本项目二次开发而产生的一切法律纠纷和责任,我们不承担任何责任!
  6. namespace Admin.NET.Core.Service;
  7. /// <summary>
  8. /// 系统职位服务 🧩
  9. /// </summary>
  10. [ApiDescriptionSettings(Order = 460)]
  11. public class SysPosService : IDynamicApiController, ITransient
  12. {
  13. private readonly UserManager _userManager;
  14. private readonly SqlSugarRepository<SysPos> _sysPosRep;
  15. private readonly SysUserExtOrgService _sysUserExtOrgService;
  16. public SysPosService(UserManager userManager,
  17. SqlSugarRepository<SysPos> sysPosRep,
  18. SysUserExtOrgService sysUserExtOrgService)
  19. {
  20. _userManager = userManager;
  21. _sysPosRep = sysPosRep;
  22. _sysUserExtOrgService = sysUserExtOrgService;
  23. }
  24. /// <summary>
  25. /// 获取职位列表 🔖
  26. /// </summary>
  27. /// <param name="input"></param>
  28. /// <returns></returns>
  29. [DisplayName("获取职位列表")]
  30. public async Task<List<SysPos>> GetList([FromQuery] PosInput input)
  31. {
  32. return await _sysPosRep.AsQueryable()
  33. .WhereIF(!string.IsNullOrWhiteSpace(input.Name), u => u.Name.Contains(input.Name))
  34. .WhereIF(!string.IsNullOrWhiteSpace(input.Code), u => u.Code.Contains(input.Code))
  35. .OrderBy(u => new { u.OrderNo, u.Id })
  36. .Mapper(u =>
  37. {
  38. u.UserList = _sysPosRep.Context.Queryable<SysUser>()
  39. .Where(a => a.PosId == u.Id || SqlFunc.Subqueryable<SysUserExtOrg>()
  40. .Where(t => a.Id == t.UserId && t.PosId == u.Id).Any())
  41. .ToList();
  42. })
  43. .ToListAsync();
  44. }
  45. /// <summary>
  46. /// 增加职位 🔖
  47. /// </summary>
  48. /// <param name="input"></param>
  49. /// <returns></returns>
  50. [ApiDescriptionSettings(Name = "Add"), HttpPost]
  51. [DisplayName("增加职位")]
  52. public async Task AddPos(AddPosInput input)
  53. {
  54. if (await _sysPosRep.IsAnyAsync(u => u.Name == input.Name && u.Code == input.Code)) throw Oops.Oh(ErrorCodeEnum.D6000);
  55. await _sysPosRep.InsertAsync(input.Adapt<SysPos>());
  56. }
  57. /// <summary>
  58. /// 更新职位 🔖
  59. /// </summary>
  60. /// <param name="input"></param>
  61. /// <returns></returns>
  62. [ApiDescriptionSettings(Name = "Update"), HttpPost]
  63. [DisplayName("更新职位")]
  64. public async Task UpdatePos(UpdatePosInput input)
  65. {
  66. if (await _sysPosRep.IsAnyAsync(u => u.Name == input.Name && u.Code == input.Code && u.Id != input.Id))
  67. throw Oops.Oh(ErrorCodeEnum.D6000);
  68. var sysPos = await _sysPosRep.GetByIdAsync(input.Id) ?? throw Oops.Oh(ErrorCodeEnum.D6003);
  69. if (!_userManager.SuperAdmin && sysPos.CreateUserId != _userManager.UserId) throw Oops.Oh(ErrorCodeEnum.D6002);
  70. await _sysPosRep.AsUpdateable(input.Adapt<SysPos>()).IgnoreColumns(true).ExecuteCommandAsync();
  71. }
  72. /// <summary>
  73. /// 删除职位 🔖
  74. /// </summary>
  75. /// <param name="input"></param>
  76. /// <returns></returns>
  77. [ApiDescriptionSettings(Name = "Delete"), HttpPost]
  78. [DisplayName("删除职位")]
  79. public async Task DeletePos(DeletePosInput input)
  80. {
  81. var sysPos = await _sysPosRep.GetFirstAsync(u => u.Id == input.Id) ?? throw Oops.Oh(ErrorCodeEnum.D6003);
  82. if (!_userManager.SuperAdmin && sysPos.CreateUserId != _userManager.UserId) throw Oops.Oh(ErrorCodeEnum.D6002);
  83. // 若职位有用户则禁止删除
  84. var hasPosEmp = await _sysPosRep.ChangeRepository<SqlSugarRepository<SysUser>>()
  85. .IsAnyAsync(u => u.PosId == input.Id);
  86. if (hasPosEmp) throw Oops.Oh(ErrorCodeEnum.D6001);
  87. // 若附属职位有用户则禁止删除
  88. var hasExtPosEmp = await _sysUserExtOrgService.HasUserPos(input.Id);
  89. if (hasExtPosEmp) throw Oops.Oh(ErrorCodeEnum.D6001);
  90. await _sysPosRep.DeleteAsync(u => u.Id == input.Id);
  91. }
  92. }