AreaRelevantController.cs 7.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172
  1. using Azure.Cosmos;
  2. using Microsoft.AspNetCore.Http;
  3. using Microsoft.AspNetCore.Mvc;
  4. using Microsoft.Extensions.Options;
  5. using System;
  6. using System.Collections.Generic;
  7. using System.Linq;
  8. using System.Text.Json;
  9. using System.Threading.Tasks;
  10. using TEAMModelBI.Filter;
  11. using TEAMModelBI.Tool.Extension;
  12. using TEAMModelOS.Models;
  13. using TEAMModelOS.SDK.DI;
  14. using TEAMModelOS.SDK.Extension;
  15. using TEAMModelOS.SDK.Models;
  16. using TEAMModelOS.SDK.Models.Cosmos.BI;
  17. namespace TEAMModelBI.Controllers.BISchool
  18. {
  19. [Route("area")]
  20. [ApiController]
  21. public class AreaRelevantController : ControllerBase
  22. {
  23. //数据容器
  24. private readonly AzureCosmosFactory _azureCosmos;
  25. private readonly AzureStorageFactory _azureStorage;
  26. //钉钉提示信息
  27. private readonly DingDing _dingDing;
  28. private readonly Option _option;
  29. public AreaRelevantController(AzureCosmosFactory azureCosmos, AzureStorageFactory azureStorage, DingDing dingDing, IOptionsSnapshot<Option> option)
  30. {
  31. _azureCosmos = azureCosmos;
  32. _azureStorage = azureStorage;
  33. _dingDing = dingDing;
  34. _option = option?.Value;
  35. }
  36. /// <summary>
  37. /// 查询区域已经有的学校
  38. /// </summary>
  39. /// <param name="jsonElement"></param>
  40. /// <returns></returns>
  41. [ProducesDefaultResponseType]
  42. [HttpPost("get-areaschools")]
  43. public async Task<IActionResult> GetAreaSchools(JsonElement jsonElement)
  44. {
  45. try
  46. {
  47. jsonElement.TryGetProperty("areaId", out JsonElement _areaId);
  48. var cosmosClient = _azureCosmos.GetCosmosClient();
  49. List<JoinAreaSchool> joinAreaSchools = new List<JoinAreaSchool>();
  50. string sqltxt = $"SELECT c.id,c.name,c.schoolCode,c.province,c.city,c.dist,c.picture,c.period FROM c WHERE c.areaId='{_areaId}'";
  51. if (!string.IsNullOrEmpty($"{_areaId}"))
  52. {
  53. sqltxt = $"SELECT c.id,c.name,c.schoolCode,c.province,c.city,c.dist,c.picture,c.period,c.manyAreas FROM c WHERE c.areaId ='{_areaId}' and ARRAY_CONTAINS(c.manyAreas,'{_areaId}',true) or ARRAY_LENGTH(c.manyAreas) = 0 ";
  54. //sqltxt = $"SELECT c.id,c.name,c.schoolCode,c.province,c.city,c.dist,c.picture,c.period FROM c join m in c.manyAreas where m.areaId='{_areaId}' or c.areaId='{_areaId}'";
  55. }
  56. await foreach (var item in cosmosClient.GetContainer(Constant.TEAMModelOS, "School").GetItemQueryStreamIterator(queryText: sqltxt, requestOptions:new QueryRequestOptions() { PartitionKey = new PartitionKey("Base")}))
  57. {
  58. using var json = await JsonDocument.ParseAsync(item.ContentStream);
  59. if (json.RootElement.TryGetProperty("_count", out JsonElement count) && count.GetUInt16() > 0)
  60. {
  61. foreach(var obj in json.RootElement.GetProperty("Documents").EnumerateArray())
  62. {
  63. JoinAreaSchool joinAreaSchool = new JoinAreaSchool
  64. {
  65. id = obj.GetProperty("id").GetString(),
  66. name = obj.GetProperty("name").GetString(),
  67. schoolCode = obj.GetProperty("schoolCode").GetString(),
  68. province = obj.GetProperty("province").GetString(),
  69. city = obj.GetProperty("city").GetString(),
  70. dist = obj.GetProperty("dist").GetString(),
  71. picture = obj.GetProperty("picture").GetString(),
  72. period = obj.GetProperty("period").ToObject<List<Period>>().Select(x => x.name).ToList()
  73. };
  74. try
  75. {
  76. joinAreaSchool.manyAreas = obj.GetProperty("manyAreas").ToObject<List<ManyArea>>();
  77. }
  78. catch { }
  79. joinAreaSchools.Add(joinAreaSchool);
  80. }
  81. }
  82. }
  83. return Ok(new { state = 200, joinAreaSchools });
  84. }
  85. catch (Exception ex)
  86. {
  87. await _dingDing.SendBotMsg($"BI, {_option.Location} /area/get-areaschools \n {ex.Message}\n{ex.StackTrace}", GroupNames.成都开发測試群組);
  88. return BadRequest();
  89. }
  90. }
  91. /// <summary>
  92. /// 学校移出区域
  93. /// </summary>
  94. /// <param name="jsonElement"></param>
  95. /// <returns></returns>
  96. [ProducesDefaultResponseType]
  97. [AuthToken(Roles = "admin,assist")]
  98. [HttpPost("set-areashiftschool")]
  99. public async Task<IActionResult> SetAreaShiftSchool(JsonElement jsonElement)
  100. {
  101. try
  102. {
  103. if (!jsonElement.TryGetProperty("schoolId", out JsonElement schoolId)) return BadRequest();
  104. jsonElement.TryGetProperty("areaId", out JsonElement areaId);
  105. jsonElement.TryGetProperty("standard", out JsonElement standard);
  106. jsonElement.TryGetProperty("isDefault", out JsonElement isDefault);
  107. var (_tmdId, _tmdName, pic, did, dname, dpic) = HttpJwtAnalysis.JwtXAuthBI(HttpContext.GetXAuth("AuthToken"), _option);
  108. var cosmosClient = _azureCosmos.GetCosmosClient();
  109. School tempSchool = await cosmosClient.GetContainer(Constant.TEAMModelOS, "School").ReadItemAsync<School>($"{schoolId}", new PartitionKey("Base"));
  110. if (bool.Parse($"{isDefault}") == true)
  111. {
  112. tempSchool.areaId = null;
  113. tempSchool.standard = null;
  114. }
  115. if (tempSchool.manyAreas.Count > 0)
  116. {
  117. var temp = tempSchool.manyAreas.Find(ma => ma.areaId == $"{areaId}");
  118. if (temp != null)
  119. tempSchool.manyAreas.Remove(new ManyArea { areaId = $"{areaId}", standard = $"{standard}" });
  120. }
  121. School school = await cosmosClient.GetContainer(Constant.TEAMModelOS, "School").ReplaceItemAsync<School>(tempSchool, tempSchool.id, new PartitionKey("Base"));
  122. //保存操作记录
  123. await _azureStorage.SaveBILog("school-update", $"{_tmdName}【{_tmdId}】已操作学校({schoolId})移除该区域", _dingDing, httpContext: HttpContext);
  124. return Ok(new { state = 200, school });
  125. }
  126. catch (Exception ex)
  127. {
  128. await _dingDing.SendBotMsg($"BI, {_option.Location} /area/set-areashiftschool \n {ex.Message}\n{ex.StackTrace}", GroupNames.成都开发測試群組);
  129. return BadRequest();
  130. }
  131. }
  132. /// <summary>
  133. /// 已加入区域的学校
  134. /// </summary>
  135. public record JoinAreaSchool
  136. {
  137. public string id { get; set; }
  138. public string name { get; set; }
  139. public string schoolCode { get; set; }
  140. public string picture { get; set; }
  141. public List<string> period { get; set; }
  142. public string province { get; set; }
  143. public string city { get; set; }
  144. public string dist { get; set; }
  145. public List<ManyArea> manyAreas { get; set; } = new List<ManyArea>();
  146. }
  147. }
  148. }