ServerUpdateJob.cs 6.5 KB

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