SysDataResourceService.cs 7.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190
  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/tree")]
  18. public async Task<List<SysDataResource>> GetDataResourceTree([FromQuery] DataResourcesTreeInput input)
  19. {
  20. //通过根节点值来获取当前节点下的树结构数据
  21. var rootValue = !string.IsNullOrEmpty(input.RootValue?.Trim());
  22. SysDataResource rootDataTree = null;
  23. if (rootValue)
  24. {
  25. rootDataTree = await _sysDataResourceRep.AsQueryable().Where(u => u.Value == input.RootValue && u.Pid == 0)
  26. .Where(u => u.Status == StatusEnum.Enable).FirstAsync();
  27. var childName = !string.IsNullOrEmpty(input.ChildName?.Trim());
  28. //获取根节点下对应的子节点名称id
  29. if (childName && rootDataTree != null)
  30. {
  31. rootDataTree = await _sysDataResourceRep.AsQueryable()
  32. .Where(u => u.Code.Contains(rootDataTree.Code))
  33. .Where(u => u.Name == input.ChildName)
  34. .Where(u => u.Status == StatusEnum.Enable).FirstAsync();
  35. }
  36. }
  37. if (rootDataTree == null)
  38. {
  39. return null;
  40. }
  41. var idList = rootDataTree.Id > 0 ? await GetChildIdListWithSelfById(rootDataTree.Id) : new List<long>();
  42. var iSugarQueryable = _sysDataResourceRep.AsQueryable().OrderBy(u => u.Order)
  43. .WhereIF(idList.Count > 0, u => idList.Contains(u.Id))
  44. .Where(u => u.Status == StatusEnum.Enable); // 非超级管理员限制
  45. var tree = await iSugarQueryable.ToTreeAsync(u => u.Children, u => u.Pid, rootDataTree.Id > 0 ? rootDataTree.Id : 0);
  46. //如果包含自己,则添加自己信息
  47. if (input.IsContainSelf)
  48. {
  49. rootDataTree.Children = new List<SysDataResource>();
  50. rootDataTree.Children.AddRange(tree);
  51. var list = new List<SysDataResource>();
  52. list.Add(rootDataTree);
  53. return list;
  54. }
  55. return tree;
  56. }
  57. /// <summary>
  58. /// 获取数据资源列表
  59. /// </summary>
  60. /// <returns></returns>
  61. [HttpGet("/sysDataResource/list")]
  62. public async Task<List<SysDataResource>> GetDataResourceList([FromQuery] DataResourceInput input)
  63. {
  64. var idList = input.Id > 0 ? await GetChildIdListWithSelfById(input.Id) : new List<long>();
  65. var iSugarQueryable = _sysDataResourceRep.AsQueryable().OrderBy(u => u.Order)
  66. .WhereIF(idList.Count > 0, u => idList.Contains(u.Id)); // 非超级管理员限制
  67. if (!string.IsNullOrWhiteSpace(input.Name) || !string.IsNullOrWhiteSpace(input.Code) || !string.IsNullOrWhiteSpace(input.Value) || input.Id > 0)
  68. {
  69. return await iSugarQueryable
  70. .WhereIF(!string.IsNullOrWhiteSpace(input.Name), u => u.Name.Contains(input.Name))
  71. .WhereIF(!string.IsNullOrWhiteSpace(input.Value), u => u.Value.Contains(input.Value))
  72. .WhereIF(!string.IsNullOrWhiteSpace(input.Code), u => u.Code.Contains(input.Code))
  73. .ToListAsync();
  74. }
  75. return await iSugarQueryable.ToTreeAsync(u => u.Children, u => u.Pid, input.Id > 0 ? input.Id : 0);
  76. }
  77. /// <summary>
  78. /// 增加数据资源
  79. /// </summary>
  80. /// <param name="input"></param>
  81. /// <returns></returns>
  82. [HttpPost("/sysDataResource/add")]
  83. public async Task<long> AddDataResource(AddDataResourceInput input)
  84. {
  85. var isExist = await _sysDataResourceRep.IsAnyAsync(u => u.Code == input.Code && u.Name == input.Name);
  86. if (isExist)
  87. throw Oops.Oh(ErrorCodeEnum.D1602);
  88. var newCode = "";
  89. // 生成编码Code和排序(每级2位编码)
  90. var sysDataResource = await _sysDataResourceRep.AsQueryable().OrderByDescending(o => o.Code)
  91. .FirstAsync(u => u.Pid == input.Pid);
  92. if (sysDataResource != null)
  93. {
  94. newCode = sysDataResource.Code[0..^3] + string.Format("{0:d3}", int.Parse(sysDataResource.Code[^3..]) + 1);
  95. }
  96. else
  97. {
  98. //如果没有根节点,默认为1001
  99. if (input.Pid == 0)
  100. {
  101. newCode = "1001";
  102. }
  103. else
  104. {
  105. sysDataResource = await _sysDataResourceRep.GetFirstAsync(u => u.Id == input.Pid);
  106. newCode = sysDataResource.Code + "01";
  107. }
  108. }
  109. var newDataResource = input.Adapt<SysDataResource>();
  110. newDataResource.Code = newCode;
  111. newDataResource.Order = int.Parse(newCode[^3..]);
  112. newDataResource = await _sysDataResourceRep.AsInsertable(newDataResource).ExecuteReturnEntityAsync();
  113. return newDataResource.Id;
  114. }
  115. /// <summary>
  116. /// 更新数据资源
  117. /// </summary>
  118. /// <param name="input"></param>
  119. /// <returns></returns>
  120. [HttpPost("/sysDataResource/update")]
  121. [UnitOfWork]
  122. public async Task UpdateDataResource(UpdateDataResourceInput input)
  123. {
  124. if (input.Pid != 0)
  125. {
  126. var pDataResource = await _sysDataResourceRep.GetFirstAsync(u => u.Id == input.Pid);
  127. _ = pDataResource ?? throw Oops.Oh(ErrorCodeEnum.D1600);
  128. }
  129. if (input.Id == input.Pid)
  130. throw Oops.Oh(ErrorCodeEnum.D1601);
  131. var sysDataResource = await _sysDataResourceRep.GetFirstAsync(u => u.Id == input.Id);
  132. var isExist = await _sysDataResourceRep.IsAnyAsync(u => (u.Name == input.Name && u.Code == input.Code) && u.Id != sysDataResource.Id);
  133. if (isExist)
  134. throw Oops.Oh(ErrorCodeEnum.D1602);
  135. // 父Id不能为自己的子节点
  136. var childIdList = await GetChildIdListWithSelfById(input.Id);
  137. if (childIdList.Contains(input.Pid))
  138. throw Oops.Oh(ErrorCodeEnum.D1601);
  139. var dataResource = input.Adapt<SysDataResource>();
  140. await _sysDataResourceRep.AsUpdateable(dataResource).IgnoreColumns(true).ExecuteCommandAsync();
  141. }
  142. /// <summary>
  143. /// 删除数据资源
  144. /// </summary>
  145. /// <param name="input"></param>
  146. /// <returns></returns>
  147. [HttpPost("/sysDataResource/delete")]
  148. public async Task DeleteDataResource(DeleteDataResourceInput input)
  149. {
  150. var sysDataResource = await _sysDataResourceRep.GetFirstAsync(u => u.Id == input.Id);
  151. // 获取本节点对应所有子节点id列表
  152. var treeList = await _sysDataResourceRep.AsQueryable().ToChildListAsync(u => u.Pid, input.Id);
  153. var idList = treeList.Select(u => u.Id).ToList();
  154. // 级联删除数据资源子节点
  155. await _sysDataResourceRep.DeleteAsync(u => idList.Contains(u.Id));
  156. }
  157. /// <summary>
  158. /// 根据节点Id获取子节点Id集合(包含自己)
  159. /// </summary>
  160. /// <param name="pid"></param>
  161. /// <returns></returns>
  162. private async Task<List<long>> GetChildIdListWithSelfById(long pid)
  163. {
  164. var treeList = await _sysDataResourceRep.AsQueryable().ToChildListAsync(u => u.Pid, pid);
  165. return treeList.Select(u => u.Id).ToList();
  166. }
  167. }