TchListController.cs 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296
  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.IdentityModel.Tokens.Jwt;
  8. using System.IO;
  9. using System.Linq;
  10. using System.Text;
  11. using System.Text.Json;
  12. using System.Threading.Tasks;
  13. using TEAMModelOS.Models;
  14. using TEAMModelOS.Models.Dto;
  15. using TEAMModelOS.SDK.Models;
  16. using TEAMModelOS.SDK.DI;
  17. using TEAMModelOS.SDK.DI.AzureCosmos.Inner;
  18. using TEAMModelOS.SDK.Extension;
  19. using TEAMModelOS.SDK;
  20. using TEAMModelOS.SDK.Helper.Common.StringHelper;
  21. using System.Dynamic;
  22. using Azure;
  23. using TEAMModelOS.SDK.Models.Cosmos.Common;
  24. using Azure.Messaging.ServiceBus;
  25. using Microsoft.Extensions.Configuration;
  26. using TEAMModelOS.Filter;
  27. using Azure.Storage.Blobs.Models;
  28. using HTEXLib.COMM.Helpers;
  29. using TEAMModelFunction;
  30. namespace TEAMModelOS.Controllers
  31. {
  32. [ProducesResponseType(StatusCodes.Status200OK)]
  33. [ProducesResponseType(StatusCodes.Status400BadRequest)]
  34. //[Authorize(Roles = "IES5")]
  35. [Route("tchlist")]
  36. [ApiController]
  37. public class TchListController : ControllerBase
  38. {
  39. private AzureCosmosFactory _azureCosmos;
  40. private readonly DingDing _dingDing;
  41. private readonly Option _option;
  42. private readonly AzureServiceBusFactory _serviceBus;
  43. private readonly AzureStorageFactory _azureStorage;
  44. public IConfiguration _configuration { get; set; }
  45. public TchListController(AzureCosmosFactory azureCosmos, DingDing dingDing, IOptionsSnapshot<Option> option, AzureServiceBusFactory serviceBus, AzureStorageFactory azureStorage, IConfiguration configuration)
  46. {
  47. _azureCosmos = azureCosmos;
  48. _dingDing = dingDing;
  49. _option = option?.Value;
  50. _serviceBus = serviceBus;
  51. _configuration = configuration;
  52. _azureStorage = azureStorage;
  53. }
  54. //查询名单
  55. [ProducesDefaultResponseType]
  56. // [AuthToken(Roles = "admin,teacher")]
  57. [HttpPost("get-research-list")]
  58. public async Task<IActionResult> getResearch(JsonElement requert)
  59. {
  60. try
  61. {
  62. if (!requert.TryGetProperty("code", out JsonElement code)) return BadRequest();
  63. requert.TryGetProperty("ids", out JsonElement _stuids);
  64. var client = _azureCosmos.GetCosmosClient();
  65. List<TchList> tchLists = new();
  66. List<string> ids = new();
  67. if (!_stuids.ValueKind.Equals(JsonValueKind.Undefined) && _stuids.ValueKind.Equals(JsonValueKind.Array))
  68. {
  69. ids = _stuids.ToObject<List<string>>();
  70. }
  71. // var query = $"select c.id,c.name,c.students,c.tmids,c.periodId from c";
  72. StringBuilder query = new StringBuilder($"select value(c) from c where c.type='research' ");
  73. if (ids.IsNotEmpty())
  74. {
  75. string sql = $" and c.id in ({string.Join(",", ids.Select(o => $"'{o}'"))})";
  76. query.Append(sql);
  77. }
  78. await foreach (var item in client.GetContainer(Constant.TEAMModelOS, "School").GetItemQueryIterator<TchList>(queryText: query.ToString(), requestOptions: new QueryRequestOptions() { PartitionKey = new PartitionKey($"TchList-{code}") }))
  79. {
  80. tchLists.Add(item);
  81. }
  82. return Ok(new { tchLists });
  83. }
  84. catch (Exception ex)
  85. {
  86. await _dingDing.SendBotMsg($"OS,{_option.Location},course/get-summary-list()\n{ex.Message}", GroupNames.醍摩豆服務運維群組);
  87. return BadRequest();
  88. }
  89. }
  90. //处理教师名单
  91. [ProducesDefaultResponseType]
  92. [AuthToken(Roles = "teacher,admin")]
  93. [HttpPost("find-list-members")]
  94. public async Task<IActionResult> FindListMembers(JsonElement json) {
  95. try
  96. {
  97. var (userid, _, _, school) = HttpContext.GetAuthTokenInfo();
  98. if (!json.TryGetProperty("school_code", out JsonElement _code)) return BadRequest();
  99. if (!json.TryGetProperty("ids", out JsonElement _ids)) return BadRequest();
  100. var client = _azureCosmos.GetCosmosClient();
  101. List<string> classes = _ids.ToObject<List<string>>();
  102. List<dynamic> list = new List<dynamic>();
  103. foreach (string cls in classes)
  104. {
  105. (List<TmdInfo> tmdids,List<ClassListInfo> classLists) = await TriggerStuActivity.GetTchList(client, _dingDing, new List<string> { cls }, $"{_code}");
  106. if (classLists.IsNotEmpty())
  107. {
  108. list.Add(new { tmdids, @class = classLists.First() });
  109. }
  110. }
  111. return Ok(new { list });
  112. }
  113. catch (Exception ex)
  114. {
  115. await _dingDing.SendBotMsg($"OS,{_option.Location},course/upsert-list()\n{ex.Message}{ex.StackTrace}\n{json}", GroupNames.醍摩豆服務運維群組);
  116. return BadRequest();
  117. }
  118. }
  119. //处理教师名单
  120. [ProducesDefaultResponseType]
  121. [AuthToken(Roles = "teacher,admin")]
  122. [HttpPost("upsert-list")]
  123. public async Task<IActionResult> upsertList(JsonElement json)
  124. {
  125. try
  126. {
  127. var (userid, _, _, school) = HttpContext.GetAuthTokenInfo();
  128. TchList tchList =null;
  129. if (!string.IsNullOrEmpty(school))
  130. {
  131. tchList = json.ToObject<TchList>();
  132. tchList.creatorId = userid;
  133. tchList.school = school;
  134. tchList.pk = "TchList";
  135. tchList.code = $"TchList-{school}";
  136. tchList.scope = "school";
  137. tchList.ttl = -1;
  138. tchList = await upsertList(tchList);
  139. }
  140. return Ok(new { tchList });
  141. }
  142. catch (Exception ex)
  143. {
  144. await _dingDing.SendBotMsg($"OS,{_option.Location},course/upsert-list()\n{ex.Message}{ex.StackTrace}\n{json}", GroupNames.醍摩豆服務運維群組);
  145. return BadRequest();
  146. }
  147. }
  148. //处理教师名单
  149. [ProducesDefaultResponseType]
  150. [AuthToken(Roles = "teacher,admin")]
  151. [HttpPost("delete-list")]
  152. public async Task<IActionResult> deleteList(JsonElement request)
  153. {
  154. try
  155. {
  156. var client = _azureCosmos.GetCosmosClient();
  157. var (userid, _, _, school) = HttpContext.GetAuthTokenInfo();
  158. if (!request.TryGetProperty("id", out JsonElement _id)) return BadRequest();
  159. await client.GetContainer(Constant.TEAMModelOS, "School").DeleteItemStreamAsync($"{_id}", new PartitionKey($"TchList-{school}"));
  160. return Ok(new { });
  161. }
  162. catch (Exception ex)
  163. {
  164. await _dingDing.SendBotMsg($"OS,{_option.Location},course/upsert-list()\n{ex.Message}{ex.StackTrace}\n{request}", GroupNames.醍摩豆服務運維群組);
  165. return BadRequest();
  166. }
  167. }
  168. private async Task<TchList> upsertList(TchList tchList)
  169. {
  170. try
  171. {
  172. var client = _azureCosmos.GetCosmosClient();
  173. //todo 需要校验是否重复
  174. if (string.IsNullOrEmpty(tchList.no))
  175. {
  176. tchList.no = $"{Utils.CreatSaltString(6, "0123456789")}";
  177. for (int i = 0; i < 10; i++)
  178. {
  179. var queryNo = $"SELECT c.no FROM c where c.no ='{tchList.no}'";
  180. List<string> noStus = new();
  181. await foreach (var item in client.GetContainer(Constant.TEAMModelOS, "School").GetItemQueryStreamIterator(queryText: queryNo,
  182. requestOptions: new QueryRequestOptions() { PartitionKey = new Azure.Cosmos.PartitionKey($"{tchList.code}") }))
  183. {
  184. using var jsonNo = await JsonDocument.ParseAsync(item.ContentStream);
  185. if (jsonNo.RootElement.TryGetProperty("_count", out JsonElement count) && count.GetUInt16() > 0)
  186. {
  187. var accounts = jsonNo.RootElement.GetProperty("Documents").EnumerateArray();
  188. while (accounts.MoveNext())
  189. {
  190. JsonElement account = accounts.Current;
  191. noStus.Add(account.GetProperty("no").GetString());
  192. }
  193. }
  194. }
  195. if (noStus.Count == 0)
  196. {
  197. break;
  198. }
  199. else
  200. {
  201. if (i == 9)
  202. {
  203. string msg = $"OS,{_option.Location},upsert-list()\n 编号生成异常,重复生成次数超过10次";
  204. await _dingDing.SendBotMsg(msg, GroupNames.醍摩豆服務運維群組);
  205. throw new Exception(msg);
  206. }
  207. else
  208. {
  209. tchList.no = $"{Utils.CreatSaltString(6, "0123456789")}";
  210. }
  211. }
  212. }
  213. }
  214. ListChange change = new ListChange()
  215. {
  216. type = tchList.type,
  217. listid = tchList.id,
  218. scope = "school",
  219. originCode = tchList.school,
  220. school = tchList.school,
  221. creatorId = tchList.creatorId
  222. };
  223. var query = $"SELECT distinct value(c) FROM c where c.id='{tchList.id}'";
  224. List<TchList> odlStus = new List<TchList>();
  225. await foreach (var item in client.GetContainer(Constant.TEAMModelOS, "School").GetItemQueryIterator<TchList>(queryText: query,
  226. requestOptions: new QueryRequestOptions() { PartitionKey = new Azure.Cosmos.PartitionKey($"TchList-{tchList.school}") }))
  227. {
  228. odlStus.Add(item);
  229. }
  230. if (odlStus.Count > 0)
  231. {
  232. if (tchList.teachers != null)
  233. {
  234. if (odlStus[0].teachers != null)
  235. {
  236. TchList oldStu = odlStus[0];
  237. foreach (var teacher in tchList.teachers)
  238. {
  239. bool flag = false;
  240. //判断新增名单成员不在已经存在的名单
  241. foreach (var old in oldStu.teachers)
  242. {
  243. if (old.Equals(teacher))
  244. {
  245. flag = true;
  246. }
  247. }
  248. if (flag == false)
  249. {
  250. change.tchjoin.Add(teacher);
  251. }
  252. }
  253. foreach (var old in oldStu.teachers)
  254. {
  255. bool flag = false;
  256. //判断已存在名单成员不在变更后的名单里
  257. foreach (var teacher in tchList.teachers)
  258. {
  259. if (old.Equals(teacher))
  260. {
  261. flag = true;
  262. }
  263. }
  264. if (flag == false)
  265. {
  266. change.tchleave.Add(old);
  267. }
  268. }
  269. }
  270. }
  271. if (change.tmdjoin.Count != 0 || change.tmdhleave.Count != 0 || change.stujoin.Count != 0 || change.stuleave.Count != 0 || change.tchjoin.Count != 0 || change.tchleave.Count != 0)
  272. {
  273. var messageChange = new ServiceBusMessage(change.ToJsonString());
  274. messageChange.ApplicationProperties.Add("name", "StuList");
  275. var ActiveTask = _configuration.GetValue<string>("Azure:ServiceBus:ActiveTask");
  276. await _serviceBus.GetServiceBusClient().SendMessageAsync(ActiveTask, messageChange);
  277. }
  278. }
  279. tchList = await _azureCosmos.GetCosmosClient().GetContainer(Constant.TEAMModelOS, "School").UpsertItemAsync(tchList, new PartitionKey($"TchList-{tchList.school}"));
  280. return tchList;
  281. }
  282. catch (Exception ex)
  283. {
  284. string msg = $"OS,{_option.Location},course/upsert-list()\n{ex.Message}{ex.StackTrace}\n{tchList.ToJsonString()}";
  285. await _dingDing.SendBotMsg(msg, GroupNames.醍摩豆服務運維群組);
  286. throw new Exception(msg, ex);
  287. }
  288. }
  289. }
  290. }