ServerUpdateJob.cs 7.0 KB

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