ClassStudentController.cs 8.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using System.Threading.Tasks;
  5. using Microsoft.AspNetCore.Http;
  6. using Microsoft.AspNetCore.Mvc;
  7. using TEAMModelOS.SDK.Context.Exception;
  8. using TEAMModelOS.SDK.Extension.DataResult.JsonRpcRequest;
  9. using TEAMModelOS.SDK.Extension.DataResult.JsonRpcResponse;
  10. using TEAMModelOS.SDK.Helper.Common.CollectionHelper;
  11. using TEAMModelOS.SDK.Helper.Common.ValidateHelper;
  12. using TEAMModelOS.SDK.Module.AzureCosmosDBV3;
  13. using TEAMModelOS.Service.Models;
  14. namespace TEAMModelOS.Controllers
  15. {
  16. [Route("api/[controller]")]
  17. [ApiController]
  18. public class ClassStudentController : BaseController
  19. {
  20. private IAzureCosmosDBV3Repository _cosmos;
  21. public ClassStudentController(IAzureCosmosDBV3Repository cosmos)
  22. {
  23. _cosmos = cosmos;
  24. }
  25. /// <summary>
  26. /// 获取实时的学生-班级关联信息
  27. /// </summary>
  28. /// <param name="request"></param>
  29. /// <returns></returns>
  30. [HttpPost("find")]
  31. public async Task<BaseJosnRPCResponse> find(JosnRPCRequest<Dictionary<string,object>> request) {
  32. JsonRPCResponseBuilder builder = JsonRPCResponseBuilder.custom();
  33. // 班级编码
  34. if (request.@params.TryGetValue("classroomCode", out object classroomCode)
  35. ///学校编码
  36. && request.@params.TryGetValue("schoolCode", out object schoolCode)
  37. )
  38. {
  39. List<ClassStudent> classroomStudents = await _cosmos.FindByDict<ClassStudent>(new Dictionary<string, object> { { "id", classroomCode } });
  40. List<Student> students = await _cosmos.FindByDict<Student>(
  41. new Dictionary<string, object>() { { "classroomCode", classroomCode }, { "code", schoolCode } },
  42. new List<string> { "id", "name", "code", "seatNo", "studentId", "classroomCode" });
  43. List<dynamic> stus = new List<dynamic>();
  44. List<ClassStudent> newClassStudents = new List<ClassStudent>();
  45. ///新增的学生
  46. if (students.IsNotEmpty())
  47. {
  48. students.ForEach(x =>
  49. {
  50. if (!classroomStudents.Select(m => m.code).Contains(x.studentId))
  51. {
  52. newClassStudents.Add(new ClassStudent() { id = x.classroomCode, code = x.studentId });
  53. }
  54. var stu = new { x.id, x.name, x.code, x.seatNo, x.studentId, x.classroomCode };
  55. stus.Add(stu);
  56. });
  57. }
  58. ///反射已存在的id信息
  59. if (classroomStudents.IsNotEmpty())
  60. {
  61. ///处理冗余的id查询
  62. List<string> ids = new List<string>();
  63. classroomStudents.ForEach(x =>
  64. {
  65. if (!students.Select(m => m.studentId).Contains(x.code))
  66. {
  67. ids.Add(x.code);
  68. }
  69. });
  70. var sts = await _cosmos.FindByDict<Student>(new Dictionary<string, object>() { { "studentId", ids.ToArray() } });
  71. if (sts.IsNotEmpty())
  72. {
  73. sts.ForEach(x =>
  74. {
  75. var stu = new { x.id, x.name, x.code, x.seatNo, x.studentId, x.classroomCode };
  76. stus.Add(stu);
  77. });
  78. }
  79. }
  80. //保存新增学生
  81. if (newClassStudents.IsNotEmpty())
  82. {
  83. classroomStudents.AddRange(await _cosmos.SaveOrUpdateAll(newClassStudents));
  84. }
  85. return builder.Data(classroomStudents).Extend(new Dictionary<string, object> { { "students", stus }, { "count", stus.Count } }).build();
  86. }
  87. else
  88. {
  89. return builder.Error(ResponseCode.PARAMS_ERROR, "参数异常classroomCode,code!").build();
  90. }
  91. }
  92. /// <summary>
  93. /// 保存或修改教室学生关联
  94. /// </summary>
  95. /// <param name="request"></param>
  96. /// <returns></returns>
  97. [HttpPost("upsert")]
  98. public async Task<BaseJosnRPCResponse> Upsert(JosnRPCRequest<List<ClassStudent>> request)
  99. {
  100. JsonRPCResponseBuilder builder = JsonRPCResponseBuilder.custom();
  101. List<ClassStudent> students = await _cosmos.SaveOrUpdateAll(request.@params);
  102. builder.Data(students);
  103. return builder.build();
  104. }
  105. ///// <summary>
  106. ///// 学生加入教室
  107. ///// </summary>
  108. ///// <param name="request"></param>
  109. ///// <returns></returns>
  110. //[HttpPost("addStudent")]
  111. //public async Task<BaseJosnRPCResponse> addStudent(JosnRPCRequest<List<ClassStudent>> request)
  112. //{
  113. // JsonRPCResponseBuilder builder = JsonRPCResponseBuilder.custom();
  114. // List<ClassStudent> students = await _cosmos.SaveOrUpdateAll(request.@params);
  115. // builder.Data(students);
  116. // return builder.build();
  117. //}
  118. /// <summary>
  119. /// 学生退出教室,只能退出非原生班级的教室
  120. /// </summary>
  121. /// <param name="request"></param>
  122. /// <returns></returns>
  123. [HttpPost("exit")]
  124. public async Task<BaseJosnRPCResponse> Exit(JosnRPCRequest<List<ClassStudent>> request)
  125. {
  126. JsonRPCResponseBuilder builder = JsonRPCResponseBuilder.custom();
  127. if (ValidateHelper.IsValid(request.@params) && request.@params.Count>0)
  128. {
  129. List<ClassStudent> rm = new List<ClassStudent>();
  130. List<Student> students = await _cosmos.FindByDict<Student>(new Dictionary<string, object> { { "studentId", request.@params.GroupBy(x => x.code).ToList().Select(x => x.Key).ToArray() } });
  131. students.ForEach(x => {
  132. if (!string.IsNullOrEmpty(x.classroomCode)) {
  133. request.@params.ForEach(m =>
  134. {
  135. if (x.classroomCode.Equals(m.id) && x.studentId.Equals(m.code)) {
  136. rm.Add(m);
  137. }
  138. });
  139. }
  140. });
  141. rm.ForEach(x=> { request.@params.Remove(x); });
  142. List<IdPk> idPks = await _cosmos.DeleteAll<ClassStudent>(request.@params.Select(x=> new IdPk { id=x.id,pk=x.code}).ToList());
  143. builder.Data(idPks);
  144. }
  145. return builder.build();
  146. }
  147. /// <summary>
  148. /// 查询教室学生关联 根据id
  149. /// </summary>
  150. /// <param name="request"></param>
  151. /// <returns></returns>
  152. [HttpPost("findById")]
  153. public async Task<BaseJosnRPCResponse> FindById(JosnRPCRequest<IdPk> request)
  154. {
  155. JsonRPCResponseBuilder builder = JsonRPCResponseBuilder.custom();
  156. if (ValidateHelper.IsValid(request.@params))
  157. {
  158. ClassStudent classStudent = await _cosmos.FindByIdPk<ClassStudent>(request.@params.id,request.@params.pk);
  159. List<Student> students = await _cosmos.FindByDict<Student>(new Dictionary<string, object> { { "studentId",request.@params.pk } }, new List<string> { "id", "name", "code", "seatNo", "studentId", "classroomCode" });
  160. builder.Data(classStudent).Extend(new Dictionary<string, object> { { "student",students.IsNotEmpty()&& classStudent !=null? new { students[0].id, students[0].name, students[0].code, students[0].seatNo, students[0].studentId, students[0].classroomCode }:null } });
  161. }
  162. return builder.build();
  163. }
  164. /// <summary>
  165. /// 查询学生在哪些教室
  166. /// </summary>
  167. /// <param name="studentId"></param>
  168. /// <returns></returns>
  169. [HttpPost("findByStu")]
  170. public async Task<BaseJosnRPCResponse> FindByStu(JosnRPCRequest<string> studentId)
  171. {
  172. JsonRPCResponseBuilder builder = JsonRPCResponseBuilder.custom();
  173. if (!string.IsNullOrEmpty(studentId.@params))
  174. {
  175. List<ClassStudent> sc = await _cosmos.FindByDict<ClassStudent>(new Dictionary<string, object> { { "code",studentId.@params} });
  176. List<Classroom> classrooms = await _cosmos.FindByDict<Classroom>(new Dictionary<string, object> { { "classroomCode", sc.GroupBy(x => x.id).Select(x => x.Key).ToArray() } });
  177. builder.Data(classrooms).Extend(new Dictionary<string, object> { { "count", classrooms.Count } });
  178. }
  179. return builder.build();
  180. }
  181. }
  182. }