PaperController.cs 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251
  1. using Microsoft.AspNetCore.Mvc;
  2. using System;
  3. using System.Collections.Generic;
  4. using System.Linq;
  5. using System.Text.Json;
  6. using System.Threading.Tasks;
  7. using TEAMModelOS.SDK;
  8. using TEAMModelOS.SDK.DI;
  9. using TEAMModelOS.SDK.Models;
  10. using TEAMModelOS.SDK.Helper.Common.StringHelper;
  11. using Microsoft.AspNetCore.Http;
  12. using System.IdentityModel.Tokens.Jwt;
  13. using Azure.Cosmos;
  14. using TEAMModelOS.SDK.Extension;
  15. using TEAMModelOS.SDK.DI.AzureCosmos.Inner;
  16. using System.Text;
  17. namespace TEAMModelOS.Controllers
  18. {
  19. [ProducesResponseType(StatusCodes.Status200OK)]
  20. [ProducesResponseType(StatusCodes.Status400BadRequest)]
  21. //[Authorize(Roles = "IES5")]
  22. [Route("school/paper")]
  23. [ApiController]
  24. public class PaperController: ControllerBase
  25. {
  26. private readonly SnowflakeId _snowflakeId;
  27. private readonly AzureCosmosFactory _azureCosmos;
  28. public PaperController(AzureCosmosFactory azureCosmos, SnowflakeId snowflakeId)
  29. {
  30. _azureCosmos = azureCosmos;
  31. _snowflakeId = snowflakeId;
  32. }
  33. /// <summary>
  34. /// 删除
  35. /// </summary>
  36. /// <param name="request"></param>
  37. /// <returns></returns>
  38. [ProducesDefaultResponseType]
  39. //[AuthToken(Roles = "Teacher")]
  40. [HttpPost("delete")]
  41. public async Task<IActionResult> Delete(JsonElement request)
  42. {
  43. if (!request.TryGetProperty("code", out JsonElement code)) return BadRequest();
  44. if (!request.TryGetProperty("id", out JsonElement id)) return BadRequest();
  45. if (!request.TryGetProperty("scope", out JsonElement scope)) return BadRequest();
  46. //ResponseBuilder builder = ResponseBuilder.custom();
  47. Paper paper;
  48. var client = _azureCosmos.GetCosmosClient();
  49. if (scope.ToString().Equals("school"))
  50. {
  51. paper = await client.GetContainer("TEAMModelOS", "School").DeleteItemAsync<Paper>(id.ToString(), new PartitionKey($"{code}"));
  52. }
  53. else {
  54. paper = await client.GetContainer("TEAMModelOS", "Teacher").DeleteItemAsync<Paper>(id.ToString(), new PartitionKey($"{code}"));
  55. }
  56. //IdPk items = await _azureCosmos.DeleteAsync<Paper>(request.id, request.pk);
  57. return Ok(new { paper });
  58. }
  59. /// <summary>
  60. /// 查询试卷摘要信息
  61. /// </summary>
  62. /// <param name="request"></param>
  63. /// <returns></returns>
  64. [ProducesDefaultResponseType]
  65. //[AuthToken(Roles = "Teacher")]
  66. [HttpPost("find-summary")]
  67. public async Task<IActionResult> findSummary(JsonElement requert)
  68. {
  69. //ResponseBuilder builder = ResponseBuilder.custom();
  70. if (!requert.TryGetProperty("id_token", out JsonElement id_token)) return BadRequest();
  71. if (!requert.TryGetProperty("school_code", out JsonElement school_code)) return BadRequest();
  72. var jwt = new JwtSecurityToken(id_token.GetString());
  73. if (!jwt.Payload.Iss.Equals("account.teammodel", StringComparison.Ordinal)) return BadRequest();
  74. var id = jwt.Payload.Sub;
  75. var client = _azureCosmos.GetCosmosClient();
  76. List<object> papers = new List<object>();
  77. var query = $"select c.id,c.subjectCode,c.code,c.periodCode,c.name,c.itemCount,c.level,c.pointItem,c.pointScore,c.score,c.gradeCode from c where c.id = {id}";
  78. await foreach (var item in client.GetContainer("TEAMModelOS", "School").GetItemQueryStreamIterator(queryText: query, requestOptions: new QueryRequestOptions() { PartitionKey = new PartitionKey($"Paper-{school_code}") }))
  79. {
  80. using var json = await JsonDocument.ParseAsync(item.ContentStream);
  81. if (json.RootElement.TryGetProperty("_count", out JsonElement count) && count.GetUInt16() > 0)
  82. {
  83. foreach (var obj in json.RootElement.GetProperty("Documents").EnumerateArray())
  84. {
  85. papers.Add(obj.ToObject<object>());
  86. }
  87. }
  88. }
  89. return Ok(new { papers });
  90. /* List<string> props = new List<string> {
  91. "subjectCode", "id", "code", "periodCode",
  92. "name","itemCount","level","pointItem","pointScore","score", "gradeCode"
  93. };
  94. if (StringHelper.getKeyCount(request) > 0)
  95. {
  96. return builder.Data(await _azureCosmos.FindByDict<Paper>(request, propertys: props)).build();
  97. }
  98. else {
  99. return builder.build();
  100. }*/
  101. }
  102. /// <summary>
  103. /// 查询试卷
  104. /// </summary>
  105. /// <param name="request"></param>
  106. /// <returns></returns>
  107. [ProducesDefaultResponseType]
  108. //[AuthToken(Roles = "Teacher")]
  109. [HttpPost("find")]
  110. public async Task<IActionResult> Find(JsonElement requert)
  111. {
  112. //ResponseBuilder builder = ResponseBuilder.custom();
  113. //if (!requert.TryGetProperty("id_token", out JsonElement id_token)) return BadRequest();
  114. if (!requert.TryGetProperty("code", out JsonElement code)) return BadRequest();
  115. if (!requert.TryGetProperty("scope", out JsonElement scope)) return BadRequest();
  116. /*var jwt = new JwtSecurityToken(id_token.GetString());
  117. if (!jwt.Payload.Iss.Equals("account.teammodel", StringComparison.Ordinal)) return BadRequest();
  118. var id = jwt.Payload.Sub;*/
  119. var client = _azureCosmos.GetCosmosClient();
  120. StringBuilder sql = new StringBuilder();
  121. Dictionary<string, object> dict = new Dictionary<string, object>();
  122. var emobj = requert.EnumerateObject();
  123. while (emobj.MoveNext())
  124. {
  125. dict[emobj.Current.Name] = emobj.Current.Value;
  126. }
  127. //处理code
  128. if (dict.TryGetValue("code", out object _))
  129. {
  130. dict.Remove("code");
  131. }
  132. List<object> papers = new List<object>();
  133. if (scope.ToString().Equals("school"))
  134. {
  135. sql.Append("select c.id,c.code,c.name,c.blob,c.periodId,c.gradeIds,c.subjectId,c.subjectName,c.score,c.useCount,c.scope,c.scoring from c");
  136. AzureCosmosQuery cosmosDbQuery = SQLHelper.GetSQL(dict, sql);
  137. await foreach (var item in client.GetContainer("TEAMModelOS", "School").GetItemQueryStreamIterator(queryDefinition: cosmosDbQuery.CosmosQueryDefinition, requestOptions: new QueryRequestOptions() { PartitionKey = new PartitionKey($"Paper-{code}") }))
  138. {
  139. using var json = await JsonDocument.ParseAsync(item.ContentStream);
  140. if (json.RootElement.TryGetProperty("_count", out JsonElement count) && count.GetUInt16() > 0)
  141. {
  142. foreach (var obj in json.RootElement.GetProperty("Documents").EnumerateArray())
  143. {
  144. papers.Add(obj.ToObject<object>());
  145. }
  146. }
  147. }
  148. }
  149. if (scope.ToString().Equals("private"))
  150. {
  151. sql.Append("select c.id,c.code,c.name,c.blob,c.subjectName,c.score,c.useCount,c.scope,c.scoring from c");
  152. AzureCosmosQuery cosmosDbQuery = SQLHelper.GetSQL(dict, sql);
  153. await foreach (var item in client.GetContainer("TEAMModelOS", "Teacher").GetItemQueryStreamIterator(queryDefinition: cosmosDbQuery.CosmosQueryDefinition, requestOptions: new QueryRequestOptions() { PartitionKey = new PartitionKey($"Paper-{code}") }))
  154. {
  155. using var json = await JsonDocument.ParseAsync(item.ContentStream);
  156. if (json.RootElement.TryGetProperty("_count", out JsonElement count) && count.GetUInt16() > 0)
  157. {
  158. foreach (var obj in json.RootElement.GetProperty("Documents").EnumerateArray())
  159. {
  160. papers.Add(obj.ToObject<object>());
  161. }
  162. }
  163. }
  164. }
  165. return Ok(new { papers });
  166. /*if (StringHelper.getKeyCount(request) > 0) {
  167. return builder.Data(await _azureCosmos.FindByDict<Paper>(request)).build();
  168. }
  169. else
  170. {
  171. return builder.build();
  172. }*/
  173. }
  174. /// <summary>
  175. /// 保存试卷
  176. /// </summary>
  177. /// <param name="request"></param>
  178. /// <returns></returns>
  179. [ProducesDefaultResponseType]
  180. //[AuthToken(Roles = "Teacher")]
  181. [HttpPost("upsert")]
  182. public async Task<IActionResult> Upsert(JsonElement request)
  183. {
  184. var client = _azureCosmos.GetCosmosClient();
  185. if (!request.TryGetProperty("paper", out JsonElement papers)) return BadRequest();
  186. if (!request.TryGetProperty("option", out JsonElement option)) return BadRequest();
  187. Paper paper;
  188. paper = papers.ToObject<Paper>();
  189. paper.createTime = DateTimeOffset.UtcNow.ToUnixTimeMilliseconds();
  190. if (option.ToString().Equals("insert"))
  191. {
  192. paper.code = "Paper-" + paper.code;
  193. var response = await client.GetContainer("TEAMModelOS", "School").ReadItemStreamAsync(paper.id, new PartitionKey($"{paper.code}"));
  194. if (response.Status == 200)
  195. {
  196. return Ok(new { error = ResponseCode.DATA_EXIST, V = "试卷已经存在!" });
  197. }
  198. else
  199. {
  200. if (paper.scope.Equals("private"))
  201. {
  202. //paper.JsonRemove("periodId");
  203. paper = await client.GetContainer("TEAMModelOS", "Teacher").CreateItemAsync(paper, new PartitionKey($"{paper.code}"));
  204. }
  205. else
  206. {
  207. //paper.JsonRemove("periodId");
  208. paper = await client.GetContainer("TEAMModelOS", "School").CreateItemAsync(paper, new PartitionKey($"{paper.code}"));
  209. }
  210. }
  211. }
  212. else
  213. {
  214. if (paper.scope.Equals("private"))
  215. {
  216. paper = await client.GetContainer("TEAMModelOS", "Teacher").ReplaceItemAsync(paper, paper.id, new PartitionKey($"{paper.code}"));
  217. }
  218. else
  219. {
  220. paper = await client.GetContainer("TEAMModelOS", "School").ReplaceItemAsync(paper, paper.id, new PartitionKey($"{paper.code}"));
  221. }
  222. }
  223. return Ok(new { paper });
  224. /*ResponseBuilder builder = ResponseBuilder.custom();
  225. if (string.IsNullOrEmpty(request.id))
  226. {
  227. request.id = _snowflakeId.NextId() + "";
  228. request.createTime = DateTimeOffset.UtcNow.ToUnixTimeMilliseconds();
  229. await _azureCosmos.SaveOrUpdate(request);
  230. }
  231. else
  232. {
  233. await _azureCosmos.SaveOrUpdate(request);
  234. }
  235. return builder.Data(request).build();*/
  236. //return Ok();
  237. }
  238. }
  239. }