SysDataResourceService.cs 5.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140
  1. namespace Admin.NET.Core.Service;
  2. /// <summary>
  3. /// 系统数据资源服务
  4. /// </summary>
  5. [ApiDescriptionSettings(Name = "系统数据资源", Order = 189)]
  6. public class SysDataResourceService : IDynamicApiController, ITransient
  7. {
  8. private readonly SqlSugarRepository<SysDataResource> _sysDataResourceRep;
  9. public SysDataResourceService(SqlSugarRepository<SysDataResource> sysDataResourceRep)
  10. {
  11. _sysDataResourceRep = sysDataResourceRep;
  12. }
  13. /// <summary>
  14. /// 获取数据资源列表
  15. /// </summary>
  16. /// <returns></returns>
  17. [HttpGet("/sysDataResource/list")]
  18. public async Task<List<SysDataResource>> GetDataResourceList([FromQuery] DataResourceInput input)
  19. {
  20. var idList = input.Id > 0 ? await GetChildIdListWithSelfById(input.Id) : new List<long>();
  21. var iSugarQueryable = _sysDataResourceRep.AsQueryable().OrderBy(u => u.Order)
  22. .WhereIF(idList.Count > 0, u => idList.Contains(u.Id)); // 非超级管理员限制
  23. if (!string.IsNullOrWhiteSpace(input.Name) || !string.IsNullOrWhiteSpace(input.Code) || !string.IsNullOrWhiteSpace(input.Value) || input.Id > 0)
  24. {
  25. return await iSugarQueryable
  26. .WhereIF(!string.IsNullOrWhiteSpace(input.Name), u => u.Name.Contains(input.Name))
  27. .WhereIF(!string.IsNullOrWhiteSpace(input.Value), u => u.Value.Contains(input.Value))
  28. .WhereIF(!string.IsNullOrWhiteSpace(input.Code), u => u.Code.Contains(input.Code))
  29. .ToListAsync();
  30. }
  31. return await iSugarQueryable.ToTreeAsync(u => u.Children, u => u.Pid, input.Id > 0 ? input.Id : 0);
  32. }
  33. /// <summary>
  34. /// 增加数据资源
  35. /// </summary>
  36. /// <param name="input"></param>
  37. /// <returns></returns>
  38. [HttpPost("/sysDataResource/add")]
  39. public async Task<long> AddDataResource(AddDataResourceInput input)
  40. {
  41. var isExist = await _sysDataResourceRep.IsAnyAsync(u => u.Code == input.Code && u.Name == input.Name);
  42. if (isExist)
  43. throw Oops.Oh(ErrorCodeEnum.D1602);
  44. var newCode = "";
  45. // 生成编码Code和排序(每级2位编码)
  46. var sysDataResource = await _sysDataResourceRep.AsQueryable().OrderByDescending(o => o.Code)
  47. .FirstAsync(u => u.Pid == input.Pid);
  48. if (sysDataResource != null)
  49. {
  50. newCode = sysDataResource.Code[0..^3] + string.Format("{0:d3}", int.Parse(sysDataResource.Code[^3..]) + 1);
  51. }
  52. else
  53. {
  54. //如果没有根节点,默认为1001
  55. if (input.Pid == 0)
  56. {
  57. newCode = "1001";
  58. }
  59. else
  60. {
  61. sysDataResource = await _sysDataResourceRep.GetFirstAsync(u => u.Id == input.Pid);
  62. newCode = sysDataResource.Code + "01";
  63. }
  64. }
  65. var newDataResource = input.Adapt<SysDataResource>();
  66. newDataResource.Code = newCode;
  67. newDataResource.Order = int.Parse(newCode[^3..]);
  68. newDataResource = await _sysDataResourceRep.AsInsertable(newDataResource).ExecuteReturnEntityAsync();
  69. return newDataResource.Id;
  70. }
  71. /// <summary>
  72. /// 更新数据资源
  73. /// </summary>
  74. /// <param name="input"></param>
  75. /// <returns></returns>
  76. [HttpPost("/sysDataResource/update")]
  77. [UnitOfWork]
  78. public async Task UpdateDataResource(UpdateDataResourceInput input)
  79. {
  80. if (input.Pid != 0)
  81. {
  82. var pDataResource = await _sysDataResourceRep.GetFirstAsync(u => u.Id == input.Pid);
  83. _ = pDataResource ?? throw Oops.Oh(ErrorCodeEnum.D1600);
  84. }
  85. if (input.Id == input.Pid)
  86. throw Oops.Oh(ErrorCodeEnum.D1601);
  87. var sysDataResource = await _sysDataResourceRep.GetFirstAsync(u => u.Id == input.Id);
  88. var isExist = await _sysDataResourceRep.IsAnyAsync(u => (u.Name == input.Name && u.Code == input.Code) && u.Id != sysDataResource.Id);
  89. if (isExist)
  90. throw Oops.Oh(ErrorCodeEnum.D1602);
  91. // 父Id不能为自己的子节点
  92. var childIdList = await GetChildIdListWithSelfById(input.Id);
  93. if (childIdList.Contains(input.Pid))
  94. throw Oops.Oh(ErrorCodeEnum.D1601);
  95. var dataResource = input.Adapt<SysDataResource>();
  96. await _sysDataResourceRep.AsUpdateable(dataResource).IgnoreColumns(true).ExecuteCommandAsync();
  97. }
  98. /// <summary>
  99. /// 删除数据资源
  100. /// </summary>
  101. /// <param name="input"></param>
  102. /// <returns></returns>
  103. [HttpPost("/sysDataResource/delete")]
  104. public async Task DeleteDataResource(DeleteDataResourceInput input)
  105. {
  106. var sysDataResource = await _sysDataResourceRep.GetFirstAsync(u => u.Id == input.Id);
  107. // 获取本节点对应所有子节点id列表
  108. var treeList = await _sysDataResourceRep.AsQueryable().ToChildListAsync(u => u.Pid, input.Id);
  109. var idList = treeList.Select(u => u.Id).ToList();
  110. // 级联删除数据资源子节点
  111. await _sysDataResourceRep.DeleteAsync(u => idList.Contains(u.Id));
  112. }
  113. /// <summary>
  114. /// 根据节点Id获取子节点Id集合(包含自己)
  115. /// </summary>
  116. /// <param name="pid"></param>
  117. /// <returns></returns>
  118. private async Task<List<long>> GetChildIdListWithSelfById(long pid)
  119. {
  120. var treeList = await _sysDataResourceRep.AsQueryable().ToChildListAsync(u => u.Pid, pid);
  121. return treeList.Select(u => u.Id).ToList();
  122. }
  123. }