ServerUpdateJob.cs 6.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138
  1. using EVCB_OCPP.Domain;
  2. using EVCB_OCPP.Packet.Messages.RemoteTrigger;
  3. using EVCB_OCPP.WSServer.Message;
  4. using EVCB_OCPP.WSServer.Service.WsService;
  5. using Microsoft.EntityFrameworkCore;
  6. using Microsoft.Extensions.Logging;
  7. using Quartz;
  8. using System;
  9. using System.Collections.Generic;
  10. using System.Collections.ObjectModel;
  11. using System.Linq;
  12. using System.Text;
  13. using System.Threading.Tasks;
  14. namespace EVCB_OCPP.WSServer.Jobs;
  15. [DisallowConcurrentExecution]
  16. public class ServerUpdateJob : IJob
  17. {
  18. private readonly ProtalServer protalServer;
  19. private readonly IDbContextFactory<MainDBContext> maindbContextFactory;
  20. private readonly ILogger<ServerUpdateJob> logger;
  21. public ServerUpdateJob(
  22. ProtalServer protalServer,
  23. IDbContextFactory<MainDBContext> maindbContextFactory,
  24. ILogger<ServerUpdateJob> logger)
  25. {
  26. this.protalServer = protalServer;
  27. this.maindbContextFactory = maindbContextFactory;
  28. this.logger = logger;
  29. }
  30. public async Task Execute(IJobExecutionContext context)
  31. {
  32. //logger.LogDebug("{0} Started", nameof(ServerUpdateJob));
  33. BasicMessageHandler msgAnalyser = new BasicMessageHandler();
  34. Dictionary<string, WsClientData> _copyClientDic = protalServer.GetClientDic();
  35. var checkUpdateDt = DateTime.UtcNow;
  36. List<string> needUpdateChargers = new List<string>();
  37. using (var db = await maindbContextFactory.CreateDbContextAsync())
  38. {
  39. //var needUpdateChargers = db.Machine.Where(x => x.FW_AssignedMachineVersionId.HasValue == true &&
  40. // x.FW_AssignedMachineVersionId != x.FwVersionReport && x.Online == true)
  41. // .Select(x => new { x.Id, x.ChargeBoxId, x.FW_AssignedMachineVersionId }).ToList();
  42. needUpdateChargers = await db.Machine.Where(x => x.FwAssignedVersion.HasValue == true &&
  43. x.FwAssignedVersion != x.FwVersionReport && x.Online == true)
  44. .Select(x => x.ChargeBoxId).AsNoTracking().ToListAsync();
  45. }
  46. foreach (var chargeBoxId in needUpdateChargers)
  47. {
  48. try
  49. {
  50. WsClientData session;
  51. if (_copyClientDic.TryGetValue(chargeBoxId, out session))
  52. {
  53. string requestId = Guid.NewGuid().ToString();
  54. // using (var db = maindbContextFactory.CreateDbContextAsync())
  55. if (session.IsCheckIn && !session.ISOCPP20)
  56. {
  57. var _request = new TriggerMessageRequest()
  58. {
  59. requestedMessage = Packet.Messages.SubTypes.MessageTrigger.FirmwareStatusNotification
  60. };
  61. var uuid = session.queue.store(_request);
  62. string rawRequest = BasicMessageHandler.GenerateRequest(uuid, _request.Action, _request);
  63. protalServer.SendMsg(session, rawRequest, string.Format("{0} {1}", _request.Action, "Request"), "");
  64. #region OCTT ,測試韌體更新方式
  65. //--------------------> OCTT ,測試韌體更新方式
  66. //{
  67. // var machine = db.Machine.Where(x => x.FW_AssignedMachineVersionId.HasValue == true &&
  68. // x.FW_AssignedMachineVersionId != x.FwVersionReport && x.ChargeBoxId == session.ChargeBoxId)
  69. // .Select(x => new { x.Id, x.FW_AssignedMachineVersionId }).FirstOrDefault();
  70. // if (machine != null)
  71. // {
  72. // var mv = db.MachineVersion.Include(c => c.PublishVersion)
  73. // .Include(c => c.PublishVersion.PublishVersionFiles)
  74. // .Include(c => c.PublishVersion.PublishVersionFiles.Select(z => z.UploadFile))
  75. // .Where(c => c.Id == machine.FW_AssignedMachineVersionId.Value).First();
  76. // string downloadUrl = mv.PublishVersion.PublishVersionFiles.FirstOrDefault().UploadFile.FileUrl;
  77. // var _updateFWrequest = new UpdateFirmwareRequest()
  78. // {
  79. // location = new Uri(downloadUrl),
  80. // retries = 3,
  81. // retrieveDate = DateTime.UtcNow,
  82. // retryInterval = 10
  83. // };
  84. // db.MachineOperateRecord.Add(new MachineOperateRecord()
  85. // {
  86. // CreatedOn = DateTime.UtcNow,
  87. // ChargeBoxId = session.ChargeBoxId,
  88. // SerialNo = requestId,
  89. // RequestContent = JsonConvert.SerializeObject(_updateFWrequest, new JsonSerializerSettings() { NullValueHandling = NullValueHandling.Ignore, Formatting = Formatting.None }),
  90. // EvseStatus = 0,
  91. // EvseValue = "Fw Version:" + machine.FW_AssignedMachineVersionId,
  92. // Status = 0,
  93. // RequestType = 0,
  94. // });
  95. // db.ServerMessage.Add(new ServerMessage()
  96. // {
  97. // ChargeBoxId = session.ChargeBoxId,
  98. // CreatedBy = "Server",
  99. // CreatedOn = DateTime.UtcNow,
  100. // OutAction = _updateFWrequest.Action.ToString(),
  101. // OutRequest = JsonConvert.SerializeObject(_updateFWrequest, new JsonSerializerSettings() { NullValueHandling = NullValueHandling.Ignore, Formatting = Formatting.None }),
  102. // SerialNo = requestId,
  103. // InMessage = string.Empty
  104. // });
  105. // await db.SaveChangesAsync();
  106. // }
  107. //}
  108. #endregion
  109. }
  110. }
  111. }
  112. catch (Exception ex)
  113. {
  114. logger.LogError("serverUpdateTrigger ChargeBoxId:{0} Ex:{1}", chargeBoxId, ex.ToString());
  115. }
  116. }
  117. }
  118. }