X-Git-Url: https://git.piment-noir.org/?a=blobdiff_plain;f=src%2Fcharging-station%2Focpp%2F2.0%2FOCPP20RequestService.ts;h=6a7fe370cbf9103e5c98c7942299f248d601401e;hb=6e939d9e416de33fa1c64fc7f4eb6be70954f69c;hp=336327c9cfde468287e60eb9b4c579bccb83caf2;hpb=98fc1389a2464ce8738047f8990731ae31938ee5;p=e-mobility-charging-stations-simulator.git diff --git a/src/charging-station/ocpp/2.0/OCPP20RequestService.ts b/src/charging-station/ocpp/2.0/OCPP20RequestService.ts index 336327c9..6a7fe370 100644 --- a/src/charging-station/ocpp/2.0/OCPP20RequestService.ts +++ b/src/charging-station/ocpp/2.0/OCPP20RequestService.ts @@ -10,12 +10,13 @@ import OCPPError from '../../../exception/OCPPError'; import type { JsonObject, JsonType } from '../../../types/JsonType'; import { type OCPP20BootNotificationRequest, + type OCPP20HeartbeatRequest, OCPP20RequestCommand, + type OCPP20StatusNotificationRequest, } from '../../../types/ocpp/2.0/Requests'; import { ErrorType } from '../../../types/ocpp/ErrorType'; import { OCPPVersion } from '../../../types/ocpp/OCPPVersion'; import type { RequestParams } from '../../../types/ocpp/Requests'; -import logger from '../../../utils/Logger'; import Utils from '../../../utils/Utils'; import type ChargingStation from '../../ChargingStation'; import OCPPRequestService from '../OCPPRequestService'; @@ -25,7 +26,7 @@ import { OCPP20ServiceUtils } from './OCPP20ServiceUtils'; const moduleName = 'OCPP20RequestService'; export default class OCPP20RequestService extends OCPPRequestService { - private jsonSchemas: Map>; + protected jsonSchemas: Map>; public constructor(ocppResponseService: OCPPResponseService) { if (new.target?.name === moduleName) { @@ -45,6 +46,30 @@ export default class OCPP20RequestService extends OCPPRequestService { ) ) as JSONSchemaType, ], + [ + OCPP20RequestCommand.HEARTBEAT, + JSON.parse( + fs.readFileSync( + path.resolve( + path.dirname(fileURLToPath(import.meta.url)), + '../../../assets/json-schemas/ocpp/2.0/HeartbeatRequest.json' + ), + 'utf8' + ) + ) as JSONSchemaType, + ], + [ + OCPP20RequestCommand.STATUS_NOTIFICATION, + JSON.parse( + fs.readFileSync( + path.resolve( + path.dirname(fileURLToPath(import.meta.url)), + '../../../assets/json-schemas/ocpp/2.0/StatusNotificationRequest.json' + ), + 'utf8' + ) + ) as JSONSchemaType, + ], ]); this.buildRequestPayload.bind(this); } @@ -78,19 +103,6 @@ export default class OCPP20RequestService extends OCPPRequestService { ); } - protected getRequestPayloadValidationSchema( - chargingStation: ChargingStation, - commandName: OCPP20RequestCommand - ): JSONSchemaType | false { - if (this.jsonSchemas.has(commandName) === true) { - return this.jsonSchemas.get(commandName); - } - logger.warn( - `${chargingStation.logPrefix()} ${moduleName}.getPayloadValidationSchema: No JSON schema found for command ${commandName} PDU validation` - ); - return false; - } - private buildRequestPayload( chargingStation: ChargingStation, commandName: OCPP20RequestCommand, @@ -124,6 +136,15 @@ export default class OCPP20RequestService extends OCPPRequestService { }), }, } as unknown as Request; + case OCPP20RequestCommand.HEARTBEAT: + return {} as unknown as Request; + case OCPP20RequestCommand.STATUS_NOTIFICATION: + return { + timestamp: commandParams?.timestamp, + connectorStatus: commandParams?.connectorStatus, + evseId: commandParams?.evseId, + connectorId: commandParams?.connectorId, + } as unknown as Request; default: // OCPPError usage here is debatable: it's an error in the OCPP stack but not targeted to sendError(). throw new OCPPError(