import chalk from 'chalk'
-import { logger } from './Logger.js'
-import { isNotEmptyString } from './Utils.js'
import type { ChargingStation } from '../charging-station/index.js'
+import { getMessageTypeString } from '../charging-station/ocpp/OCPPServiceUtils.js'
import type {
EmptyObject,
FileType,
HandleErrorParams,
IncomingRequestCommand,
JsonType,
+ MessageType,
RequestCommand
} from '../types/index.js'
+import { logger } from './Logger.js'
+import { isNotEmptyString } from './Utils.js'
const defaultErrorParams = {
throwError: true,
consoleOut: false
-}
+} satisfies HandleErrorParams<EmptyObject>
export const handleUncaughtException = (): void => {
process.on('uncaughtException', (error: Error) => {
logPrefix: string,
params: HandleErrorParams<EmptyObject> = defaultErrorParams
): void => {
- setDefaultErrorParams(params)
+ params = setDefaultErrorParams(params)
const prefix = isNotEmptyString(logPrefix) ? `${logPrefix} ` : ''
let logMsg: string
switch (error.code) {
default:
logMsg = `${fileType} file ${file} error:`
}
- if (params?.consoleOut === true) {
+ if (params.consoleOut === true) {
logMsg = `${logMsg} `
- if (params?.throwError === true) {
+ if (params.throwError === true) {
console.error(`${chalk.green(prefix)}${chalk.red(logMsg)}`, error)
} else {
console.warn(`${chalk.green(prefix)}${chalk.yellow(logMsg)}`, error)
}
- } else if (params?.consoleOut === false) {
- if (params?.throwError === true) {
+ } else if (params.consoleOut === false) {
+ if (params.throwError === true) {
logger.error(`${prefix}${logMsg}`, error)
} else {
logger.warn(`${prefix}${logMsg}`, error)
}
}
- if (params?.throwError === true) {
+ if (params.throwError === true) {
throw error
}
}
export const handleSendMessageError = (
chargingStation: ChargingStation,
commandName: RequestCommand | IncomingRequestCommand,
+ messageType: MessageType,
error: Error,
- params: HandleErrorParams<EmptyObject> = { throwError: false, consoleOut: false }
+ params: HandleErrorParams<EmptyObject> = {
+ throwError: false,
+ consoleOut: false
+ }
): void => {
- setDefaultErrorParams(params, { throwError: false, consoleOut: false })
- logger.error(`${chargingStation.logPrefix()} Request command '${commandName}' error:`, error)
- if (params?.throwError === true) {
+ params = setDefaultErrorParams(params, { throwError: false, consoleOut: false })
+ logger.error(
+ `${chargingStation.logPrefix()} Send ${getMessageTypeString(messageType)} command '${commandName}' error:`,
+ error
+ )
+ if (params.throwError === true) {
throw error
}
}
params: HandleErrorParams<T>,
defaultParams: HandleErrorParams<T> = defaultErrorParams
): HandleErrorParams<T> => {
- params = { ...defaultParams, ...params }
- return params
+ return { ...defaultParams, ...params }
}