- logger.info(
- `${this.logPrefix()} Reservation expiration date interval is set to ${interval}
- and starts on charging station now`
- );
- // eslint-disable-next-line @typescript-eslint/no-misused-promises
- this.reservationExpirationSetInterval = setInterval(async (): Promise<void> => {
- if (this.hasEvses) {
- for (const evse of this.evses.values()) {
- for (const connector of evse.connectors.values()) {
- if (connector?.reservation?.expiryDate.toString() < new Date().toISOString()) {
- await this.removeReservation(
- connector.reservation,
- ReservationTerminationReason.EXPIRED
- );
- }
- }
- }
- } else {
- for (const connector of this.connectors.values()) {
- if (connector?.reservation?.expiryDate.toString() < new Date().toISOString()) {
- await this.removeReservation(
- connector.reservation,
- ReservationTerminationReason.EXPIRED
- );
- }
- }
- }
- }, interval);
- }
-
- public restartReservationExpiryDateSetInterval(): void {
- this.stopReservationExpirationSetInterval();
- this.startReservationExpirationSetInterval();
- }
-
- public validateIncomingRequestWithReservation(connectorId: number, idTag: string): boolean {
- const reservation = this.getReservationBy(ReservationFilterKey.CONNECTOR_ID, connectorId);
- return !Utils.isUndefined(reservation) && reservation.idTag === idTag;
+ if (interval > 0) {
+ logger.info(
+ `${this.logPrefix()} Reservation expiration date checks started every ${formatDurationMilliSeconds(
+ interval,
+ )}`,
+ );
+ this.reservationExpirationSetInterval = setInterval((): void => {
+ removeExpiredReservations(this).catch(Constants.EMPTY_FUNCTION);
+ }, interval);
+ }