EvalAppService.cs 45 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Data.Entity;
  4. using System.Linq;
  5. using System.Threading;
  6. using System.Threading.Tasks;
  7. using Abp.Auditing;
  8. using Abp.Authorization;
  9. using Abp.Configuration;
  10. using Abp.Domain.Repositories;
  11. using Abp.Runtime.Caching;
  12. using IwbZero.Auditing;
  13. using IwbZero.ToolCommon;
  14. using IwbZero.ToolCommon.StringModel;
  15. using Microsoft.AspNet.SignalR;
  16. using WeApp.BaseInfo;
  17. using WeApp.BasicInfo;
  18. using WeApp.CommonManager.MqttClient;
  19. using WeApp.Configuration;
  20. using WeApp.Configuration.Cache;
  21. using WeApp.Hubs;
  22. using WeApp.TrainingCamp;
  23. using WeApp.TrainingEval.Dto;
  24. using WeEngine.CommonDto;
  25. using WeEngine.Packages;
  26. namespace WeApp.TrainingEval
  27. {
  28. [AbpAuthorize, AuditLog("演练培训营评估")]
  29. public class EvalAppService : IwbAppServiceBase, IEvalAppService
  30. {
  31. public EvalAppService(IRepository<CampInfo, string> campRepository, IRepository<CampGroupInfo, string> groupRepository, IRepository<GroupScoreInfo> gsRepository, IRepository<GroupLogInfo> glRepository,ICacheManager cacheManager, IRepository<TrainingGroupRelateRoleInfo> grrRepository, IRepository<GroupRoleInfo> groupRoleRepository, IRepository<CampSceneMapInfo> sceneMapRepository, IRepository<SysAttachFile> attachRepository, WeAppMsgClientManager msgClientManager)
  32. {
  33. CampRepository = campRepository;
  34. GroupRepository = groupRepository;
  35. GsRepository = gsRepository;
  36. GlRepository = glRepository;
  37. GrrRepository = grrRepository;
  38. GroupRoleRepository = groupRoleRepository;
  39. SceneMapRepository = sceneMapRepository;
  40. AttachRepository = attachRepository;
  41. MsgClientManager = msgClientManager;
  42. CacheManager = cacheManager;
  43. IwbHubContext = GlobalHost.ConnectionManager.GetHubContext<IwbHub>();
  44. }
  45. //private string DataCenterUrl => SettingManager.GetSettingValue(IwbSettingNames.WeDataCenterIp).Ew("/");
  46. private string EngineApiUrl => SettingManager.GetSettingValue(IwbSettingNames.WeEngineIp).Ew("/");
  47. protected IHubContext IwbHubContext { get; }
  48. private bool HasReStart { get; set; }
  49. protected WeAppMsgClientManager MsgClientManager { get; }
  50. protected IRepository<CampInfo, string> CampRepository { get; }
  51. protected IRepository<CampGroupInfo, string> GroupRepository { get; }
  52. protected IRepository<GroupScoreInfo> GsRepository { get; }
  53. protected IRepository<GroupLogInfo> GlRepository { get; }
  54. protected IRepository<TrainingGroupRelateRoleInfo> GrrRepository { get; }
  55. protected IRepository<GroupRoleInfo> GroupRoleRepository { get; }
  56. protected IRepository<CampSceneMapInfo> SceneMapRepository { get; }
  57. protected IRepository<SysAttachFile> AttachRepository { get; }
  58. #region Operation
  59. /// <summary>
  60. /// 进入演练页面成功后反馈
  61. /// </summary>
  62. /// <param name="no"></param>
  63. [AbpAllowAnonymous]
  64. public bool StartFeedback(string no)
  65. {
  66. return WeAppMsgClientManager.StartPushScene(no);
  67. }
  68. /// <summary>
  69. /// 启动培训营
  70. /// </summary>
  71. /// <param name="campNo"></param>
  72. /// <param name="groupNo"></param>
  73. /// <returns></returns>
  74. [AuditLog("启动培训营")]
  75. public async Task StartCamp(string campNo, string groupNo)
  76. {
  77. CampInfo camp;
  78. List<string> groupNos = new List<string>();
  79. if (groupNo == "none")
  80. {
  81. camp = await CampRepository.FirstOrDefaultAsync(a => a.Id == campNo);
  82. if (camp.CampState == CampStateDefinition.Run)
  83. {
  84. CheckErrors("培训营已运行,不能操作!");
  85. }
  86. var groups = await GroupRepository.GetAll().Where(a => a.CampNo == campNo).OrderBy(a => a.Id).ToListAsync();
  87. foreach (var g in groups)
  88. {
  89. if (g.CampGroupState >= CampGroupStateDefinition.Run &&
  90. g.CampGroupState < CampGroupStateDefinition.Ready)
  91. {
  92. continue;
  93. }
  94. groupNos.Add(g.Id);
  95. WeAppMsgClientManager.StopPushScene(g.Id);
  96. await WriteLog(g.CampNo, g.Id, g.RoundIndex, LogCommandDefinition.Start);
  97. //if (WeAppMsgClientManager.StartGroupNos.Contains(g.Id))
  98. //{
  99. // WeAppMsgClientManager.StartGroupNos.Remove(g.Id);
  100. //}
  101. }
  102. }
  103. else
  104. {
  105. var group = await CheckGroup(groupNo,isStart:true);
  106. await WriteLog(group.CampNo, groupNo, group.RoundIndex, LogCommandDefinition.Start);
  107. groupNos.Add(groupNo);
  108. camp = group.CampInfo;
  109. if (group.CampGroupState == CampGroupStateDefinition.Run)
  110. {
  111. CheckErrors($"培训营[{group.Name}]已运行,不能操作!");
  112. }
  113. //if (WeAppMsgClientManager.StartGroupNos.Contains(groupNo))
  114. //{
  115. // WeAppMsgClientManager.StartGroupNos.Remove(groupNo);
  116. //}
  117. }
  118. if (camp == null)
  119. {
  120. CheckErrors($"未查询编号为【{campNo}】到培训营!");
  121. return;
  122. }
  123. if (camp.CampState == CampStateDefinition.New)
  124. {
  125. CheckErrors("培训营未审核,请先通过审核后再试!");
  126. }
  127. else if (camp.CampState == CampStateDefinition.End)
  128. {
  129. CheckErrors("培训营已结束,不能操作!");
  130. }
  131. WeAppMsgClientManager.StopPushScene(groupNo);
  132. RunStartPackageDto dto = new RunStartPackageDto()
  133. {
  134. PackageId = camp.PackageNo,
  135. AssessAuto = camp.AssessAuto,
  136. AssessRoles = camp.AssessRoleNames?.Split(',').ToList() ?? new List<string>(),
  137. AutoNextRound = false,
  138. RoundScore = camp.RoundScore,
  139. Variable = camp.Variable,
  140. GroupNos = groupNos,
  141. TargetClientId = MsgClientManager.ClientId
  142. };
  143. var url = $"{EngineApiUrl}api/services/Engine/Run/Start";
  144. var result = url.RequestPost(dto.Obj2String());
  145. if (result.Contains("\"success\":false"))
  146. {
  147. CheckErrors("培训营启动失败!");
  148. }
  149. }
  150. /// <summary>
  151. /// 停止培训营
  152. /// </summary>
  153. /// <param name="campNo"></param>
  154. /// <param name="groupNo"></param>
  155. /// <returns></returns>
  156. [AuditLog("停止培训营")]
  157. public async Task StopCamp(string campNo, string groupNo)
  158. {
  159. if (groupNo == "none")
  160. {
  161. var groups = await GroupRepository.GetAll().Where(a => a.CampNo == campNo && a.CampGroupState != CampGroupStateDefinition.End).OrderBy(a => a.Id).ToListAsync();
  162. foreach (var g in groups)
  163. {
  164. await WriteLog(g.CampNo, g.Id, g.RoundIndex, LogCommandDefinition.End);
  165. g.EngDate = g.EngDate ?? DateTime.Now;
  166. g.CampGroupState = CampGroupStateDefinition.End;
  167. await GroupRepository.UpdateAsync(g);
  168. ReloadPage(g.CampNo);
  169. }
  170. }
  171. else
  172. {
  173. var group = await CheckGroup(groupNo);
  174. if (group.CampGroupState != CampGroupStateDefinition.End)
  175. {
  176. group.EngDate = group.EngDate ?? DateTime.Now;
  177. group.CampGroupState = CampGroupStateDefinition.End;
  178. await GroupRepository.UpdateAsync(group);
  179. await WriteLog(group.CampNo, groupNo, group.RoundIndex, LogCommandDefinition.End);
  180. await UnitOfWorkManager.Current.SaveChangesAsync();
  181. ReloadPage(group.CampNo);
  182. }
  183. }
  184. }
  185. /// <summary>
  186. /// 结束培训营
  187. /// </summary>
  188. /// <param name="campNo"></param>
  189. /// <returns></returns>
  190. [AuditLog("结束培训营")]
  191. public async Task EndCamp(string campNo)
  192. {
  193. var camp = await CampRepository.FirstOrDefaultAsync(a => a.Id == campNo);
  194. if (camp != null && camp.CampState != CampStateDefinition.End)
  195. {
  196. camp.EngDate = camp.EngDate ?? DateTime.Now;
  197. camp.CampState = CampStateDefinition.End;
  198. await CampRepository.UpdateAsync(camp);
  199. }
  200. }
  201. /// <summary>
  202. /// 等待报告生成
  203. /// </summary>
  204. /// <param name="campNo"></param>
  205. /// <param name="groupNo"></param>
  206. /// <returns></returns>
  207. [AuditLog("等待报告生成")]
  208. public async Task WaitReport(string campNo, string groupNo)
  209. {
  210. var date = DateTime.Now;
  211. CampInfo camp;
  212. if (groupNo == "none")
  213. {
  214. camp = await CampRepository.FirstOrDefaultAsync(a => a.Id == campNo);
  215. if (camp.CampState == CampStateDefinition.End)
  216. {
  217. CheckErrors("演练已结束,不能操作");
  218. }
  219. var groups = await GroupRepository.GetAll().Where(a => a.CampNo == campNo).OrderBy(a => a.Id).ToListAsync();
  220. foreach (var g in groups)
  221. {
  222. await WriteLog(g.CampNo, g.Id, g.RoundIndex, LogCommandDefinition.End);
  223. g.CampGroupState = CampGroupStateDefinition.Report;
  224. g.EngDate = date;
  225. g.TrainingMinute = Convert.ToDateTime(g.StartDate).GetTimeSpanMinute(date);
  226. await GroupRepository.UpdateAsync(g);
  227. ReloadPage(g.CampNo);
  228. }
  229. }
  230. else
  231. {
  232. var group = await CheckGroup(groupNo);
  233. camp = group.CampInfo;
  234. if (camp.CampState==CampStateDefinition.End)
  235. {
  236. CheckErrors("演练已结束,不能操作");
  237. }
  238. group.CampGroupState = CampGroupStateDefinition.Report;
  239. group.EngDate = date;
  240. group.TrainingMinute = Convert.ToDateTime(group.StartDate).GetTimeSpanMinute(date);
  241. await GroupRepository.UpdateAsync(group);
  242. await WriteLog(group.CampNo, groupNo, group.RoundIndex, LogCommandDefinition.End);
  243. ReloadPage(group.CampNo);
  244. }
  245. camp.EngDate = date;
  246. await CampRepository.UpdateAsync(camp);
  247. }
  248. /// <summary>
  249. /// 重启培训营
  250. /// </summary>
  251. /// <param name="campNo"></param>
  252. /// <param name="groupNo"></param>
  253. /// <returns></returns>
  254. [AuditLog("重启培训营")]
  255. public async Task ReStartCamp(string campNo, string groupNo)
  256. {
  257. CampInfo camp;
  258. var groups = new List<CampGroupInfo>();
  259. if (groupNo == "none")
  260. {
  261. camp = await CampRepository.FirstOrDefaultAsync(a => a.Id == campNo);
  262. groups = await GroupRepository.GetAll().Where(a => a.CampNo == campNo).OrderBy(a => a.Id).ToListAsync();
  263. //groupNos = groups.Select(a => a.Id).ToList();
  264. foreach (var g in groups)
  265. {
  266. await WriteLog(g.CampNo, g.Id, g.RoundIndex, LogCommandDefinition.Start);
  267. }
  268. }
  269. else
  270. {
  271. var group = await CheckGroup(groupNo, isStart: true);
  272. await WriteLog(group.CampNo, groupNo, group.RoundIndex, LogCommandDefinition.Start);
  273. groups.Add(group);
  274. camp = group.CampInfo;
  275. }
  276. if (camp == null)
  277. {
  278. CheckErrors($"未查询编号为【{campNo}】到培训营!");
  279. return;
  280. }
  281. if (camp.CampState == CampStateDefinition.New)
  282. {
  283. CheckErrors("培训营未审核,请先通过审核后再试!");
  284. }
  285. else if (camp.CampState == CampStateDefinition.End)
  286. {
  287. CheckErrors("培训营已结束,不能操作!");
  288. }
  289. foreach (var g in groups)
  290. {
  291. //ReStartPackageDto dto = new ReStartPackageDto()
  292. //{
  293. // PackageId = camp.PackageNo,
  294. // AutoNextRound = false,
  295. // RunningInfo = g.RunningInfo,
  296. // TargetClientId = MsgClientManager.ClientId
  297. //};
  298. //var url = $"{EngineApiUrl}api/services/Engine/Run/ReStart";
  299. //var result = url.RequestPost(dto.Obj2String());
  300. //if (result.Contains("\"success\":false"))
  301. //{
  302. // CheckErrors("培训营启动失败!");
  303. //}
  304. ReStartGroup(g);
  305. Thread.Sleep(3000);
  306. }
  307. }
  308. /// <summary>
  309. /// 重启分组
  310. /// </summary>
  311. /// <param name="group"></param>
  312. /// <returns></returns>
  313. private bool ReStartGroup(CampGroupInfo group)
  314. {
  315. ReStartPackageDto dto = new ReStartPackageDto()
  316. {
  317. PackageId = group.CampInfo?.PackageNo,
  318. AutoNextRound = false,
  319. RunningInfo = group.RunningInfo,
  320. TargetClientId = MsgClientManager.ClientId
  321. };
  322. var url = $"{EngineApiUrl}api/services/Engine/Run/ReStart";
  323. var result = url.RequestPost(dto.Obj2String());
  324. if (result.Contains("\"success\":false"))
  325. {
  326. return false;
  327. }
  328. return true;
  329. }
  330. /// <summary>
  331. /// 下一轮次
  332. /// </summary>
  333. /// <param name="campNo"></param>
  334. /// <param name="groupNo"></param>
  335. /// <returns></returns>
  336. [AuditLog("下一轮次")]
  337. public async Task NextRound(string campNo, string groupNo)
  338. {
  339. string dataStr = "";
  340. string url = $"{EngineApiUrl}api/services/Engine/Run/NextRound";
  341. if (groupNo == "none")
  342. {
  343. var entity = await CampRepository.FirstOrDefaultAsync(a => a.Id == campNo);
  344. if (entity == null)
  345. {
  346. CheckErrors($"未查询编号为【{campNo}】到培训营!");
  347. return;
  348. }
  349. if (entity.CampState == CampStateDefinition.New)
  350. {
  351. CheckErrors("培训营未审核,请先通过审核后再试!");
  352. }
  353. if (entity.CampState == CampStateDefinition.End)
  354. {
  355. CheckErrors("培训营已结束!");
  356. }
  357. var groups = await GroupRepository.GetAll().Where(a => a.CampNo == campNo).OrderBy(a => a.Id).ToListAsync();
  358. //var groupNos = groups.Select(a => a.Id).ToList();
  359. //dataStr = new {GroupNos = groupNos}.Obj2String();
  360. foreach (var g in groups)
  361. {
  362. var postUrl = $"{url}?groupNo={g.Id}";
  363. Post(postUrl, dataStr,g);
  364. await WriteLog(g.CampNo, g.Id, g.RoundIndex, LogCommandDefinition.NextRound);
  365. Thread.Sleep(1000);
  366. }
  367. }
  368. else
  369. {
  370. var group = await CheckGroup(groupNo);
  371. await WriteLog(campNo, groupNo, group.RoundIndex, LogCommandDefinition.NextRound);
  372. url = $"{url}?groupNo={groupNo}";
  373. Post(url,dataStr,group);
  374. }
  375. //url = $"{EngineApiUrl}api/services/Engine/Run/NextRound{url}";
  376. //var result = url.RequestPost(dataStr);
  377. //if (result.Contains("\"success\":false"))
  378. //{
  379. // CheckErrors("培训营操作失败!");
  380. //}
  381. }
  382. /// <summary>
  383. /// 操作培训营分组
  384. /// </summary>
  385. /// <param name="url"></param>
  386. /// <param name="dataStr"></param>
  387. /// <param name="group"></param>
  388. /// <param name="send"></param>
  389. private void Post(string url,string dataStr,CampGroupInfo group=null,bool send=true)
  390. {
  391. var result = url.RequestPost(dataStr);
  392. if (result.Contains("\"success\":false"))
  393. {
  394. if (!HasReStart && group!=null && ReStartGroup(group))
  395. {
  396. HasReStart = true;
  397. Post(url, dataStr, group,send);
  398. }
  399. else
  400. {
  401. HasReStart = false;
  402. CheckErrors("培训营操作失败!");
  403. }
  404. }
  405. else if(send && group!=null)
  406. {
  407. IwbHubContext.Clients.Group(group?.CampNo).getDisabledScene(group?.Id);
  408. }
  409. }
  410. /// <summary>
  411. /// 下一情景流节点
  412. /// </summary>
  413. /// <param name="campNo"></param>
  414. /// <param name="groupNo"></param>
  415. /// <returns></returns>
  416. [AbpAllowAnonymous, AuditLog("下一情景流节点")]
  417. public async Task NextFlowNode(string campNo, string groupNo)
  418. {
  419. string url = "", dataStr = "";
  420. url = $"{EngineApiUrl}api/services/Engine/Run/NextGroupFlowNodes{url}";
  421. if (groupNo == "none")
  422. {
  423. var entity = await CampRepository.FirstOrDefaultAsync(a => a.Id == campNo);
  424. if (entity == null)
  425. {
  426. CheckErrors($"未查询编号为【{campNo}】到培训营!");
  427. return;
  428. }
  429. if (entity.CampState == CampStateDefinition.New)
  430. {
  431. CheckErrors("培训营未审核,请先通过审核后再试!");
  432. }
  433. if (entity.CampState == CampStateDefinition.End)
  434. {
  435. CheckErrors("培训营已结束!");
  436. }
  437. var groups = await GroupRepository.GetAll().Where(a => a.CampNo == campNo).ToListAsync();
  438. //var groupNos = await GroupRepository.GetAll().Where(a => a.CampNo == campNo).Select(a => a.Id).ToListAsync();
  439. //var dto = new RunGroupPackageDto()
  440. //{
  441. // GroupNos = groupNos
  442. //};
  443. //dataStr = dto.Obj2String();
  444. foreach (var g in groups)
  445. {
  446. var postUrl = $"{url}?groupNo={g.Id}";
  447. Post(postUrl, dataStr, g);
  448. await WriteLog(g.CampNo, g.Id, g.RoundIndex, LogCommandDefinition.NextNode);
  449. await ChangeLogState(g.Id);
  450. Thread.Sleep(1000);
  451. }
  452. //for (int i = 0; i < groupNos.Count; i++)
  453. //{
  454. // if (i == 0)
  455. // {
  456. // var group = await GroupRepository.FirstOrDefaultAsync(a => a.Id == groupNos[0]);
  457. // if (group != null)
  458. // {
  459. // }
  460. // }
  461. // await ChangeLogState(g.Id);
  462. //}
  463. }
  464. else
  465. {
  466. var group = await CheckGroup(groupNo);
  467. await ChangeLogState(group);
  468. await WriteLog(group.CampNo, groupNo, group.RoundIndex, LogCommandDefinition.NextNode);
  469. url = $"{url}?groupNo={groupNo}";
  470. Post(url, dataStr, group);
  471. }
  472. //var result = url.RequestPost(dataStr);
  473. //if (result.Contains("\"success\":false"))
  474. //{
  475. // CheckErrors("培训营操作失败!");
  476. //}
  477. }
  478. private async Task<CampGroupInfo> CheckGroup(string groupNo, CampGroupInfo group=null,bool isStart=false)
  479. {
  480. group = group ?? await GroupRepository.GetAllIncluding(a=>a.CampInfo).FirstOrDefaultAsync(a => a.Id == groupNo);
  481. if (group == null)
  482. {
  483. CheckErrors($"未查询编号为【{groupNo}】到培训营!");
  484. return null;
  485. }
  486. if (group.CampGroupState == CampGroupStateDefinition.End)
  487. {
  488. CheckErrors("培训营已结束,不能操作!");
  489. }
  490. else if (group.CampGroupState != CampGroupStateDefinition.Run&& !isStart)
  491. {
  492. CheckErrors("培训营未运行,不能操作!");
  493. }
  494. return group;
  495. }
  496. private async Task ChangeLogState(string no)
  497. {
  498. var group = await GroupRepository.FirstOrDefaultAsync(a => a.Id == no);
  499. if (group != null)
  500. {
  501. await ChangeLogState(group);
  502. }
  503. }
  504. private async Task ChangeLogState(CampGroupInfo group)
  505. {
  506. var logList = await GlRepository.GetAllListAsync(a =>
  507. a.GroupNo == group.Id && a.RoundIndex == group.RoundIndex &&
  508. a.LogType == LogTypeDefinition.SceneOperation &&
  509. (a.LogState == LogStateDefinition.New || a.LogState == LogStateDefinition.Submit|| a.LogState == LogStateDefinition.HasMatch));
  510. if (logList.Any())
  511. {
  512. foreach (var log in logList)
  513. {
  514. log.LogState = log.LogState == LogStateDefinition.New ? LogStateDefinition.NotSend :
  515. log.LogState == LogStateDefinition.Submit ? LogStateDefinition.Send : log.LogState == LogStateDefinition.HasMatch ? LogStateDefinition.HasSendMatch : log.LogState;
  516. await GlRepository.UpdateAsync(log);
  517. }
  518. }
  519. }
  520. /// <summary>
  521. /// 提交情景处理
  522. /// </summary>
  523. /// <param name="input"></param>
  524. /// <returns></returns>
  525. [AbpAllowAnonymous, AuditLog("提交情景处理")]
  526. public async Task SaveOperationScene(RunOperationDto input)
  527. {
  528. var group = await GroupRepository.FirstOrDefaultAsync(a => a.Id == input.GroupNo);
  529. if (group == null)
  530. {
  531. CheckErrors($"未查询编号为【{input.GroupNo}】到培训营!");
  532. return;
  533. }
  534. var groupLog = new GroupLogInfo()
  535. {
  536. CampNo = group.CampNo,
  537. GroupNo = input.GroupNo,
  538. LogType = LogTypeDefinition.SceneOperation,
  539. LogCommand = LogCommandDefinition.SceneOperation,
  540. LogState = LogStateDefinition.New,
  541. LogScore = 0,
  542. RoleName = input.BehaviorRole,
  543. LogMessage = input.BehaviorWord,
  544. RoundIndex = group.RoundIndex
  545. };
  546. await GlRepository.InsertAsync(groupLog);
  547. await CurrentUnitOfWork.SaveChangesAsync();
  548. IwbHubContext.Clients.Group(group.CampNo).getOperationLog(new
  549. {
  550. id = groupLog.Id,
  551. no = group.Id,
  552. role = input.BehaviorRole,
  553. word = input.BehaviorWord,
  554. logState = LogStateDefinition.New
  555. }.Obj2String());
  556. }
  557. /// <summary>
  558. /// 处理情景
  559. /// </summary>
  560. /// <param name="id"></param>
  561. /// <returns></returns>
  562. [AbpAllowAnonymous, AuditLog("处理情景")]
  563. public async Task OperationScene(int id)
  564. {
  565. var log = await GlRepository.FirstOrDefaultAsync(a => a.Id == id);
  566. if (log == null)
  567. {
  568. CheckErrors("未查询到处理记录!");
  569. return;
  570. }
  571. var group = await GroupRepository.GetAllIncluding(a=>a.CampInfo).FirstOrDefaultAsync(a => a.Id == log.GroupNo);
  572. if (group == null)
  573. {
  574. CheckErrors($"未查询编号为【{log.GroupNo}】到培训营!");
  575. return;
  576. }
  577. if (group.CampGroupState != CampGroupStateDefinition.Run)
  578. {
  579. CheckErrors("培训营未运行!");
  580. }
  581. var checkRole = (await SettingManager.GetSettingValueAsync(IwbSettingNames.EvalCheckRole)).UAndT()=="Y"&& group.CampInfo.AssessRoleNames.IsNotEmpty();
  582. log.LogState = LogStateDefinition.Submit;
  583. await GlRepository.UpdateAsync(log);
  584. var dataStr = new
  585. {
  586. log.GroupNo,
  587. BehaviorRole = log.RoleName,
  588. BehaviorWord = $"{log.Id}|{log.LogMessage}",
  589. CheckRole = checkRole
  590. }.Obj2String();
  591. string url = $"{EngineApiUrl}api/services/Engine/Run/MatchWord";
  592. Post(url,dataStr,group,false);
  593. //var result = url.RequestPost(dataStr);
  594. //if (result.Contains("\"success\":false"))
  595. //{
  596. // CheckErrors("培训营操作失败!");
  597. //}
  598. IwbHubContext.Clients.Group(group.CampNo).getOperationLogSubmit(new { no = group.Id, logId = log.Id }.Obj2String());
  599. }
  600. /// <summary>
  601. /// 变更状态
  602. /// </summary>
  603. /// <param name="campNo"></param>
  604. /// <param name="groupNo"></param>
  605. /// <param name="groupState"></param>
  606. /// <returns></returns>
  607. [AuditLog("变更状态")]
  608. public async Task ChangeState(string campNo, string groupNo, int groupState)
  609. {
  610. if (groupState != CampGroupStateDefinition.Ready && groupState != CampGroupStateDefinition.HeadQuarterBuilding && groupState != CampGroupStateDefinition.HeadQuarterBuilded)
  611. {
  612. CheckErrors($"非法状态!");
  613. }
  614. string text = groupState == CampGroupStateDefinition.Ready ? "演练已就绪" :
  615. groupState == CampGroupStateDefinition.HeadQuarterBuilding ? "正在组建指挥部" :
  616. groupState == CampGroupStateDefinition.HeadQuarterBuilded ? "指挥部已组建" : "";
  617. if (groupNo == "none")
  618. {
  619. var groups = await GroupRepository.GetAllIncluding(a => a.CampInfo).Where(a => a.CampNo == campNo)
  620. .ToListAsync();
  621. foreach (var g in groups)
  622. {
  623. await ChangGroupState(g, groupState);
  624. await CurrentUnitOfWork.SaveChangesAsync();
  625. IwbHubContext.Clients.Group(campNo).getHeadquarter(new { no = g.Id, text }.Obj2String());
  626. }
  627. ReloadPage(campNo);
  628. }
  629. else
  630. {
  631. var group = await GroupRepository.GetAllIncluding(a => a.CampInfo).FirstOrDefaultAsync(a => a.Id == groupNo);
  632. if (group == null)
  633. {
  634. CheckErrors($"未查询编号为【{groupNo}】到培训营!");
  635. return;
  636. }
  637. await ChangGroupState(group, groupState);
  638. await CurrentUnitOfWork.SaveChangesAsync();
  639. ReloadPage(groupNo);
  640. IwbHubContext.Clients.Group(group.CampNo).getHeadquarter(new { no = groupNo, text }.Obj2String());
  641. }
  642. }
  643. /// <summary>
  644. /// 保存分组评分
  645. /// </summary>
  646. /// <param name="input"></param>
  647. /// <returns></returns>
  648. [AuditLog("保存分组评分")]
  649. public async Task SaveGroupScore(List<GroupScoreDto> input)
  650. {
  651. foreach (var gs in input)
  652. {
  653. var group = await GroupRepository.FirstOrDefaultAsync(a => a.Id == gs.GroupNo);
  654. if (group == null || group.CampGroupState == CampGroupStateDefinition.New)
  655. {
  656. CheckErrors($"分组【{gs.GroupNo}】不在运行状态,不能操作");
  657. }
  658. var entity = await GsRepository.FirstOrDefaultAsync(a => a.GroupNo == gs.GroupNo && a.RoundIndex == gs.RoundIndex);
  659. if (entity == null)
  660. {
  661. entity = ObjectMapper.Map<GroupScoreInfo>(gs);
  662. await GsRepository.InsertAsync(entity);
  663. }
  664. else
  665. {
  666. entity = ObjectMapper.Map(gs, entity);
  667. await GsRepository.UpdateAsync(entity);
  668. }
  669. await CurrentUnitOfWork.SaveChangesAsync();
  670. await CacheManager.GetCache(IwbCacheNames.GroupRunningInfoCache)
  671. .SetAsync($"SCORE-{gs.GroupNo}-{gs.RoundIndex}", entity);
  672. if (gs.IsSend)
  673. {
  674. string url = $"{EngineApiUrl}api/services/Engine/Run/CorrectScore?groupNo={entity.GroupNo}&score={entity.FinalTotalScore}";
  675. var result = url.RequestPost("");
  676. if (result.Contains("\"success\":false"))
  677. {
  678. CheckErrors("培训营评分发送失败!");
  679. }
  680. }
  681. }
  682. foreach (var gs in input)
  683. {
  684. if (gs.IsSend)
  685. {
  686. IwbHubContext.Clients.Group(gs.CampNo)
  687. .getSendScore(new {no = gs.GroupNo, systemScore = gs.FinalTotalScore}.Obj2String());
  688. }
  689. }
  690. }
  691. /// <summary>
  692. /// 保存分组角色
  693. /// </summary>
  694. /// <param name="input"></param>
  695. /// <returns></returns>
  696. [AbpAllowAnonymous, AuditLog("保存分组角色")]
  697. public async Task CreateGroupRole(RoleGroupDto input)
  698. {
  699. var entity = await GroupRepository.GetAllIncluding(a => a.CampInfo)
  700. .FirstOrDefaultAsync(a => a.Id == input.GroupNo);
  701. if (entity == null)
  702. {
  703. CheckErrors($"未查询到编号未【{input.GroupNo}】的培训营分组");
  704. return;
  705. }
  706. var list = new List<string>();
  707. string roleGroupNos = "", customRoles = "";
  708. if (input.SelfRoleNames != null && input.SelfRoleNames.Any())
  709. {
  710. list.AddRange(input.SelfRoleNames);
  711. customRoles = string.Join(",", input.SelfRoleNames.ToArray());
  712. }
  713. if (input.RoleGroupNos != null)
  714. {
  715. roleGroupNos = string.Join(",", input.RoleGroupNos.ToArray());
  716. foreach (var no in input.RoleGroupNos)
  717. {
  718. var roleNames = await GrrRepository.GetAllIncluding(a => a.TrainingRoleInfo)
  719. .Where(a => a.RoleGroupNo == no).Select(a => a.TrainingRoleInfo.RoleName).ToListAsync();
  720. if (roleNames.Any())
  721. {
  722. foreach (var name in roleNames)
  723. {
  724. if (!list.Contains(name)) list.Add(name);
  725. }
  726. }
  727. }
  728. }
  729. string names = string.Join(",", list.ToArray());
  730. var roleInfo = await GroupRoleRepository.FirstOrDefaultAsync(a => a.GroupNo == input.GroupNo);
  731. if (roleInfo == null)
  732. {
  733. roleInfo = new GroupRoleInfo
  734. {
  735. GroupNo = input.GroupNo, RoleNames = names, RoleGroupNos = roleGroupNos, CustomRoles = customRoles,
  736. };
  737. await GroupRoleRepository.InsertAsync(roleInfo);
  738. }
  739. else
  740. {
  741. roleInfo.RoleNames = names;
  742. roleInfo.RoleGroupNos = roleGroupNos;
  743. roleInfo.CustomRoles = customRoles;
  744. await GroupRoleRepository.UpdateAsync(roleInfo);
  745. }
  746. await CurrentUnitOfWork.SaveChangesAsync();
  747. entity.CampGroupState = CampGroupStateDefinition.HeadQuarterBuilded;
  748. await GroupRepository.UpdateAsync(entity);
  749. await CurrentUnitOfWork.SaveChangesAsync();
  750. await CacheManager.GetCache(IwbCacheNames.GroupInfoCache).RemoveAsync($"Plan-{input.GroupNo}");
  751. ReloadPage(entity.Id);
  752. IwbHubContext.Clients.Group(entity.Id).getGroupRole(new { no = entity.Id }.Obj2String());
  753. IwbHubContext.Clients.Group(entity.Id).getHeadquarter(new { no = entity.Id, text = "指挥部已组建" }.Obj2String());
  754. }
  755. /// <summary>
  756. /// 刷新前台页面
  757. /// </summary>
  758. /// <param name="no"></param>
  759. private void ReloadPage(string no)
  760. {
  761. IwbHubContext.Clients.Group(no).getReloadStu(new { no }.Obj2String());
  762. IwbHubContext.Clients.Group(no).getReloadLeader(new { no }.Obj2String());
  763. IwbHubContext.Clients.Group(no).getReloadPublic(new { no }.Obj2String());
  764. }
  765. /// <summary>
  766. /// 手动记录
  767. /// </summary>
  768. /// <param name="input"></param>
  769. /// <returns></returns>
  770. [AbpAllowAnonymous, AuditLog("手动记录")]
  771. public async Task ManualLog(LogDto input)
  772. {
  773. var group = await GroupRepository.FirstOrDefaultAsync(a => a.Id == input.No);
  774. if (group == null)
  775. {
  776. CheckErrors($"未查询编号为【{input.No}】到培训营!");
  777. return;
  778. }
  779. await WriteLog(group.CampNo, input.No, group.RoundIndex, LogCommandDefinition.Manual, input.Msg,
  780. logType: LogTypeDefinition.Manual);
  781. }
  782. /// <summary>
  783. /// 专家评语
  784. /// </summary>
  785. /// <param name="input"></param>
  786. /// <returns></returns>
  787. [AbpAllowAnonymous, AuditLog("专家评语")]
  788. public async Task ZhuanJiaLog(LogDto input)
  789. {
  790. var group = await GroupRepository.FirstOrDefaultAsync(a => a.Id == input.No);
  791. if (group == null)
  792. {
  793. CheckErrors($"未查询编号为【{input.No}】到培训营!");
  794. return;
  795. }
  796. await WriteLog(group.CampNo, input.No, group.RoundIndex, LogCommandDefinition.ZhuanJia, input.Msg,
  797. logType: LogTypeDefinition.ZhuanJia);
  798. }
  799. /// <summary>
  800. /// 更新日志
  801. /// </summary>
  802. /// <param name="input"></param>
  803. /// <returns></returns>
  804. [AbpAllowAnonymous,DisableAuditing]
  805. public async Task UpdateLog(UpdateLogDto input)
  806. {
  807. var log = await GlRepository.FirstOrDefaultAsync(a => a.Id == input.Id);
  808. if (log != null)
  809. {
  810. log.LogMessage = input.Text;
  811. await GlRepository.UpdateAsync(log);
  812. }
  813. }
  814. #endregion
  815. #region Query
  816. /// <summary>
  817. /// 查询当前情景的处理日志
  818. /// </summary>
  819. /// <param name="no"></param>
  820. /// <returns></returns>
  821. [DisableAuditing]
  822. public async Task<List<GroupRoleLogDto>> GetCurrentSceneLog(string no)
  823. {
  824. var group = await GroupRepository.FirstOrDefaultAsync(a => a.Id == no);
  825. if (group == null)
  826. {
  827. CheckErrors($"未查询编号为【{no}】到培训营!");
  828. return null;
  829. }
  830. var query = GlRepository.GetAll().Where(a =>
  831. a.GroupNo == no && a.LogType == LogTypeDefinition.SceneOperation &&
  832. a.RoundIndex == group.RoundIndex &&
  833. (a.LogState == LogStateDefinition.New || a.LogState == LogStateDefinition.Submit || a.LogState == LogStateDefinition.HasMatch))
  834. .OrderByDescending(a => a.Id).Select(a => new GroupRoleLogDto()
  835. {
  836. Id = a.Id,
  837. GroupNo = no,
  838. Role = a.RoleName,
  839. Word = a.LogMessage,
  840. LogState = a.LogState
  841. });
  842. var dtoList = await query.ToListAsync();
  843. return dtoList;
  844. }
  845. /// <summary>
  846. /// 查询当前轮次的处理日志
  847. /// </summary>
  848. /// <param name="no"></param>
  849. /// <returns></returns>
  850. [DisableAuditing]
  851. public async Task<List<GroupRoleLogDto>> GetRoundLog(string no)
  852. {
  853. var group = await GroupRepository.FirstOrDefaultAsync(a => a.Id == no);
  854. if (group == null)
  855. {
  856. CheckErrors($"未查询编号为【{no}】到培训营!");
  857. return null;
  858. }
  859. var query = GlRepository.GetAll().Where(a =>
  860. a.GroupNo == no && a.LogType == LogTypeDefinition.SceneOperation &&
  861. a.RoundIndex == group.RoundIndex)
  862. .OrderByDescending(a => a.Id).Select(a => new GroupRoleLogDto()
  863. {
  864. Id = a.Id,
  865. GroupNo = no,
  866. Role = a.RoleName,
  867. Word = a.LogMessage,
  868. LogState = a.LogState
  869. });
  870. var dtoList = await query.ToListAsync();
  871. return dtoList;
  872. }
  873. /// <summary>
  874. /// 查询所有处理日志
  875. /// </summary>
  876. /// <param name="no"></param>
  877. /// <returns></returns>
  878. [DisableAuditing]
  879. public async Task<List<GroupRoleLogDto>> GetAllLog(string no)
  880. {
  881. var group = await GroupRepository.FirstOrDefaultAsync(a => a.Id == no);
  882. if (group == null)
  883. {
  884. CheckErrors($"未查询编号为【{no}】到培训营!");
  885. return null;
  886. }
  887. var query = GlRepository.GetAll().Where(a => a.GroupNo == no && a.LogType == LogTypeDefinition.SceneOperation)
  888. .OrderByDescending(a => a.Id).Select(a => new GroupRoleLogDto()
  889. {
  890. Id = a.Id,
  891. GroupNo = no,
  892. Role = a.RoleName,
  893. Word = a.LogMessage,
  894. LogState = a.LogState
  895. });
  896. var dtoList = await query.ToListAsync();
  897. return dtoList;
  898. }
  899. /// <summary>
  900. /// 查询所有处理日志
  901. /// </summary>
  902. /// <param name="no"></param>
  903. /// <param name="roleName"></param>
  904. /// <returns></returns>
  905. [DisableAuditing]
  906. public async Task<List<GroupRoleLogDto>> GetAllRoleLog(string no, string roleName)
  907. {
  908. var group = await GroupRepository.FirstOrDefaultAsync(a => a.Id == no);
  909. if (group == null)
  910. {
  911. CheckErrors($"未查询编号为【{no}】到培训营!");
  912. return null;
  913. }
  914. var query = GlRepository.GetAll().Where(a => a.GroupNo == no && a.LogType == LogTypeDefinition.SceneOperation && a.RoleName == roleName)
  915. .OrderByDescending(a => a.Id).Select(a => new GroupRoleLogDto()
  916. {
  917. GroupNo = no,
  918. Role = a.RoleName,
  919. Word = a.LogMessage,
  920. LogState = a.LogState
  921. });
  922. var dtoList = await query.ToListAsync();
  923. return dtoList;
  924. }
  925. /// <summary>
  926. /// 记录日志
  927. /// </summary>
  928. /// <param name="campNo"></param>
  929. /// <param name="groupNo"></param>
  930. /// <param name="round"></param>
  931. /// <param name="cmd"></param>
  932. /// <param name="logMsg"></param>
  933. /// <param name="role"></param>
  934. /// <param name="score"></param>
  935. /// <param name="logType"></param>
  936. /// <returns></returns>
  937. private async Task WriteLog(string campNo, string groupNo, int round, string cmd, string logMsg = "", string role = "", decimal score = 0, int? logType = null)
  938. {
  939. logType = logType ?? LogTypeDefinition.System;
  940. var groupLog = new GroupLogInfo()
  941. {
  942. CampNo = campNo,
  943. GroupNo = groupNo,
  944. RoundIndex = round,
  945. LogCommand = cmd,
  946. LogMessage = logMsg,
  947. RoleName = role,
  948. LogType = (int)logType,
  949. LogScore = score
  950. };
  951. await GlRepository.InsertAsync(groupLog);
  952. await CurrentUnitOfWork.SaveChangesAsync();
  953. }
  954. /// <summary>
  955. /// 变更分组状态
  956. /// </summary>
  957. /// <param name="group"></param>
  958. /// <param name="groupState"></param>
  959. /// <returns></returns>
  960. private async Task ChangGroupState(CampGroupInfo group, int groupState)
  961. {
  962. var camp = group.CampInfo;
  963. if (group.CampGroupState == CampGroupStateDefinition.Run)
  964. {
  965. CheckErrors("培训营已运行!");
  966. }
  967. if (camp == null)
  968. {
  969. CheckErrors($"未查询编号为【{group.CampNo}】到培训营!");
  970. return;
  971. }
  972. if (camp.CampState == CampStateDefinition.New)
  973. {
  974. CheckErrors("培训营未审核,请先通过审核后再试!");
  975. }
  976. group.CampGroupState = groupState;
  977. await GroupRepository.UpdateAsync(group);
  978. }
  979. /// <summary>
  980. /// 获取培训营详情
  981. /// </summary>
  982. /// <param name="no"></param>
  983. /// <returns></returns>
  984. [DisableAuditing]
  985. public async Task<CampDetailDto> GetCampDetail(string no)
  986. {
  987. var entity = await CampRepository.FirstOrDefaultAsync(a => a.Id == no);
  988. if (entity == null)
  989. {
  990. CheckErrors($"未查询编号为【{no}】到培训营!");
  991. return null;
  992. }
  993. if (entity.CampState == CampStateDefinition.New)
  994. {
  995. CheckErrors("培训营未审核,请先通过审核后再试!");
  996. }
  997. if (entity.CampState == CampStateDefinition.End)
  998. {
  999. CheckErrors("培训营已结束!");
  1000. }
  1001. var groupInfos = await GroupRepository.GetAllListAsync(a => a.CampNo == no);
  1002. var groups = new List<GroupDto>();
  1003. foreach (var group in groupInfos)
  1004. {
  1005. var groupDto = await MapGroupDto(group);
  1006. groups.Add(groupDto);
  1007. }
  1008. return new CampDetailDto()
  1009. {
  1010. Id = no,
  1011. Name = entity.Name,
  1012. PackageNo = entity.PackageNo,
  1013. PackageName = entity.PackageName,
  1014. CampState = entity.CampState,
  1015. ScoreRule = entity.ScoreRule,
  1016. RoundScore = entity.RoundScore,
  1017. EvalBehaviorTags = entity.EvalBehaviorTags,
  1018. Groups = groups
  1019. };
  1020. }
  1021. /// <summary>
  1022. /// 获取培训营分组详情
  1023. /// </summary>
  1024. /// <param name="no"></param>
  1025. /// <returns></returns>
  1026. [AbpAllowAnonymous, DisableAuditing]
  1027. public async Task<GroupDto> GetGroupDetail(string no)
  1028. {
  1029. var group = await GroupRepository.FirstOrDefaultAsync(a => a.Id == no);
  1030. if (group == null)
  1031. {
  1032. CheckErrors($"未查询编号为【{no}】到培训营!");
  1033. return null;
  1034. }
  1035. var dto = await MapGroupDto(group);
  1036. return dto;
  1037. }
  1038. /// <summary>
  1039. /// 映射分组详情
  1040. /// </summary>
  1041. /// <param name="group"></param>
  1042. /// <returns></returns>
  1043. private async Task<GroupDto> MapGroupDto(CampGroupInfo group)
  1044. {
  1045. var dto = new GroupDto()
  1046. {
  1047. Id = group.Id,
  1048. Name = group.Name,
  1049. CampNo = group.CampNo,
  1050. CampGroupState = group.CampGroupState,
  1051. StartDate = group.StartDate,
  1052. EngDate = group.EngDate,
  1053. TrainingMinute = group.TrainingMinute,
  1054. RunningInfo = await GetGroupRunningInfo(group.Id),
  1055. //GroupScore = (await GsRepository.GetAllListAsync(s => s.GroupNo == group.Id)).Select(ObjectMapper.Map<GroupScoreDto>).ToList()
  1056. };
  1057. var gsList = await GsRepository.GetAllListAsync(a => a.GroupNo == group.Id);
  1058. dto.GroupScore = new List<GroupScoreDto>();
  1059. foreach (var gs in gsList)
  1060. {
  1061. var groupScore = await CacheManager.GetGroupRoundScore(group.Id, gs.RoundIndex, GsRepository);
  1062. if (groupScore != null)
  1063. {
  1064. dto.GroupScore.Add(ObjectMapper.Map<GroupScoreDto>(groupScore));
  1065. }
  1066. }
  1067. return dto;
  1068. }
  1069. /// <summary>
  1070. /// 获取分组运行信息
  1071. /// </summary>
  1072. /// <param name="no"></param>
  1073. /// <returns></returns>
  1074. [DisableAuditing]
  1075. public async Task<PackageDataNode> GetGroupRunningInfo(string no)
  1076. {
  1077. var runGroupInfo = await CacheManager.GetGroupRunningInfo(no, GroupRepository);
  1078. return runGroupInfo;
  1079. }
  1080. #endregion
  1081. }
  1082. }