IESCosmosDBTrigger.cs 7.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Text.Json;
  4. using Microsoft.Azure.Functions.Worker;
  5. using Microsoft.Extensions.Configuration;
  6. using Microsoft.Extensions.Logging;
  7. using TEAMModelOS.SDK.DI;
  8. using TEAMModelOS.SDK;
  9. using System.Xml.Linq;
  10. using TEAMModelOS.SDK.Extension;
  11. using TEAMModelOS.CosmosDBTriggers;
  12. namespace TEAMModelOS.Function
  13. {
  14. public class IESCosmosDBTrigger
  15. {
  16. private readonly ILogger _logger;
  17. private readonly AzureCosmosFactory _azureCosmos;
  18. private readonly AzureServiceBusFactory _serviceBus;
  19. private readonly AzureStorageFactory _azureStorage;
  20. private readonly DingDing _dingDing;
  21. private readonly AzureRedisFactory _azureRedis;
  22. private readonly IHttpClientFactory _httpClient;
  23. private IConfiguration _configuration { get; set; }
  24. private readonly CoreAPIHttpService _coreAPIHttpService;
  25. private readonly HttpTrigger _httpTrigger;
  26. public IESCosmosDBTrigger(ILoggerFactory loggerFactory, CoreAPIHttpService coreAPIHttpService, AzureCosmosFactory azureCosmos, AzureServiceBusFactory azureServiceBus, AzureStorageFactory azureStorage, DingDing dingDing, AzureRedisFactory azureRedis
  27. , IConfiguration configuration, IHttpClientFactory httpClient, HttpTrigger httpTrigger)
  28. {
  29. _logger = loggerFactory.CreateLogger<IESCosmosDBTrigger>();
  30. _azureCosmos = azureCosmos;
  31. _serviceBus = azureServiceBus;
  32. _azureStorage = azureStorage;
  33. _dingDing = dingDing;
  34. _azureRedis = azureRedis;
  35. _configuration = configuration;
  36. _coreAPIHttpService=coreAPIHttpService;
  37. _httpClient = httpClient;
  38. _httpTrigger = httpTrigger;
  39. }
  40. [Function("Common")]
  41. public async Task Common([CosmosDBTrigger(
  42. databaseName: "TEAMModelOS",
  43. containerName: "Common",
  44. Connection = "Azure:Cosmos:ConnectionString",
  45. LeaseDatabaseName ="Lease",
  46. LeaseContainerName = "lease",
  47. LeaseContainerPrefix = "TEAMModelOS",
  48. CreateLeaseContainerIfNotExists = true,StartFromBeginning =false)] IReadOnlyList<JsonElement> input)
  49. {
  50. if (input != null && input.Count > 0)
  51. {
  52. _logger.LogInformation("Documents modified: " + input.Count);
  53. _logger.LogInformation("First document Id: " +JsonSerializer.Serialize(input[0]));
  54. var client = _azureCosmos.GetCosmosClient();
  55. foreach (var element in input) {
  56. element.TryGetProperty("_ts", out JsonElement _ts);
  57. element.TryGetProperty("id", out JsonElement _id);
  58. //_logger.LogInformation($"过期数据=>时间戳:{_ts.GetInt64()}-id:{_id}");
  59. //return;
  60. //if (JsonValueKind.Number.Equals(_ts.ValueKind) && 1719331200>_ts.GetInt64()) {
  61. // _logger.LogInformation($"过期数据=>时间戳:{_ts.GetInt64()}-id:{_id}" );
  62. // return;
  63. //}
  64. _logger.LogInformation("变化参数 " + element);
  65. element.TryGetProperty("pk", out JsonElement jsond);
  66. if (!string.IsNullOrWhiteSpace($"{jsond}"))
  67. {
  68. if ($"{jsond}".Equals("Receiver", StringComparison.OrdinalIgnoreCase)
  69. || $"{jsond}".Equals("Notice", StringComparison.OrdinalIgnoreCase)
  70. || $"{jsond}".Equals("ExamClassResult", StringComparison.OrdinalIgnoreCase))
  71. {
  72. ///通知接收者的变更
  73. continue;
  74. }
  75. //else if ($"{jsond}".Equals("StatsNotice", StringComparison.OrdinalIgnoreCase))
  76. //{
  77. // var sert = 012;
  78. //}
  79. else
  80. {
  81. TriggerData data = element.ToObject<TriggerData>();
  82. ///活动类型的变更
  83. #if DEBUG
  84. await _dingDing.SendBotMsg($"{Environment.GetEnvironmentVariable("Option:Location")}-CosmosDBTrigger,{data.pk}触发变更\n{data.ToJsonString()}",
  85. GroupNames.醍摩豆服務運維群組);
  86. #endif
  87. switch (data.pk)
  88. {
  89. case "Exam":
  90. await TriggerExam.Trigger(_coreAPIHttpService, _azureCosmos, _serviceBus, _azureStorage, _dingDing, client, element, data, _httpClient, _configuration, _httpTrigger, _azureRedis);
  91. break;
  92. case "Vote":
  93. await TriggerVote.Trigger(_coreAPIHttpService, _serviceBus, _azureStorage, _dingDing, client, element, data, _azureRedis, _configuration);
  94. break;
  95. case "Survey":
  96. await TriggerSurvey.Trigger(_coreAPIHttpService, _serviceBus, _azureStorage, _dingDing, client, element, data, _azureRedis, _configuration);
  97. break;
  98. case "Correct":
  99. await TriggerCorrect.Trigger(_coreAPIHttpService, _serviceBus, _azureStorage, _dingDing, client, element, data, _azureRedis);
  100. break;
  101. case "ExamLite":
  102. await TriggerExamLite.Trigger(_coreAPIHttpService, _serviceBus, _azureStorage, _dingDing, client, element, data, _azureRedis, _configuration);
  103. break;
  104. case "Study":
  105. await TriggerStudy.Trigger(_coreAPIHttpService, _serviceBus, _azureStorage, _dingDing, client, element, data, _azureRedis, _configuration);
  106. break;
  107. case "Homework":
  108. await TriggerHomework.Trigger(_coreAPIHttpService, _serviceBus, _azureStorage, _dingDing, client, element, data, _azureRedis, _configuration);
  109. break;
  110. case "Art":
  111. await TriggerArt.Trigger(_coreAPIHttpService, _serviceBus, _azureStorage, _dingDing, client, element, data, _azureRedis, _configuration, _httpTrigger);
  112. break;
  113. case "ExamImport":
  114. await TriggerExamImport.Trigger(_coreAPIHttpService, _azureCosmos, _serviceBus, _azureStorage, _dingDing, client, element, data, _httpClient, _configuration, _azureRedis);
  115. break;
  116. case "QuotaImport":
  117. await TriggerQuotaImport.Trigger(_coreAPIHttpService, _azureCosmos, _serviceBus, _azureStorage, _dingDing, client, element, data, _httpClient, _configuration, _azureRedis);
  118. break;
  119. }
  120. }
  121. }
  122. }
  123. }
  124. }
  125. }
  126. public class TriggerData
  127. {
  128. public string pk { get; set; }
  129. public int? status { get; set; }
  130. public string name { get; set; }
  131. public long startTime { get; set; }
  132. public long endTime { get; set; }
  133. public string school { get; set; }
  134. public string code { get; set; }
  135. public string creatorId { get; set; }
  136. public string progress { get; set; }
  137. public string scope { get; set; }
  138. public int ttl { get; set; }
  139. public string id { get; set; }
  140. public int? publish { get; set; }
  141. }
  142. }