repositories
/
e-mobility-charging-stations-simulator.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
fix: fix remote transaction start debug log
[e-mobility-charging-stations-simulator.git]
/
src
/
charging-station
/
ChargingStation.ts
diff --git
a/src/charging-station/ChargingStation.ts
b/src/charging-station/ChargingStation.ts
index ba1979542cf0767ae030cd5030ed779478cf9b3c..def985c0447a4a6df065b32a8af94281d337c6e8 100644
(file)
--- a/
src/charging-station/ChargingStation.ts
+++ b/
src/charging-station/ChargingStation.ts
@@
-236,6
+236,11
@@
export class ChargingStation extends EventEmitter {
this.on(ChargingStationEvents.rejected, () => {
this.wsConnectionRetried = false
})
this.on(ChargingStationEvents.rejected, () => {
this.wsConnectionRetried = false
})
+ this.on(ChargingStationEvents.connected, () => {
+ if (this.wsPingSetInterval == null) {
+ this.startWebSocketPing()
+ }
+ })
this.on(ChargingStationEvents.disconnected, () => {
try {
this.internalStopMessageSequence()
this.on(ChargingStationEvents.disconnected, () => {
try {
this.internalStopMessageSequence()
@@
-554,7
+559,8
@@
export class ChargingStation extends EventEmitter {
}
public startHeartbeat (): void {
}
public startHeartbeat (): void {
- if (this.getHeartbeatInterval() > 0 && this.heartbeatSetInterval == null) {
+ const heartbeatInterval = this.getHeartbeatInterval()
+ if (heartbeatInterval > 0 && this.heartbeatSetInterval == null) {
this.heartbeatSetInterval = setInterval(() => {
this.ocppRequestService
.requestHandler<HeartbeatRequest, HeartbeatResponse>(this, RequestCommand.HEARTBEAT)
this.heartbeatSetInterval = setInterval(() => {
this.ocppRequestService
.requestHandler<HeartbeatRequest, HeartbeatResponse>(this, RequestCommand.HEARTBEAT)
@@
-564,21
+570,21
@@
export class ChargingStation extends EventEmitter {
error
)
})
error
)
})
- },
this.getHeartbeatInterval()
)
+ },
heartbeatInterval
)
logger.info(
`${this.logPrefix()} Heartbeat started every ${formatDurationMilliSeconds(
logger.info(
`${this.logPrefix()} Heartbeat started every ${formatDurationMilliSeconds(
- this.getHeartbeatInterval()
+ heartbeatInterval
)}`
)
} else if (this.heartbeatSetInterval != null) {
logger.info(
`${this.logPrefix()} Heartbeat already started every ${formatDurationMilliSeconds(
)}`
)
} else if (this.heartbeatSetInterval != null) {
logger.info(
`${this.logPrefix()} Heartbeat already started every ${formatDurationMilliSeconds(
- this.getHeartbeatInterval()
+ heartbeatInterval
)}`
)
} else {
logger.error(
)}`
)
} else {
logger.error(
- `${this.logPrefix()} Heartbeat interval set to ${
this.getHeartbeatInterval()
}, not starting the heartbeat`
+ `${this.logPrefix()} Heartbeat interval set to ${
heartbeatInterval
}, not starting the heartbeat`
)
}
}
)
}
}
@@
-1822,6
+1828,7
@@
export class ChargingStation extends EventEmitter {
private async onOpen (): Promise<void> {
if (this.isWebSocketConnectionOpened()) {
private async onOpen (): Promise<void> {
if (this.isWebSocketConnectionOpened()) {
+ this.emit(ChargingStationEvents.connected)
this.emit(ChargingStationEvents.updated)
logger.info(
`${this.logPrefix()} Connection to OCPP server through ${
this.emit(ChargingStationEvents.updated)
logger.info(
`${this.logPrefix()} Connection to OCPP server through ${
@@
-1832,6
+1839,7
@@
export class ChargingStation extends EventEmitter {
if (!this.isRegistered()) {
// Send BootNotification
do {
if (!this.isRegistered()) {
// Send BootNotification
do {
+ // FIXME: duplicated assignment with the boot notification response handler
this.bootNotificationResponse = await this.ocppRequestService.requestHandler<
BootNotificationRequest,
BootNotificationResponse
this.bootNotificationResponse = await this.ocppRequestService.requestHandler<
BootNotificationRequest,
BootNotificationResponse
@@
-2221,9
+2229,13
@@
export class ChargingStation extends EventEmitter {
})
}
// Start WebSocket ping
})
}
// Start WebSocket ping
- this.startWebSocketPing()
+ if (this.wsPingSetInterval == null) {
+ this.startWebSocketPing()
+ }
// Start heartbeat
// Start heartbeat
- this.startHeartbeat()
+ if (this.heartbeatSetInterval == null) {
+ this.startHeartbeat()
+ }
// Initialize connectors status
if (this.hasEvses) {
for (const [evseId, evseStatus] of this.evses) {
// Initialize connectors status
if (this.hasEvses) {
for (const [evseId, evseStatus] of this.evses) {
@@
-2313,13
+2325,14
@@
export class ChargingStation extends EventEmitter {
}
}
}
}
+ private getWebSocketPingInterval (): number {
+ return getConfigurationKey(this, StandardParametersKey.WebSocketPingInterval) != null
+ ? convertToInt(getConfigurationKey(this, StandardParametersKey.WebSocketPingInterval)?.value)
+ : 0
+ }
+
private startWebSocketPing (): void {
private startWebSocketPing (): void {
- const webSocketPingInterval =
- getConfigurationKey(this, StandardParametersKey.WebSocketPingInterval) != null
- ? convertToInt(
- getConfigurationKey(this, StandardParametersKey.WebSocketPingInterval)?.value
- )
- : 0
+ const webSocketPingInterval = this.getWebSocketPingInterval()
if (webSocketPingInterval > 0 && this.wsPingSetInterval == null) {
this.wsPingSetInterval = setInterval(() => {
if (this.isWebSocketConnectionOpened()) {
if (webSocketPingInterval > 0 && this.wsPingSetInterval == null) {
this.wsPingSetInterval = setInterval(() => {
if (this.isWebSocketConnectionOpened()) {
@@
-2436,9
+2449,7
@@
export class ChargingStation extends EventEmitter {
)
} else if (this.stationInfo?.autoReconnectMaxRetries !== -1) {
logger.error(
)
} else if (this.stationInfo?.autoReconnectMaxRetries !== -1) {
logger.error(
- `${this.logPrefix()} WebSocket connection retries failure: maximum retries reached (${
- this.wsConnectionRetryCount
- }) or retries disabled (${this.stationInfo?.autoReconnectMaxRetries})`
+ `${this.logPrefix()} WebSocket connection retries failure: maximum retries reached (${this.wsConnectionRetryCount.toString()}) or retries disabled (${this.stationInfo?.autoReconnectMaxRetries?.toString()})`
)
}
}
)
}
}