OpenApiController.cs 8.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193
  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 TEAMModelOS.Filter;
  11. using TEAMModelOS.Models;
  12. using TEAMModelOS.SDK.DI;
  13. using TEAMModelOS.SDK.Extension;
  14. using TEAMModelOS.SDK.Models;
  15. using TEAMModelOS.SDK.Models.Cosmos;
  16. namespace TEAMModelOS.Controllers.Core
  17. {
  18. [ProducesResponseType(StatusCodes.Status200OK)]
  19. [ProducesResponseType(StatusCodes.Status400BadRequest)]
  20. [Route("open-api")]
  21. [ApiController]
  22. public class OpenApiController : ControllerBase
  23. {
  24. private readonly AzureCosmosFactory _azureCosmos;
  25. private readonly AzureStorageFactory _azureStorage;
  26. private readonly AzureRedisFactory _azureRedis;
  27. private readonly DingDing _dingDing;
  28. private readonly Option _option;
  29. public OpenApiController(AzureCosmosFactory azureCosmos, AzureStorageFactory azureStorage, AzureRedisFactory azureRedis, DingDing dingDing, IOptionsSnapshot<Option> option) {
  30. _azureCosmos = azureCosmos;
  31. _azureStorage = azureStorage;
  32. _azureRedis = azureRedis;
  33. _dingDing = dingDing;
  34. _option = option?.Value;
  35. }
  36. /// <summary>
  37. /// 获取
  38. /// </summary>
  39. /// <param name="request"></param>
  40. /// <returns></returns>
  41. [ProducesDefaultResponseType]
  42. // [AuthToken(Roles = "admin")]
  43. [HttpPost("get")]
  44. public async Task<IActionResult> Get(JsonElement json) {
  45. List<OpenApi> apis = await _azureStorage.FindListByDict<OpenApi>(new Dictionary<string, object>() { { "PartitionKey", "IES5-API" } });
  46. return Ok(new { apis });
  47. }
  48. /// <summary>
  49. /// {"id":"uuid","code":"hbcn学校编码"}
  50. /// </summary>
  51. /// <param name="requert"></param>
  52. /// <returns></returns>
  53. [ProducesDefaultResponseType]
  54. //[AuthToken(Roles = "admin")]
  55. [HttpPost("create-token")]
  56. public async Task<IActionResult> CreateToken(JsonElement request) {
  57. try
  58. {
  59. var client = _azureCosmos.GetCosmosClient();
  60. //id
  61. if (!request.TryGetProperty("id", out JsonElement id)) return BadRequest();
  62. //
  63. if (!request.TryGetProperty("code", out JsonElement code)) return BadRequest();
  64. var response = await client.GetContainer("TEAMModelOS", "School").ReadItemStreamAsync(id.GetString(), new PartitionKey($"OpenApp-{code}")) ;
  65. if (response.Status == 200)
  66. {
  67. using var json = await JsonDocument.ParseAsync(response.ContentStream);
  68. var info = json.ToObject<OpenApp>();
  69. //创建Token
  70. //域名 应用的id, jwtkey 学校编码
  71. var auth_token = JwtAuthExtension.CreateApiToken(_option.HostName, info.id, _option.JwtSecretKey, info.name, info.school);
  72. info.token = auth_token;
  73. info = await client.GetContainer("TEAMModelOS", "School").ReplaceItemAsync(info, info.id, new PartitionKey($"{info.code}"));
  74. return Ok(new { auth_token });
  75. }
  76. else
  77. {
  78. return BadRequest();
  79. }
  80. }
  81. catch (Exception e)
  82. {
  83. await _dingDing.SendBotMsg($"OS,{_option.Location},open-api/upsert()\n{e.Message}", GroupNames.醍摩豆服務運維群組);
  84. return BadRequest();
  85. }
  86. }
  87. /// <summary>
  88. /// {"code":"hbcn学校编码"}
  89. /// </summary>
  90. /// <param name="requert"></param>
  91. /// <returns></returns>
  92. [ProducesDefaultResponseType]
  93. [AuthToken(Roles = "admin")]
  94. [HttpPost("find-app")]
  95. public async Task<IActionResult> FindApp(JsonElement request)
  96. {
  97. try
  98. {
  99. if (!request.TryGetProperty("code", out JsonElement code)) { return BadRequest(); }
  100. var client = _azureCosmos.GetCosmosClient();
  101. List<OpenApp> apps = new List<OpenApp>();
  102. await foreach (var item in client.GetContainer("TEAMModelOS", "School").GetItemQueryIterator<OpenApp>(queryText: $"select value(c) from c ",
  103. requestOptions: new QueryRequestOptions() { PartitionKey = new Azure.Cosmos.PartitionKey($"OpenApp-{code}") }))
  104. {
  105. apps.Add(item);
  106. }
  107. return Ok(new { apps });
  108. }
  109. catch (Exception ex)
  110. {
  111. await _dingDing.SendBotMsg($"OS,{_option.Location},open-api/find-app()\n{ex.Message}", GroupNames.醍摩豆服務運維群組);
  112. return BadRequest();
  113. }
  114. }
  115. /// <summary>
  116. /// {
  117. ///
  118. /// }
  119. /// </summary>
  120. /// <param name="request"></param>
  121. /// <returns></returns>
  122. [ProducesDefaultResponseType]
  123. //[AuthToken(Roles = "Teacher")]
  124. [HttpPost("upsert")]
  125. public async ValueTask<IActionResult> Upsert(OpenApp request)
  126. {
  127. try
  128. {
  129. var client = _azureCosmos.GetCosmosClient();
  130. request.pk = "OpenApp";
  131. request.code = request.pk + "-" + request.code;
  132. request.ttl = -1;
  133. if (string.IsNullOrEmpty(request.id))
  134. {
  135. request.id = Guid.NewGuid().ToString();
  136. request = await client.GetContainer("TEAMModelOS", "School").CreateItemAsync(request, new PartitionKey($"{request.code}"));
  137. }
  138. else
  139. {
  140. var response = await client.GetContainer("TEAMModelOS", "School").ReadItemStreamAsync(request.id, new PartitionKey($"{request.code}"));
  141. if (response.Status == 200)
  142. {
  143. using var json = await JsonDocument.ParseAsync(response.ContentStream);
  144. var info = json.ToObject<OpenApp>();
  145. request.token = info.token;
  146. request = await client.GetContainer("TEAMModelOS", "School").ReplaceItemAsync(request, info.id, new PartitionKey($"{info.code}"));
  147. }
  148. else
  149. {
  150. request = await client.GetContainer("TEAMModelOS", "School").CreateItemAsync(request, new PartitionKey($"{request.code}"));
  151. }
  152. }
  153. return Ok(new { app = request });
  154. }
  155. catch (Exception e)
  156. {
  157. await _dingDing.SendBotMsg($"OS,{_option.Location},open-api/upsert()\n{e.Message}", GroupNames.醍摩豆服務運維群組);
  158. return BadRequest();
  159. }
  160. }
  161. /// <summary>
  162. /// {"id":"教室id","code":"hbcn学校编码"}
  163. /// </summary>
  164. /// <param name="requert"></param>
  165. /// <returns></returns>
  166. [ProducesDefaultResponseType]
  167. [HttpPost("delete")]
  168. public async Task<IActionResult> Delete(JsonElement requert)
  169. {
  170. try
  171. {
  172. var client = _azureCosmos.GetCosmosClient();
  173. //id
  174. if (!requert.TryGetProperty("id", out JsonElement id)) return BadRequest();
  175. //
  176. if (!requert.TryGetProperty("code", out JsonElement code)) return BadRequest();
  177. var room = await client.GetContainer("TEAMModelOS", "School").DeleteItemAsync<Room>(id.GetString(), new PartitionKey($"OpenApp-{code}"));
  178. return Ok();
  179. }
  180. catch (Exception ex)
  181. {
  182. await _dingDing.SendBotMsg($"OS,{_option.Location},school/room/find-id()\n{ex.Message}", GroupNames.醍摩豆服務運維群組);
  183. return BadRequest();
  184. }
  185. }
  186. }
  187. }