import {
ProcedureName,
Protocol,
+ ProtocolRequest,
ProtocolResponse,
ProtocolVersion,
RequestPayload,
public stop(): void {
this.chargingStations.clear();
- this.responseHandlers.clear();
}
// eslint-disable-next-line @typescript-eslint/no-unused-vars
- public sendRequest(request: string): void {
+ public sendRequest(request: ProtocolRequest): void {
// This is intentionally left blank
}
- public sendResponse(response: string): void {
- const [uuid, payload] = JSON.parse(response) as ProtocolResponse;
+ public sendResponse(response: ProtocolResponse): void {
+ const [uuid, payload] = response;
const statusCode = this.responseStatusToStatusCode(payload.status);
if (this.responseHandlers.has(uuid) === true) {
const { res } = this.responseHandlers.get(uuid);
this.responseHandlers.delete(uuid);
} else {
logger.error(
- `${this.logPrefix()} ${moduleName}.sendResponse: Response for unknown request: ${response}`
+ `${this.logPrefix(moduleName, 'sendResponse')} Response for unknown request id: ${uuid}`
);
}
}
- public logPrefix(modName?: string, methodName?: string): string {
+ public logPrefix(modName?: string, methodName?: string, prefixSuffix?: string): string {
+ const logMsgPrefix = prefixSuffix ? `UI HTTP Server ${prefixSuffix}` : 'UI HTTP Server';
const logMsg =
- modName && methodName ? ` UI HTTP Server | ${modName}.${methodName}:` : ' UI HTTP Server |';
+ modName && methodName ? ` ${logMsgPrefix} | ${modName}.${methodName}:` : ` ${logMsgPrefix} |`;
return Utils.logPrefix(logMsg);
}
const uuid = Utils.generateUUID();
this.responseHandlers.set(uuid, { procedureName, res });
try {
- if (UIServiceUtils.isProtocolSupported(protocol, version) === false) {
+ if (UIServiceUtils.isProtocolAndVersionSupported(protocol, version) === false) {
throw new BaseError(`Unsupported UI protocol version: '/${protocol}/${version}'`);
}
req.on('error', (error) => {
error
);
});
- if (!this.uiServices.has(version)) {
+ if (this.uiServices.has(version) === false) {
this.uiServices.set(version, UIServiceFactory.getUIServiceImplementation(version, this));
}
if (req.method === 'POST') {