ServerUpdateJob.cs 6.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137
  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. [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, ClientData> _copyClientDic = protalServer.ClientDic;
  35. var checkUpdateDt = DateTime.UtcNow;
  36. using (var db = maindbContextFactory.CreateDbContext())
  37. {
  38. //var needUpdateChargers = db.Machine.Where(x => x.FW_AssignedMachineVersionId.HasValue == true &&
  39. // x.FW_AssignedMachineVersionId != x.FW_VersionReport && x.Online == true)
  40. // .Select(x => new { x.Id, x.ChargeBoxId, x.FW_AssignedMachineVersionId }).ToList();
  41. var needUpdateChargers = db.Machine.Where(x => x.FW_AssignedVersion.HasValue == true &&
  42. x.FW_AssignedVersion != x.FW_VersionReport && x.Online == true)
  43. .Select(x => x.ChargeBoxId).AsNoTracking().ToList();
  44. foreach (var chargeBoxId in needUpdateChargers)
  45. {
  46. try
  47. {
  48. ClientData session;
  49. if (_copyClientDic.TryGetValue(chargeBoxId, out session))
  50. {
  51. string requestId = Guid.NewGuid().ToString();
  52. // using (var db = maindbContextFactory.CreateDbContext())
  53. if (session.IsCheckIn && !session.ISOCPP20)
  54. {
  55. var _request = new TriggerMessageRequest()
  56. {
  57. requestedMessage = Packet.Messages.SubTypes.MessageTrigger.FirmwareStatusNotification
  58. };
  59. var uuid = session.queue.store(_request);
  60. string rawRequest = BasicMessageHandler.GenerateRequest(uuid, _request.Action, _request);
  61. protalServer.SendMsg(session, rawRequest, string.Format("{0} {1}", _request.Action, "Request"), "");
  62. #region OCTT ,測試韌體更新方式
  63. //--------------------> OCTT ,測試韌體更新方式
  64. //{
  65. // var machine = db.Machine.Where(x => x.FW_AssignedMachineVersionId.HasValue == true &&
  66. // x.FW_AssignedMachineVersionId != x.FW_VersionReport && x.ChargeBoxId == session.ChargeBoxId)
  67. // .Select(x => new { x.Id, x.FW_AssignedMachineVersionId }).FirstOrDefault();
  68. // if (machine != null)
  69. // {
  70. // var mv = db.MachineVersion.Include(c => c.PublishVersion)
  71. // .Include(c => c.PublishVersion.PublishVersionFiles)
  72. // .Include(c => c.PublishVersion.PublishVersionFiles.Select(z => z.UploadFile))
  73. // .Where(c => c.Id == machine.FW_AssignedMachineVersionId.Value).First();
  74. // string downloadUrl = mv.PublishVersion.PublishVersionFiles.FirstOrDefault().UploadFile.FileUrl;
  75. // var _updateFWrequest = new UpdateFirmwareRequest()
  76. // {
  77. // location = new Uri(downloadUrl),
  78. // retries = 3,
  79. // retrieveDate = DateTime.UtcNow,
  80. // retryInterval = 10
  81. // };
  82. // db.MachineOperateRecord.Add(new MachineOperateRecord()
  83. // {
  84. // CreatedOn = DateTime.UtcNow,
  85. // ChargeBoxId = session.ChargeBoxId,
  86. // SerialNo = requestId,
  87. // RequestContent = JsonConvert.SerializeObject(_updateFWrequest, new JsonSerializerSettings() { NullValueHandling = NullValueHandling.Ignore, Formatting = Formatting.None }),
  88. // EVSE_Status = 0,
  89. // EVSE_Value = "Fw Version:" + machine.FW_AssignedMachineVersionId,
  90. // Status = 0,
  91. // RequestType = 0,
  92. // });
  93. // db.ServerMessage.Add(new ServerMessage()
  94. // {
  95. // ChargeBoxId = session.ChargeBoxId,
  96. // CreatedBy = "Server",
  97. // CreatedOn = DateTime.UtcNow,
  98. // OutAction = _updateFWrequest.Action.ToString(),
  99. // OutRequest = JsonConvert.SerializeObject(_updateFWrequest, new JsonSerializerSettings() { NullValueHandling = NullValueHandling.Ignore, Formatting = Formatting.None }),
  100. // SerialNo = requestId,
  101. // InMessage = string.Empty
  102. // });
  103. // db.SaveChanges();
  104. // }
  105. //}
  106. #endregion
  107. }
  108. }
  109. }
  110. catch (Exception ex)
  111. {
  112. logger.LogError("serverUpdateTrigger ChargeBoxId:{0} Ex:{1}", chargeBoxId, ex.ToString());
  113. }
  114. }
  115. }
  116. }
  117. }