SysDataResourceService.cs 6.4 KB

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