SchoolController.cs 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355
  1. using Microsoft.AspNetCore.Mvc;
  2. using System;
  3. using System.Collections.Generic;
  4. using System.Text;
  5. using System.Threading.Tasks;
  6. using TEAMModelOS.Models;
  7. using TEAMModelOS.SDK;
  8. using TEAMModelOS.SDK.DI;
  9. using System.Text.Json;
  10. using TEAMModelOS.SDK.Models;
  11. using TEAMModelOS.SDK.Extension;
  12. using Azure.Cosmos;
  13. using Microsoft.AspNetCore.Http;
  14. using Microsoft.Extensions.Options;
  15. using System.IO;
  16. using System.Dynamic;
  17. using System.Net.Http;
  18. using System.Net;
  19. using Newtonsoft.Json;
  20. using System.Linq;
  21. using StackExchange.Redis;
  22. using static TEAMModelOS.SDK.Models.Teacher;
  23. using Microsoft.Extensions.Configuration;
  24. using TEAMModelOS.Filter;
  25. using Microsoft.AspNetCore.Authorization;
  26. using HTEXLib.COMM.Helpers;
  27. using TEAMModelOS.SDK.Models.Service;
  28. namespace TEAMModelAPI.Controllers
  29. {
  30. [ProducesResponseType(StatusCodes.Status200OK)]
  31. [ProducesResponseType(StatusCodes.Status400BadRequest)]
  32. [ApiController]
  33. [Route("school")]
  34. public class SchoolController : ControllerBase
  35. {
  36. public AzureCosmosFactory _azureCosmos;
  37. private readonly AzureStorageFactory _azureStorage;
  38. private readonly AzureRedisFactory _azureRedis;
  39. private readonly DingDing _dingDing;
  40. private readonly Option _option;
  41. private readonly IConfiguration _configuration;
  42. private readonly CoreAPIHttpService _coreAPIHttpService;
  43. public SchoolController(CoreAPIHttpService coreAPIHttpService, AzureCosmosFactory azureCosmos, AzureStorageFactory azureStorage, AzureRedisFactory azureRedis, DingDing dingDing, IOptionsSnapshot<Option> option, IConfiguration configuration)
  44. {
  45. _azureCosmos = azureCosmos;
  46. _azureStorage = azureStorage;
  47. _azureRedis = azureRedis;
  48. _dingDing = dingDing;
  49. _option = option?.Value;
  50. _configuration = configuration;
  51. }
  52. /// <summary>
  53. /// 学校基础信息
  54. /// </summary>
  55. /// <param name="request"></param>
  56. /// <returns></returns>
  57. [ProducesDefaultResponseType]
  58. [HttpGet("get-school-info")]
  59. [ApiToken(Auth = "2",Name = "学校基础信息", RW = "R", Limit =false)]
  60. public async Task<IActionResult> GetSchoolInfo()
  61. {
  62. var (id, school) = HttpContext.GetApiTokenInfo();
  63. School data = await _azureCosmos.GetCosmosClient().GetContainer(Constant.TEAMModelOS, "School").ReadItemAsync<School>(school, new PartitionKey("Base"));
  64. List<dynamic> period = new List<dynamic>();
  65. data.period.ForEach(x => { period.Add(new { x.subjects ,x.grades,x.name,x.id,x.campusId,x.semesters}); });
  66. return Ok(new {
  67. id = data.id, name = data.name, data.areaId, type = data.type,
  68. data.region, data.province, data.city, data.dist,
  69. campuses=data.campuses,
  70. period
  71. });
  72. }
  73. /// <summary>
  74. /// 获取学校教师列表
  75. /// </summary>
  76. /// <param name="request"></param>
  77. /// <returns></returns>
  78. [ProducesDefaultResponseType]
  79. [HttpGet("get-teacher-list")]
  80. [ApiToken(Auth = "3", Name = "学校教师列表", RW = "R", Limit = false)]
  81. public async Task<IActionResult> GetTeacherList()
  82. {
  83. var (id, school) = HttpContext.GetApiTokenInfo();
  84. List<dynamic> teachers= new List<dynamic>();
  85. string sql = $"select c.id,c.name ,c.picture,c.job ,c.subjectIds,c.roles from c where c.status='join' ";
  86. await foreach (var item in _azureCosmos.GetCosmosClient().GetContainer(Constant.TEAMModelOS, "School").GetItemQueryIterator<dynamic>
  87. (queryText: sql, requestOptions: new QueryRequestOptions { PartitionKey = new PartitionKey($"Teacher-{school}") })) {
  88. teachers.Add(item);
  89. }
  90. return Ok(new
  91. {
  92. teachers
  93. });
  94. }
  95. /// <summary>
  96. /// 获取学校教师信息
  97. /// </summary>
  98. /// <returns></returns>
  99. [ProducesDefaultResponseType]
  100. [HttpPost("get-teacher-info")]
  101. [ApiToken(Auth = "4", Name = "学校教师信息", RW = "R", Limit = false)]
  102. public async Task<IActionResult> GetTeacherInfo(JsonElement json )
  103. {
  104. json.TryGetProperty("tmdid", out JsonElement _tmdid);
  105. var (id, school) = HttpContext.GetApiTokenInfo();
  106. Azure.Response responseSchoolTch =await _azureCosmos.GetCosmosClient().GetContainer(Constant.TEAMModelOS, "School")
  107. .ReadItemStreamAsync($"{_tmdid}", new PartitionKey($"Teacher-{school}"));
  108. Azure.Response responseTch = await _azureCosmos.GetCosmosClient().GetContainer(Constant.TEAMModelOS, "Teacher")
  109. .ReadItemStreamAsync($"{_tmdid}", new PartitionKey($"Base"));
  110. Teacher teacher = null;
  111. if (responseTch.Status == 200)
  112. {
  113. teacher = JsonDocument.Parse(responseTch.Content).RootElement.Deserialize<Teacher>();
  114. }
  115. else
  116. {
  117. return Ok(new { error = 3, msg = "账号未创建!" });
  118. }
  119. if (responseSchoolTch.Status == 200 && teacher!= null )
  120. {
  121. SchoolTeacher schoolTeacher= JsonDocument.Parse(responseSchoolTch.Content).RootElement.Deserialize<SchoolTeacher>();
  122. if (schoolTeacher.status.Equals("join"))
  123. {
  124. return Ok(new {teacher.id,teacher.name,teacher.picture,schoolTeacher.job,schoolTeacher.status,schoolTeacher.roles,schoolTeacher.subjectIds, school=teacher.schools?.Find(x=>x.schoolId.Equals(school)) } );
  125. }
  126. else
  127. {
  128. return Ok(new { error = 2, msg = "教师未加入学校!" });
  129. }
  130. }
  131. else {
  132. return Ok(new { error = 1, msg = "教师未就职该学校!" });
  133. }
  134. }
  135. /*
  136. "periodId":"学段(选填)"
  137. */
  138. /// <summary>
  139. /// 获取学校的行政班,教学班,教研组,研修名单
  140. /// </summary>
  141. /// <param name="request"></param>
  142. /// <returns></returns>
  143. [ProducesDefaultResponseType]
  144. [HttpPost("get-group-list")]
  145. [ApiToken(Auth = "5", Name = "学校教师列表", RW = "R", Limit = false)]
  146. public async Task<IActionResult> GetGroupList(JsonElement json)
  147. {
  148. var client = _azureCosmos.GetCosmosClient();
  149. var (id, school) = HttpContext.GetApiTokenInfo();
  150. json.TryGetProperty("periodId", out JsonElement periodId);
  151. List<GroupListGrp> groupLists = new List<GroupListGrp>();
  152. //包含,学校的行政班,教学班
  153. json.TryGetProperty("type", out JsonElement _type);
  154. List<string> types = null;
  155. if (_type.ValueKind.Equals(JsonValueKind.Array))
  156. {
  157. types = _type.ToObject<List<string>>();
  158. }
  159. else if (_type.ValueKind.Equals(JsonValueKind.String))
  160. {
  161. types = new List<string> { $"{types}" };
  162. }
  163. if (types.IsEmpty() || types.Contains("class"))
  164. {
  165. StringBuilder classsql = new StringBuilder($"SELECT c.id,c.name,c.periodId ,c.year FROM c ");
  166. if (!string.IsNullOrEmpty($"{periodId}"))
  167. {
  168. classsql.Append($" where c.periodId='{periodId}' ");
  169. }
  170. await foreach (var item in client.GetContainer(Constant.TEAMModelOS, "School").GetItemQueryIterator<ClassInfo>(queryText: classsql.ToString(),
  171. requestOptions: new QueryRequestOptions() { PartitionKey = new PartitionKey($"Class-{school}") }))
  172. {
  173. HashSet<string> groupNames = new HashSet<string>();
  174. string gpsql = $"SELECT distinct c.groupId,c.groupName FROM c where c.classId='{item.id}'and c.groupName <>null";
  175. await foreach (var gp in client.GetContainer(Constant.TEAMModelOS, "Student").GetItemQueryIterator<Student>(queryText: gpsql,
  176. requestOptions: new QueryRequestOptions() { PartitionKey = new Azure.Cosmos.PartitionKey($"Base-{school}") }))
  177. {
  178. groupNames.Add(gp.groupName);
  179. }
  180. ///行政班(学生搜寻classId动态返回)class
  181. GroupListGrp group = new GroupListGrp
  182. {
  183. id = item.id,
  184. code = $"GroupList-{school}",
  185. name = item.name,
  186. periodId = item.periodId,
  187. scope = "school",
  188. school = $"{school}",
  189. type = "class",
  190. year = item.year,
  191. groupName = groupNames
  192. };
  193. groupLists.Add(group);
  194. }
  195. }
  196. if (types.IsEmpty() || types.Contains("teach"))
  197. {
  198. //教学班
  199. StringBuilder teachsql = new StringBuilder($" SELECT distinct value(c) FROM c where c.type='teach'");
  200. if (!string.IsNullOrEmpty($"{periodId}"))
  201. {
  202. teachsql.Append($" and c.periodId='{periodId}'");
  203. }
  204. await foreach (var item in client.GetContainer(Constant.TEAMModelOS, "School").
  205. GetItemQueryIterator<GroupList>(queryText: teachsql.ToString(), requestOptions: new QueryRequestOptions() { PartitionKey = new PartitionKey($"GroupList-{school}") }))
  206. {
  207. HashSet<string> groupName = item.members.Where(x => !string.IsNullOrEmpty(x.groupName)).Select(y => y.groupName).ToHashSet();
  208. groupLists.Add(new GroupListGrp(item, groupName));
  209. }
  210. }
  211. if (types.IsEmpty() || types.Contains("research"))
  212. {
  213. //教研组
  214. StringBuilder researchsql = new StringBuilder($"SELECT distinct value(c) FROM c where c.type='research'");
  215. await foreach (var item in client.GetContainer(Constant.TEAMModelOS, "School").
  216. GetItemQueryIterator<GroupList>(queryText: researchsql.ToString(), requestOptions: new QueryRequestOptions() { PartitionKey = new PartitionKey($"GroupList-{school}") }))
  217. {
  218. HashSet<string> groupName = item.members.Where(x => !string.IsNullOrEmpty(x.groupName)).Select(y => y.groupName).ToHashSet();
  219. groupLists.Add(new GroupListGrp(item, groupName));
  220. }
  221. }
  222. if (types.IsEmpty() || types.Contains("yxtrain"))
  223. {
  224. //研修名单
  225. StringBuilder yxtrainsql = new StringBuilder($"SELECT distinct value(c) FROM c where c.type='yxtrain'");
  226. await foreach (var item in client.GetContainer(Constant.TEAMModelOS, "School").
  227. GetItemQueryIterator<GroupList>(queryText: yxtrainsql.ToString(), requestOptions: new QueryRequestOptions() { PartitionKey = new PartitionKey($"GroupList-{school}") }))
  228. {
  229. HashSet<string> groupName = item.members.Where(x => !string.IsNullOrEmpty(x.groupName)).Select(y => y.groupName).ToHashSet();
  230. groupLists.Add(new GroupListGrp(item, groupName));
  231. }
  232. }
  233. return Ok(new
  234. {
  235. groupLists=groupLists.Select(x=>new { x.id,x.type,x.name,x.periodId,x.school,x.scope,x.year})
  236. });
  237. }
  238. [ProducesDefaultResponseType]
  239. [HttpPost("get-group-members")]
  240. [ApiToken(Auth = "6", Name = "获取名单详细信息和成员信息", RW = "R", Limit = false)]
  241. public async Task<IActionResult> GetGroupMembers(JsonElement json)
  242. {
  243. var client = _azureCosmos.GetCosmosClient();
  244. if (!json.TryGetProperty("ids", out JsonElement ids)) return BadRequest();
  245. var (id, school) = HttpContext.GetApiTokenInfo();
  246. List<string> listids = ids.ToObject<List<string>>();
  247. (List<RMember> members, List<RGroupList> groups) = await GroupListService.GetStutmdidListids(_coreAPIHttpService, client, _dingDing, listids, $"{school}");
  248. return Ok(new { groups = groups.Select(x => new { x.name, x.no, x.periodId, x.school, x.type, x.year, x.tcount, x.scount, x.leader, x.members, x.id }), members });
  249. }
  250. [ProducesDefaultResponseType]
  251. [HttpPost("get-course-list")]
  252. [ApiToken(Auth = "7", Name = "获取课程列表信息",RW ="R", Limit = false)]
  253. public async Task<IActionResult> GetCourseList(JsonElement json) {
  254. var client = _azureCosmos.GetCosmosClient();
  255. var (id, school) = HttpContext.GetApiTokenInfo();
  256. json.TryGetProperty("periodId", out JsonElement periodId);
  257. json.TryGetProperty("subjectId", out JsonElement subjectId);
  258. StringBuilder sql = new StringBuilder($"SELECT c.id,c.name,c.subject,c.period,c.scope,c.no,c.school FROM c where 1=1 ");
  259. if (!string.IsNullOrWhiteSpace($"{periodId}")) {
  260. sql.Append($" and c.period.id='{periodId}'");
  261. }
  262. if (!string.IsNullOrWhiteSpace($"{subjectId}"))
  263. {
  264. sql.Append($" and c.subject.id='{subjectId}'");
  265. }
  266. List<dynamic> courses = new List<dynamic>();
  267. await foreach (var item in client.GetContainer(Constant.TEAMModelOS, "School").
  268. GetItemQueryIterator<dynamic>(queryText: sql.ToString(), requestOptions: new QueryRequestOptions() { PartitionKey = new PartitionKey($"Course-{school}") }))
  269. {
  270. courses.Add(item);
  271. }
  272. return Ok(new { courses });
  273. }
  274. [ProducesDefaultResponseType]
  275. [HttpPost("get-course-info")]
  276. [ApiToken(Auth = "8", Name = "课程详细信息", RW = "R", Limit = false)]
  277. public async Task<IActionResult> GetCourseInfo(JsonElement json)
  278. {
  279. var (id, school) = HttpContext.GetApiTokenInfo();
  280. json.TryGetProperty("courseId", out JsonElement courseId);
  281. Azure.Response response = await _azureCosmos.GetCosmosClient().GetContainer(Constant.TEAMModelOS, "School")
  282. .ReadItemStreamAsync($"{courseId}", new PartitionKey($"Course-{school}"));
  283. if (response.Status == 200)
  284. {
  285. JsonDocument document= JsonDocument.Parse(response.Content);
  286. Course course= document.RootElement.Deserialize<Course>();
  287. return Ok(new { course.name,course.id, course.subject, course .period, course .scope, course.school, course .no, course .desc, course.schedule});
  288. }
  289. else {
  290. return Ok(new { error=1,msg="课程不存在!"});
  291. }
  292. }
  293. /// <summary>
  294. /// 获取物理教室列表
  295. /// </summary>
  296. /// <param name="json"></param>
  297. /// <returns></returns>
  298. [ProducesDefaultResponseType]
  299. [HttpPost("get-room-list")]
  300. [ApiToken(Auth = "9", Name = "获取物理教室列表", RW = "R", Limit = false)]
  301. public async Task<IActionResult> GetRoomList(JsonElement json)
  302. {
  303. var client = _azureCosmos.GetCosmosClient();
  304. var (id, school) = HttpContext.GetApiTokenInfo();
  305. StringBuilder sql = new StringBuilder($"select value(c) from c where 1=1 ");
  306. json.TryGetProperty("openType", out JsonElement openType);
  307. if (!string.IsNullOrWhiteSpace($"{openType}"))
  308. {
  309. sql.Append($" and c.openType='{openType}'");
  310. }
  311. List<Room> rooms = new List<Room>();
  312. await foreach (var item in client.GetContainer(Constant.TEAMModelOS, "School").GetItemQueryIterator<Room>(queryText: sql.ToString(),
  313. requestOptions: new QueryRequestOptions() { PartitionKey = new Azure.Cosmos.PartitionKey($"Room-{school}") }))
  314. {
  315. rooms.Add(item);
  316. }
  317. return Ok(new { rooms =rooms.Select(x=>new {x.id,x.name,x.x,x.y, x.openType,x.style,x.area,x.address,school=school}) });
  318. }
  319. /// <summary>
  320. /// 获取物理教室详细信息
  321. /// </summary>
  322. /// <param name="json"></param>
  323. /// <returns></returns>
  324. [ProducesDefaultResponseType]
  325. [HttpPost("get-room-info")]
  326. [ApiToken(Auth = "10", Name = "获取物理教室详细信息", RW = "R", Limit = false)]
  327. public async Task<IActionResult> GetRoomInfo(JsonElement json)
  328. {
  329. var (id, school) = HttpContext.GetApiTokenInfo();
  330. if (!json.TryGetProperty("roomId", out JsonElement roomId)) return BadRequest();
  331. Azure.Response response = await _azureCosmos.GetCosmosClient().GetContainer(Constant.TEAMModelOS, "School")
  332. .ReadItemStreamAsync($"{roomId}", new PartitionKey($"Room-{school}"));
  333. if (response.Status == 200)
  334. {
  335. JsonDocument document = JsonDocument.Parse(response.Content);
  336. Room room = document.RootElement.Deserialize<Room>();
  337. return Ok(new { room.id, room.name, room.x, room.y, room.openType, room.style, room.area,room.address, school = school });
  338. }
  339. else
  340. {
  341. return Ok(new { error = 1, msg = "教室不存在!" });
  342. }
  343. }
  344. }
  345. }