import { StatusCodes } from 'http-status-codes';
import BaseError from '../../exception/BaseError';
-import { ServerOptions } from '../../types/ConfigurationData';
+import type { ServerOptions } from '../../types/ConfigurationData';
import {
ProcedureName,
Protocol,
ProtocolResponse,
ProtocolVersion,
RequestPayload,
- ResponsePayload,
ResponseStatus,
} from '../../types/UIProtocol';
import Configuration from '../../utils/Configuration';
}
public start(): void {
- (this.server as Server).listen(this.options ?? Configuration.getUIServer().options);
+ if ((this.server as Server).listening === false) {
+ (this.server as Server).listen(this.options ?? Configuration.getUIServer().options);
+ }
}
public stop(): void {
this.chargingStations.clear();
+ this.responseHandlers.clear();
}
// eslint-disable-next-line @typescript-eslint/no-unused-vars
public sendResponse(response: string): void {
const [uuid, payload] = JSON.parse(response) as ProtocolResponse;
- let statusCode: StatusCodes;
- switch (payload.status) {
- case ResponseStatus.SUCCESS:
- statusCode = StatusCodes.OK;
- break;
- case ResponseStatus.FAILURE:
- default:
- statusCode = StatusCodes.BAD_REQUEST;
- break;
- }
- if (this.responseHandlers.has(uuid)) {
+ const statusCode = this.responseStatusToStatusCode(payload.status);
+ if (this.responseHandlers.has(uuid) === true) {
const { res } = this.responseHandlers.get(uuid);
res.writeHead(statusCode, { 'Content-Type': 'application/json' });
res.write(JSON.stringify(payload));
this.responseHandlers.delete(uuid);
} else {
logger.error(
- `${this.logPrefix()} ${moduleName}.sendResponse: Response received for unknown request: ${response}`
+ `${this.logPrefix(moduleName, 'sendResponse')} Response for unknown request: ${response}`
);
}
}
- 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) => {
logger.error(
- `${this.logPrefix(
- moduleName,
- 'requestListener.req.onerror'
- )} Error at incoming request handling:`,
+ `${this.logPrefix(moduleName, 'requestListener.req.onerror')} Error on HTTP request:`,
error
);
});
}
if (req.method === 'POST') {
const bodyBuffer = [];
- let body: RequestPayload;
req
.on('data', (chunk) => {
bodyBuffer.push(chunk);
})
.on('end', () => {
- body = JSON.parse(Buffer.concat(bodyBuffer).toString()) as RequestPayload;
+ const body = JSON.parse(Buffer.concat(bodyBuffer).toString()) as RequestPayload;
this.uiServices
.get(version)
- .requestHandler(this.buildRequest(uuid, procedureName, body ?? {}))
+ .requestHandler(this.buildProtocolRequest(uuid, procedureName, body ?? {}))
.catch(() => {
- this.sendResponse(this.buildResponse(uuid, { status: ResponseStatus.FAILURE }));
+ this.sendResponse(
+ this.buildProtocolResponse(uuid, { status: ResponseStatus.FAILURE })
+ );
});
});
} else {
throw new BaseError(`Unsupported HTTP method: '${req.method}'`);
}
} catch (error) {
- this.sendResponse(this.buildResponse(uuid, { status: ResponseStatus.FAILURE }));
+ logger.error(
+ `${this.logPrefix(moduleName, 'requestListener')} Handle HTTP request error:`,
+ error
+ );
+ this.sendResponse(this.buildProtocolResponse(uuid, { status: ResponseStatus.FAILURE }));
}
}
- private buildRequest(
- id: string,
- procedureName: ProcedureName,
- requestPayload: RequestPayload
- ): string {
- return JSON.stringify([id, procedureName, requestPayload]);
- }
-
- private buildResponse(id: string, responsePayload: ResponsePayload): string {
- return JSON.stringify([id, responsePayload]);
+ private responseStatusToStatusCode(status: ResponseStatus): StatusCodes {
+ switch (status) {
+ case ResponseStatus.SUCCESS:
+ return StatusCodes.OK;
+ case ResponseStatus.FAILURE:
+ return StatusCodes.BAD_REQUEST;
+ default:
+ return StatusCodes.INTERNAL_SERVER_ERROR;
+ }
}
}