ClassStudentController.cs 7.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178
  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,string>> request) {
  32. JsonRPCResponseBuilder builder = JsonRPCResponseBuilder.custom();
  33. // 班级编码
  34. if (request.@params.TryGetValue("classroomCode", out string classroomCode)
  35. ///学校编码
  36. && request.@params.TryGetValue("schoolCode", out string 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>(new Dictionary<string, object>() { { "classroomCode", classroomCode }, { "code", schoolCode } });
  41. List<dynamic> stus = new List<dynamic>();
  42. List<ClassStudent> newClassStudents = new List<ClassStudent>();
  43. ///新增的学生
  44. if (students.IsNotEmpty())
  45. {
  46. students.ForEach(x =>
  47. {
  48. if (!classroomStudents.Select(m=>m.code).Contains(x.studentId))
  49. {
  50. newClassStudents.Add(new ClassStudent() { id = classroomCode, code = x.studentId });
  51. }
  52. var stu = new { x.id, x.name, x.code, x.seatNo, x.studentId, x.classroomCode };
  53. stus.Add(stu);
  54. });
  55. }
  56. ///反射已存在的id信息
  57. if (classroomStudents.IsNotEmpty())
  58. {
  59. var sts = await _cosmos.FindByDict<Student>(new Dictionary<string, object>() { { "studentId", classroomStudents.Select(x=>x.code).ToArray() } });
  60. sts.ForEach(x => {
  61. var stu = new { x.id, x.name, x.code, x.seatNo, x.studentId, x.classroomCode };
  62. stus.Add(stu);
  63. });
  64. }
  65. //保存新增学生
  66. if (newClassStudents.IsNotEmpty()) {
  67. classroomStudents.AddRange( await _cosmos.SaveOrUpdateAll(newClassStudents));
  68. }
  69. return builder.Data(classroomStudents).Extend(new Dictionary<string, object> { { "students", stus }, { "count", stus.Count } }).build();
  70. }
  71. else { throw new BizException("参数异常classroomCode,code", ResponseCode.PARAMS_ERROR); }
  72. }
  73. /// <summary>
  74. /// 保存或修改教室学生关联
  75. /// </summary>
  76. /// <param name="request"></param>
  77. /// <returns></returns>
  78. [HttpPost("save")]
  79. public async Task<BaseJosnRPCResponse> Save(JosnRPCRequest<List<ClassStudent>> request)
  80. {
  81. JsonRPCResponseBuilder builder = JsonRPCResponseBuilder.custom();
  82. if (ValidateHelper.IsValid(request.@params))
  83. {
  84. List<ClassStudent> students = await _cosmos.SaveOrUpdateAll(request.@params);
  85. builder.Data(students);
  86. }
  87. return builder.build();
  88. }
  89. /// <summary>
  90. /// 学生加入教室
  91. /// </summary>
  92. /// <param name="request"></param>
  93. /// <returns></returns>
  94. [HttpPost("addStudent")]
  95. public async Task<BaseJosnRPCResponse> addStudent(JosnRPCRequest<List<ClassStudent>> request)
  96. {
  97. JsonRPCResponseBuilder builder = JsonRPCResponseBuilder.custom();
  98. if (ValidateHelper.IsValid(request.@params))
  99. {
  100. List<ClassStudent> students = await _cosmos.SaveOrUpdateAll(request.@params);
  101. builder.Data(students);
  102. }
  103. return builder.build();
  104. }
  105. /// <summary>
  106. /// 学生退出教室,只能退出非原生班级的教室
  107. /// </summary>
  108. /// <param name="request"></param>
  109. /// <returns></returns>
  110. [HttpPost("Exit")]
  111. public async Task<BaseJosnRPCResponse> Exit(JosnRPCRequest<List<ClassStudent>> request)
  112. {
  113. JsonRPCResponseBuilder builder = JsonRPCResponseBuilder.custom();
  114. if (ValidateHelper.IsValid(request.@params) && request.@params.Count>0)
  115. {
  116. List<Student> students = await _cosmos.FindByDict<Student>(new Dictionary<string, object> { { "studentId", request.@params.GroupBy(x => x.id).ToList().Select(x => x.Key).ToArray() } });
  117. students.ForEach(x => {
  118. if (!string.IsNullOrEmpty(x.classroomCode)) {
  119. request.@params.ForEach(m =>
  120. {
  121. if (x.classroomCode.Equals(m.id) && x.studentId.Equals(m.code)) {
  122. request.@params.Remove(m);
  123. }
  124. });
  125. }
  126. });
  127. List<IdPk> idPks = await _cosmos.DeleteAll<ClassStudent>(request.@params.Select(x=> new IdPk { id=x.id,pk=x.code}).ToList());
  128. builder.Data(idPks);
  129. }
  130. return builder.build();
  131. }
  132. /// <summary>
  133. /// 查询教室学生关联 根据id
  134. /// </summary>
  135. /// <param name="request"></param>
  136. /// <returns></returns>
  137. [HttpPost("findById")]
  138. public async Task<BaseJosnRPCResponse> FindById(JosnRPCRequest<IdPk> request)
  139. {
  140. JsonRPCResponseBuilder builder = JsonRPCResponseBuilder.custom();
  141. if (ValidateHelper.IsValid(request.@params))
  142. {
  143. ClassStudent classStudent = await _cosmos.FindByIdPk<ClassStudent>(request.@params.id,request.@params.pk);
  144. List<Student> students = await _cosmos.FindByDict<Student>(new Dictionary<string, object> { { "studentId",request.@params.pk } });
  145. builder.Data(classStudent).Extend(new Dictionary<string, object> { { "student",students.IsNotEmpty()? students[0]:null } });
  146. }
  147. return builder.build();
  148. }
  149. /// <summary>
  150. /// 查询学生在哪些教室
  151. /// </summary>
  152. /// <param name="studentId"></param>
  153. /// <returns></returns>
  154. [HttpPost("findByStu")]
  155. public async Task<BaseJosnRPCResponse> FindByStu(JosnRPCRequest<string> studentId)
  156. {
  157. JsonRPCResponseBuilder builder = JsonRPCResponseBuilder.custom();
  158. if (!string.IsNullOrEmpty(studentId.@params))
  159. {
  160. List<ClassStudent> sc = await _cosmos.FindByDict<ClassStudent>(new Dictionary<string, object> { { "code",studentId.@params} });
  161. List<Classroom> classrooms = await _cosmos.FindByDict<Classroom>(new Dictionary<string, object> { { "classroomCode", sc.GroupBy(x => x.id).Select(x => x.Key).ToArray() } });
  162. builder.Data(classrooms).Extend(new Dictionary<string, object> { { "count", classrooms.Count } });
  163. }
  164. return builder.build();
  165. }
  166. }
  167. }