ScsYxptApis.cs 53 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945
  1. using Azure.Cosmos;
  2. using HTEXLib.COMM.Helpers;
  3. using Microsoft.Azure.Functions.Worker;
  4. using Microsoft.Azure.Functions.Worker.Http;
  5. using System;
  6. using System.Collections.Generic;
  7. using System.IO;
  8. using System.Linq;
  9. using System.Net;
  10. using System.Text;
  11. using System.Text.Json;
  12. using System.Threading.Tasks;
  13. using TEAMModelOS.SDK;
  14. using TEAMModelOS.SDK.DI;
  15. using TEAMModelOS.SDK.Extension;
  16. using TEAMModelOS.SDK.Models;
  17. namespace TEAMModelOS.FunctionV4.HttpTrigger
  18. {
  19. public class ScsYxptApis
  20. {
  21. private readonly AzureCosmosFactory _azureCosmos;
  22. private readonly DingDing _dingDing;
  23. private readonly AzureStorageFactory _azureStorage;
  24. private readonly AzureRedisFactory _azureRedis;
  25. private readonly ThirdApisService _thirdApisService;
  26. public static string Code { get; set; }
  27. public static Dictionary<string, object> parameterMap = null;
  28. public ScsYxptApis(AzureCosmosFactory azureCosmos, DingDing dingDing, AzureStorageFactory azureStorage, ThirdApisService thirdApisService
  29. , AzureRedisFactory azureRedis)
  30. {
  31. _azureCosmos = azureCosmos;
  32. _dingDing = dingDing;
  33. _azureStorage = azureStorage;
  34. _azureRedis = azureRedis;
  35. _thirdApisService = thirdApisService;
  36. }
  37. /// <summary>
  38. /// 5.3.1.1获取项目列表
  39. /// </summary>
  40. /// <param name="req"></param>
  41. /// <param name="log"></param>
  42. /// <returns></returns>
  43. [Function("GetProjectInfoByTrainComIDV2")]
  44. public async Task<HttpResponseData> GetProjectInfoByTrainComIDV2([HttpTrigger(AuthorizationLevel.Anonymous, "post", Route = null)] HttpRequestData req)
  45. {
  46. var response = req.CreateResponse(HttpStatusCode.OK);
  47. List<ScProject> projects = new List<ScProject>();
  48. string data = await new StreamReader(req.Body).ReadToEndAsync();
  49. JsonElement accessConfig = data.ToObject<JsonElement>().GetProperty("accessConfig");
  50. ScAccessConfig config = $"{accessConfig}".ToObject<ScAccessConfig>();
  51. string areaId = null;
  52. if (data.ToObject<JsonElement>().TryGetProperty("areaId", out JsonElement _areaId))
  53. {
  54. areaId = $"{_areaId}";
  55. }
  56. Code = "GetProjectInfoByTrainComID";
  57. parameterMap = new Dictionary<string, object>();
  58. parameterMap.Add("TrainComID", config.trainComID);
  59. ScsResult result = new ScsResult { code = Code, title = "5.3.1.1获取项目列表" };
  60. try
  61. {
  62. result = await _thirdApisService.Post(config.url, Code, config.passKey, config.privateKey, parameterMap);
  63. if (result.result)
  64. {
  65. projects = result.content.ToObject<List<ScProject>>();
  66. }
  67. else
  68. {
  69. }
  70. await response.WriteAsJsonAsync(new { data = projects.ToJsonString() });
  71. return response;
  72. }
  73. catch (Exception ex)
  74. {
  75. await _dingDing.SendBotMsg($"{Environment.GetEnvironmentVariable("Option:Location")},IES5.ScApisService:GetProjectInfoByTrainComID\n{ex.Message}{ex.StackTrace}\n{result.ToJsonString()}\n{data}", GroupNames.成都开发測試群組);
  76. await response.WriteAsJsonAsync(new { data = projects.ToJsonString() });
  77. return response;
  78. }
  79. }
  80. /// <summary>
  81. /// 5.3.1.1获取项目列表
  82. /// </summary>
  83. /// <param name="req"></param>
  84. /// <param name="log"></param>
  85. /// <returns></returns>
  86. [Function("GetProjectInfoByTrainComID")]
  87. public async Task<HttpResponseData> GetProjectInfoByTrainComID([HttpTrigger(AuthorizationLevel.Anonymous, "post", Route = null)] HttpRequestData req)
  88. {
  89. var response = req.CreateResponse(HttpStatusCode.OK);
  90. List<ScProject> projects = new List<ScProject>();
  91. string data = await new StreamReader(req.Body).ReadToEndAsync();
  92. JsonElement accessConfig = data.ToObject<JsonElement>().GetProperty("accessConfig");
  93. ScAccessConfig config = $"{accessConfig}".ToObject<ScAccessConfig>();
  94. string areaId = null;
  95. if (data.ToObject<JsonElement>().TryGetProperty("areaId", out JsonElement _areaId))
  96. {
  97. areaId = $"{_areaId}";
  98. }
  99. Code = "GetProjectInfoByTrainComID";
  100. parameterMap = new Dictionary<string, object>();
  101. parameterMap.Add("TrainComID", config.trainComID);
  102. ScsResult result = new ScsResult { code = Code, title = "5.3.1.1获取项目列表" };
  103. try
  104. {
  105. result = await _thirdApisService.Post(config.url, Code, config.passKey, config.privateKey, parameterMap);
  106. if (result.result)
  107. {
  108. projects = result.content.ToObject<List<ScProject>>();
  109. }
  110. else
  111. {
  112. }
  113. await response.WriteAsJsonAsync(new { data = projects.ToJsonString() });
  114. return response;
  115. }
  116. catch (Exception ex)
  117. {
  118. await _dingDing.SendBotMsg($"{Environment.GetEnvironmentVariable("Option:Location")},IES5.ScApisService:GetProjectInfoByTrainComID\n{ex.Message}{ex.StackTrace}\n{result.ToJsonString()}\n{data}", GroupNames.成都开发測試群組);
  119. await response.WriteAsJsonAsync(new { data = projects.ToJsonString() });
  120. return response;
  121. }
  122. }
  123. /// <summary>
  124. /// 5.3.1.18根据机构ID、项目ID、子项目ID返回学校列表
  125. /// </summary>
  126. /// <param name="req"></param>
  127. /// <param name="log"></param>
  128. /// <returns></returns>
  129. [Function("GetSchoolList")]
  130. public async Task<HttpResponseData> GetSchoolList([HttpTrigger(AuthorizationLevel.Anonymous, "post", Route = null)] HttpRequestData req)
  131. {
  132. var response = req.CreateResponse(HttpStatusCode.OK);
  133. List<ScSchool> scSchools = new List<ScSchool>();
  134. string data = await new StreamReader(req.Body).ReadToEndAsync();
  135. JsonElement accessConfig = data.ToObject<JsonElement>().GetProperty("accessConfig");
  136. string areaId = null;
  137. if (data.ToObject<JsonElement>().TryGetProperty("areaId", out JsonElement _areaId))
  138. {
  139. areaId = $"{_areaId}";
  140. }
  141. ScAccessConfig config = $"{accessConfig}".ToObject<ScAccessConfig>();
  142. Code = "GetSchoolList";
  143. parameterMap = new Dictionary<string, object>();
  144. parameterMap.Add("TrainComID", config.trainComID);
  145. List<ScsResult> results = new List<ScsResult>();
  146. try
  147. {
  148. if (config.p.IsNotEmpty())
  149. {
  150. foreach (var ps in config.p)
  151. {
  152. parameterMap["ProjectID"] = ps.pd;
  153. parameterMap["ProjectItemID"] = ps.pid;
  154. ScsResult result = new ScsResult { code = Code, title = " 5.3.1.18根据机构ID、项目ID、子项目ID返回学校列表" };
  155. result = await _thirdApisService.Post(config.url, Code, config.passKey, config.privateKey, parameterMap);
  156. if (result.result)
  157. {
  158. List<ScSchool> schools = result.content.ToObject<List<ScSchool>>();
  159. if (schools.IsNotEmpty())
  160. {
  161. schools.ForEach(x => { x.ProjectID = int.Parse(ps.pd); x.ProjectItemID = int.Parse(ps.pid); });
  162. scSchools.AddRange(schools);
  163. }
  164. }
  165. results.Add(result);
  166. }
  167. }
  168. await response.WriteAsJsonAsync(new { data = scSchools.ToJsonString() });
  169. return response;
  170. }
  171. catch (Exception ex)
  172. {
  173. await _dingDing.SendBotMsg($"{Environment.GetEnvironmentVariable("Option:Location")},IES5.ScApisService:GetSchoolList\n{ex.Message}{ex.StackTrace}\n{results.ToJsonString()}\n{data}", GroupNames.成都开发測試群組);
  174. await response.WriteAsJsonAsync(new { data = scSchools.ToJsonString() });
  175. return response;
  176. }
  177. }
  178. /// <summary>
  179. /// 5.3.1.2获取学员名单
  180. /// </summary>
  181. /// <param name="req"></param>
  182. /// <param name="log"></param>
  183. /// <returns></returns>
  184. [Function("GetTeachersListByProject")]
  185. public async Task<HttpResponseData> GetTeachersListByProject([HttpTrigger(AuthorizationLevel.Anonymous, "post", Route = null)] HttpRequestData req)
  186. {
  187. var response = req.CreateResponse(HttpStatusCode.OK);
  188. List<ScTeacher> scTeachers = new List<ScTeacher>();
  189. string data = await new StreamReader(req.Body).ReadToEndAsync();
  190. JsonElement accessConfig = data.ToObject<JsonElement>().GetProperty("accessConfig");
  191. ScAccessConfig config = $"{accessConfig}".ToObject<ScAccessConfig>();
  192. string areaId = null;
  193. if (data.ToObject<JsonElement>().TryGetProperty("areaId", out JsonElement _areaId))
  194. {
  195. areaId = $"{_areaId}";
  196. }
  197. Code = "GetTeachersListByProject";
  198. parameterMap = new Dictionary<string, object>();
  199. parameterMap.Add("TrainComID", config.trainComID);
  200. List<ScsResult> results = new List<ScsResult>();
  201. try
  202. {
  203. if (config.p.IsNotEmpty())
  204. {
  205. foreach (var ps in config.p)
  206. {
  207. parameterMap["ProjectID"] = ps.pd;
  208. parameterMap["ProjectItemID"] = ps.pid;
  209. ScsResult result = new ScsResult { code = Code, title = "5.3.1.2获取学员名单" };
  210. result = await _thirdApisService.Post(config.url, Code, config.passKey, config.privateKey, parameterMap);
  211. if (result.result)
  212. {
  213. List<ScTeacher> teachers = result.content.ToObject<List<ScTeacher>>();
  214. if (teachers.IsNotEmpty())
  215. {
  216. scTeachers.AddRange(teachers);
  217. }
  218. }
  219. results.Add(result);
  220. }
  221. }
  222. await response.WriteAsJsonAsync(new { data = scTeachers.ToJsonString() });
  223. return response;
  224. }
  225. catch (Exception ex)
  226. {
  227. await _dingDing.SendBotMsg($"{Environment.GetEnvironmentVariable("Option:Location")},IES5.ScApisService:GetTeachersListByProject\n{ex.Message}{ex.StackTrace}\n{results.ToJsonString()}\n{data}", GroupNames.成都开发測試群組);
  228. await response.WriteAsJsonAsync(new { data = scTeachers.ToJsonString() });
  229. return response;
  230. }
  231. }
  232. /// <summary>
  233. /// 5.3.1.20获取学校设置的可选能力点
  234. /// </summary>
  235. /// <param name="req"></param>
  236. /// <param name="log"></param>
  237. /// <returns></returns>
  238. [Function("GetSchoolDiagnosis")]
  239. public async Task<HttpResponseData> GetSchoolDiagnosis([HttpTrigger(AuthorizationLevel.Anonymous, "post", Route = null)] HttpRequestData req)
  240. {
  241. var response = req.CreateResponse(HttpStatusCode.OK);
  242. List<ScsProjectDiagnosis> projects = new List<ScsProjectDiagnosis>();
  243. string data = await new StreamReader(req.Body).ReadToEndAsync();
  244. JsonElement accessConfig = data.ToObject<JsonElement>().GetProperty("accessConfig");
  245. JsonElement schoolCode = data.ToObject<JsonElement>().GetProperty("schoolCode");
  246. string areaId = null;
  247. if(data.ToObject<JsonElement>().TryGetProperty("areaId", out JsonElement _areaId))
  248. {
  249. areaId = $"{_areaId}";
  250. }
  251. ScAccessConfig config = $"{accessConfig}".ToObject<ScAccessConfig>();
  252. Code = "GetSchoolDiagnosis";
  253. parameterMap = new Dictionary<string, object>();
  254. parameterMap.Add("TrainComID", config.trainComID);
  255. List<ScsResult> results = new List<ScsResult>();
  256. try
  257. {
  258. if (config.p.IsNotEmpty())
  259. {
  260. foreach (var ps in config.p)
  261. {
  262. parameterMap["ProjectID"] = ps.pd;
  263. parameterMap["ProjectItemID"] = ps.pid;
  264. parameterMap["SchoolID"] = $"{schoolCode}";
  265. parameterMap["School"] = $"{schoolCode}";
  266. ScsResult result = new ScsResult { code = Code, title = " 5.3.1.20获取学校设置的可选能力点" };
  267. result = await _thirdApisService.Post(config.url, Code, config.passKey, config.privateKey, parameterMap);
  268. if (result.result)
  269. {
  270. List<ScPDiagnosis> diagnoses = result.content.ToObject<List<ScPDiagnosis>>();
  271. if (diagnoses.IsNotEmpty())
  272. {
  273. projects.Add(new ScsProjectDiagnosis { project = ps, diagnoses = diagnoses, });
  274. await _azureStorage.SaveOrUpdate<ScProjectDiagnosis>(new ScProjectDiagnosis {schoolCode=$"{schoolCode}",areaId= areaId,
  275. ProjectID=int.Parse(ps.pd),
  276. ProjectItemID=int.Parse(ps.pid),
  277. RowKey = $"{ps.pid}-{schoolCode}", PartitionKey = "ScSchoolDiagnosis", abilityNos = diagnoses.ToJsonString() });
  278. }
  279. }
  280. else
  281. {
  282. List<ScProjectDiagnosis> teacherDiagnoses = await _azureStorage.FindListByDict<ScProjectDiagnosis>(new Dictionary<string, object> { { "PartitionKey", "ScSchoolDiagnosis" }, { "RowKey", $"{ps.pid}-{schoolCode}" } });
  283. if (teacherDiagnoses.IsNotEmpty())
  284. {
  285. projects.Add(new ScsProjectDiagnosis { project = ps, diagnoses = teacherDiagnoses[0].abilityNos.ToObject<List<ScPDiagnosis>>() });
  286. }
  287. }
  288. results.Add(result);
  289. }
  290. }
  291. await response.WriteAsJsonAsync(new { data = projects.ToJsonString() });
  292. return response;
  293. }
  294. catch (Exception ex)
  295. {
  296. //await _dingDing.SendBotMsg($"{Environment.GetEnvironmentVariable("Option:Location")},IES5.ScApisService:GetSchoolDiagnosis\n{ex.Message}{ex.StackTrace}\n{results.ToJsonString()}\n{data}", GroupNames.成都开发測試群組);
  297. if (config.p.IsNotEmpty())
  298. {
  299. foreach (var ps in config.p)
  300. {
  301. List<ScProjectDiagnosis> teacherDiagnoses = await _azureStorage.FindListByDict<ScProjectDiagnosis>(new Dictionary<string, object> { { "PartitionKey", "ScSchoolDiagnosis" }, { "RowKey", $"{ps.pid}-{schoolCode}" } });
  302. if (teacherDiagnoses.IsNotEmpty())
  303. {
  304. projects.Add(new ScsProjectDiagnosis { project = ps, diagnoses = teacherDiagnoses[0].abilityNos.ToObject<List<ScPDiagnosis>>() });
  305. }
  306. }
  307. }
  308. await response.WriteAsJsonAsync(new { data = projects.ToJsonString() });
  309. return response;
  310. }
  311. }
  312. /// <summary>
  313. /// 5.3.1.19获取项目设置的可选能力点
  314. /// </summary>
  315. /// <param name="req"></param>
  316. /// <param name="log"></param>
  317. /// <returns></returns>
  318. [Function("GetProjectDiagnosis")]
  319. public async Task<HttpResponseData> GetProjectDiagnosis([HttpTrigger(AuthorizationLevel.Anonymous, "post", Route = null)] HttpRequestData req)
  320. {
  321. var response = req.CreateResponse(HttpStatusCode.OK);
  322. List<ScsProjectDiagnosis> projects = new List<ScsProjectDiagnosis>();
  323. string data = await new StreamReader(req.Body).ReadToEndAsync();
  324. JsonElement accessConfig = data.ToObject<JsonElement>().GetProperty("accessConfig");
  325. string areaId = null;
  326. if (data.ToObject<JsonElement>().TryGetProperty("areaId", out JsonElement _areaId))
  327. {
  328. areaId = $"{_areaId}";
  329. }
  330. ScAccessConfig config = $"{accessConfig}".ToObject<ScAccessConfig>();
  331. Code = "GetProjectDiagnosis";
  332. parameterMap = new Dictionary<string, object>();
  333. parameterMap.Add("TrainComID", config.trainComID);
  334. List<ScsResult> results = new List<ScsResult>();
  335. try
  336. {
  337. if (config.p.IsNotEmpty())
  338. {
  339. foreach (var ps in config.p)
  340. {
  341. parameterMap["ProjectID"] = ps.pd;
  342. parameterMap["ProjectItemID"] = ps.pid;
  343. ScsResult result = new ScsResult { code = Code, title = "5.3.1.19获取项目设置的可选能力点" };
  344. result = await _thirdApisService.Post(config.url, Code, config.passKey, config.privateKey, parameterMap);
  345. if (result.result)
  346. {
  347. List<ScPDiagnosis> diagnoses = result.content.ToObject<List<ScPDiagnosis>>();
  348. if (diagnoses.IsNotEmpty())
  349. {
  350. projects.Add(new ScsProjectDiagnosis { project = ps, diagnoses = diagnoses });
  351. await _azureStorage.SaveOrUpdate<ScProjectDiagnosis>(new ScProjectDiagnosis { areaId=areaId, RowKey = $"{ps.pid}", PartitionKey = "ScProjectDiagnosis", abilityNos = diagnoses.ToJsonString() });
  352. }
  353. }
  354. else
  355. {
  356. List<ScProjectDiagnosis> teacherDiagnoses = await _azureStorage.FindListByDict<ScProjectDiagnosis>(new Dictionary<string, object> { { "PartitionKey", "ScProjectDiagnosis" }, { "RowKey", $"{ps.pid}" } });
  357. if (teacherDiagnoses.IsNotEmpty())
  358. {
  359. projects.Add(new ScsProjectDiagnosis { project = ps, diagnoses = teacherDiagnoses[0].abilityNos.ToObject<List<ScPDiagnosis>>() });
  360. }
  361. }
  362. results.Add(result);
  363. }
  364. }
  365. await response.WriteAsJsonAsync(new { data = projects.ToJsonString() });
  366. return response;
  367. }
  368. catch (Exception ex)
  369. {
  370. if (config.p.IsNotEmpty())
  371. {
  372. foreach (var ps in config.p)
  373. {
  374. //await _dingDing.SendBotMsg($"{Environment.GetEnvironmentVariable("Option:Location")},IES5.ScApisService:GetProjectDiagnosis\n{ex.Message}{ex.StackTrace}\n{results.ToJsonString()}\n{data}", GroupNames.成都开发測試群組);
  375. List<ScProjectDiagnosis> teacherDiagnoses = await _azureStorage.FindListByDict<ScProjectDiagnosis>(new Dictionary<string, object> { { "PartitionKey", "ScProjectDiagnosis" }, { "RowKey", $"{ps.pid}" } });
  376. if (teacherDiagnoses.IsNotEmpty())
  377. {
  378. projects.Add(new ScsProjectDiagnosis { project = ps, diagnoses = teacherDiagnoses[0].abilityNos.ToObject<List<ScPDiagnosis>>() });
  379. }
  380. }
  381. }
  382. await response.WriteAsJsonAsync(new { data = projects.ToJsonString() });
  383. return response;
  384. }
  385. }
  386. /// <summary>
  387. /// 5.3.1.3通过项目编号获取学员测评能力项V2
  388. /// </summary>
  389. /// <param name="req"></param>
  390. /// <param name="log"></param>
  391. /// <returns></returns>
  392. [Function("GetDiagnosisListByProject_V2")]
  393. public async Task<HttpResponseData> GetDiagnosisListByProject_V2([HttpTrigger(AuthorizationLevel.Anonymous, "post", Route = null)] HttpRequestData req)
  394. {
  395. var response = req.CreateResponse(HttpStatusCode.OK);
  396. List<string> abilityNos = new List<string>();
  397. string data = await new StreamReader(req.Body).ReadToEndAsync();
  398. JsonElement accessConfig = data.ToObject<JsonElement>().GetProperty("accessConfig");
  399. string areaId = null;
  400. if (data.ToObject<JsonElement>().TryGetProperty("areaId", out JsonElement _areaId))
  401. {
  402. areaId = $"{_areaId}";
  403. }
  404. JsonElement pxid = data.ToObject<JsonElement>().GetProperty("pxid");
  405. JsonElement schoolCode = data.ToObject<JsonElement>().GetProperty("schoolCode");
  406. ScAccessConfig config = $"{accessConfig}".ToObject<ScAccessConfig>();
  407. Code = "GetDiagnosisListByProject_V2";
  408. parameterMap = new Dictionary<string, object>();
  409. parameterMap.Add("TrainComID", config.trainComID);
  410. parameterMap.Add("PXID", pxid);
  411. ScsResult result = new ScsResult { code = Code, title = "5.3.1.3通过项目编号获取学员测评能力项V2" };
  412. try
  413. {
  414. result = await _thirdApisService.Post(config.url, Code, config.passKey, config.privateKey, parameterMap);
  415. if (result.result)
  416. {
  417. List<ScDiagnosis> diagnoses = result.content.ToObject<List<ScDiagnosis>>();
  418. if (diagnoses != null)
  419. {
  420. abilityNos = diagnoses.Select(x => x.DiagnosisDicNum).ToList();
  421. }
  422. if (abilityNos.IsNotEmpty())
  423. {
  424. await _azureStorage.SaveOrUpdate<ScTeacherDiagnosis>(new ScTeacherDiagnosis {areaId = areaId,schoolCode=$"{schoolCode}", RowKey = $"{pxid}", PartitionKey = "ScTeacherDiagnosis", abilityNos = abilityNos.ToJsonString() });
  425. }
  426. }
  427. else
  428. {
  429. List<ScTeacherDiagnosis> teacherDiagnoses = await _azureStorage.FindListByDict<ScTeacherDiagnosis>(new Dictionary<string, object> { { "PartitionKey", "ScTeacherDiagnosis" }, { "RowKey", $"{pxid}" } });
  430. if (teacherDiagnoses.IsNotEmpty())
  431. {
  432. abilityNos = teacherDiagnoses[0].abilityNos.ToObject<List<string>>();
  433. }
  434. }
  435. await response.WriteAsJsonAsync(new { data = abilityNos.ToJsonString() });
  436. return response;
  437. }
  438. catch (Exception ex)
  439. {
  440. //await _dingDing.SendBotMsg($"{Environment.GetEnvironmentVariable("Option:Location")},IES5.ScApisService:getDiagnosisListByProject_V2\n{ex.Message}{ex.StackTrace}\n{result.ToJsonString()}\n{data}", GroupNames.成都开发測試群組);
  441. List<ScTeacherDiagnosis> teacherDiagnoses = await _azureStorage.FindListByDict<ScTeacherDiagnosis>(new Dictionary<string, object> { { "PartitionKey", "ScTeacherDiagnosis" }, { "RowKey", $"{pxid}" } });
  442. if (teacherDiagnoses.IsNotEmpty())
  443. {
  444. abilityNos = teacherDiagnoses[0].abilityNos.ToObject<List<string>>();
  445. }
  446. await response.WriteAsJsonAsync(new { data = abilityNos.ToJsonString() });
  447. return response;
  448. }
  449. }
  450. /// <summary>
  451. /// 5.3.1.11获取跳转学员信息,用于sso单点,后端验证。
  452. /// </summary>
  453. /// <param name="req"></param>
  454. /// <param name="log"></param>
  455. /// <returns></returns>
  456. [Function("GetSingleTeacherByProject")]
  457. public async Task<HttpResponseData> GetSingleTeacherByProject([HttpTrigger(AuthorizationLevel.Anonymous, "post", Route = null)] HttpRequestData req)
  458. {
  459. var response = req.CreateResponse(HttpStatusCode.OK);
  460. string teacher = null;
  461. string data = await new StreamReader(req.Body).ReadToEndAsync();
  462. JsonElement accessConfig = data.ToObject<JsonElement>().GetProperty("accessConfig");
  463. JsonElement pxid = data.ToObject<JsonElement>().GetProperty("pxid");
  464. JsonElement tid = data.ToObject<JsonElement>().GetProperty("tid");
  465. ScAccessConfig config = $"{accessConfig}".ToObject<ScAccessConfig>();
  466. string areaId = null;
  467. if (data.ToObject<JsonElement>().TryGetProperty("areaId", out JsonElement _areaId))
  468. {
  469. areaId = $"{_areaId}";
  470. }
  471. Code = "GetSingleTeacherByProject";
  472. parameterMap = new Dictionary<string, object>();
  473. parameterMap.Add("TrainComID", config.trainComID);
  474. parameterMap.Add("Pxid", $"{pxid}");
  475. parameterMap.Add("Tid", $"{tid}");
  476. ScsResult result = new ScsResult { code = Code, title = "5.3.1.11获取跳转学员信息,用于sso单点,后端验证。" };
  477. try
  478. {
  479. ///{“result”:true,”reason”:null,”content”:”{“PXID”:””,”TID”:””,”TeacherName”:””,”ProjectTitle”:””,”ProjectItemTitle”:””,”CityName”:””,
  480. ///”DisName”:””,”SchoolName”:””,”Sex”:””,”PXXK”:””,”PXXD”:””,”TeacherXK”:””,”TeacherXD”:””,”Email”:””}”,”pagecount”:1}
  481. result = await _thirdApisService.Post(config.url, Code, config.passKey, config.privateKey, parameterMap);
  482. if (result.result)
  483. {
  484. teacher = result.content;
  485. }
  486. await response.WriteAsJsonAsync(new { data = teacher });
  487. return response;
  488. }
  489. catch (Exception ex)
  490. {
  491. //await _dingDing.SendBotMsg($"{Environment.GetEnvironmentVariable("Option:Location")},IES5.ScApisService:GetSingleTeacherByProject\n{ex.Message}{ex.StackTrace}\n{result.ToJsonString()}\n{data}", GroupNames.成都开发測試群組);
  492. await response.WriteAsJsonAsync(new { data = teacher });
  493. return response;
  494. }
  495. }
  496. /// <summary>
  497. /// 数据推送接口
  498. /// </summary>
  499. /// <param name="req"></param>
  500. /// <param name="log"></param>
  501. /// <returns></returns>
  502. [Function("SchoolDataPush")]
  503. public async Task<HttpResponseData> SchoolDataPush([HttpTrigger(AuthorizationLevel.Anonymous, "post", Route = null)] HttpRequestData req)
  504. {
  505. var response = req.CreateResponse(HttpStatusCode.OK);
  506. var client = _azureCosmos.GetCosmosClient();
  507. string data = await new StreamReader(req.Body).ReadToEndAsync();
  508. JsonElement accessConfig = data.ToObject<JsonElement>().GetProperty("accessConfig");
  509. ScAccessConfig config = $"{accessConfig}".ToObject<ScAccessConfig>();
  510. JsonElement school = data.ToObject<JsonElement>().GetProperty("school");
  511. List<string> pushTeachers = data.ToObject<JsonElement>().GetProperty("pushTeachers").ToObject<List<string>>();
  512. StringBuilder queryText = new StringBuilder($"SELECT distinct value(c) FROM c where c.type='yxtrain'");
  513. List<GroupList> yxtrain = new List<GroupList>();
  514. await foreach (var item in _azureCosmos.GetCosmosClient().GetContainer(Constant.TEAMModelOS, "School").GetItemQueryIterator<GroupList>(queryText: queryText.ToString(),
  515. requestOptions: new QueryRequestOptions() { PartitionKey = new Azure.Cosmos.PartitionKey($"GroupList-{school}") }))
  516. {
  517. yxtrain.Add(item);
  518. }
  519. List<TeacherTrain> trains = new List<TeacherTrain>();
  520. var members = yxtrain.SelectMany(x => x.members).ToList();
  521. //指定推送一部分的教师
  522. if (pushTeachers.IsNotEmpty()) {
  523. members= members.FindAll(x => pushTeachers.Contains(x.id));
  524. }
  525. if (members.IsNotEmpty())
  526. {
  527. queryText = new StringBuilder($"SELECT distinct value(c) FROM c where " +
  528. $"and c.id in ({string.Join(",", members.Select(x => $"'{x.id}'"))}) ");
  529. await foreach (var item in _azureCosmos.GetCosmosClient().GetContainer(Constant.TEAMModelOS, "Teacher").GetItemQueryIterator<TeacherTrain>(queryText: queryText.ToString(),
  530. requestOptions: new QueryRequestOptions() { PartitionKey = new Azure.Cosmos.PartitionKey($"TeacherTrain-{school}") }))
  531. {
  532. trains.Add(item);
  533. }
  534. }
  535. //string sql = $" SELECT value(c) FROM c join a in c.binds where ARRAY_LENGTH(c.binds)>0 and a.type='{config.config}' ";
  536. //List<Teacher> teachers = new List<Teacher>();
  537. //await foreach (var item in _azureCosmos.GetCosmosClient().GetContainer(Constant.TEAMModelOS, "Teacher").GetItemQueryIterator<Teacher>(queryText: sql,
  538. // requestOptions: new QueryRequestOptions() { PartitionKey = new PartitionKey($"Base") }))
  539. //{
  540. // teachers.Add(item);
  541. //}
  542. List<ScTeacher> scTeachers= await _azureStorage.FindListByDict<ScTeacher>(new Dictionary<string, object> { { "PartitionKey", "ScTeacher" },{ "schoolCode",$"{school}" } });
  543. List<ScTeacherDiagnosis> scTeacherDiagnoses = await _azureStorage.FindListByDict<ScTeacherDiagnosis>(new Dictionary<string, object> { { "PartitionKey", "ScTeacherDiagnosis" }, { "schoolCode", $"{school}" } });
  544. List<KeyValuePair<TeacherTrain, string>> trainsNO = new List<KeyValuePair<TeacherTrain, string>>();
  545. List<PushFail> fails = new List<PushFail>();
  546. int pages = (trains.Count + 19) / 20; //pages = (total + max -1) / max;
  547. for (int i = 0; i < pages; i++) {
  548. List<TeacherTrain> lists = trains.Skip((i) * 20).Take(20).ToList();
  549. //5.3.1.12学员培训基本情况批量回写-UpdateTeacherListSituation
  550. List<TeacherTrain> trains53112OK = new List<TeacherTrain>();
  551. ScsResult UpdateTeacherListSituation = null;
  552. Dictionary<string, object> parameterContent53112 = new Dictionary<string, object>();
  553. List<Dictionary<string, object>> list53112 = new List<Dictionary<string, object>>();
  554. parameterContent53112.Add("TrainComID", config.trainComID);
  555. parameterContent53112.Add("List", list53112);
  556. //5.3.1.13学员能力点测评结果批量回写-UpdateTeacherListDiagnosis 300条限制
  557. List<TeacherTrain> trains53113OK = new List<TeacherTrain>();
  558. ScsResult UpdateTeacherListDiagnosis = null;
  559. Dictionary<string, object> parameterContent53113 = new Dictionary<string, object>();
  560. List<Dictionary<string, object>> list53113 = new List<Dictionary<string, object>>();
  561. parameterContent53113.Add("TrainComID", config.trainComID);
  562. parameterContent53113.Add("List", list53113);
  563. //5.3.1.17学员课堂实录批量回写-UploadKTSLList 300条限制
  564. List<TeacherTrain> trains53117OK = new List<TeacherTrain>();
  565. ScsResult UploadKTSLList = null;
  566. Dictionary<string, object> parameterContent53117 = new Dictionary<string, object>();
  567. List<Dictionary<string, object>> list53117 = new List<Dictionary<string, object>>();
  568. parameterContent53117.Add("TrainComID", config.trainComID);
  569. parameterContent53117.Add("List", list53117);
  570. //5.3.1.22学员校本教研PDF(每人可以返回多条)批量回写-UploadSBTARPDFListV2 100条限制
  571. List<TeacherTrain> trains53122OK = new List<TeacherTrain>();
  572. ScsResult UploadSBTARPDFListV2 = null;
  573. Dictionary<string, object> parameterContent53122 = new Dictionary<string, object>();
  574. List<Dictionary<string, object>> list53122 = new List<Dictionary<string, object>>();
  575. parameterContent53122.Add("TrainComID", config.trainComID);
  576. parameterContent53122.Add("List", list53122);
  577. //装载数据
  578. foreach (var x in lists) {
  579. List<KeyValuePair<string, string>> msgs = new List<KeyValuePair<string, string>>();
  580. List<ScTeacher> teacher = scTeachers.FindAll(t => t.tmdid.Equals(x.id));
  581. foreach (var t in teacher)
  582. {
  583. ScTeacherDiagnosis diagnosis = scTeacherDiagnoses.Find(x => x.RowKey.Equals(t.PXID));
  584. (int t53112OK, List<KeyValuePair<string, string>> msgs53112) = check53112(x, msgs);
  585. (int t53113OK, List<KeyValuePair<string, string>> msgs53113, List<AbilitySub> abilitySubs) = await check53113(x, diagnosis, msgs);
  586. (int t53117OK, List<KeyValuePair<string, string>> msgs53117) = check53117(x, msgs);
  587. (int t53122OK, List<KeyValuePair<string, string>> msgs53122) = check53122(x, msgs);
  588. //5.3.1.12学员培训基本情况批量回写-UpdateTeacherListSituation
  589. if (t53112OK == 1)
  590. {
  591. Dictionary<string, object> parameterMapData = new Dictionary<string, object>();
  592. parameterMapData.Add("PXID", $"{t.PXID}");
  593. parameterMapData.Add("TID", $"{t.TID}");
  594. parameterMapData.Add("TeacherName", $"{t.TeacherName}");
  595. parameterMapData.Add("CourseHour", $"{x.totalTime}");
  596. parameterMapData.Add("ResearchText", $"{x.summary}");
  597. /// <summary>
  598. ///省上标准 最终结果 0未认定,1合格,2优秀,3不合格,4其他
  599. ///系统标准 -2 其他 -1 未认定,0不合格,1合格,2优秀
  600. /// </summary>
  601. string ComPassed = "0";
  602. switch (x.finalScore)
  603. {
  604. case -2:
  605. ComPassed = "4";
  606. break;
  607. case -1:
  608. ComPassed = "0";
  609. break;
  610. case 0:
  611. ComPassed = "3";
  612. break;
  613. case 1:
  614. ComPassed = "1";
  615. break;
  616. case 2:
  617. ComPassed = "2";
  618. break;
  619. default:
  620. ComPassed = "4";
  621. break;
  622. }
  623. parameterMapData.Add("ComPassed", ComPassed);//0、未认定 1、合格 2、优秀 3、不合格 4、其他
  624. list53112.Add(parameterMapData);
  625. }
  626. else
  627. {
  628. fails.Add(new PushFail { tmdid = t.tmdid, name = t.TeacherName, msgs = msgs53112 });
  629. }
  630. //5.3.1.13学员能力点测评结果批量回写-UpdateTeacherListDiagnosis
  631. if (t53113OK == 1)
  632. {
  633. x.currency.teacherAilities.ForEach(a => {
  634. Dictionary<string, object> parameterMapData = new Dictionary<string, object>();
  635. parameterMapData.Add("PXID", $"{t.PXID}");
  636. parameterMapData.Add("TID", $"{t.TID}");
  637. parameterMapData.Add("DiagnosisNum", $"{a.no}");
  638. //0"未认定", 1"合格", 2"优秀", 3"不合格"
  639. //系统 -1 未认定,0 不合格,1 合格,2 优秀
  640. string zpscore = "0";
  641. switch (a.zpscore)
  642. {
  643. case -1:
  644. zpscore = "0";
  645. break;
  646. case 0:
  647. zpscore = "3";
  648. break;
  649. case 1:
  650. zpscore = "1";
  651. break;
  652. case 2:
  653. zpscore = "2";
  654. break;
  655. default:
  656. zpscore = "0";
  657. break;
  658. }
  659. string hpscore = "0";
  660. switch (a.hpscore)
  661. {
  662. case -1:
  663. hpscore = "0";
  664. break;
  665. case 0:
  666. hpscore = "3";
  667. break;
  668. case 1:
  669. hpscore = "1";
  670. break;
  671. case 2:
  672. hpscore = "2";
  673. break;
  674. default:
  675. hpscore = "0";
  676. break;
  677. }
  678. string xzpresult = "0";
  679. switch (a.xzscore)
  680. {
  681. case -1:
  682. xzpresult = "0";
  683. break;
  684. case 0:
  685. xzpresult = "3";
  686. break;
  687. case 1:
  688. xzpresult = "1";
  689. break;
  690. case 2:
  691. xzpresult = "2";
  692. break;
  693. default:
  694. xzpresult = "0";
  695. break;
  696. }
  697. parameterMapData.Add("zpresult", zpscore);
  698. parameterMapData.Add("hpresult", hpscore);
  699. parameterMapData.Add("xzpresult", xzpresult);
  700. List<Dictionary<string, object>> pfiles = new List<Dictionary<string, object>>();
  701. parameterMapData.Add("pfiles", pfiles);
  702. AbilitySub abilitySub = abilitySubs.Find(sub => sub.id.Equals(a.id));
  703. if (abilitySub != null)
  704. {
  705. abilitySub.uploads.ForEach(upload => {
  706. upload.urls.ForEach(url => {
  707. Dictionary<string, object> pfileMap = new Dictionary<string, object>();
  708. pfileMap.Add("url", url.url);
  709. pfileMap.Add("fileName", url.name);
  710. pfileMap.Add("fileSize", url.size);
  711. pfileMap.Add("md5", url.hash);
  712. string fileext = url.url.Substring(url.url.LastIndexOf(".") > 0 ? url.url.LastIndexOf(".") + 1 : 0);
  713. pfileMap.Add("fileType", fileext);
  714. pfiles.Add(pfileMap);
  715. });
  716. });
  717. }
  718. list53113.Add(parameterMapData);
  719. });
  720. }
  721. else
  722. {
  723. fails.Add(new PushFail { tmdid = t.tmdid, name = t.TeacherName, msgs = msgs53113 });
  724. }
  725. //5.3.1.17学员课堂实录批量回写-UploadKTSLList
  726. if (t53117OK == 1)
  727. {
  728. x.teacherClasses.ForEach(clss =>
  729. {
  730. Dictionary<string, object> parameterMapData = new Dictionary<string, object>();
  731. parameterMapData.Add("PXID", $"{t.PXID}");
  732. parameterMapData.Add("TID", $"{t.TID}");
  733. parameterMapData.Add("url", clss.url);//添加访问授权
  734. parameterMapData.Add("url2", clss.url);
  735. parameterMapData.Add("fileName", clss.name);
  736. parameterMapData.Add("fileSize", clss.size);
  737. parameterMapData.Add("md5", clss.hash);
  738. string fileext = clss.url.Substring(clss.url.LastIndexOf(".") > 0 ? clss.url.LastIndexOf(".") + 1 : 0);
  739. parameterMapData.Add("fileType", fileext);
  740. list53117.Add(parameterMapData);
  741. });
  742. }
  743. else
  744. {
  745. fails.Add(new PushFail { tmdid = t.tmdid, name = t.TeacherName, msgs = msgs53117 });
  746. }
  747. //5.3.1.22学员校本教研PDF(每人可以返回多条)批量回写-UploadSBTARPDFListV2
  748. if (t53122OK == 1)
  749. {
  750. Dictionary<string, object> parameterMapData = new Dictionary<string, object>();
  751. parameterMapData.Add("PXID", $"{t.PXID}");
  752. parameterMapData.Add("TID", $"{t.TID}");
  753. List<Dictionary<string, object>> files = new List<Dictionary<string, object>>();
  754. x.offlineRecords.ForEach(record => {
  755. Dictionary<string, object> fileMap = new Dictionary<string, object>();
  756. fileMap.Add("url", record.url);
  757. fileMap.Add("fileName", record.name);
  758. fileMap.Add("fileSize", record.size);
  759. fileMap.Add("md5", record.hash);
  760. string fileext = record.url.Substring(record.url.LastIndexOf(".") > 0 ? record.url.LastIndexOf(".") + 1 : 0);
  761. fileMap.Add("fileType", fileext);
  762. files.Add(fileMap);
  763. });
  764. parameterMapData.Add("files", files);
  765. list53122.Add(parameterMapData);
  766. }
  767. else
  768. {
  769. fails.Add(new PushFail { tmdid = t.tmdid, name = t.TeacherName, msgs = msgs53122 });
  770. }
  771. }
  772. }
  773. //推送数据
  774. UpdateTeacherListSituation = await _thirdApisService.Post(config.url, Code, config.passKey, config.privateKey, parameterContent53112);
  775. UpdateTeacherListSituation.code = "UpdateTeacherListSituation";
  776. UpdateTeacherListSituation.title = "5.3.1.12学员培训基本情况批量回写";
  777. UpdateTeacherListDiagnosis = await _thirdApisService.Post(config.url, Code, config.passKey, config.privateKey, parameterContent53113);
  778. UpdateTeacherListDiagnosis.code = "UpdateTeacherListDiagnosis";
  779. UpdateTeacherListDiagnosis.title = "5.3.1.13学员能力点测评结果批量回写";
  780. UploadKTSLList = await _thirdApisService.Post(config.url, Code, config.passKey, config.privateKey, parameterContent53117);
  781. UploadKTSLList.code = "UploadKTSLList";
  782. UploadKTSLList.title = "5.3.1.17学员课堂实录批量回写";
  783. UploadSBTARPDFListV2 = await _thirdApisService.Post(config.url, Code, config.passKey, config.privateKey, parameterContent53122);
  784. UploadSBTARPDFListV2.code = "UploadSBTARPDFListV2";
  785. UploadSBTARPDFListV2.title = "5.3.1.22学员校本教研PDF(每人可以返回多条)批量回写";
  786. }
  787. await response.WriteAsJsonAsync(new { });
  788. return response;
  789. }
  790. //5.3.1.22学员校本教研PDF(每人可以返回多条)批量回写-UploadSBTARPDFListV2
  791. public (int t53122OK, List<KeyValuePair<string, string>> msgs) check53122(TeacherTrain teacherTrain, List<KeyValuePair<string, string>> msgs) {
  792. int t53122OK = 1;
  793. if (teacherTrain.offlineRecords.Count<= 0)
  794. {
  795. msgs.Add(new KeyValuePair<string, string>("offlineRecord-count", $"文件个数为0"));
  796. }
  797. teacherTrain.offlineRecords.ForEach(x => {
  798. if (string.IsNullOrEmpty(x.url)) {
  799. msgs.Add(new KeyValuePair<string, string>("offlineRecord-url", $"链接为空"));
  800. }
  801. if (x.size<=0)
  802. {
  803. msgs.Add(new KeyValuePair<string, string>("offlineRecord-size", $"文件大小"));
  804. }
  805. });
  806. return (t53122OK, msgs);
  807. }
  808. //5.3.1.17学员课堂实录批量回写-UploadKTSLList
  809. public (int t53117OK, List<KeyValuePair<string, string>> msgs) check53117(TeacherTrain teacherTrain, List<KeyValuePair<string, string>> msgs) {
  810. //校验 基本情况是否满足
  811. int t53117OK = 1;
  812. if (teacherTrain.classTime <= 0)
  813. {
  814. msgs.Add(new KeyValuePair<string, string>("classTime", $"未获得学时:{teacherTrain.classTime}"));
  815. t53117OK = 0;
  816. }
  817. if (teacherTrain.teacherClasses.Count() <= 0) {
  818. msgs.Add(new KeyValuePair<string, string>("teacherClasses", $"未上传课堂实录:{teacherTrain.teacherClasses.Count()}个视频"));
  819. t53117OK = 0;
  820. }
  821. teacherTrain.teacherClasses.ForEach(x =>{
  822. if (string.IsNullOrWhiteSpace(x.url)) {
  823. t53117OK = 0;
  824. msgs.Add(new KeyValuePair<string, string>("teacherClasses", $"课堂实录链接无效"));
  825. }
  826. });
  827. return (t53117OK, msgs);
  828. }
  829. //5.3.1.12学员培训基本情况批量回写-UpdateTeacherListSituation
  830. public (int t53112OK, List<KeyValuePair<string, string>> msgs) check53112(TeacherTrain teacherTrain, List<KeyValuePair<string, string>> msgs)
  831. {
  832. //校验 基本情况是否满足
  833. int t53112OK = 1;
  834. if (teacherTrain.finalScore < 0)
  835. {
  836. //总体认定结果0、未认定 1、合格 2、优秀 3、不合格 4、其他
  837. msgs.Add(new KeyValuePair<string, string>("finalScore", $"最终评定结果参数:{teacherTrain.finalScore}"));
  838. t53112OK = 0;
  839. }
  840. if (string.IsNullOrEmpty(teacherTrain.summary) || teacherTrain.summary.Length > 300)
  841. {
  842. string msg = string.IsNullOrEmpty(teacherTrain.summary) ? "未填写" : teacherTrain.summary.Length > 300 ? "字数超过300." : "";
  843. msgs.Add(new KeyValuePair<string, string>("summary", $"教师培训总结:{msg}"));
  844. t53112OK = 0;
  845. }
  846. if (teacherTrain.totalTime <= 0)
  847. {
  848. msgs.Add(new KeyValuePair<string, string>("totalTime", $"未获得学时:{teacherTrain.totalTime}"));
  849. t53112OK = 0;
  850. }
  851. return (t53112OK, msgs);
  852. }
  853. //5.3.1.13学员能力点测评结果批量回写-UpdateTeacherListDiagnosis
  854. public async Task<(int t53113OK, List<KeyValuePair<string, string>> msgs, List<AbilitySub> abilitySubs)> check53113(TeacherTrain teacherTrain, ScTeacherDiagnosis diagnosis, List<KeyValuePair<string, string>> msgs)
  855. {
  856. //校验 基本情况是否满足
  857. int t53113OK = 1;
  858. List<AbilitySub> abilitySubs = new List<AbilitySub>();
  859. if (teacherTrain.currency.videoTime < 0)
  860. {
  861. msgs.Add(new KeyValuePair<string, string>("videoTime", $"视频学习时长:{teacherTrain.currency.videoTime}"));
  862. t53113OK = 0;
  863. }
  864. if (teacherTrain.currency.submitTime < 0)
  865. {
  866. msgs.Add(new KeyValuePair<string, string>("submitTime", $"认证材料学习:{teacherTrain.currency.submitTime}"));
  867. t53113OK = 0;
  868. }
  869. if (teacherTrain.currency.teacherAilities.Count <= 0 || teacherTrain.currency.teacherAilities.Select(x=>x.no).Count()<=0)
  870. {
  871. msgs.Add(new KeyValuePair<string, string>("teacherAilities", $"能力点不匹配:{teacherTrain.currency.submitTime}"));
  872. t53113OK = 0;
  873. }
  874. if (teacherTrain.currency.teacherAilities.Count <= 0 || teacherTrain.currency.teacherAilities.Select(x => x.no).Count() <= 0)
  875. {
  876. string insql = "";
  877. if (teacherTrain.currency.teacherAilities.IsNotEmpty())
  878. {
  879. IEnumerable<string> ds= diagnosis.abilityNos.ToObject<List<string>>().Except(teacherTrain.currency.teacherAilities.Select(x => x.no));
  880. if (ds != null && ds.Count() > 0) {
  881. msgs.Add(new KeyValuePair<string, string>("diagnosisNos", $"省平台勾选的能力点编号为学习完成:省平台:{diagnosis.abilityNos},已学习:{teacherTrain.currency.teacherAilities.Select(x => x.no).ToJsonString()}"));
  882. }
  883. insql = $" where c.id in ({string.Join(",", teacherTrain.currency.teacherAilities.Select(o => $"'{o.id}'"))})";
  884. }
  885. //认证材料
  886. await foreach (var item in _azureCosmos.GetCosmosClient().GetContainer("TEAMModelOS", "Teacher")
  887. .GetItemQueryIterator<AbilitySub>(queryText: $"select value(c) from c {insql}", requestOptions: new QueryRequestOptions() { PartitionKey = new PartitionKey($"AbilitySub-{teacherTrain.school}-{teacherTrain.id}") }))
  888. {
  889. abilitySubs.Add(item);
  890. }
  891. teacherTrain.currency.teacherAilities.ForEach(x => {
  892. var abilitySub= abilitySubs.Find(z => z.id.Equals(x.id));
  893. if (abilitySub == null || abilitySub.uploads.IsNotEmpty()) {
  894. msgs.Add(new KeyValuePair<string, string>("uploads", $"未上传认证材料:{x.no},{x.name}"));
  895. }
  896. if (x.zpscore <= 0) {
  897. msgs.Add(new KeyValuePair<string, string>("zpscore", $"认证材料,没有完成自评:{x.no},{x.name},{x.zpscore}"));
  898. }
  899. if (x.hpscore <= 0)
  900. {
  901. msgs.Add(new KeyValuePair<string, string>("hpscore", $"认证材料,没有完成互评:{x.no},{x.name},{x.hpscore}"));
  902. }
  903. if (x.xzscore <= 0)
  904. {
  905. msgs.Add(new KeyValuePair<string, string>("xzscore", $"认证材料,没有完成小组评:{x.no},{x.name},{x.xzscore}"));
  906. }
  907. });
  908. t53113OK = 0;
  909. }
  910. return (t53113OK, msgs, abilitySubs);
  911. }
  912. }
  913. }