CoreProfileHandler.cs 44 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827
  1. using EVCB_OCPP.Domain;
  2. using EVCB_OCPP.Domain.Models.Database;
  3. using EVCB_OCPP.Packet.Features;
  4. using EVCB_OCPP.Packet.Messages;
  5. using EVCB_OCPP.Packet.Messages.Core;
  6. using EVCB_OCPP.Packet.Messages.SubTypes;
  7. using EVCB_OCPP.WSServer.Dto;
  8. using EVCB_OCPP.WSServer.Service;
  9. using Newtonsoft.Json;
  10. using NLog;
  11. using OCPPPackage.Profiles;
  12. using OCPPServer.Protocol;
  13. using System;
  14. using System.Collections.Generic;
  15. using System.Data.Entity;
  16. using System.Data.SqlClient;
  17. using System.Diagnostics;
  18. using System.Linq;
  19. using System.Threading.Tasks;
  20. namespace EVCB_OCPP.WSServer.Message
  21. {
  22. internal partial class ProfileHandler
  23. {
  24. static private ILogger logger = NLog.LogManager.GetCurrentClassLogger();
  25. async internal Task<MessageResult> ExecuteCoreRequest(Actions action, ClientData session, IRequest request)
  26. {
  27. Stopwatch watch = new Stopwatch();
  28. if (action == Actions.Heartbeat)
  29. {
  30. watch.Start();
  31. }
  32. MessageResult result = new MessageResult() { Success = false };
  33. try
  34. {
  35. switch (action)
  36. {
  37. case Actions.DataTransfer:
  38. {
  39. var confirm = new DataTransferConfirmation() { status = DataTransferStatus.Rejected };
  40. result.Message = confirm;
  41. result.Success = true;
  42. }
  43. break;
  44. case Actions.BootNotification:
  45. {
  46. BootNotificationRequest _request = request as BootNotificationRequest;
  47. int heartbeat_interval = GlobalConfig.GetHEARTBEAT_INTERVAL();
  48. using (var db = new MainDBContext())
  49. {
  50. var _machine = db.Machine.Where(x => x.ChargeBoxId == session.ChargeBoxId).FirstOrDefault();
  51. _machine.ChargeBoxSerialNumber = string.IsNullOrEmpty(_request.chargeBoxSerialNumber) ? string.Empty : _request.chargeBoxSerialNumber;
  52. _machine.ChargePointModel = string.IsNullOrEmpty(_request.chargePointModel) ? string.Empty : _request.chargePointModel;
  53. _machine.ChargePointVendor = string.IsNullOrEmpty(_request.chargePointVendor) ? string.Empty : _request.chargePointVendor;
  54. _machine.FW_CurrentVersion = string.IsNullOrEmpty(_request.firmwareVersion) ? string.Empty : _request.firmwareVersion;
  55. _machine.Iccid = string.IsNullOrEmpty(_request.iccid) ? string.Empty : _request.iccid;
  56. _machine.Imsi = string.IsNullOrEmpty(_request.imsi) ? string.Empty : _request.imsi;
  57. _machine.MeterSerialNumber = string.IsNullOrEmpty(_request.meterSerialNumber) ? string.Empty : _request.meterSerialNumber;
  58. _machine.MeterType = string.IsNullOrEmpty(_request.meterType) ? string.Empty : _request.meterType;
  59. db.SaveChanges();
  60. var configVaule = db.MachineConfiguration.Where(x => x.ChargeBoxId == session.ChargeBoxId && x.ConfigureName == StandardConfiguration.HeartbeatInterval)
  61. .Select(x => x.ConfigureSetting).FirstOrDefault();
  62. if (configVaule != null)
  63. {
  64. int.TryParse(configVaule, out heartbeat_interval);
  65. }
  66. }
  67. var confirm = new BootNotificationConfirmation() { currentTime = DateTime.Now, interval = session.IsPending ? heartbeat_interval : 5, status = session.IsPending ? Packet.Messages.SubTypes.RegistrationStatus.Accepted : RegistrationStatus.Pending };
  68. session.IsPending = !session.IsPending;
  69. result.Message = confirm;
  70. result.Success = true;
  71. }
  72. break;
  73. case Actions.StatusNotification:
  74. {
  75. //只保留最新上報狀況
  76. StatusNotificationRequest _request = request as StatusNotificationRequest;
  77. int preStatus = 0;
  78. using (var db = new MainDBContext())
  79. {
  80. var _oldStatus = db.ConnectorStatus.Where(x => x.ChargeBoxId == session.ChargeBoxId
  81. && x.ConnectorId == _request.connectorId).AsNoTracking().FirstOrDefault();
  82. if (_oldStatus != null && (_request.status != (ChargePointStatus)_oldStatus.Status || _request.status == ChargePointStatus.Faulted))
  83. {
  84. preStatus = _oldStatus.Status;
  85. db.Configuration.AutoDetectChangesEnabled = false;
  86. db.Configuration.ValidateOnSaveEnabled = false;
  87. db.ConnectorStatus.Attach(_oldStatus);
  88. _oldStatus.CreatedOn = _request.timestamp.HasValue ? _request.timestamp.Value : DateTime.Now;
  89. _oldStatus.Status = (int)_request.status;
  90. _oldStatus.ChargePointErrorCodeId = (int)_request.errorCode;
  91. _oldStatus.ErrorInfo = string.IsNullOrEmpty(_request.info) ? string.Empty : _request.info;
  92. _oldStatus.VendorId = string.IsNullOrEmpty(_request.vendorId) ? string.Empty : _request.vendorId;
  93. _oldStatus.VendorErrorCode = string.IsNullOrEmpty(_request.vendorErrorCode) ? string.Empty : _request.vendorErrorCode;
  94. db.Entry(_oldStatus).Property(x => x.CreatedOn).IsModified = true;
  95. db.Entry(_oldStatus).Property(x => x.Status).IsModified = true;
  96. db.Entry(_oldStatus).Property(x => x.ChargePointErrorCodeId).IsModified = true;
  97. db.Entry(_oldStatus).Property(x => x.ErrorInfo).IsModified = true;
  98. db.Entry(_oldStatus).Property(x => x.VendorId).IsModified = true;
  99. db.Entry(_oldStatus).Property(x => x.VendorErrorCode).IsModified = true;
  100. }
  101. if (_oldStatus == null)
  102. {
  103. var _currentStatus = new Domain.Models.Database.ConnectorStatus()
  104. {
  105. ChargeBoxId = session.ChargeBoxId,
  106. ConnectorId = (byte)_request.connectorId,
  107. CreatedOn = _request.timestamp.HasValue ? _request.timestamp.Value : DateTime.Now,
  108. Status = (int)_request.status,
  109. ChargePointErrorCodeId = (int)_request.errorCode,
  110. ErrorInfo = string.IsNullOrEmpty(_request.info) ? string.Empty : _request.info,
  111. VendorId = string.IsNullOrEmpty(_request.vendorId) ? string.Empty : _request.vendorId,
  112. VendorErrorCode = string.IsNullOrEmpty(_request.vendorErrorCode) ? string.Empty : _request.vendorErrorCode,
  113. Id = Guid.NewGuid().ToString()
  114. };
  115. db.ConnectorStatus.Add(_currentStatus);
  116. }
  117. if (_request.status == Packet.Messages.SubTypes.ChargePointStatus.Faulted)
  118. {
  119. db.MachineError.Add(new MachineError()
  120. {
  121. ConnectorId = (byte)_request.connectorId,
  122. CreatedOn = _request.timestamp.HasValue ? _request.timestamp.Value : DateTime.Now,
  123. Status = (int)_request.status,
  124. ChargeBoxId = session.ChargeBoxId,
  125. ErrorCodeId = (int)_request.errorCode,
  126. ErrorInfo = string.IsNullOrEmpty(_request.info) ? string.Empty : _request.info,
  127. PreStatus = _oldStatus == null ? -1 : preStatus,
  128. VendorErrorCode = string.IsNullOrEmpty(_request.vendorErrorCode) ? string.Empty : _request.vendorErrorCode,
  129. VendorId = string.IsNullOrEmpty(_request.vendorId) ? string.Empty : _request.vendorId
  130. });
  131. }
  132. db.SaveChanges();
  133. }
  134. if (_request.status == Packet.Messages.SubTypes.ChargePointStatus.Faulted)
  135. {
  136. var businessService = BusinessServiceFactory.CreateBusinessService(session.CustomerId.ToString());
  137. var notification = businessService.NotifyFaultStatus(new ErrorDetails()
  138. {
  139. ChargeBoxId = session.ChargeBoxId,
  140. ConnectorId = _request.connectorId,
  141. ErrorCode = _request.errorCode,
  142. Info = string.IsNullOrEmpty(_request.info) ? string.Empty : _request.info,
  143. OCcuredOn = _request.timestamp ?? DateTime.Now,
  144. VendorErrorCode = string.IsNullOrEmpty(_request.vendorErrorCode) ? string.Empty : _request.vendorErrorCode,
  145. });
  146. }
  147. var confirm = new StatusNotificationConfirmation() { };
  148. result.Message = confirm;
  149. result.Success = true;
  150. }
  151. break;
  152. case Actions.Heartbeat:
  153. {
  154. //Task updateBeatTask = Task.Run(async () =>
  155. // {
  156. // using (var db = new MainDBContext())
  157. // {
  158. // var machine = new Machine() { Id = session.MachineId };
  159. // if (machine != null)
  160. // {
  161. // db.Configuration.AutoDetectChangesEnabled = false;
  162. // db.Configuration.ValidateOnSaveEnabled = false;
  163. // db.Machine.Attach(machine);
  164. // machine.HeartbeatUpdatedOn = DateTime.Now;
  165. // machine.ConnectionType = session.UriScheme.Equals("wss") ? 2 : 1;
  166. // db.Entry(machine).Property(x => x.HeartbeatUpdatedOn).IsModified = true;
  167. // db.Entry(machine).Property(x => x.ConnectionType).IsModified = true;
  168. // await db.SaveChangesAsync();
  169. // }
  170. // }
  171. // });
  172. var confirm = new HeartbeatConfirmation() { currentTime = DateTime.Now };
  173. result.Message = confirm;
  174. result.Success = true;
  175. }
  176. break;
  177. case Actions.MeterValues:
  178. {
  179. MeterValuesRequest _request = request as MeterValuesRequest;
  180. if (_request.meterValue.Count > 0)
  181. {
  182. using (var db = new MeterValueDBContext())
  183. {
  184. foreach (var item in _request.meterValue)
  185. {
  186. foreach (var sampleVaule in item.sampledValue)
  187. {
  188. decimal value = Convert.ToDecimal(sampleVaule.value);
  189. string sp = "[dbo].[uspInsertMeterValueRecord] @ChargeBoxId," +
  190. "@ConnectorId,@Value,@CreatedOn,@ContextId,@FormatId,@MeasurandId,@PhaseId,@LocationId,@UnitId,@TransactionId";
  191. List<SqlParameter> parameter = new List<SqlParameter>
  192. {
  193. new SqlParameter("ChargeBoxId",session.ChargeBoxId),
  194. new SqlParameter("ConnectorId", (byte)_request.connectorId),
  195. new SqlParameter("Value",value),
  196. new SqlParameter("CreatedOn",item.timestamp),
  197. new SqlParameter("ContextId",sampleVaule.context.HasValue ? (int)sampleVaule.context : 0),
  198. new SqlParameter("FormatId",sampleVaule.format.HasValue ? (int)sampleVaule.format : 0),
  199. new SqlParameter("MeasurandId",sampleVaule.measurand.HasValue ? (int)sampleVaule.measurand : 0),
  200. new SqlParameter("PhaseId",sampleVaule.phase.HasValue ? (int)sampleVaule.phase : 0),
  201. new SqlParameter("LocationId",sampleVaule.location.HasValue ? (int)sampleVaule.location : 0),
  202. new SqlParameter("UnitId",sampleVaule.unit.HasValue ? (int)sampleVaule.unit : 0),
  203. new SqlParameter("TransactionId",_request.transactionId.HasValue?_request.transactionId:-1),
  204. };
  205. db.Database.ExecuteSqlCommand(sp, parameter.ToArray());
  206. }
  207. }
  208. }
  209. }
  210. var confirm = new MeterValuesConfirmation() { };
  211. result.Message = confirm;
  212. result.Success = true;
  213. }
  214. break;
  215. case Actions.StartTransaction:
  216. {
  217. StartTransactionRequest _request = request as StartTransactionRequest;
  218. int _transactionId = -1;
  219. var businessService = BusinessServiceFactory.CreateBusinessService(session.CustomerId.ToString());
  220. //var _idTagInfo = new IdTagInfo() { status = AuthorizationStatus.Accepted };
  221. var _idTagInfo = _request.idTag == "Backend" ? new IdTagInfo() { expiryDate = DateTime.UtcNow.AddDays(1), status = AuthorizationStatus.Accepted } : await businessService.Authorize(session.ChargeBoxId, _request.idTag);
  222. using (var db = new MainDBContext())
  223. {
  224. var _CustomerId = db.Machine.Where(x => x.ChargeBoxId == session.ChargeBoxId).Include(x => x.Customer).
  225. Select(x => x.CustomerId).FirstOrDefault();
  226. var _existedTx = db.TransactionRecord.Where(x => x.CustomerId == _CustomerId && x.ChargeBoxId == session.ChargeBoxId
  227. && x.ConnectorId == _request.connectorId && x.StartTime == _request.timestamp).Select(C => new { C.Id }).AsNoTracking().FirstOrDefault();
  228. TransactionRecord _newTransaction = new TransactionRecord();
  229. if (_existedTx == null)
  230. {
  231. _newTransaction = new TransactionRecord()
  232. {
  233. ChargeBoxId = session.ChargeBoxId,
  234. ConnectorId = (byte)_request.connectorId,
  235. CreatedOn = DateTime.Now,
  236. StartIdTag = _request.idTag,
  237. MeterStart = _request.meterStart,
  238. CustomerId = _CustomerId,
  239. StartTime = _request.timestamp,
  240. ReservationId = _request.reservationId.HasValue ? _request.reservationId.Value : 0,
  241. };
  242. db.TransactionRecord.Add(_newTransaction);
  243. db.SaveChanges();
  244. _transactionId = _newTransaction.Id;
  245. Console.WriteLine("***************************************************** ");
  246. Console.WriteLine(string.Format("{0} :TransactionId {1} ", session.ChargeBoxId, _newTransaction.Id));
  247. Console.WriteLine("***************************************************** ");
  248. }
  249. else
  250. {
  251. _transactionId = _existedTx.Id;
  252. Console.WriteLine("Duplication ***************************************************** " + _existedTx.Id);
  253. }
  254. }
  255. var confirm = new StartTransactionConfirmation()
  256. {
  257. idTagInfo = _idTagInfo,
  258. transactionId = _transactionId
  259. };
  260. result.Message = confirm;
  261. result.Success = true;
  262. }
  263. break;
  264. case Actions.StopTransaction:
  265. {
  266. StopTransactionRequest _request = request as StopTransactionRequest;
  267. List<TransactionDataRecord> _TransactionDatas = new List<TransactionDataRecord>();
  268. int _ConnectorId = 0;
  269. var businessService = BusinessServiceFactory.CreateBusinessService(session.CustomerId.ToString());
  270. var _idTagInfo = new IdTagInfo() { status = AuthorizationStatus.Accepted };
  271. using (var db = new MainDBContext())
  272. {
  273. var transaction = db.TransactionRecord.Where(x => x.Id == _request.transactionId
  274. && x.ChargeBoxId == session.ChargeBoxId).FirstOrDefault();
  275. if (transaction != null)
  276. {
  277. _ConnectorId = transaction.ConnectorId;
  278. transaction.MeterStop = _request.meterStop;
  279. transaction.StopTime = _request.timestamp;
  280. transaction.StopReasonId = _request.reason.HasValue ? (int)_request.reason.Value : 0;
  281. transaction.StopIdTag = _request.idTag;
  282. if (_TransactionDatas.Count > 0)
  283. {
  284. _TransactionDatas.ForEach(x => x.ConnectorId = (byte)transaction.ConnectorId);
  285. }
  286. await db.SaveChangesAsync();
  287. var confirm = new StopTransactionConfirmation()
  288. {
  289. idTagInfo = _idTagInfo
  290. };
  291. result.Message = confirm;
  292. result.Success = true;
  293. }
  294. else
  295. {
  296. result.Exception = new Exception("Can't find transactionId " + _request.transactionId);
  297. }
  298. }
  299. if (_request.transactionData != null)
  300. {
  301. if (_request.transactionData.Count > 0)
  302. {
  303. using (var _meterDb = new MeterValueDBContext())
  304. {
  305. foreach (var item in _request.transactionData)
  306. {
  307. foreach (var sampleVaule in item.sampledValue)
  308. {
  309. decimal value = Convert.ToDecimal(sampleVaule.value);
  310. string sp = "[dbo].[uspInsertMeterValueRecord] @ChargeBoxId," +
  311. "@ConnectorId,@Value,@CreatedOn,@ContextId,@FormatId,@MeasurandId,@PhaseId,@LocationId,@UnitId,@TransactionId";
  312. List<SqlParameter> parameter = new List<SqlParameter>
  313. {
  314. new SqlParameter("ChargeBoxId",session.ChargeBoxId),
  315. new SqlParameter("ConnectorId", (byte)_ConnectorId),
  316. new SqlParameter("Value",value),
  317. new SqlParameter("CreatedOn",item.timestamp),
  318. new SqlParameter("ContextId",sampleVaule.context.HasValue ? (int)sampleVaule.context : 0),
  319. new SqlParameter("FormatId",sampleVaule.format.HasValue ? (int)sampleVaule.format : 0),
  320. new SqlParameter("MeasurandId",sampleVaule.measurand.HasValue ? (int)sampleVaule.measurand : 0),
  321. new SqlParameter("PhaseId",sampleVaule.phase.HasValue ? (int)sampleVaule.phase : 0),
  322. new SqlParameter("LocationId",sampleVaule.location.HasValue ? (int)sampleVaule.location : 0),
  323. new SqlParameter("UnitId",sampleVaule.unit.HasValue ? (int)sampleVaule.unit : 0),
  324. new SqlParameter("TransactionId",_request.transactionId),
  325. };
  326. _meterDb.Database.ExecuteSqlCommand(sp, parameter.ToArray());
  327. }
  328. }
  329. }
  330. }
  331. }
  332. }
  333. break;
  334. case Actions.Authorize:
  335. {
  336. AuthorizeRequest _request = request as AuthorizeRequest;
  337. var businessService = BusinessServiceFactory.CreateBusinessService(session.CustomerId.ToString());
  338. var confirm = new AuthorizeConfirmation()
  339. {
  340. idTagInfo = _request.idTag == "Backend" ? new IdTagInfo() { expiryDate = DateTime.UtcNow.AddDays(1), status = AuthorizationStatus.Accepted } : await businessService.Authorize(session.ChargeBoxId, _request.idTag)
  341. };
  342. result.Message = confirm;
  343. result.Success = true;
  344. }
  345. break;
  346. default:
  347. {
  348. Console.WriteLine(string.Format("Not Implement {0} Logic(ExecuteCoreRequest)", request.GetType().ToString().Replace("OCPPPackage.Messages.Core.", "")));
  349. }
  350. break;
  351. }
  352. }
  353. catch (Exception ex)
  354. {
  355. logger.Fatal(string.Format("chargeBoxId:{0} {1}", session.ChargeBoxId, action));
  356. logger.Fatal(string.Format("Data {0}", request.ToString()));
  357. logger.Fatal(string.Format("Error {0}", ex.ToString()));
  358. result.Exception = ex;
  359. }
  360. if (action == Actions.Heartbeat)
  361. {
  362. watch.Stop();
  363. if (watch.ElapsedMilliseconds / 1000 > 3)
  364. {
  365. logger.Error("Processing Hearbeat costs " + watch.ElapsedMilliseconds / 1000 + " seconds");
  366. }
  367. }
  368. return result;
  369. }
  370. internal MessageResult ExecuteCoreConfirm(Actions action, ClientData session, IConfirmation confirm, string requestId)
  371. {
  372. MessageResult result = new MessageResult() { Success = true };
  373. switch (action)
  374. {
  375. case Actions.DataTransfer:
  376. {
  377. DataTransferConfirmation _confirm = confirm as DataTransferConfirmation;
  378. DataTransferRequest _request = _confirm.GetRequest() as DataTransferRequest;
  379. using (var db = new MainDBContext())
  380. {
  381. var operation = db.MachineOperateRecord.Where(x => x.SerialNo == requestId &&
  382. x.ChargeBoxId == session.ChargeBoxId && x.Status == 0).FirstOrDefault();
  383. if (operation != null)
  384. {
  385. operation.FinishedOn = DateTime.Now;
  386. operation.Status = 1;//電樁有回覆
  387. operation.EVSE_Status = (int)_confirm.status;
  388. operation.EVSE_Value = string.IsNullOrEmpty(_confirm.data) ? "" : _confirm.data;
  389. db.SaveChanges();
  390. }
  391. if (_request.messageId == "ID_FirmwareVersion")
  392. {
  393. var machine = new Machine() { Id = session.MachineId };
  394. if (machine != null)
  395. {
  396. db.Configuration.AutoDetectChangesEnabled = false;
  397. db.Configuration.ValidateOnSaveEnabled = false;
  398. db.Machine.Attach(machine);
  399. machine.BoardVersions = _confirm.data;
  400. db.Entry(machine).Property(x => x.BoardVersions).IsModified = true;
  401. db.SaveChanges();
  402. }
  403. }
  404. }
  405. }
  406. break;
  407. case Actions.ChangeAvailability:
  408. {
  409. ChangeAvailabilityConfirmation _confirm = confirm as ChangeAvailabilityConfirmation;
  410. ChangeAvailabilityRequest _request = _confirm.GetRequest() as ChangeAvailabilityRequest;
  411. using (var db = new MainDBContext())
  412. {
  413. var operation = db.MachineOperateRecord.Where(x => x.SerialNo == requestId &&
  414. x.ChargeBoxId == session.ChargeBoxId && x.Status == 0).FirstOrDefault();
  415. if (operation != null)
  416. {
  417. operation.FinishedOn = DateTime.Now;
  418. operation.Status = 1;//電樁有回覆
  419. operation.EVSE_Status = (int)_confirm.status;
  420. operation.EVSE_Value = _confirm.status.ToString();
  421. db.SaveChanges();
  422. }
  423. }
  424. }
  425. break;
  426. case Actions.ClearCache:
  427. {
  428. ClearCacheConfirmation _confirm = confirm as ClearCacheConfirmation;
  429. ClearCacheRequest _request = _confirm.GetRequest() as ClearCacheRequest;
  430. using (var db = new MainDBContext())
  431. {
  432. var operation = db.MachineOperateRecord.Where(x => x.SerialNo == requestId &&
  433. x.ChargeBoxId == session.ChargeBoxId && x.Status == 0).FirstOrDefault();
  434. if (operation != null)
  435. {
  436. operation.FinishedOn = DateTime.Now;
  437. operation.Status = 1;//電樁有回覆
  438. operation.EVSE_Status = (int)_confirm.status;
  439. operation.EVSE_Value = _confirm.status.ToString();
  440. db.SaveChanges();
  441. }
  442. }
  443. }
  444. break;
  445. case Actions.RemoteStartTransaction:
  446. {
  447. RemoteStartTransactionConfirmation _confirm = confirm as RemoteStartTransactionConfirmation;
  448. RemoteStartTransactionRequest _request = _confirm.GetRequest() as RemoteStartTransactionRequest;
  449. using (var db = new MainDBContext())
  450. {
  451. var operation = db.MachineOperateRecord.Where(x => x.SerialNo == requestId &&
  452. x.ChargeBoxId == session.ChargeBoxId && x.Status == 0).FirstOrDefault();
  453. if (operation != null)
  454. {
  455. operation.FinishedOn = DateTime.Now;
  456. operation.Status = 1;//電樁有回覆
  457. operation.EVSE_Status = (int)_confirm.status;
  458. operation.EVSE_Value = _confirm.status.ToString();
  459. db.SaveChanges();
  460. }
  461. }
  462. }
  463. break;
  464. case Actions.RemoteStopTransaction:
  465. {
  466. RemoteStopTransactionConfirmation _confirm = confirm as RemoteStopTransactionConfirmation;
  467. RemoteStopTransactionRequest _request = _confirm.GetRequest() as RemoteStopTransactionRequest;
  468. using (var db = new MainDBContext())
  469. {
  470. var operation = db.MachineOperateRecord.Where(x => x.SerialNo == requestId &&
  471. x.ChargeBoxId == session.ChargeBoxId && x.Status == 0).FirstOrDefault();
  472. if (operation != null)
  473. {
  474. operation.FinishedOn = DateTime.Now;
  475. operation.Status = 1;//電樁有回覆
  476. operation.EVSE_Status = (int)_confirm.status;
  477. operation.EVSE_Value = _confirm.status.ToString();
  478. db.SaveChanges();
  479. }
  480. }
  481. }
  482. break;
  483. case Actions.Reset:
  484. {
  485. ResetConfirmation _confirm = confirm as ResetConfirmation;
  486. ResetRequest _request = _confirm.GetRequest() as ResetRequest;
  487. using (var db = new MainDBContext())
  488. {
  489. var operation = db.MachineOperateRecord.Where(x => x.SerialNo == requestId &&
  490. x.ChargeBoxId == session.ChargeBoxId && x.Status == 0).FirstOrDefault();
  491. if (operation != null)
  492. {
  493. operation.FinishedOn = DateTime.Now;
  494. operation.Status = 1;//電樁有回覆
  495. operation.EVSE_Status = (int)_confirm.status;
  496. operation.EVSE_Value = _confirm.status.ToString();
  497. db.SaveChanges();
  498. }
  499. }
  500. }
  501. break;
  502. case Actions.ChangeConfiguration:
  503. {
  504. ChangeConfigurationConfirmation _confirm = confirm as ChangeConfigurationConfirmation;
  505. ChangeConfigurationRequest _request = _confirm.GetRequest() as ChangeConfigurationRequest;
  506. using (var db = new MainDBContext())
  507. {
  508. var operation = db.MachineOperateRecord.Where(x => x.SerialNo == requestId &&
  509. x.ChargeBoxId == session.ChargeBoxId && x.Status == 0).FirstOrDefault();
  510. if (operation != null)
  511. {
  512. operation.FinishedOn = DateTime.Now;
  513. operation.Status = 1;//電樁有回覆
  514. operation.EVSE_Status = (int)_confirm.status;
  515. operation.EVSE_Value = _confirm.status.ToString();
  516. }
  517. if (_confirm.status == Packet.Messages.SubTypes.ConfigurationStatus.Accepted || _confirm.status == Packet.Messages.SubTypes.ConfigurationStatus.RebootRequired)
  518. {
  519. var configure = db.MachineConfiguration.Where(x => x.ChargeBoxId == session.ChargeBoxId).ToList();
  520. var foundConfig = configure.Find(x => x.ConfigureName == _request.key);
  521. if (foundConfig != null)
  522. {
  523. foundConfig.ReadOnly = false;
  524. foundConfig.ConfigureSetting = _request.value;
  525. }
  526. else
  527. {
  528. db.MachineConfiguration.Add(new MachineConfiguration()
  529. {
  530. ChargeBoxId = session.ChargeBoxId,
  531. ConfigureName = _request.key,
  532. ReadOnly = false,
  533. ConfigureSetting = _request.value
  534. });
  535. }
  536. }
  537. db.SaveChanges();
  538. }
  539. }
  540. break;
  541. case Actions.GetConfiguration:
  542. {
  543. try
  544. {
  545. GetConfigurationConfirmation _confirm = confirm as GetConfigurationConfirmation;
  546. // GetConfigurationRequest _request = _confirm.GetRequest() as GetConfigurationRequest;
  547. using (var db = new MainDBContext())
  548. {
  549. var configure = db.MachineConfiguration.Where(x => x.ChargeBoxId == session.ChargeBoxId).ToList();
  550. if (_confirm.configurationKey != null)
  551. {
  552. foreach (var item in _confirm.configurationKey)
  553. {
  554. string oldValue = string.Empty;
  555. if (item.key == null)
  556. {
  557. Console.WriteLine("*********************");
  558. }
  559. var foundConfig = configure.Find(x => x.ConfigureName == item.key);
  560. if (foundConfig != null)
  561. {
  562. if (foundConfig.ConfigureName == null)
  563. {
  564. Console.WriteLine("*********************");
  565. }
  566. if (foundConfig.ConfigureName == "SecurityProfile")
  567. {
  568. oldValue = foundConfig.ConfigureSetting;
  569. }
  570. foundConfig.ReadOnly = item.IsReadOnly;
  571. foundConfig.ConfigureSetting = string.IsNullOrEmpty(item.value) ? string.Empty : item.value;
  572. }
  573. else
  574. {
  575. db.MachineConfiguration.Add(new MachineConfiguration()
  576. {
  577. ChargeBoxId = session.ChargeBoxId,
  578. ConfigureName = item.key,
  579. ReadOnly = item.IsReadOnly,
  580. ConfigureSetting = string.IsNullOrEmpty(item.value) ? string.Empty : item.value,
  581. Exists = true
  582. });
  583. }
  584. }
  585. }
  586. if (_confirm.unknownKey != null)
  587. {
  588. foreach (var item in _confirm.unknownKey)
  589. {
  590. var foundConfig = configure.Find(x => x.ConfigureName == item);
  591. if (foundConfig != null)
  592. {
  593. foundConfig.ReadOnly = true;
  594. foundConfig.ConfigureSetting = string.Empty;
  595. foundConfig.Exists = false;
  596. }
  597. else
  598. {
  599. db.MachineConfiguration.Add(new MachineConfiguration()
  600. {
  601. ChargeBoxId = session.ChargeBoxId,
  602. ConfigureName = item
  603. });
  604. }
  605. }
  606. }
  607. var operation = db.MachineOperateRecord.Where(x => x.SerialNo == requestId &&
  608. x.ChargeBoxId == session.ChargeBoxId && x.Status == 0).FirstOrDefault();
  609. if (operation != null)
  610. {
  611. operation.FinishedOn = DateTime.Now;
  612. operation.Status = 1;//電樁有回覆
  613. operation.EVSE_Status = 1;
  614. operation.EVSE_Value = JsonConvert.SerializeObject(_confirm.configurationKey, Formatting.None);
  615. }
  616. db.SaveChanges();
  617. }
  618. }
  619. catch (Exception ex)
  620. {
  621. logger.Error(ex.ToString());
  622. }
  623. }
  624. break;
  625. case Actions.UnlockConnector:
  626. {
  627. UnlockConnectorConfirmation _confirm = confirm as UnlockConnectorConfirmation;
  628. UnlockConnectorRequest _request = _confirm.GetRequest() as UnlockConnectorRequest;
  629. using (var db = new MainDBContext())
  630. {
  631. var operation = db.MachineOperateRecord.Where(x => x.SerialNo == requestId &&
  632. x.ChargeBoxId == session.ChargeBoxId && x.Status == 0).FirstOrDefault();
  633. if (operation != null)
  634. {
  635. operation.FinishedOn = DateTime.Now;
  636. operation.Status = 1;//電樁有回覆
  637. operation.EVSE_Status = (int)_confirm.status;
  638. operation.EVSE_Value = _confirm.status.ToString();
  639. db.SaveChanges();
  640. }
  641. }
  642. }
  643. break;
  644. default:
  645. {
  646. Console.WriteLine(string.Format("Not Implement {0} Logic(ExecuteCoreConfirm)", confirm.GetType().ToString().Replace("OCPPPackage.Messages.Core.", "")));
  647. }
  648. break;
  649. }
  650. return result;
  651. }
  652. internal MessageResult ReceivedCoreError(Actions action, string errorMsg, ClientData session, string requestId)
  653. {
  654. MessageResult result = new MessageResult() { Success = true };
  655. switch (action)
  656. {
  657. case Actions.ChangeAvailability:
  658. case Actions.ChangeConfiguration:
  659. case Actions.ClearCache:
  660. case Actions.RemoteStartTransaction:
  661. case Actions.RemoteStopTransaction:
  662. case Actions.Reset:
  663. case Actions.GetConfiguration:
  664. case Actions.UnlockConnector:
  665. case Actions.DataTransfer:
  666. {
  667. if (action == Actions.DataTransfer)
  668. {
  669. logger.Debug(string.Format("DataTransfer Error {0}: {1}", session.ChargeBoxId, requestId));
  670. }
  671. using (var db = new MainDBContext())
  672. {
  673. var operation = db.MachineOperateRecord.Where(x => x.SerialNo == requestId &&
  674. x.ChargeBoxId == session.ChargeBoxId && x.Status == 0).FirstOrDefault();
  675. if (operation != null)
  676. {
  677. operation.FinishedOn = DateTime.Now;
  678. operation.Status = 1;//電樁有回覆
  679. operation.EVSE_Status = (int)255;//錯誤
  680. operation.EVSE_Value = errorMsg;
  681. db.SaveChanges();
  682. }
  683. }
  684. }
  685. break;
  686. default:
  687. {
  688. Console.WriteLine(string.Format("Not Implement {0} Logic(ReceivedCoreError)", action));
  689. }
  690. break;
  691. }
  692. return result;
  693. }
  694. }
  695. }