import fs from 'node:fs';
+import path from 'node:path';
+import { fileURLToPath } from 'node:url';
import type { DefinedError, ErrorObject, JSONSchemaType } from 'ajv';
-import { OCPP16Constants, OCPP20Constants } from './internal';
+import { OCPP16Constants } from './1.6/OCPP16Constants';
+import { OCPP20Constants } from './2.0/OCPP20Constants';
import { type ChargingStation, ChargingStationConfigurationUtils } from '../../charging-station';
import { BaseError } from '../../exception';
import {
type StatusNotificationRequest,
type StatusNotificationResponse,
} from '../../types';
-import { Constants, FileUtils, Utils, logger } from '../../utils';
+import { Constants, ErrorUtils, Utils, logger } from '../../utils';
export class OCPPServiceUtils {
protected constructor() {
switch (chargingStation.stationInfo.ocppVersion) {
case OCPPVersion.VERSION_16:
if (
- connectorId === 0 &&
- OCPP16Constants.ChargePointStatusChargingStationTransitions.findIndex(
- (transition) => transition.from === fromStatus && transition.to === status
- ) !== -1
- ) {
- transitionAllowed = true;
- } else if (
- OCPP16Constants.ChargePointStatusConnectorTransitions.findIndex(
- (transition) => transition.from === fromStatus && transition.to === status
- ) !== -1
+ (connectorId === 0 &&
+ OCPP16Constants.ChargePointStatusChargingStationTransitions.findIndex(
+ (transition) => transition.from === fromStatus && transition.to === status
+ ) !== -1) ||
+ (connectorId > 0 &&
+ OCPP16Constants.ChargePointStatusConnectorTransitions.findIndex(
+ (transition) => transition.from === fromStatus && transition.to === status
+ ) !== -1)
) {
transitionAllowed = true;
}
case OCPPVersion.VERSION_20:
case OCPPVersion.VERSION_201:
if (
- connectorId === 0 &&
- OCPP20Constants.ChargingStationStatusTransitions.findIndex(
- (transition) => transition.from === fromStatus && transition.to === status
- ) !== -1
- ) {
- transitionAllowed = true;
- } else if (
- OCPP20Constants.ConnectorStatusTransitions.findIndex(
- (transition) => transition.from === fromStatus && transition.to === status
- ) !== -1
+ (connectorId === 0 &&
+ OCPP20Constants.ChargingStationStatusTransitions.findIndex(
+ (transition) => transition.from === fromStatus && transition.to === status
+ ) !== -1) ||
+ (connectorId > 0 &&
+ OCPP20Constants.ConnectorStatusTransitions.findIndex(
+ (transition) => transition.from === fromStatus && transition.to === status
+ ) !== -1)
) {
transitionAllowed = true;
}
}
protected static parseJsonSchemaFile<T extends JsonType>(
- filePath: string,
+ relativePath: string,
ocppVersion: OCPPVersion,
moduleName?: string,
methodName?: string
): JSONSchemaType<T> {
+ const filePath = path.join(path.dirname(fileURLToPath(import.meta.url)), relativePath);
try {
return JSON.parse(fs.readFileSync(filePath, 'utf8')) as JSONSchemaType<T>;
} catch (error) {
- FileUtils.handleFileException(
+ ErrorUtils.handleFileException(
filePath,
FileType.JsonSchema,
error as NodeJS.ErrnoException,