BasicInfoUpdateProcedure.cs 5.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using System.Net.Sockets;
  5. using System.Text;
  6. using System.Threading.Tasks;
  7. namespace AwInitilizer.Procedure
  8. {
  9. public class BasicInfoUpdateProcedure : ProcedureBase
  10. {
  11. public BasicInfoUpdateProcedure() : base()
  12. {
  13. Name = "Basic Intlize";
  14. Content = "Set and check Model Name,SerilNumber,DateTime.";
  15. }
  16. internal override async Task<bool> Run()
  17. {
  18. if (!await base.CheckAndCreateSocket())
  19. {
  20. InfoLog += "EVSE connect failed\n";
  21. return false;
  22. }
  23. //base.serialPortocol.OnMsgReceived += SerialPortocol_OnMsgReceived;
  24. if (!await serialPortocol.SetModelName(UpdateData.ModelName))
  25. {
  26. InfoLog += "Model Name update failed\n";
  27. Logger.Print("Model Name update Failed", isError: true);
  28. return false;
  29. }
  30. else
  31. {
  32. Logger.Print("Model Name write Success");
  33. }
  34. if (!await serialPortocol.SetSerialNumber(UpdateData.SerialNumber))
  35. {
  36. InfoLog += "Serial Number update failed\n";
  37. Logger.Print("Serial Number update Failed", isError: true);
  38. return false;
  39. }
  40. else
  41. {
  42. Logger.Print("Serial Number write Success");
  43. }
  44. var setDateTime = DateTime.Now.ToUniversalTime();
  45. if (!await serialPortocol.SetUTCTime(setDateTime))
  46. {
  47. InfoLog += "RTC update failed\n";
  48. Logger.Print("RTC update Failed", isError: true);
  49. return false;
  50. }
  51. else
  52. {
  53. Logger.Print("RTC update write Success");
  54. }
  55. if (!await serialPortocol.SettingChangeConfirm())
  56. {
  57. InfoLog += "Setting save request failed\n";
  58. Logger.Print("Setting save Failed", isError: true);
  59. return false;
  60. }
  61. else
  62. {
  63. Logger.Print("Setting save Success");
  64. }
  65. Logger.Print("Waiting EVSE reboot...");
  66. serialPortocol.Close();
  67. await Task.Delay(TimeSpan.FromMinutes(1));
  68. if (!await base.CheckAndCreateSocket())
  69. {
  70. InfoLog += "EVSE not found after reboot\n";
  71. Logger.Print("EVSE reboot timeout", isError: true);
  72. return false;
  73. }
  74. var receivedModelName = await serialPortocol.GetModelName();
  75. if (string.IsNullOrEmpty(receivedModelName))
  76. {
  77. InfoLog += "Model name get failed after reboot\n";
  78. Logger.Print("Model Name read Failed", isError: true);
  79. return false;
  80. }
  81. else
  82. {
  83. InfoLog += $"Get Updated Model Name { receivedModelName }\n";
  84. if (receivedModelName != UpdateData.ModelName)
  85. {
  86. InfoLog += "Updated Model Name Mismatched\n";
  87. Logger.Print("Stored Model Name Mismatched", isError: true);
  88. return false;
  89. }
  90. Logger.Print("Model Name update Success");
  91. }
  92. var receivedSeerialNumber = await serialPortocol.GetSerialNumber();
  93. if (string.IsNullOrEmpty(receivedSeerialNumber))
  94. {
  95. InfoLog += "Serial number get failed after reboot\n";
  96. Logger.Print("Stored Serial read Failed", isError: true);
  97. return false;
  98. }
  99. else
  100. {
  101. InfoLog += $"Get Updated serial number { receivedSeerialNumber }\n";
  102. if (receivedSeerialNumber != UpdateData.SerialNumber)
  103. {
  104. InfoLog += "Updated serial number mismatched\n";
  105. Logger.Print("Stored Serial Number Mismatched", isError: true);
  106. return false;
  107. }
  108. Logger.Print("Serial Number update Success");
  109. }
  110. var receivedDateTime = await serialPortocol.GetUTCTime();
  111. if (string.IsNullOrEmpty(receivedModelName))
  112. {
  113. InfoLog += "UTC Time receive failed after reboot\n";
  114. Logger.Print("UTC Time receive failed", isError: true);
  115. return false;
  116. }
  117. else
  118. {
  119. InfoLog += $"UTC Time received : {receivedDateTime.Value.ToString("yyyyMMddHHmmss")}\n";
  120. var diff = receivedDateTime.Value - DateTime.Now.ToUniversalTime();
  121. if (Math.Abs(diff.TotalSeconds) > 10)
  122. {
  123. InfoLog += "Stored UTC time Mismatched\n";
  124. Logger.Print("Stored UTC time Mismatched", isError: true);
  125. return false;
  126. }
  127. else
  128. {
  129. Logger.Print("Model Name update Success");
  130. }
  131. }
  132. return true;
  133. }
  134. }
  135. }