12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034 |
- using Azure.Cosmos;
- using HTEXLib.COMM.Helpers;
- using Microsoft.Azure.Functions.Worker;
- using Microsoft.Azure.Functions.Worker.Http;
- using System;
- using System.Collections.Generic;
- using System.IO;
- using System.Linq;
- using System.Net;
- using System.Net.Http;
- using System.Text;
- using System.Text.Json;
- using System.Threading.Tasks;
- using TEAMModelOS.SDK;
- using TEAMModelOS.SDK.DI;
- using TEAMModelOS.SDK.Extension;
- using TEAMModelOS.SDK.Models;
- namespace TEAMModelOS.FunctionV4
- {
- public class ScsYxptApis
- {
- private readonly AzureCosmosFactory _azureCosmos;
- private readonly DingDing _dingDing;
- private readonly AzureStorageFactory _azureStorage;
- private readonly AzureRedisFactory _azureRedis;
- private readonly IHttpClientFactory _httpClient;
- public static string Code { get; set; }
- public static Dictionary<string, object> parameterMap = null;
- public ScsYxptApis(IHttpClientFactory httpClient,AzureCosmosFactory azureCosmos, DingDing dingDing, AzureStorageFactory azureStorage
- , AzureRedisFactory azureRedis)
- {
- _azureCosmos = azureCosmos;
- _dingDing = dingDing;
- _azureStorage = azureStorage;
- _azureRedis = azureRedis;
- _httpClient= httpClient;
- }
- /// <summary>
- /// 5.3.1.1获取项目列表
- /// </summary>
- /// <param name="req"></param>
- /// <param name="log"></param>
- /// <returns></returns>
- // [Function("GetProjectInfoByTrainComIDV2")]
- public async Task<HttpResponseData> GetProjectInfoByTrainComIDV2([HttpTrigger(AuthorizationLevel.Anonymous, "post", Route = null)] HttpRequestData req)
- {
- var response = req.CreateResponse(HttpStatusCode.OK);
- List<ScProject> projects = new List<ScProject>();
- string data = await new StreamReader(req.Body).ReadToEndAsync();
- JsonElement accessConfig = data.ToObject<JsonElement>().GetProperty("accessConfig");
- ScAccessConfig config = $"{accessConfig}".ToObject<ScAccessConfig>();
- string areaId = null;
- if (data.ToObject<JsonElement>().TryGetProperty("areaId", out JsonElement _areaId))
- {
- areaId = $"{_areaId}";
- }
- Code = "GetProjectInfoByTrainComID";
- parameterMap = new Dictionary<string, object>();
- parameterMap.Add("TrainComID", config.trainComID);
- ScsResult result = new ScsResult { bizcode = Code, title = "5.3.1.1获取项目列表" };
- try
- {
- result = await ThirdApisService.Post(_httpClient.CreateClient(), config.url, Code, config.passKey, config.privateKey, parameterMap);
- if (result.result)
- {
- projects = result.content.ToObject<List<ScProject>>();
- }
- else
- {
- }
- await response.WriteAsJsonAsync(new { data = projects.ToJsonString() });
- return response;
- }
- catch (Exception ex)
- {
- await _dingDing.SendBotMsg($"{Environment.GetEnvironmentVariable("Option:Location")},IES5.ScApisService:GetProjectInfoByTrainComID\n{ex.Message}\n{ex.StackTrace}\n{result.ToJsonString()}\n{data}", GroupNames.醍摩豆服務運維群組);
- await response.WriteAsJsonAsync(new { data = projects.ToJsonString() });
- return response;
- }
- }
- /// <summary>
- /// 5.3.1.1获取项目列表
- /// </summary>
- /// <param name="req"></param>
- /// <param name="log"></param>
- /// <returns></returns>
- //[Function("GetProjectInfoByTrainComID")]
- public async Task<HttpResponseData> GetProjectInfoByTrainComID([HttpTrigger(AuthorizationLevel.Anonymous, "post", Route = null)] HttpRequestData req)
- {
- var response = req.CreateResponse(HttpStatusCode.OK);
- List<ScProject> projects = new List<ScProject>();
- string data = await new StreamReader(req.Body).ReadToEndAsync();
- JsonElement accessConfig = data.ToObject<JsonElement>().GetProperty("accessConfig");
- ScAccessConfig config = $"{accessConfig}".ToObject<ScAccessConfig>();
- string areaId = null;
- if (data.ToObject<JsonElement>().TryGetProperty("areaId", out JsonElement _areaId))
- {
- areaId = $"{_areaId}";
- }
- Code = "GetProjectInfoByTrainComID";
- parameterMap = new Dictionary<string, object>();
- parameterMap.Add("TrainComID", config.trainComID);
- ScsResult result = new ScsResult { bizcode = Code, title = "5.3.1.1获取项目列表" };
- try
- {
- result = await ThirdApisService.Post(_httpClient.CreateClient(),config.url, Code, config.passKey, config.privateKey, parameterMap);
- if (result.result)
- {
- projects = result.content.ToObject<List<ScProject>>();
- }
- else
- {
- }
- await response.WriteAsJsonAsync(new { data = projects.ToJsonString() });
- return response;
- }
- catch (Exception ex)
- {
- await _dingDing.SendBotMsg($"{Environment.GetEnvironmentVariable("Option:Location")},IES5.ScApisService:GetProjectInfoByTrainComID\n{ex.Message}\n{ex.StackTrace}\n{result.ToJsonString()}\n{data}", GroupNames.醍摩豆服務運維群組);
- await response.WriteAsJsonAsync(new { data = projects.ToJsonString() });
- return response;
- }
- }
- /// <summary>
- /// 5.3.1.18根据机构ID、项目ID、子项目ID返回学校列表
- /// </summary>
- /// <param name="req"></param>
- /// <param name="log"></param>
- /// <returns></returns>
- //[Function("GetSchoolList")]
- public async Task<HttpResponseData> GetSchoolList([HttpTrigger(AuthorizationLevel.Anonymous, "post", Route = null)] HttpRequestData req)
- {
- var response = req.CreateResponse(HttpStatusCode.OK);
- List<ScSchool> scSchools = new List<ScSchool>();
- string data = await new StreamReader(req.Body).ReadToEndAsync();
- JsonElement accessConfig = data.ToObject<JsonElement>().GetProperty("accessConfig");
- string areaId = null;
- if (data.ToObject<JsonElement>().TryGetProperty("areaId", out JsonElement _areaId))
- {
- areaId = $"{_areaId}";
- }
- ScAccessConfig config = $"{accessConfig}".ToObject<ScAccessConfig>();
- Code = "GetSchoolList";
- parameterMap = new Dictionary<string, object>();
- parameterMap.Add("TrainComID", config.trainComID);
- List<ScsResult> results = new List<ScsResult>();
- try
- {
- if (config.p.IsNotEmpty())
- {
- foreach (var ps in config.p)
- {
- if (ps.status == 1) {
- parameterMap["ProjectID"] = ps.pd;
- parameterMap["ProjectItemID"] = ps.pid;
- ScsResult result = new ScsResult { bizcode = Code, title = " 5.3.1.18根据机构ID、项目ID、子项目ID返回学校列表" };
- result = await ThirdApisService.Post(_httpClient.CreateClient(),config.url, Code, config.passKey, config.privateKey, parameterMap);
- if (result.result)
- {
- List<ScSchool> schools = result.content.ToObject<List<ScSchool>>();
- if (schools.IsNotEmpty())
- {
- //schools.ForEach(x => { x.ProjectID = int.Parse(ps.pd); x.ProjectItemID = int.Parse(ps.pid); });
- scSchools.AddRange(schools);
- }
- }
- results.Add(result);
- }
- }
- }
- await response.WriteAsJsonAsync(new { data = scSchools.ToJsonString() });
- return response;
- }
- catch (Exception ex)
- {
- await _dingDing.SendBotMsg($"{Environment.GetEnvironmentVariable("Option:Location")},IES5.ScApisService:GetSchoolList\n{ex.Message}\n{ex.StackTrace}\n{results.ToJsonString()}\n{data}", GroupNames.醍摩豆服務運維群組);
- await response.WriteAsJsonAsync(new { data = scSchools.ToJsonString() });
- return response;
- }
- }
- /// <summary>
- /// 5.3.1.2获取学员名单
- /// </summary>
- /// <param name="req"></param>
- /// <param name="log"></param>
- /// <returns></returns>
- //[Function("GetTeachersListByProject")]
- public async Task<HttpResponseData> GetTeachersListByProject([HttpTrigger(AuthorizationLevel.Anonymous, "post", Route = null)] HttpRequestData req)
- {
- var response = req.CreateResponse(HttpStatusCode.OK);
- List<ScTeacher> scTeachers = new List<ScTeacher>();
- string data = await new StreamReader(req.Body).ReadToEndAsync();
- JsonElement accessConfig = data.ToObject<JsonElement>().GetProperty("accessConfig");
- ScAccessConfig config = $"{accessConfig}".ToObject<ScAccessConfig>();
- string areaId = null;
- if (data.ToObject<JsonElement>().TryGetProperty("areaId", out JsonElement _areaId))
- {
- areaId = $"{_areaId}";
- }
- Code = "GetTeachersListByProject";
- parameterMap = new Dictionary<string, object>();
- parameterMap.Add("TrainComID", config.trainComID);
- List<ScsResult> results = new List<ScsResult>();
- try
- {
- if (config.p.IsNotEmpty())
- {
- foreach (var ps in config.p)
- {
- if (ps.status == 1)
- {
- parameterMap["ProjectID"] = ps.pd;
- parameterMap["ProjectItemID"] = ps.pid;
- ScsResult result = new ScsResult { bizcode = Code, title = "5.3.1.2获取学员名单" };
- result = await ThirdApisService.Post(_httpClient.CreateClient(),config.url, Code, config.passKey, config.privateKey, parameterMap);
- if (result.result)
- {
- List<ScTeacher> teachers = result.content.ToObject<List<ScTeacher>>();
- if (teachers.IsNotEmpty())
- {
- scTeachers.AddRange(teachers);
- }
- }
- results.Add(result);
- }
- }
- }
- await response.WriteAsJsonAsync(new { data = scTeachers.ToJsonString() });
- return response;
- }
- catch (Exception ex)
- {
- await _dingDing.SendBotMsg($"{Environment.GetEnvironmentVariable("Option:Location")},IES5.ScApisService:GetTeachersListByProject\n{ex.Message}\n{ex.StackTrace}\n{results.ToJsonString()}\n{data}", GroupNames.醍摩豆服務運維群組);
- await response.WriteAsJsonAsync(new { data = scTeachers.ToJsonString() });
- return response;
- }
- }
- /// <summary>
- /// 5.3.1.20获取学校设置的可选能力点
- /// </summary>
- /// <param name="req"></param>
- /// <param name="log"></param>
- /// <returns></returns>
- //[Function("GetSchoolDiagnosis")]
- public async Task<HttpResponseData> GetSchoolDiagnosis([HttpTrigger(AuthorizationLevel.Anonymous, "post", Route = null)] HttpRequestData req)
- {
- var response = req.CreateResponse(HttpStatusCode.OK);
- List<ScsProjectDiagnosis> projects = new List<ScsProjectDiagnosis>();
- string data = await new StreamReader(req.Body).ReadToEndAsync();
- JsonElement accessConfig = data.ToObject<JsonElement>().GetProperty("accessConfig");
- JsonElement schoolCode = data.ToObject<JsonElement>().GetProperty("schoolCode");
- string areaId = null;
- if(data.ToObject<JsonElement>().TryGetProperty("areaId", out JsonElement _areaId))
- {
- areaId = $"{_areaId}";
- }
- ScAccessConfig config = $"{accessConfig}".ToObject<ScAccessConfig>();
- Code = "GetSchoolDiagnosis";
- var table = _azureStorage.GetCloudTableClient().GetTableReference("ScYxpt");
- parameterMap = new Dictionary<string, object>();
- parameterMap.Add("TrainComID", config.trainComID);
- List<ScsResult> results = new List<ScsResult>();
- try
- {
- if (config.p.IsNotEmpty())
- {
- foreach (var ps in config.p)
- {
- if (ps.status == 1) {
- parameterMap["ProjectID"] = ps.pd;
- parameterMap["ProjectItemID"] = ps.pid;
- parameterMap["SchoolID"] = $"{schoolCode}";
- parameterMap["School"] = $"{schoolCode}";
- ScsResult result = new ScsResult { bizcode = Code, title = " 5.3.1.20获取学校设置的可选能力点" };
- result = await ThirdApisService.Post(_httpClient.CreateClient(),config.url, Code, config.passKey, config.privateKey, parameterMap);
- if (result.result)
- {
- List<ScPDiagnosis> diagnoses = result.content.ToObject<List<ScPDiagnosis>>();
- if (diagnoses.IsNotEmpty())
- {
- projects.Add(new ScsProjectDiagnosis { project = ps, diagnoses = diagnoses, });
- await table.SaveOrUpdate<ScProjectDiagnosis>(new ScProjectDiagnosis
- {
- schoolCode = $"{schoolCode}",
- areaId = areaId,
- ProjectID = int.Parse(ps.pd),
- ProjectItemID = int.Parse(ps.pid),
- RowKey = $"{ps.pid}-{schoolCode}",
- PartitionKey = "ScSchoolDiagnosis",
- abilityNos = diagnoses.ToJsonString()
- });
- }
- }
- else
- {
- List<ScProjectDiagnosis> teacherDiagnoses = await table.FindListByDict<ScProjectDiagnosis>(new Dictionary<string, object> { { "PartitionKey", "ScSchoolDiagnosis" }, { "RowKey", $"{ps.pid}-{schoolCode}" } });
- if (teacherDiagnoses.IsNotEmpty())
- {
- projects.Add(new ScsProjectDiagnosis { project = ps, diagnoses = teacherDiagnoses[0].abilityNos.ToObject<List<ScPDiagnosis>>() });
- }
- }
- results.Add(result);
- }
- }
- }
- await response.WriteAsJsonAsync(new { data = projects.ToJsonString() });
- return response;
- }
- catch (Exception ex)
- {
- //await _dingDing.SendBotMsg($"{Environment.GetEnvironmentVariable("Option:Location")},IES5.ScApisService:GetSchoolDiagnosis\n{ex.Message}\n{ex.StackTrace}\n{results.ToJsonString()}\n{data}", GroupNames.醍摩豆服務運維群組);
- if (config.p.IsNotEmpty())
- {
- foreach (var ps in config.p)
- {
- List<ScProjectDiagnosis> teacherDiagnoses = await table.FindListByDict<ScProjectDiagnosis>(new Dictionary<string, object> { { "PartitionKey", "ScSchoolDiagnosis" }, { "RowKey", $"{ps.pid}-{schoolCode}" } });
- if (teacherDiagnoses.IsNotEmpty())
- {
- projects.Add(new ScsProjectDiagnosis { project = ps, diagnoses = teacherDiagnoses[0].abilityNos.ToObject<List<ScPDiagnosis>>() });
- }
- }
- }
- await response.WriteAsJsonAsync(new { data = projects.ToJsonString() });
- return response;
- }
- }
- /// <summary>
- /// 5.3.1.19获取项目设置的可选能力点
- /// </summary>
- /// <param name="req"></param>
- /// <param name="log"></param>
- /// <returns></returns>
- //[Function("GetProjectDiagnosis")]
- public async Task<HttpResponseData> GetProjectDiagnosis([HttpTrigger(AuthorizationLevel.Anonymous, "post", Route = null)] HttpRequestData req)
- {
- var response = req.CreateResponse(HttpStatusCode.OK);
- List<ScsProjectDiagnosis> projects = new List<ScsProjectDiagnosis>();
- string data = await new StreamReader(req.Body).ReadToEndAsync();
- JsonElement accessConfig = data.ToObject<JsonElement>().GetProperty("accessConfig");
- string areaId = null;
- if (data.ToObject<JsonElement>().TryGetProperty("areaId", out JsonElement _areaId))
- {
- areaId = $"{_areaId}";
- }
- ScAccessConfig config = $"{accessConfig}".ToObject<ScAccessConfig>();
- Code = "GetProjectDiagnosis";
- var table = _azureStorage.GetCloudTableClient().GetTableReference("ScYxpt");
- parameterMap = new Dictionary<string, object>();
- parameterMap.Add("TrainComID", config.trainComID);
- List<ScsResult> results = new List<ScsResult>();
- try
- {
- if (config.p.IsNotEmpty())
- {
- foreach (var ps in config.p)
- {
- if (ps.status==1) {
- parameterMap["ProjectID"] = ps.pd;
- parameterMap["ProjectItemID"] = ps.pid;
- ScsResult result = new ScsResult { bizcode = Code, title = "5.3.1.19获取项目设置的可选能力点" };
- result = await ThirdApisService.Post(_httpClient.CreateClient(),config.url, Code, config.passKey, config.privateKey, parameterMap);
- if (result.result)
- {
- List<ScPDiagnosis> diagnoses = result.content.ToObject<List<ScPDiagnosis>>();
- if (diagnoses.IsNotEmpty())
- {
- projects.Add(new ScsProjectDiagnosis { project = ps, diagnoses = diagnoses });
- await table.SaveOrUpdate<ScProjectDiagnosis>(new ScProjectDiagnosis { areaId = areaId, RowKey = $"{ps.pid}", PartitionKey = "ScProjectDiagnosis", abilityNos = diagnoses.ToJsonString() });
- }
- }
- else
- {
- List<ScProjectDiagnosis> teacherDiagnoses = await table.FindListByDict<ScProjectDiagnosis>(new Dictionary<string, object> { { "PartitionKey", "ScProjectDiagnosis" }, { "RowKey", $"{ps.pid}" } });
- if (teacherDiagnoses.IsNotEmpty())
- {
- projects.Add(new ScsProjectDiagnosis { project = ps, diagnoses = teacherDiagnoses[0].abilityNos.ToObject<List<ScPDiagnosis>>() });
- }
- }
- results.Add(result);
- }
- }
- }
- await response.WriteAsJsonAsync(new { data = projects.ToJsonString() });
- return response;
- }
- catch (Exception ex)
- {
- if (config.p.IsNotEmpty())
- {
- foreach (var ps in config.p)
- {
- //await _dingDing.SendBotMsg($"{Environment.GetEnvironmentVariable("Option:Location")},IES5.ScApisService:GetProjectDiagnosis\n{ex.Message}\n{ex.StackTrace}\n{results.ToJsonString()}\n{data}", GroupNames.醍摩豆服務運維群組);
- List<ScProjectDiagnosis> teacherDiagnoses = await table.FindListByDict<ScProjectDiagnosis>(new Dictionary<string, object> { { "PartitionKey", "ScProjectDiagnosis" }, { "RowKey", $"{ps.pid}" } });
- if (teacherDiagnoses.IsNotEmpty())
- {
- projects.Add(new ScsProjectDiagnosis { project = ps, diagnoses = teacherDiagnoses[0].abilityNos.ToObject<List<ScPDiagnosis>>() });
- }
- }
- }
- await response.WriteAsJsonAsync(new { data = projects.ToJsonString() });
- return response;
- }
- }
- /// <summary>
- /// 5.3.1.3通过项目编号获取学员测评能力项V2
- /// </summary>
- /// <param name="req"></param>
- /// <param name="log"></param>
- /// <returns></returns>
- //[Function("GetDiagnosisListByProject_V2")]
- public async Task<HttpResponseData> GetDiagnosisListByProject_V2([HttpTrigger(AuthorizationLevel.Anonymous, "post", Route = null)] HttpRequestData req)
- {
- var response = req.CreateResponse(HttpStatusCode.OK);
- List<string> abilityNos = new List<string>();
- string data = await new StreamReader(req.Body).ReadToEndAsync();
- JsonElement accessConfig = data.ToObject<JsonElement>().GetProperty("accessConfig");
- string areaId = null;
- if (data.ToObject<JsonElement>().TryGetProperty("areaId", out JsonElement _areaId))
- {
- areaId = $"{_areaId}";
- }
- var table = _azureStorage.GetCloudTableClient().GetTableReference("ScYxpt");
- JsonElement pxid = data.ToObject<JsonElement>().GetProperty("pxid");
- JsonElement schoolCode = data.ToObject<JsonElement>().GetProperty("schoolCode");
- ScAccessConfig config = $"{accessConfig}".ToObject<ScAccessConfig>();
- Code = "GetDiagnosisListByProject_V2";
- parameterMap = new Dictionary<string, object>();
- parameterMap.Add("TrainComID", config.trainComID);
- parameterMap.Add("PXID", pxid);
- ScsResult result = new ScsResult { bizcode = Code, title = "5.3.1.3通过项目编号获取学员测评能力项V2" };
- try
- {
- result = await ThirdApisService.Post(_httpClient.CreateClient(),config.url, Code, config.passKey, config.privateKey, parameterMap);
- if (result.result)
- {
- List<ScDiagnosis> diagnoses = result.content.ToObject<List<ScDiagnosis>>();
- if (diagnoses != null)
- {
- abilityNos = diagnoses.Select(x => x.DiagnosisDicNum).ToList();
- }
- if (abilityNos.IsNotEmpty())
- {
- await table.SaveOrUpdate<ScTeacherDiagnosis>(new ScTeacherDiagnosis {areaId = areaId,schoolCode=$"{schoolCode}", RowKey = $"{pxid}", PartitionKey = "ScTeacherDiagnosis", abilityNos = abilityNos.ToJsonString() });
- }
- }
- else
- {
- List<ScTeacherDiagnosis> teacherDiagnoses = await table.FindListByDict<ScTeacherDiagnosis>(new Dictionary<string, object> { { "PartitionKey", "ScTeacherDiagnosis" }, { "RowKey", $"{pxid}" } });
- if (teacherDiagnoses.IsNotEmpty())
- {
- abilityNos = teacherDiagnoses[0].abilityNos.ToObject<List<string>>();
- }
- }
- await response.WriteAsJsonAsync(new { data = abilityNos.ToJsonString() });
- return response;
- }
- catch (Exception ex)
- {
- //await _dingDing.SendBotMsg($"{Environment.GetEnvironmentVariable("Option:Location")},IES5.ScApisService:getDiagnosisListByProject_V2\n{ex.Message}\n{ex.StackTrace}\n{result.ToJsonString()}\n{data}", GroupNames.醍摩豆服務運維群組);
- List<ScTeacherDiagnosis> teacherDiagnoses = await table.FindListByDict<ScTeacherDiagnosis>(new Dictionary<string, object> { { "PartitionKey", "ScTeacherDiagnosis" }, { "RowKey", $"{pxid}" } });
- if (teacherDiagnoses.IsNotEmpty())
- {
- abilityNos = teacherDiagnoses[0].abilityNos.ToObject<List<string>>();
- }
- await response.WriteAsJsonAsync(new { data = abilityNos.ToJsonString() });
- return response;
- }
- }
- /// <summary>
- /// 5.3.1.11获取跳转学员信息,用于sso单点,后端验证。
- /// </summary>
- /// <param name="req"></param>
- /// <param name="log"></param>
- /// <returns></returns>
- //[Function("GetSingleTeacherByProject")]
- public async Task<HttpResponseData> GetSingleTeacherByProject([HttpTrigger(AuthorizationLevel.Anonymous, "post", Route = null)] HttpRequestData req)
- {
- var response = req.CreateResponse(HttpStatusCode.OK);
- string teacher = null;
- string data = await new StreamReader(req.Body).ReadToEndAsync();
- JsonElement accessConfig = data.ToObject<JsonElement>().GetProperty("accessConfig");
- JsonElement pxid = data.ToObject<JsonElement>().GetProperty("pxid");
- JsonElement tid = data.ToObject<JsonElement>().GetProperty("tid");
- ScAccessConfig config = $"{accessConfig}".ToObject<ScAccessConfig>();
- string areaId = null;
- if (data.ToObject<JsonElement>().TryGetProperty("areaId", out JsonElement _areaId))
- {
- areaId = $"{_areaId}";
- }
- Code = "GetSingleTeacherByProject";
- parameterMap = new Dictionary<string, object>();
- parameterMap.Add("TrainComID", config.trainComID);
- parameterMap.Add("Pxid", $"{pxid}");
- parameterMap.Add("Tid", $"{tid}");
- ScsResult result = new ScsResult { bizcode = Code, title = "5.3.1.11获取跳转学员信息,用于sso单点,后端验证。" };
- try
- {
- ///{“result”:true,”reason”:null,”content”:”{“PXID”:””,”TID”:””,”TeacherName”:””,”ProjectTitle”:””,”ProjectItemTitle”:””,”CityName”:””,
- ///”DisName”:””,”SchoolName”:””,”Sex”:””,”PXXK”:””,”PXXD”:””,”TeacherXK”:””,”TeacherXD”:””,”Email”:””}”,”pagecount”:1}
- result = await ThirdApisService.Post(_httpClient.CreateClient(),config.url, Code, config.passKey, config.privateKey, parameterMap);
- if (result.result)
- {
- teacher = result.content;
- }
- await response.WriteAsJsonAsync(new { data = teacher });
- return response;
- }
- catch (Exception ex)
- {
- //await _dingDing.SendBotMsg($"{Environment.GetEnvironmentVariable("Option:Location")},IES5.ScApisService:GetSingleTeacherByProject\n{ex.Message}\n{ex.StackTrace}\n{result.ToJsonString()}\n{data}", GroupNames.醍摩豆服務運維群組);
- await response.WriteAsJsonAsync(new { data = teacher });
- return response;
- }
- }
- /// <summary>
- /// 数据推送接口
- /// </summary>
- /// <param name="req"></param>
- /// <param name="log"></param>
- /// <returns></returns>
- //[Function("SchoolDataPush")]
- public async Task<HttpResponseData> SchoolDataPush([HttpTrigger(AuthorizationLevel.Anonymous, "post", Route = null)] HttpRequestData req)
- {
- var response = req.CreateResponse(HttpStatusCode.OK);
- var client = _azureCosmos.GetCosmosClient();
- string data = await new StreamReader(req.Body).ReadToEndAsync();
- JsonElement areaIdJson = data.ToObject<JsonElement>().GetProperty("areaId");
- AreaSetting areaSetting= await _azureCosmos.GetCosmosClient().GetContainer(Constant.TEAMModelOS, Constant.Normal).ReadItemAsync<AreaSetting>($"{areaIdJson}", new PartitionKey("AreaSetting"));
- ScAccessConfig config = areaSetting.accessConfig.ToObject<ScAccessConfig>();
- JsonElement school = data.ToObject<JsonElement>().GetProperty("school");
- List<string> pushTeachers = data.ToObject<JsonElement>().GetProperty("pushTeachers").ToObject<List<string>>();
- StringBuilder queryText = new StringBuilder($"SELECT distinct value(c) FROM c where c.type='yxtrain'");
- List<GroupList> yxtrain = new List<GroupList>();
- await foreach (var item in _azureCosmos.GetCosmosClient().GetContainer(Constant.TEAMModelOS, "School").GetItemQueryIterator<GroupList>(queryText: queryText.ToString(),
- requestOptions: new QueryRequestOptions() { PartitionKey = new Azure.Cosmos.PartitionKey($"GroupList-{school}") }))
- {
- yxtrain.Add(item);
- }
- List<TeacherTrain> trains = new List<TeacherTrain>();
- var members = yxtrain.SelectMany(x => x.members).ToList();
- //指定推送一部分的教师
- if (pushTeachers.IsNotEmpty()) {
- members= members.FindAll(x => pushTeachers.Contains(x.id));
- }
- if (members.IsNotEmpty())
- {
- queryText = new StringBuilder($"SELECT distinct value(c) FROM c where 1=1 " +
- $"and c.id in ({string.Join(",", members.Select(x => $"'{x.id}'"))}) ");
- await foreach (var item in _azureCosmos.GetCosmosClient().GetContainer(Constant.TEAMModelOS, "Teacher").GetItemQueryIterator<TeacherTrain>(queryText: queryText.ToString(),
- requestOptions: new QueryRequestOptions() { PartitionKey = new Azure.Cosmos.PartitionKey($"TeacherTrain-{school}") }))
- {
- trains.Add(item);
- }
- }
- //string sql = $" SELECT value(c) FROM c join a in c.binds where ARRAY_LENGTH(c.binds)>0 and a.type='{config.config}' ";
- //List<Teacher> teachers = new List<Teacher>();
- //await foreach (var item in _azureCosmos.GetCosmosClient().GetContainer(Constant.TEAMModelOS, "Teacher").GetItemQueryIterator<Teacher>(queryText: sql,
- // requestOptions: new QueryRequestOptions() { PartitionKey = new PartitionKey($"Base") }))
- //{
- // teachers.Add(item);
- //}
- var table = _azureStorage.GetCloudTableClient().GetTableReference("ScYxpt");
- List<ScTeacher> scTeachers= await table.FindListByDict<ScTeacher>(new Dictionary<string, object> { { "PartitionKey", "ScTeacher" },{ "schoolCode",$"{school}" } });
- List<ScTeacherDiagnosis> scTeacherDiagnoses = await table.FindListByDict<ScTeacherDiagnosis>(new Dictionary<string, object> { { "PartitionKey", "ScTeacherDiagnosis" }, { "schoolCode", $"{school}" } });
-
- List<KeyValuePair<TeacherTrain, string>> trainsNO = new List<KeyValuePair<TeacherTrain, string>>();
-
- List<ScsResult> results = new List<ScsResult>();
- Dictionary<string, Dictionary<string, object>> pushDatas = new Dictionary<string, Dictionary<string, object>>();
- int pages = (trains.Count + 19) / 20; //pages = (total + max -1) / max;
- for (int i = 0; i < pages; i++) {
- List<TeacherTrain> lists = trains.Skip((i) * 20).Take(20).ToList();
- //5.3.1.12学员培训基本情况批量回写-UpdateTeacherListSituation
- List<TeacherTrain> trains53112OK = new List<TeacherTrain>();
- ScsResult UpdateTeacherListSituation = null;
- Dictionary<string, object> parameterContent53112 = new Dictionary<string, object>();
- List<Dictionary<string, object>> list53112 = new List<Dictionary<string, object>>();
- parameterContent53112.Add("TrainComID", config.trainComID);
- parameterContent53112.Add("List", list53112);
- //5.3.1.13学员能力点测评结果批量回写-UpdateTeacherListDiagnosis 300条限制
- List<TeacherTrain> trains53113OK = new List<TeacherTrain>();
- ScsResult UpdateTeacherListDiagnosis = null;
- Dictionary<string, object> parameterContent53113 = new Dictionary<string, object>();
- List<Dictionary<string, object>> list53113 = new List<Dictionary<string, object>>();
- parameterContent53113.Add("TrainComID", config.trainComID);
- parameterContent53113.Add("List", list53113);
- //5.3.1.17学员课堂实录批量回写-UploadKTSLList 300条限制
- List<TeacherTrain> trains53117OK = new List<TeacherTrain>();
- ScsResult UploadKTSLList = null;
- Dictionary<string, object> parameterContent53117 = new Dictionary<string, object>();
- List<Dictionary<string, object>> list53117 = new List<Dictionary<string, object>>();
- parameterContent53117.Add("TrainComID", config.trainComID);
- parameterContent53117.Add("List", list53117);
- //5.3.1.22学员校本教研PDF(每人可以返回多条)批量回写-UploadSBTARPDFListV2 100条限制
- List<TeacherTrain> trains53122OK = new List<TeacherTrain>();
- ScsResult UploadSBTARPDFListV2 = null;
- Dictionary<string, object> parameterContent53122 = new Dictionary<string, object>();
- List<Dictionary<string, object>> list53122 = new List<Dictionary<string, object>>();
- parameterContent53122.Add("TrainComID", config.trainComID);
- parameterContent53122.Add("List", list53122);
- //装载数据
-
- foreach (var x in lists) {
- List<CodeValue> msgs = new List<CodeValue>();
- List<ScTeacher> teacher = scTeachers.FindAll(t => !string.IsNullOrWhiteSpace(t.tmdid) && t.tmdid.Equals(x.id));
- foreach (var t in teacher)
- {
- List<PushFail> fails = new List<PushFail>();
- Dictionary<string,object> pushData = new Dictionary<string, object>();
- string json = scTeacherDiagnoses.ToJsonString();
- ScTeacherDiagnosis diagnosis = scTeacherDiagnoses.Find(x => x.RowKey.Equals($"{t.PXID}"));
- (int t53112OK, List<CodeValue> msgs53112) = check53112(x, msgs);
- (int t53113OK, List<CodeValue> msgs53113, List<AbilitySub> abilitySubs) = await check53113(x, diagnosis, msgs);
- (int t53117OK, List<CodeValue> msgs53117) = check53117(x, msgs);
- (int t53122OK, List<CodeValue> msgs53122) = check53122(x, msgs);
- //5.3.1.12学员培训基本情况批量回写-UpdateTeacherListSituation
- if (t53112OK == 1)
- {
- Dictionary<string, object> parameterMapData = new Dictionary<string, object>();
- parameterMapData.Add("PXID", $"{t.PXID}");
- parameterMapData.Add("TID", $"{t.TID}");
- parameterMapData.Add("TeacherName", $"{t.TeacherName}");
- parameterMapData.Add("CourseHour", $"{x.totalTime}");
- parameterMapData.Add("ResearchText", $"{x.summary}");
- /// <summary>
- ///省上标准 最终结果 0未认定,1合格,2优秀,3不合格,4其他
- ///系统标准 -2 其他 -1 未认定,0不合格,1合格,2优秀
- /// </summary>
- string ComPassed = "0";
- switch (x.finalScore)
- {
- case -2:
- ComPassed = "4";
- break;
- case -1:
- ComPassed = "0";
- break;
- case 0:
- ComPassed = "3";
- break;
- case 1:
- ComPassed = "1";
- break;
- case 2:
- ComPassed = "2";
- break;
- default:
- ComPassed = "4";
- break;
- }
- parameterMapData.Add("ComPassed", ComPassed);//0、未认定 1、合格 2、优秀 3、不合格 4、其他
- pushData.Add("success-UpdateTeacherListSituation", parameterMapData);
- list53112.Add(parameterMapData);
- }
- else
- {
- pushData.Add("fail-UpdateTeacherListSituation", new PushFail { tmdid = t.tmdid, name = t.TeacherName, msgs = msgs53112 });
- fails.Add(new PushFail { tmdid = t.tmdid, name = t.TeacherName, msgs = msgs53112 });
- }
- //5.3.1.13学员能力点测评结果批量回写-UpdateTeacherListDiagnosis
- if (t53113OK == 1)
- {
- List<Dictionary<string, object>> parameterMapDatas = new List<Dictionary<string, object>>();
- x.currency.teacherAilities.ForEach(a => {
- Dictionary<string, object> parameterMapData = new Dictionary<string, object>();
- parameterMapData.Add("PXID", $"{t.PXID}");
- parameterMapData.Add("TID", $"{t.TID}");
- parameterMapData.Add("DiagnosisNum", $"{a.no}");
- //0"未认定", 1"合格", 2"优秀", 3"不合格"
- //系统 -1 未认定,0 不合格,1 合格,2 优秀
- string zpscore = "0";
- switch (a.zpscore)
- {
- case -1:
- zpscore = "0";
- break;
- case 0:
- zpscore = "3";
- break;
- case 1:
- zpscore = "1";
- break;
- case 2:
- zpscore = "2";
- break;
- default:
- zpscore = "0";
- break;
- }
- string hpscore = "0";
- switch (a.hpscore)
- {
- case -1:
- hpscore = "0";
- break;
- case 0:
- hpscore = "3";
- break;
- case 1:
- hpscore = "1";
- break;
- case 2:
- hpscore = "2";
- break;
- default:
- hpscore = "0";
- break;
- }
- string xzpresult = "0";
- switch (a.xzscore)
- {
- case -1:
- xzpresult = "0";
- break;
- case 0:
- xzpresult = "3";
- break;
- case 1:
- xzpresult = "1";
- break;
- case 2:
- xzpresult = "2";
- break;
- default:
- xzpresult = "0";
- break;
- }
- parameterMapData.Add("zpresult", zpscore);
- parameterMapData.Add("hpresult", hpscore);
- parameterMapData.Add("xzpresult", xzpresult);
- List<Dictionary<string, object>> pfiles = new List<Dictionary<string, object>>();
- parameterMapData.Add("pfiles", pfiles);
- AbilitySub abilitySub = abilitySubs.Find(sub => sub.id.Equals(a.id));
- if (abilitySub != null)
- {
- abilitySub.uploads.ForEach(upload => {
- upload.urls.ForEach(url => {
- Dictionary<string, object> pfileMap = new Dictionary<string, object>();
- pfileMap.Add("url", url.url);
- pfileMap.Add("fileName", url.name);
- pfileMap.Add("fileSize", url.size);
- pfileMap.Add("md5", url.hash);
- string fileext = url.url.Substring(url.url.LastIndexOf(".") > 0 ? url.url.LastIndexOf(".") + 1 : 0);
- pfileMap.Add("fileType", fileext);
- pfiles.Add(pfileMap);
- });
- });
- }
- list53113.Add(parameterMapData);
- parameterMapDatas.Add(parameterMapData);
- });
- pushData.Add("success-UpdateTeacherListDiagnosis", parameterMapDatas);
- }
- else
- {
- pushData.Add("fail-UpdateTeacherListDiagnosis", new PushFail { tmdid = t.tmdid, name = t.TeacherName, msgs = msgs53113 });
- fails.Add(new PushFail { tmdid = t.tmdid, name = t.TeacherName, msgs = msgs53113 });
- }
- //5.3.1.17学员课堂实录批量回写-UploadKTSLList
- if (t53117OK == 1)
- {
- List<Dictionary<string, object>> parameterMapDatas = new List<Dictionary<string, object>>();
- x.teacherClasses.ForEach(clss =>
- {
- Dictionary<string, object> parameterMapData = new Dictionary<string, object>();
- parameterMapData.Add("PXID", $"{t.PXID}");
- parameterMapData.Add("TID", $"{t.TID}");
- parameterMapData.Add("url", clss.url);//添加访问授权
- parameterMapData.Add("url2", clss.url);
- parameterMapData.Add("fileName", clss.name);
- parameterMapData.Add("fileSize", clss.size);
- parameterMapData.Add("md5", clss.hash);
- string fileext = clss.url.Substring(clss.url.LastIndexOf(".") > 0 ? clss.url.LastIndexOf(".") + 1 : 0);
- parameterMapData.Add("fileType", fileext);
- list53117.Add(parameterMapData);
- parameterMapDatas.Add(parameterMapData);
- });
- pushData.Add("success-UploadKTSLList", parameterMapDatas);
- }
- else
- {
- pushData.Add("fail-UploadKTSLList", new PushFail { tmdid = t.tmdid, name = t.TeacherName, msgs = msgs53117 });
- fails.Add(new PushFail { tmdid = t.tmdid, name = t.TeacherName, msgs = msgs53117 });
- }
- //5.3.1.22学员校本教研PDF(每人可以返回多条)批量回写-UploadSBTARPDFListV2
- if (t53122OK == 1)
- {
- Dictionary<string, object> parameterMapData = new Dictionary<string, object>();
- parameterMapData.Add("PXID", $"{t.PXID}");
- parameterMapData.Add("TID", $"{t.TID}");
- List<Dictionary<string, object>> files = new List<Dictionary<string, object>>();
- x.offlineRecords.ForEach(record => {
- if (!string.IsNullOrWhiteSpace(record.url)) {
- Dictionary<string, object> fileMap = new Dictionary<string, object>();
- fileMap.Add("url", record.url);
- fileMap.Add("fileName", record.name);
- fileMap.Add("fileSize", record.size);
- fileMap.Add("md5", record.hash);
- string fileext = record.url.Substring(record.url.LastIndexOf(".") > 0 ? record.url.LastIndexOf(".") + 1 : 0);
- fileMap.Add("fileType", fileext);
- files.Add(fileMap);
- }
- });
- parameterMapData.Add("files", files);
- list53122.Add(parameterMapData);
- pushData.Add("success-UploadSBTARPDFListV2", parameterMapData);
- }
- else
- {
- pushData.Add("fail-UploadSBTARPDFListV2", new PushFail { tmdid = t.tmdid, name = t.TeacherName, msgs = msgs53122 });
- fails.Add(new PushFail { tmdid = t.tmdid, name = t.TeacherName, msgs = msgs53122 });
- }
- pushDatas.Add(t.tmdid,pushData);
- }
- }
- //推送数据
- UpdateTeacherListSituation = await ThirdApisService.Post(_httpClient.CreateClient(),config.url, "UpdateTeacherListSituation", config.passKey, config.privateKey, parameterContent53112);
- UpdateTeacherListSituation.bizcode = "UpdateTeacherListSituation";
- UpdateTeacherListSituation.title = "5.3.1.12学员培训基本情况批量回写";
- UpdateTeacherListDiagnosis = await ThirdApisService.Post(_httpClient.CreateClient(),config.url, "UpdateTeacherListDiagnosis", config.passKey, config.privateKey, parameterContent53113);
- UpdateTeacherListDiagnosis.bizcode = "UpdateTeacherListDiagnosis";
- UpdateTeacherListDiagnosis.title = "5.3.1.13学员能力点测评结果批量回写";
- UploadKTSLList = await ThirdApisService.Post(_httpClient.CreateClient(),config.url, "UploadKTSLList", config.passKey, config.privateKey, parameterContent53117);
- UploadKTSLList.bizcode = "UploadKTSLList";
- UploadKTSLList.title = "5.3.1.17学员课堂实录批量回写";
- UploadSBTARPDFListV2 = await ThirdApisService.Post(_httpClient.CreateClient(),config.url, "UploadSBTARPDFListV2", config.passKey, config.privateKey, parameterContent53122);
- UploadSBTARPDFListV2.bizcode = "UploadSBTARPDFListV2";
- UploadSBTARPDFListV2.title = "5.3.1.22学员校本教研PDF(每人可以返回多条)批量回写";
- results.Add(UpdateTeacherListSituation);
- results.Add(UpdateTeacherListDiagnosis);
- results.Add(UploadKTSLList);
- results.Add(UploadSBTARPDFListV2);
- }
- await response.WriteAsJsonAsync(new { data= new { results, pushDatas } });
- return response;
- }
- //5.3.1.22学员校本教研PDF(每人可以返回多条)批量回写-UploadSBTARPDFListV2
- public (int t53122OK, List<CodeValue> msgs) check53122(TeacherTrain teacherTrain, List<CodeValue> msgs) {
- int t53122OK = 1;
- if (teacherTrain.offlineRecords.Count<= 0)
- {
- msgs.Add(new CodeValue("offlineRecord-count", $"文件个数为0"));
- }
- var hasUrl= teacherTrain.offlineRecords.Where(x => !string.IsNullOrWhiteSpace(x.url) && x.size > 0);
- if (!hasUrl.Any()) {
- msgs.Add(new CodeValue("offlineRecord-url", $"需要上传的校本研修作业至少有一个。"));
- }
- //不需要检查每一个校本研修的文件记录。
- //teacherTrain.offlineRecords.ForEach(x => {
- // if (string.IsNullOrEmpty(x.url)) {
- // msgs.Add(new CodeValue("offlineRecord-url", $"链接为空"));
- // }
- // if (x.size<=0)
- // {
- // msgs.Add(new CodeValue("offlineRecord-size", $"文件大小"));
- // }
- //});
- return (t53122OK, msgs);
- }
- //5.3.1.17学员课堂实录批量回写-UploadKTSLList
- public (int t53117OK, List<CodeValue> msgs) check53117(TeacherTrain teacherTrain, List<CodeValue> msgs) {
- //校验 基本情况是否满足
- int t53117OK = 1;
- if (teacherTrain.classTime <= 0)
- {
- msgs.Add(new CodeValue("classTime", $"未获得学时:{teacherTrain.classTime}"));
- t53117OK = 0;
- }
- if (teacherTrain.teacherClasses.Count() <= 0) {
- msgs.Add(new CodeValue("teacherClasses", $"未上传课堂实录:{teacherTrain.teacherClasses.Count()}个视频"));
- t53117OK = 0;
- }
-
- teacherTrain.teacherClasses.ForEach(x =>{
- if (string.IsNullOrWhiteSpace(x.url)) {
- t53117OK = 0;
- msgs.Add(new CodeValue("teacherClasses", $"课堂实录链接无效"));
- }
- });
- return (t53117OK, msgs);
- }
- //5.3.1.12学员培训基本情况批量回写-UpdateTeacherListSituation
- public (int t53112OK, List<CodeValue> msgs) check53112(TeacherTrain teacherTrain, List<CodeValue> msgs)
- {
- //校验 基本情况是否满足
- int t53112OK = 1;
- if (teacherTrain.finalScore < 0)
- {
- //总体认定结果0、未认定 1、合格 2、优秀 3、不合格 4、其他
- msgs.Add(new CodeValue("finalScore", $"最终评定结果参数:{teacherTrain.finalScore}"));
- t53112OK = 0;
- }
- //if (string.IsNullOrEmpty(teacherTrain.summary) || teacherTrain.summary.Length > 300)
- //{
- // string msg = string.IsNullOrEmpty(teacherTrain.summary) ? "未填写" : teacherTrain.summary.Length > 300 ? "字数超过300." : "";
- // msgs.Add(new CodeValue("summary", $"教师培训总结:{msg}"));
- // t53112OK = 0;
- //}
- if (!string.IsNullOrEmpty(teacherTrain.summary) && teacherTrain.summary.Length > 300)
- {
- //string msg = string.IsNullOrEmpty(teacherTrain.summary) ? "未填写" : teacherTrain.summary.Length > 300 ? "字数超过300." : "";
- msgs.Add(new CodeValue("summary", $"教师培训总结:字数超过300."));
- t53112OK = 0;
- }
- if (teacherTrain.totalTime <= 0)
- {
- msgs.Add(new CodeValue("totalTime", $"未获得学时:{teacherTrain.totalTime}"));
- t53112OK = 0;
- }
- return (t53112OK, msgs);
- }
- //5.3.1.13学员能力点测评结果批量回写-UpdateTeacherListDiagnosis
- public async Task<(int t53113OK, List<CodeValue> msgs, List<AbilitySub> abilitySubs)> check53113(TeacherTrain teacherTrain, ScTeacherDiagnosis diagnosis, List<CodeValue> msgs)
- {
- //校验 基本情况是否满足
- int t53113OK = 1;
- List<AbilitySub> abilitySubs = new List<AbilitySub>();
- if (teacherTrain.currency.videoTime < 0)
- {
- msgs.Add(new CodeValue("videoTime", $"视频学习时长:{teacherTrain.currency.videoTime}"));
- t53113OK = 0;
- }
- if (teacherTrain.currency.submitTime < 0)
- {
- msgs.Add(new CodeValue("submitTime", $"认证材料学习:{teacherTrain.currency.submitTime}"));
- t53113OK = 0;
- }
- if (teacherTrain.currency.teacherAilities.Count <= 0 )
- {
-
- msgs.Add(new CodeValue("teacherAilities", $"已学习能力点:0"));
- t53113OK = 0;
- }
- if (diagnosis != null)
- {
- if (!string.IsNullOrWhiteSpace(diagnosis.abilityNos))
- {
- List<string> nos = diagnosis.abilityNos.ToObject<List<string>>();
- if (nos.Count > 0 && teacherTrain.currency.teacherAilities.Count > 0)
- {
- var notin = nos.Except(teacherTrain.currency.teacherAilities.Select(x => x.no).Where(z=>!string.IsNullOrWhiteSpace(z)));
- if (notin.Any())
- {
- msgs.Add(new CodeValue("diagnosisNos", $"省平台勾选的能力点编号为学习完成:省平台:{string.Join(",", nos.OrderBy(x => x))}" + $" ,已学习:{string.Join(",", teacherTrain.currency.teacherAilities.Select(x => x.no).OrderBy(x=>x))} "));
- t53113OK = 0;
- }
- else {
- string insql = "";
- if (teacherTrain.currency.teacherAilities.IsNotEmpty())
- {
- var abilites= teacherTrain.currency.teacherAilities.Where(c => !string.IsNullOrWhiteSpace(c.no) && nos.Contains(c.no));
- insql = $" where c.id in ({string.Join(",", abilites.Select(o => $"'{o.id}'"))})";
- }
- //认证材料
- await foreach (var item in _azureCosmos.GetCosmosClient().GetContainer("TEAMModelOS", "Teacher")
- .GetItemQueryIterator<AbilitySub>(queryText: $"select value(c) from c {insql}", requestOptions: new QueryRequestOptions() { PartitionKey = new PartitionKey($"AbilitySub-{teacherTrain.school}-{teacherTrain.id}") }))
- {
- abilitySubs.Add(item);
- }
- teacherTrain.currency.teacherAilities.ForEach(x => {
- var abilitySub = abilitySubs.Find(z => z.id.Equals(x.id));
- if (abilitySub == null || !abilitySub.uploads.Any())
- {
- t53113OK = 0;
- msgs.Add(new CodeValue("uploads", $"未上传认证材料:{x.no},{x.name}"));
- }
- if (x.zpscore <= 0)
- {
- t53113OK = 0;
- msgs.Add(new CodeValue("zpscore", $"认证材料,没有完成自评:{x.no},{x.name},{x.zpscore}"));
- }
- if (x.hpscore <= 0)
- {
- t53113OK = 0;
- msgs.Add(new CodeValue("hpscore", $"认证材料,没有完成互评:{x.no},{x.name},{x.hpscore}"));
- }
- if (x.xzscore <= 0)
- {
- t53113OK = 0;
- msgs.Add(new CodeValue("xzscore", $"认证材料,没有完成小组评:{x.no},{x.name},{x.xzscore}"));
- }
- });
- if (t53113OK != 1) {
- msgs.Add(new CodeValue("diagnosisNos", $"省平台勾选的能力点编号为学习完成:省平台:{string.Join(",", nos.OrderBy(x=>x))}" + $" ,已学习:{string.Join(",", teacherTrain.currency.teacherAilities.Select(x => x.no).OrderBy(x => x))} "));
- }
- }
- }
- else {
- msgs.Add(new CodeValue("teacherAilities", $"未同步省平台挑选的能力点"));
- t53113OK = 0;
- }
- }
- else {
- msgs.Add(new CodeValue("teacherAilities", $"未同步省平台挑选的能力点"));
- t53113OK = 0;
- }
- }
- else {
- msgs.Add(new CodeValue("teacherAilities", $"未同步省平台挑选的能力点"));
- t53113OK = 0;
- }
-
- return (t53113OK, msgs, abilitySubs);
- }
- }
- }
|