diff --git a/.eslintrc.json b/.eslintrc.json index d1a7ec4fc0..3810fd3ad0 100644 --- a/.eslintrc.json +++ b/.eslintrc.json @@ -22,6 +22,12 @@ "@typescript-eslint/explicit-member-accessibility": "off", "jsdoc/require-jsdoc": "off", "indent": "off", + "@typescript-eslint/unbound-method": [ + "error", + { + "ignoreStatic": true + } + ], "@typescript-eslint/indent": [ "error", 2, @@ -138,7 +144,7 @@ "max-len": [ "warn", { - "code": 180, + "code": 220, "ignoreComments": true, "ignoreUrls": true, "ignoreStrings": true, diff --git a/ecosystem.config.js b/ecosystem.config.js new file mode 100644 index 0000000000..ac4699d081 --- /dev/null +++ b/ecosystem.config.js @@ -0,0 +1,17 @@ +module.exports = { + apps: [{ + env: { + NODE_ENV: "development", + SERVER_ROLE: "ocppj" + }, + name: "pm2 - ocppj - server", + script: "./dist/start.js" + }, { + env: { + NODE_ENV: "development", + SERVER_ROLE: "rest" + }, + name: "pm2 - rest server", + script: "./dist/start.js" + }] +} diff --git a/package-lock.json b/package-lock.json index b5d1f25db3..97a39753a5 100644 --- a/package-lock.json +++ b/package-lock.json @@ -71,7 +71,7 @@ "tslib": "^2.4.0", "tz-lookup": "^6.1.25", "urlencode": "^1.1.0", - "uWebSockets.js": "github:uNetworking/uWebSockets.js#v20.10.0", + "uWebSockets.js": "github:uNetworking/uWebSockets.js#v20.19.0", "validator": "^13.7.0", "ws": "^8.10.0" }, @@ -43728,7 +43728,7 @@ }, "uWebSockets.js": { "version": "git+ssh://git@github.com/uNetworking/uWebSockets.js.git#806df48c9da86af7b3341f3e443388c7cd15c3de", - "from": "uWebSockets.js@github:uNetworking/uWebSockets.js#v20.10.0" + "from": "uWebSockets.js@github:uNetworking/uWebSockets.js#v20.19.0" }, "v8-compile-cache-lib": { "version": "3.0.1", diff --git a/package.json b/package.json index b99b74632c..212caae468 100644 --- a/package.json +++ b/package.json @@ -30,8 +30,8 @@ "start": "npm version && npm run start:prod", "start:dev": "npm version && cross-env NODE_OPTIONS=\"--max-old-space-size=4096\" NODE_ENV=development-build node -r source-map-support/register dist/start.js", "start:dev:debug": "npm version && cross-env NODE_ENV=development ts-node-dev --inspect --files --max-old-space-size=4096 -- src/start.ts", - "start:dev:debug:ocppj": "npm version && cross-env SERVER_ROLE=ocppj NODE_ENV=development ts-node-dev --inspect --files --max-old-space-size=4096 -- src/start.ts", - "start:dev:debug:rest": "npm version && cross-env SERVER_ROLE=rest NODE_ENV=development ts-node-dev --inspect --files --max-old-space-size=4096 -- src/start.ts", + "start:dev:debug:ocppj": "npm version && cross-env SERVER_ROLE=ocppj NODE_ENV=development ts-node-dev --inspect --files -- src/start.ts", + "start:dev:debug:rest": "npm version && cross-env SERVER_ROLE=rest NODE_ENV=development ts-node-dev --files -- src/start.ts", "start:dev:debug:nodemon": "npm version && nodemon --exec \"ts-node --files\" src/start.ts 9229", "start:dev:nodemon": "npm version && nodemon --exec \"ts-node --files\" src/start.ts", "start:dev:prof": "npm version && cross-env NODE_OPTIONS=\"--max-old-space-size=4096\" NODE_ENV=development node -r source-map-support/register --prof -- dist/start.js", @@ -157,7 +157,7 @@ "tslib": "^2.4.0", "tz-lookup": "^6.1.25", "urlencode": "^1.1.0", - "uWebSockets.js": "github:uNetworking/uWebSockets.js#v20.10.0", + "uWebSockets.js": "github:uNetworking/uWebSockets.js#v20.19.0", "validator": "^13.7.0", "ws": "^8.10.0" }, diff --git a/src/assets/configs-aws b/src/assets/configs-aws index 2f9ad8c1d9..9a491bc0d7 160000 --- a/src/assets/configs-aws +++ b/src/assets/configs-aws @@ -1 +1 @@ -Subproject commit 2f9ad8c1d965b0a211b6ef41c3f262120cc26b6e +Subproject commit 9a491bc0d76f713694e6473f38f18ade513f1c0c diff --git a/src/async-task/AsyncTaskBuilder.ts b/src/async-task/AsyncTaskBuilder.ts index c8adac2703..d81d1854a0 100644 --- a/src/async-task/AsyncTaskBuilder.ts +++ b/src/async-task/AsyncTaskBuilder.ts @@ -25,7 +25,7 @@ export default class AsyncTaskBuilder { // Save await AsyncTaskStorage.saveAsyncTask(asyncTask as AsyncTask); // Log - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: Constants.DEFAULT_TENANT_ID, action: ServerAction.ASYNC_TASK, module: MODULE_NAME, method: 'createAndSaveAsyncTasks', diff --git a/src/async-task/AsyncTaskManager.ts b/src/async-task/AsyncTaskManager.ts index b67835e7a9..5d9dba6d0c 100644 --- a/src/async-task/AsyncTaskManager.ts +++ b/src/async-task/AsyncTaskManager.ts @@ -54,7 +54,7 @@ export default class AsyncTaskManager { public static async handleAsyncTasks(): Promise { let failedToAcquireLock = false; - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: Constants.DEFAULT_TENANT_ID, action: ServerAction.ASYNC_TASK, module: MODULE_NAME, method: 'handleAsyncTasks', @@ -75,7 +75,7 @@ export default class AsyncTaskManager { { status: AsyncTaskStatus.PENDING }, Constants.DB_PARAMS_MAX_LIMIT); // Process them if (!Utils.isEmptyArray(asyncTasks.result)) { - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: Constants.DEFAULT_TENANT_ID, action: ServerAction.ASYNC_TASK, module: MODULE_NAME, method: 'handleAsyncTasks', @@ -98,7 +98,7 @@ export default class AsyncTaskManager { asyncTask.lastChangedOn = asyncTask.execTimestamp; await AsyncTaskStorage.saveAsyncTask(asyncTask); // Log - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: Constants.DEFAULT_TENANT_ID, action: ServerAction.ASYNC_TASK, module: MODULE_NAME, method: 'handleAsyncTasks', @@ -115,7 +115,7 @@ export default class AsyncTaskManager { await AsyncTaskStorage.saveAsyncTask(asyncTask); processedTask.inSuccess++; // Log - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: Constants.DEFAULT_TENANT_ID, action: ServerAction.ASYNC_TASK, module: MODULE_NAME, method: 'handleAsyncTasks', @@ -130,7 +130,7 @@ export default class AsyncTaskManager { asyncTask.lastChangedOn = new Date(); await AsyncTaskStorage.saveAsyncTask(asyncTask); // Log error - await Logging.logError({ + Logging.beError()?.log({ tenantID: Constants.DEFAULT_TENANT_ID, module: MODULE_NAME, method: 'handleAsyncTasks', action: ServerAction.ASYNC_TASK, @@ -162,7 +162,7 @@ export default class AsyncTaskManager { void AsyncTaskManager.handleAsyncTasks(); } } else { - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: Constants.DEFAULT_TENANT_ID, action: ServerAction.ASYNC_TASK, module: MODULE_NAME, method: 'handleAsyncTasks', @@ -201,7 +201,7 @@ export default class AsyncTaskManager { case AsyncTasks.OCPI_PUSH_EVSE_STATUSES: return new OCPIPushEVSEStatusesAsyncTask(asyncTask, correlationID); default: - await Logging.logError({ + Logging.beError()?.log({ tenantID: Constants.DEFAULT_TENANT_ID, action: ServerAction.ASYNC_TASK, module: MODULE_NAME, method: 'handleAsyncTasks', diff --git a/src/async-task/TenantAsyncTask.ts b/src/async-task/TenantAsyncTask.ts index 913d6a30dd..86c219155a 100644 --- a/src/async-task/TenantAsyncTask.ts +++ b/src/async-task/TenantAsyncTask.ts @@ -23,7 +23,7 @@ export default abstract class TenantAsyncTask extends AbstractAsyncTask { (taskSettings.task.disableAllTasks || !Utils.isEmptyArray(taskSettings.task.disableTasksInEnv) && taskSettings.task.disableTasksInEnv.includes(currentTaskEnv))) { // Tasks are disabled for this environment isTaskExecutionDisabled = true; - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: Constants.DEFAULT_TENANT_ID, action: ServerAction.ASYNC_TASK, module: MODULE_NAME, method: 'executeAsyncTask', @@ -43,7 +43,7 @@ export default abstract class TenantAsyncTask extends AbstractAsyncTask { } // Check if tenant task needs to run on a specific env if (tenant.taskExecutionEnv && tenant.taskExecutionEnv !== currentTaskEnv) { - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: Constants.DEFAULT_TENANT_ID, action: ServerAction.ASYNC_TASK, module: MODULE_NAME, method: 'executeAsyncTask', @@ -54,13 +54,13 @@ export default abstract class TenantAsyncTask extends AbstractAsyncTask { } const tenantCorrelationID = Utils.generateShortNonUniqueID(); const startTimeInTenant = moment(); - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: Constants.DEFAULT_TENANT_ID, action: ServerAction.ASYNC_TASK, module: MODULE_NAME, method: 'executeAsyncTask', message: `The Task '${this.getAsyncTask().name}~${this.getCorrelationID()}~${tenantCorrelationID}' is running for Tenant ${Utils.buildTenantName(tenant)}...` }); - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: tenant.id, action: ServerAction.ASYNC_TASK, module: MODULE_NAME, method: 'executeAsyncTask', @@ -74,14 +74,14 @@ export default abstract class TenantAsyncTask extends AbstractAsyncTask { // Hook await this.afterExecuteTenantAsyncTask(tenant); } catch (error) { - await Logging.logError({ + Logging.beError()?.log({ tenantID: Constants.DEFAULT_TENANT_ID, action: ServerAction.ASYNC_TASK, module: MODULE_NAME, method: 'executeAsyncTask', message: `Error while running the Task '${this.getAsyncTask().name}~${this.getCorrelationID()}~${tenantCorrelationID}' for Tenant ${Utils.buildTenantName(tenant)}: ${error.message as string}`, detailedMessages: { error: error.stack } }); - await Logging.logError({ + Logging.beError()?.log({ tenantID: tenant.id, action: ServerAction.ASYNC_TASK, module: MODULE_NAME, method: 'executeAsyncTask', @@ -91,13 +91,13 @@ export default abstract class TenantAsyncTask extends AbstractAsyncTask { } // Log Total Processing Time in Tenant const totalTimeSecsInTenant = moment.duration(moment().diff(startTimeInTenant)).asSeconds(); - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: Constants.DEFAULT_TENANT_ID, action: ServerAction.ASYNC_TASK, module: MODULE_NAME, method: 'executeAsyncTask', message: `The Task '${this.getAsyncTask().name}~${this.getCorrelationID()}~${tenantCorrelationID}' has been run successfully in ${totalTimeSecsInTenant} secs for Tenant ${Utils.buildTenantName(tenant)}` }); - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: tenant.id, action: ServerAction.ASYNC_TASK, module: MODULE_NAME, method: 'executeAsyncTask', diff --git a/src/async-task/tasks/BillTransactionAsyncTask.ts b/src/async-task/tasks/BillTransactionAsyncTask.ts index 4773e42844..ab5eb4992a 100644 --- a/src/async-task/tasks/BillTransactionAsyncTask.ts +++ b/src/async-task/tasks/BillTransactionAsyncTask.ts @@ -53,7 +53,7 @@ export default class BillTransactionAsyncTask extends AbstractAsyncTask { } } } catch (error) { - await Logging.logActionExceptionMessage(tenant.id, ServerAction.BILLING_TRANSACTION, error); + Logging.logActionExceptionMessage(tenant.id, ServerAction.BILLING_TRANSACTION, error); } } } diff --git a/src/async-task/tasks/ImportHelper.ts b/src/async-task/tasks/ImportHelper.ts index f1899e5911..42042b5ec1 100644 --- a/src/async-task/tasks/ImportHelper.ts +++ b/src/async-task/tasks/ImportHelper.ts @@ -140,7 +140,7 @@ export default class ImportHelper { await UserStorage.addSiteToUser(tenant, user.id, importedSiteID); } else { // Site does not exist - await Logging.logError({ + Logging.beError()?.log({ tenantID: tenant.id, action: ServerAction.USERS_IMPORT, module: MODULE_NAME, method: 'executeAsyncTask', diff --git a/src/async-task/tasks/SynchronizeCarCatalogsAsyncTask.ts b/src/async-task/tasks/SynchronizeCarCatalogsAsyncTask.ts index 32b541be11..4930a81fe0 100644 --- a/src/async-task/tasks/SynchronizeCarCatalogsAsyncTask.ts +++ b/src/async-task/tasks/SynchronizeCarCatalogsAsyncTask.ts @@ -24,7 +24,7 @@ export default class SynchronizeCarCatalogsAsyncTask extends AbstractAsyncTask { await carDatabaseImpl.synchronizeCarCatalogs(); } catch (error) { // Log error - await Logging.logActionExceptionMessage(Constants.DEFAULT_TENANT_ID, ServerAction.SYNCHRONIZE_CAR_CATALOGS, error); + Logging.logActionExceptionMessage(Constants.DEFAULT_TENANT_ID, ServerAction.SYNCHRONIZE_CAR_CATALOGS, error); } finally { // Release the lock await LockingManager.release(syncCarCatalogsLock); diff --git a/src/async-task/tasks/TagsImportAsyncTask.ts b/src/async-task/tasks/TagsImportAsyncTask.ts index 550912d519..c127618fce 100644 --- a/src/async-task/tasks/TagsImportAsyncTask.ts +++ b/src/async-task/tasks/TagsImportAsyncTask.ts @@ -43,7 +43,7 @@ export default class TagsImportAsyncTask extends AbstractAsyncTask { // Get total number of Tags to import const totalTagsToImport = await TagStorage.getImportedTagsCount(tenant); if (totalTagsToImport > 0) { - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: tenant.id, action: ServerAction.TAGS_IMPORT, module: MODULE_NAME, method: 'processTenant', @@ -66,7 +66,7 @@ export default class TagsImportAsyncTask extends AbstractAsyncTask { importedTag.errorDescription = error.message; result.inError++; await TagStorage.saveImportedTag(tenant, importedTag); - await Logging.logError({ + Logging.beError()?.log({ tenantID: tenant.id, action: ServerAction.TAGS_IMPORT, module: MODULE_NAME, method: 'processTenant', @@ -77,7 +77,7 @@ export default class TagsImportAsyncTask extends AbstractAsyncTask { } if (!Utils.isEmptyArray(importedTags.result) && (result.inError + result.inSuccess) > 0) { const intermediateDurationSecs = Math.round((new Date().getTime() - startTime) / 1000); - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: tenant.id, action: ServerAction.TAGS_IMPORT, module: MODULE_NAME, method: 'processTenant', @@ -95,7 +95,7 @@ export default class TagsImportAsyncTask extends AbstractAsyncTask { ); } catch (error) { // Log error - await Logging.logActionExceptionMessage(tenant.id, ServerAction.TAGS_IMPORT, error); + Logging.logActionExceptionMessage(tenant.id, ServerAction.TAGS_IMPORT, error); } finally { // Release the lock await LockingManager.release(importTagsLock); diff --git a/src/async-task/tasks/UsersImportAsyncTask.ts b/src/async-task/tasks/UsersImportAsyncTask.ts index 400351c935..38c987d71a 100644 --- a/src/async-task/tasks/UsersImportAsyncTask.ts +++ b/src/async-task/tasks/UsersImportAsyncTask.ts @@ -42,7 +42,7 @@ export default class UsersImportAsyncTask extends AbstractAsyncTask { // Get total number of Users to import const totalUsersToImport = await UserStorage.getImportedUsersCount(tenant); if (totalUsersToImport > 0) { - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: tenant.id, action: ServerAction.USERS_IMPORT, module: MODULE_NAME, method: 'processTenant', @@ -66,7 +66,7 @@ export default class UsersImportAsyncTask extends AbstractAsyncTask { result.inError++; // Update it await UserStorage.saveImportedUser(tenant, importedUser); - await Logging.logError({ + Logging.beError()?.log({ tenantID: tenant.id, action: ServerAction.USERS_IMPORT, module: MODULE_NAME, method: 'executeAsyncTask', @@ -77,7 +77,7 @@ export default class UsersImportAsyncTask extends AbstractAsyncTask { } if (importedUsers.result.length > 0 && (result.inError + result.inSuccess) > 0) { const intermediateDurationSecs = Math.round((new Date().getTime() - startTime) / 1000); - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: tenant.id, action: ServerAction.USERS_IMPORT, module: MODULE_NAME, method: 'processTenant', @@ -95,7 +95,7 @@ export default class UsersImportAsyncTask extends AbstractAsyncTask { ); } catch (error) { // Log error - await Logging.logActionExceptionMessage(tenant.id, ServerAction.USERS_IMPORT, error); + Logging.logActionExceptionMessage(tenant.id, ServerAction.USERS_IMPORT, error); } finally { // Release the lock await LockingManager.release(importUsersLock); diff --git a/src/async-task/tasks/ocpi/OCPICheckCdrsAsyncTask.ts b/src/async-task/tasks/ocpi/OCPICheckCdrsAsyncTask.ts index 65800f53f4..82083f0913 100644 --- a/src/async-task/tasks/ocpi/OCPICheckCdrsAsyncTask.ts +++ b/src/async-task/tasks/ocpi/OCPICheckCdrsAsyncTask.ts @@ -35,7 +35,7 @@ export default class OCPICheckCdrsAsyncTask extends AbstractAsyncTask { } } } catch (error) { - await Logging.logActionExceptionMessage(tenant.id, ServerAction.OCPI_CPO_CHECK_CDRS, error); + Logging.logActionExceptionMessage(tenant.id, ServerAction.OCPI_CPO_CHECK_CDRS, error); } } } diff --git a/src/async-task/tasks/ocpi/OCPICheckLocationsAsyncTask.ts b/src/async-task/tasks/ocpi/OCPICheckLocationsAsyncTask.ts index 928b3648e4..310f4e27f5 100644 --- a/src/async-task/tasks/ocpi/OCPICheckLocationsAsyncTask.ts +++ b/src/async-task/tasks/ocpi/OCPICheckLocationsAsyncTask.ts @@ -35,7 +35,7 @@ export default class OCPICheckLocationsAsyncTask extends AbstractAsyncTask { } } } catch (error) { - await Logging.logActionExceptionMessage(tenant.id, ServerAction.OCPI_CPO_CHECK_LOCATIONS, error); + Logging.logActionExceptionMessage(tenant.id, ServerAction.OCPI_CPO_CHECK_LOCATIONS, error); } } } diff --git a/src/async-task/tasks/ocpi/OCPICheckSessionsAsyncTask.ts b/src/async-task/tasks/ocpi/OCPICheckSessionsAsyncTask.ts index a209e6bd01..9e81159897 100644 --- a/src/async-task/tasks/ocpi/OCPICheckSessionsAsyncTask.ts +++ b/src/async-task/tasks/ocpi/OCPICheckSessionsAsyncTask.ts @@ -35,7 +35,7 @@ export default class OCPICheckSessionsAsyncTask extends AbstractAsyncTask { } } } catch (error) { - await Logging.logActionExceptionMessage(tenant.id, ServerAction.OCPI_CPO_CHECK_SESSIONS, error); + Logging.logActionExceptionMessage(tenant.id, ServerAction.OCPI_CPO_CHECK_SESSIONS, error); } } } diff --git a/src/async-task/tasks/ocpi/OCPIPullCdrsAsyncTask.ts b/src/async-task/tasks/ocpi/OCPIPullCdrsAsyncTask.ts index 455e54ff56..2f31e395fc 100644 --- a/src/async-task/tasks/ocpi/OCPIPullCdrsAsyncTask.ts +++ b/src/async-task/tasks/ocpi/OCPIPullCdrsAsyncTask.ts @@ -35,7 +35,7 @@ export default class OCPIPullCdrsAsyncTask extends AbstractAsyncTask { } } } catch (error) { - await Logging.logActionExceptionMessage(tenant.id, ServerAction.OCPI_EMSP_GET_CDR, error); + Logging.logActionExceptionMessage(tenant.id, ServerAction.OCPI_EMSP_GET_CDR, error); } } } diff --git a/src/async-task/tasks/ocpi/OCPIPullLocationsAsyncTask.ts b/src/async-task/tasks/ocpi/OCPIPullLocationsAsyncTask.ts index 776dc047be..f1ede60d02 100644 --- a/src/async-task/tasks/ocpi/OCPIPullLocationsAsyncTask.ts +++ b/src/async-task/tasks/ocpi/OCPIPullLocationsAsyncTask.ts @@ -35,7 +35,7 @@ export default class OCPIPullLocationsAsyncTask extends AbstractAsyncTask { } } } catch (error) { - await Logging.logActionExceptionMessage(tenant.id, ServerAction.OCPI_EMSP_GET_LOCATIONS, error); + Logging.logActionExceptionMessage(tenant.id, ServerAction.OCPI_EMSP_GET_LOCATIONS, error); } } } diff --git a/src/async-task/tasks/ocpi/OCPIPullSessionsAsyncTask.ts b/src/async-task/tasks/ocpi/OCPIPullSessionsAsyncTask.ts index e670b9af5b..9e0bea587c 100644 --- a/src/async-task/tasks/ocpi/OCPIPullSessionsAsyncTask.ts +++ b/src/async-task/tasks/ocpi/OCPIPullSessionsAsyncTask.ts @@ -35,7 +35,7 @@ export default class OCPIPullSessionsAsyncTask extends AbstractAsyncTask { } } } catch (error) { - await Logging.logActionExceptionMessage(tenant.id, ServerAction.OCPI_EMSP_GET_SESSION, error); + Logging.logActionExceptionMessage(tenant.id, ServerAction.OCPI_EMSP_GET_SESSION, error); } } } diff --git a/src/async-task/tasks/ocpi/OCPIPullTokensAsyncTask.ts b/src/async-task/tasks/ocpi/OCPIPullTokensAsyncTask.ts index 2dd5c1df39..d265cb715a 100644 --- a/src/async-task/tasks/ocpi/OCPIPullTokensAsyncTask.ts +++ b/src/async-task/tasks/ocpi/OCPIPullTokensAsyncTask.ts @@ -35,7 +35,7 @@ export default class OCPIPullTokensAsyncTask extends AbstractAsyncTask { } } } catch (error) { - await Logging.logActionExceptionMessage(tenant.id, ServerAction.OCPI_CPO_GET_TOKENS, error); + Logging.logActionExceptionMessage(tenant.id, ServerAction.OCPI_CPO_GET_TOKENS, error); } } } diff --git a/src/async-task/tasks/ocpi/OCPIPushEVSEStatusesAsyncTask.ts b/src/async-task/tasks/ocpi/OCPIPushEVSEStatusesAsyncTask.ts index 5e87c3e77e..e158d70e32 100644 --- a/src/async-task/tasks/ocpi/OCPIPushEVSEStatusesAsyncTask.ts +++ b/src/async-task/tasks/ocpi/OCPIPushEVSEStatusesAsyncTask.ts @@ -35,7 +35,7 @@ export default class OCPIPushEVSEStatusesAsyncTask extends AbstractAsyncTask { } } } catch (error) { - await Logging.logActionExceptionMessage(tenant.id, ServerAction.OCPI_CPO_UPDATE_STATUS, error); + Logging.logActionExceptionMessage(tenant.id, ServerAction.OCPI_CPO_UPDATE_STATUS, error); } } } diff --git a/src/async-task/tasks/ocpi/OCPIPushTokensAsyncTask.ts b/src/async-task/tasks/ocpi/OCPIPushTokensAsyncTask.ts index ed9d850793..f2a203fdf3 100644 --- a/src/async-task/tasks/ocpi/OCPIPushTokensAsyncTask.ts +++ b/src/async-task/tasks/ocpi/OCPIPushTokensAsyncTask.ts @@ -36,7 +36,7 @@ export default class OCPIPushTokensAsyncTask extends AbstractAsyncTask { } } } catch (error) { - await Logging.logActionExceptionMessage(tenant.id, ServerAction.OCPI_EMSP_UPDATE_TOKENS, error); + Logging.logActionExceptionMessage(tenant.id, ServerAction.OCPI_EMSP_UPDATE_TOKENS, error); } } } diff --git a/src/authorization/Authorizations.ts b/src/authorization/Authorizations.ts index 1a97f050f7..2e95214bb3 100644 --- a/src/authorization/Authorizations.ts +++ b/src/authorization/Authorizations.ts @@ -948,7 +948,7 @@ export default class Authorizations { if (remoteAuthorization && OCPIUtils.isAuthorizationValid(remoteAuthorization.timestamp)) { // Check Tag ID if (remoteAuthorization.tagId === tag.ocpiToken?.uid) { - await Logging.logDebug({ + Logging.beDebug()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, action, message: `${Utils.buildConnectorInfo(connector.connectorId, transaction?.id)} Valid Remote Authorization found for Tag ID '${tag.ocpiToken.uid}'`, diff --git a/src/bootstrap/LocalCarCatalogBootstrap.ts b/src/bootstrap/LocalCarCatalogBootstrap.ts index ff4c2f1d77..87daede0d1 100644 --- a/src/bootstrap/LocalCarCatalogBootstrap.ts +++ b/src/bootstrap/LocalCarCatalogBootstrap.ts @@ -54,7 +54,7 @@ export default class LocalCarCatalogBootstrap { created++; } catch (error) { const message = `Error while importing the local Car ID '${carCatalog.id}': ${error.message as string}`; - await Logging.logError({ + Logging.beError()?.log({ tenantID: Constants.DEFAULT_TENANT_ID, action: ServerAction.UPDATE_LOCAL_CAR_CATALOGS, module: MODULE_NAME, method: 'uploadLocalCarCatalogsFromFile', @@ -66,7 +66,7 @@ export default class LocalCarCatalogBootstrap { } } catch (error) { const message = `Error while importing the local Cars: ${error.message as string}`; - await Logging.logError({ + Logging.beError()?.log({ tenantID: Constants.DEFAULT_TENANT_ID, action: ServerAction.UPDATE_LOCAL_CAR_CATALOGS, module: MODULE_NAME, method: 'uploadLocalCarCatalogsFromFile', @@ -77,7 +77,7 @@ export default class LocalCarCatalogBootstrap { // Log in the default tenant if (created > 0) { const message = `${created} local Car(s) catalog created in the default tenant`; - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: Constants.DEFAULT_TENANT_ID, action: ServerAction.UPDATE_LOCAL_CAR_CATALOGS, message, module: MODULE_NAME, method: 'uploadLocalCarCatalogsFromFile', diff --git a/src/client/ocpi/CpoOCPIClient.ts b/src/client/ocpi/CpoOCPIClient.ts index 93bdc4f5ec..ba642c3c6c 100644 --- a/src/client/ocpi/CpoOCPIClient.ts +++ b/src/client/ocpi/CpoOCPIClient.ts @@ -117,7 +117,7 @@ export default class CpoOCPIClient extends OCPIClient { } const numberOfTags = response.data.data.length as number; totalNumberOfTags += numberOfTags; - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: this.tenant.id, action: ServerAction.OCPI_CPO_GET_TOKENS, message: `${numberOfTags.toString()} Tokens retrieved from ${tokensUrl}`, @@ -162,7 +162,7 @@ export default class CpoOCPIClient extends OCPIClient { } const executionDurationLoopSecs = (new Date().getTime() - startTimeLoop) / 1000; const executionDurationTotalLoopSecs = (new Date().getTime() - startTime) / 1000; - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: this.tenant.id, action: ServerAction.OCPI_CPO_GET_TOKENS, message: `${numberOfTags.toString()} token(s) processed in ${executionDurationLoopSecs}s - Total of ${totalNumberOfTags} token(s) processed in ${executionDurationTotalLoopSecs}s`, @@ -239,7 +239,7 @@ export default class CpoOCPIClient extends OCPIClient { detailedMessages: { locationReference, authorizationInfo } }); } - await Logging.logInfo({ + Logging.beInfo()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: this.tenant.id, action: ServerAction.OCPI_CPO_AUTHORIZE_TOKEN, @@ -284,7 +284,7 @@ export default class CpoOCPIClient extends OCPIClient { transaction.ocpiData = { session: ocpiSession }; - await Logging.logInfo({ + Logging.beInfo()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: this.tenant.id, action: ServerAction.OCPI_CPO_START_SESSION, @@ -330,7 +330,7 @@ export default class CpoOCPIClient extends OCPIClient { 'Content-Type': 'application/json' }, }); - await Logging.logInfo({ + Logging.beInfo()?.log({ ...LoggingHelper.getTransactionProperties(transaction), tenantID: this.tenant.id, action: ServerAction.OCPI_CPO_PUSH_SESSIONS, @@ -375,7 +375,7 @@ export default class CpoOCPIClient extends OCPIClient { 'Content-Type': 'application/json' }, }); - await Logging.logInfo({ + Logging.beInfo()?.log({ ...LoggingHelper.getTransactionProperties(transaction), tenantID: this.tenant.id, action: ServerAction.OCPI_CPO_STOP_SESSION, @@ -441,7 +441,7 @@ export default class CpoOCPIClient extends OCPIClient { 'Content-Type': 'application/json' }, }); - await Logging.logInfo({ + Logging.beInfo()?.log({ ...LoggingHelper.getTransactionProperties(transaction), tenantID: this.tenant.id, action: ServerAction.OCPI_CPO_PUSH_CDRS, @@ -451,7 +451,7 @@ export default class CpoOCPIClient extends OCPIClient { }); return true; } - await Logging.logWarning({ + Logging.beWarning()?.log({ ...LoggingHelper.getTransactionProperties(transaction), tenantID: this.tenant.id, action: ServerAction.OCPI_CPO_PUSH_CDRS, @@ -760,7 +760,7 @@ export default class CpoOCPIClient extends OCPIClient { { concurrency: Constants.OCPI_MAX_PARALLEL_REQUESTS }); const executionDurationLoopSecs = (new Date().getTime() - startTimeLoop) / 1000; const executionDurationTotalLoopSecs = (new Date().getTime() - startTime) / 1000; - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: this.tenant.id, action: ServerAction.OCPI_CPO_UPDATE_STATUS, message: `${evses.length} EVSE Status(es) processed in ${executionDurationLoopSecs}s in Location '${location.name}' - Total of ${totalNumberOfEvses} EVSE(s) processed in ${executionDurationTotalLoopSecs}s`, @@ -864,7 +864,7 @@ export default class CpoOCPIClient extends OCPIClient { 'Content-Type': 'application/json' }, }); - await Logging.logInfo({ + Logging.beInfo()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation as ChargingStation), tenantID: this.tenant.id, action: ServerAction.OCPI_CPO_UPDATE_STATUS, @@ -898,7 +898,7 @@ export default class CpoOCPIClient extends OCPIClient { }); // Create if it does not exit if (response.data.status_code === 3001) { - await Logging.logError({ + Logging.beError()?.log({ ...LoggingHelper.getTransactionProperties(transaction), tenantID: this.tenant.id, action: ServerAction.OCPI_CPO_CHECK_CDRS, @@ -920,7 +920,7 @@ export default class CpoOCPIClient extends OCPIClient { const cdr = response.data.data as OCPICdr; if (cdr) { // CDR checked - await Logging.logInfo({ + Logging.beInfo()?.log({ ...LoggingHelper.getTransactionProperties(transaction), tenantID: this.tenant.id, action: ServerAction.OCPI_CPO_CHECK_CDRS, @@ -931,7 +931,7 @@ export default class CpoOCPIClient extends OCPIClient { return true; } } - await Logging.logError({ + Logging.beError()?.log({ ...LoggingHelper.getTransactionProperties(transaction), tenantID: this.tenant.id, action: ServerAction.OCPI_CPO_CHECK_CDRS, @@ -966,7 +966,7 @@ export default class CpoOCPIClient extends OCPIClient { if (OCPIUtilsService.isSuccessResponse(response.data)) { const session = response.data.data as OCPISession; if (session) { - await Logging.logInfo({ + Logging.beInfo()?.log({ ...LoggingHelper.getTransactionProperties(transaction), tenantID: this.tenant.id, action: ServerAction.OCPI_CPO_CHECK_SESSIONS, @@ -977,7 +977,7 @@ export default class CpoOCPIClient extends OCPIClient { return true; } } - await Logging.logError({ + Logging.beError()?.log({ ...LoggingHelper.getTransactionProperties(transaction), tenantID: this.tenant.id, action: ServerAction.OCPI_CPO_CHECK_SESSIONS, @@ -1022,7 +1022,7 @@ export default class CpoOCPIClient extends OCPIClient { detailedMessages: { location, ocpiLocation } }); } - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: this.tenant.id, action: ServerAction.OCPI_CPO_CHECK_LOCATIONS, message: `Location '${location.name}' with ID '${location.id}' checked successfully`, diff --git a/src/client/ocpi/EmspOCPIClient.ts b/src/client/ocpi/EmspOCPIClient.ts index 78f9e02cd8..b93a19490f 100644 --- a/src/client/ocpi/EmspOCPIClient.ts +++ b/src/client/ocpi/EmspOCPIClient.ts @@ -99,7 +99,7 @@ export default class EmspOCPIClient extends OCPIClient { currentSkip += Constants.DB_RECORD_COUNT_DEFAULT; const executionDurationLoopSecs = (new Date().getTime() - startTimeLoop) / 1000; const executionDurationTotalLoopSecs = (new Date().getTime() - startTime) / 1000; - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: this.tenant.id, action: ServerAction.OCPI_EMSP_UPDATE_TOKENS, message: `${tokens.count.toString()} token(s) pushed in ${executionDurationLoopSecs}s - Total of ${totalNumberOfTokens} token(s) pushed in ${executionDurationTotalLoopSecs}s`, @@ -188,7 +188,7 @@ export default class EmspOCPIClient extends OCPIClient { } const numberOfLocations = response.data.data.length as number; totalNumberOfLocations += numberOfLocations; - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: this.tenant.id, action: ServerAction.OCPI_CPO_GET_TOKENS, message: `${numberOfLocations.toString()} Tokens retrieved from ${locationsUrl}`, @@ -237,7 +237,7 @@ export default class EmspOCPIClient extends OCPIClient { } const executionDurationLoopSecs = (new Date().getTime() - startTimeLoop) / 1000; const executionDurationTotalLoopSecs = (new Date().getTime() - startTime) / 1000; - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: this.tenant.id, action: ServerAction.OCPI_EMSP_GET_LOCATIONS, message: `${numberOfLocations.toString()} location(s) processed in ${executionDurationLoopSecs}s - Total of ${totalNumberOfLocations} location(s) processed in ${executionDurationTotalLoopSecs}s`, @@ -471,7 +471,7 @@ export default class EmspOCPIClient extends OCPIClient { 'Content-Type': 'application/json' }, }); - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: this.tenant.id, ...LoggingHelper.getChargingStationProperties(chargingStation), action: ServerAction.OCPI_EMSP_START_SESSION, @@ -527,7 +527,7 @@ export default class EmspOCPIClient extends OCPIClient { 'Content-Type': 'application/json' }, }); - await Logging.logDebug({ + Logging.beDebug()?.log({ ...LoggingHelper.getTransactionProperties(transaction), tenantID: this.tenant.id, action: ServerAction.OCPI_EMSP_STOP_SESSION, diff --git a/src/client/ocpi/OCPIClient.ts b/src/client/ocpi/OCPIClient.ts index 72eb7387f2..5e36abb9c2 100644 --- a/src/client/ocpi/OCPIClient.ts +++ b/src/client/ocpi/OCPIClient.ts @@ -169,7 +169,7 @@ export default abstract class OCPIClient { } public async getVersions(): Promise { - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: this.tenant.id, action: ServerAction.OCPI_GET_VERSIONS, message: `Get OCPI Versions at ${this.ocpiEndpoint.baseUrl}`, @@ -188,7 +188,7 @@ export default abstract class OCPIClient { } public async getEndpointVersions(): Promise { - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: this.tenant.id, action: ServerAction.OCPI_GET_ENDPOINT_VERSIONS, message: `Get OCPI Services at ${this.ocpiEndpoint.versionUrl}`, @@ -267,7 +267,7 @@ export default abstract class OCPIClient { private async deleteCredentials(): Promise { // Get credentials url const credentialsUrl = this.getEndpointUrl('credentials', ServerAction.OCPI_CREATE_CREDENTIALS); - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: this.tenant.id, action: ServerAction.OCPI_CREATE_CREDENTIALS, message: `Delete Credentials at ${credentialsUrl}`, @@ -288,7 +288,7 @@ export default abstract class OCPIClient { // Get credentials url const credentialsUrl = this.getEndpointUrl('credentials', ServerAction.OCPI_CREATE_CREDENTIALS); const credentials = await OCPIUtils.buildOcpiCredentialObject(this.tenant, this.ocpiEndpoint.localToken, this.ocpiEndpoint.role); - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: this.tenant.id, action: ServerAction.OCPI_CREATE_CREDENTIALS, message: `Post Credentials at ${credentialsUrl}`, @@ -310,7 +310,7 @@ export default abstract class OCPIClient { // Get credentials url const credentialsUrl = this.getEndpointUrl('credentials', ServerAction.OCPI_UPDATE_CREDENTIALS); const credentials = await OCPIUtils.buildOcpiCredentialObject(this.tenant, this.ocpiEndpoint.localToken, this.ocpiEndpoint.role); - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: this.tenant.id, action: ServerAction.OCPI_UPDATE_CREDENTIALS, message: `Put Credentials at ${credentialsUrl}`, diff --git a/src/client/ocpi/OCPIClientFactory.ts b/src/client/ocpi/OCPIClientFactory.ts index 37084e7fc4..f2fabab363 100644 --- a/src/client/ocpi/OCPIClientFactory.ts +++ b/src/client/ocpi/OCPIClientFactory.ts @@ -22,7 +22,7 @@ export default class OCPIClientFactory { if (Utils.isTenantComponentActive(tenant, TenantComponents.OCPI)) { const ocpiSettings = await SettingStorage.getOCPISettings(tenant); if (!ocpiSettings && ocpiSettings.ocpi) { - await Logging.logError({ + Logging.beError()?.log({ tenantID: tenant.id, action: ServerAction.OCPI_SETTINGS, module: MODULE_NAME, method: 'getOcpiClient', @@ -37,7 +37,7 @@ export default class OCPIClientFactory { return new EmspOCPIClient(tenant, ocpiSettings.ocpi, ocpiEndpoint); } } else { - await Logging.logError({ + Logging.beError()?.log({ tenantID: tenant.id, action: ServerAction.OCPI_SETTINGS, module: MODULE_NAME, method: 'getOcpiClient', @@ -52,7 +52,7 @@ export default class OCPIClientFactory { const client = await OCPIClientFactory.getOcpiClient(tenant, ocpiEndpoint); return client as CpoOCPIClient; } - await Logging.logError({ + Logging.beError()?.log({ tenantID: tenant.id, action: ServerAction.OCPI_CLIENT_INITIALIZATION, module: MODULE_NAME, method: 'getCpoOcpiClient', @@ -65,7 +65,7 @@ export default class OCPIClientFactory { const client = await OCPIClientFactory.getOcpiClient(tenant, ocpiEndpoint); return client as EmspOCPIClient; } - await Logging.logError({ + Logging.beError()?.log({ tenantID: tenant.id, action: ServerAction.OCPI_CLIENT_INITIALIZATION, module: MODULE_NAME, method: 'getEmspOcpiClient', diff --git a/src/client/ocpp/ChargingStationClientFactory.ts b/src/client/ocpp/ChargingStationClientFactory.ts index df1729fd85..1e488e9cb1 100644 --- a/src/client/ocpp/ChargingStationClientFactory.ts +++ b/src/client/ocpp/ChargingStationClientFactory.ts @@ -17,7 +17,7 @@ export default class ChargingStationClientFactory { // Json Server if (global.centralSystemJsonServer?.hasChargingStationConnected(tenant, chargingStation)) { // Get the local WS Connection Client - chargingClient = await global.centralSystemJsonServer.getChargingStationClient(tenant, chargingStation); + chargingClient = global.centralSystemJsonServer.getChargingStationClient(tenant, chargingStation); } else { // Get the Remote WS Connection Client (Rest) chargingClient = new JsonRestChargingStationClient(tenant.id, chargingStation); diff --git a/src/client/ocpp/json/JsonChargingStationClient.ts b/src/client/ocpp/json/JsonChargingStationClient.ts index b61e9c3640..b34db89a9f 100644 --- a/src/client/ocpp/json/JsonChargingStationClient.ts +++ b/src/client/ocpp/json/JsonChargingStationClient.ts @@ -4,7 +4,6 @@ import ChargingStationClient from '../../ocpp/ChargingStationClient'; import { Command } from '../../../types/ChargingStation'; import JsonWSConnection from '../../../server/ocpp/json/web-socket/JsonWSConnection'; import Logging from '../../../utils/Logging'; -import { OCPPMessageType } from '../../../types/ocpp/OCPPCommon'; import OCPPUtils from '../../../server/ocpp/utils/OCPPUtils'; import Tenant from '../../../types/Tenant'; import Utils from '../../../utils/Utils'; @@ -103,7 +102,7 @@ export default class JsonChargingStationClient extends ChargingStationClient { OCPPUtils.buildServerActionFromOcppCommand(command), params, '<<', { siteAreaID: this.siteAreaID, siteID: this.siteID, companyID: this.companyID }); // Execute - const result = await this.wsConnection.sendMessage(Utils.generateUUID(), OCPPMessageType.CALL_MESSAGE, command, params); + const result = await this.wsConnection.sendMessageAndWaitForResult(Utils.generateUUID(), command, params as Record); // Trace await Logging.traceOcppMessageResponse(MODULE_NAME, this.tenant, this.chargingStationID, OCPPUtils.buildServerActionFromOcppCommand(command), params, result, '>>', diff --git a/src/client/ocpp/json/JsonRestChargingStationClient.ts b/src/client/ocpp/json/JsonRestChargingStationClient.ts index 7cb9e9fdbd..4094f8f68a 100644 --- a/src/client/ocpp/json/JsonRestChargingStationClient.ts +++ b/src/client/ocpp/json/JsonRestChargingStationClient.ts @@ -115,11 +115,9 @@ export default class JsonRestChargingStationClient extends ChargingStationClient return this.sendMessage(this.buildRequest(Command.CANCEL_RESERVATION, params)); } - private async openConnection(request: OCPPOutgoingRequest): Promise { - // Extract Current Command - const triggeringCommand: Command = request[2]; + private async openConnection(triggeringCommand: string): Promise { // Log - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: this.tenantID, siteID: this.chargingStation.siteID, siteAreaID: this.chargingStation.siteAreaID, @@ -143,9 +141,8 @@ export default class JsonRestChargingStationClient extends ChargingStationClient // Create and Open the WS this.wsConnection = new WSClient(this.serverURL, wsClientOptions); // Opened - // eslint-disable-next-line @typescript-eslint/no-misused-promises - this.wsConnection.onopen = async () => { - await Logging.logInfo({ + this.wsConnection.onopen = () => { + Logging.beInfo()?.log({ tenantID: this.tenantID, siteID: this.chargingStation.siteID, siteAreaID: this.chargingStation.siteAreaID, @@ -159,9 +156,8 @@ export default class JsonRestChargingStationClient extends ChargingStationClient resolve(); }; // Closed - // eslint-disable-next-line @typescript-eslint/no-misused-promises - this.wsConnection.onclose = async (code: number) => { - await Logging.logInfo({ + this.wsConnection.onclose = (code: number) => { + Logging.beInfo()?.log({ tenantID: this.tenantID, siteID: this.chargingStation.siteID, siteAreaID: this.chargingStation.siteAreaID, @@ -174,9 +170,8 @@ export default class JsonRestChargingStationClient extends ChargingStationClient }); }; // Handle Error Message - // eslint-disable-next-line @typescript-eslint/no-misused-promises - this.wsConnection.onerror = async (error: Error) => { - await Logging.logError({ + this.wsConnection.onerror = (error: Error) => { + Logging.beError()?.log({ tenantID: this.tenantID, siteID: this.chargingStation.siteID, siteAreaID: this.chargingStation.siteAreaID, @@ -192,8 +187,7 @@ export default class JsonRestChargingStationClient extends ChargingStationClient reject(new Error(`Error on opening Web Socket connection: ${error.message}'`)); }; // Handle Server Message - // eslint-disable-next-line @typescript-eslint/no-misused-promises - this.wsConnection.onmessage = async (message) => { + this.wsConnection.onmessage = (message) => { try { // Parse the message const [messageType, messageId, command, commandPayload, errorDetails]: OCPPIncomingRequest = JSON.parse(message.data) as OCPPIncomingRequest; @@ -202,7 +196,7 @@ export default class JsonRestChargingStationClient extends ChargingStationClient // Check message type if (messageType === OCPPMessageType.CALL_ERROR_MESSAGE) { // Error message - await Logging.logError({ + Logging.beError()?.log({ tenantID: this.tenantID, siteID: this.chargingStation.siteID, siteAreaID: this.chargingStation.siteAreaID, @@ -224,7 +218,7 @@ export default class JsonRestChargingStationClient extends ChargingStationClient this.closeConnection(); } else { // Error message - await Logging.logError({ + Logging.beError()?.log({ tenantID: this.tenantID, siteID: this.chargingStation.siteID, siteAreaID: this.chargingStation.siteAreaID, @@ -237,7 +231,7 @@ export default class JsonRestChargingStationClient extends ChargingStationClient }); } } catch (error) { - await Logging.logException(error as Error, ServerAction.WS_CLIENT_MESSAGE, MODULE_NAME, 'onMessage', this.tenantID); + Logging.logException(error as Error, ServerAction.WS_CLIENT_MESSAGE, MODULE_NAME, 'onMessage', this.tenantID); } }; } catch (error) { @@ -268,11 +262,11 @@ export default class JsonRestChargingStationClient extends ChargingStationClient // Charging station is not connected to the server - let's abort the current operation throw new Error(`Charging station is not connected to the server - request '${request[2]}' has been aborted`); } - // eslint-disable-next-line @typescript-eslint/no-misused-promises, no-async-promise-executor - return new Promise(async (resolve, reject) => { - try { - // Open WS Connection - await this.openConnection(request); + // Extract Current Command + const triggeringCommand: Command = request[2]; + return new Promise((resolve, reject) => { + // Open WS Connection + this.openConnection(triggeringCommand).then(() => { // Check if wsConnection is ready if (this.wsConnection?.isConnectionOpen()) { // Send @@ -283,9 +277,9 @@ export default class JsonRestChargingStationClient extends ChargingStationClient // Reject it reject(new Error(`Socket is closed for message ${request[2]}`)); } - } catch (error) { + }).catch((error: Error) => { reject(new Error(`Unexpected error on request '${request[2]}': ${error.message}'`)); - } + }); }); } diff --git a/src/client/ocpp/soap/SoapChargingStationClient.ts b/src/client/ocpp/soap/SoapChargingStationClient.ts index 73610caff9..df32e4399f 100644 --- a/src/client/ocpp/soap/SoapChargingStationClient.ts +++ b/src/client/ocpp/soap/SoapChargingStationClient.ts @@ -39,7 +39,7 @@ export default class SoapChargingStationClient extends ChargingStationClient { break; default: // Log - void Logging.logError({ + Logging.beError()?.log({ tenantID: scsc.tenant.id, action: ServerAction.CHARGING_STATION_CLIENT_INITIALIZATION, siteID: scsc.chargingStation.siteID, @@ -54,9 +54,9 @@ export default class SoapChargingStationClient extends ChargingStationClient { // Client options const options: any = {}; // Create SOAP client - soap.createClient(chargingStationWdsl, options, async (error, client) => { + soap.createClient(chargingStationWdsl, options, (error, client) => { if (error) { - await Logging.logError({ + Logging.beError()?.log({ tenantID: scsc.tenant.id, action: ServerAction.CHARGING_STATION_CLIENT_INITIALIZATION, siteID: scsc.chargingStation.siteID, @@ -96,7 +96,7 @@ export default class SoapChargingStationClient extends ChargingStationClient { 'remoteStopTransactionRequest': params }); if (error) { - await Logging.logError({ + Logging.beError()?.log({ tenantID: this.tenant.id, action: ServerAction.CHARGING_STATION_REMOTE_STOP_TRANSACTION, siteID: this.chargingStation.siteID, @@ -135,7 +135,7 @@ export default class SoapChargingStationClient extends ChargingStationClient { const { error, result, envelope } = await this.client.RemoteStartTransaction(params); if (error) { // Log - await Logging.logError({ + Logging.beError()?.log({ tenantID: this.tenant.id, action: ServerAction.CHARGING_STATION_REMOTE_START_TRANSACTION, siteID: this.chargingStation.siteID, @@ -175,7 +175,7 @@ export default class SoapChargingStationClient extends ChargingStationClient { }); if (error) { // Log - await Logging.logError({ + Logging.beError()?.log({ tenantID: this.tenant.id, action: ServerAction.CHARGING_STATION_UNLOCK_CONNECTOR, siteID: this.chargingStation.siteID, @@ -215,7 +215,7 @@ export default class SoapChargingStationClient extends ChargingStationClient { }); if (error) { // Log - await Logging.logError({ + Logging.beError()?.log({ tenantID: this.tenant.id, action: ServerAction.CHARGING_STATION_RESET, siteID: this.chargingStation.siteID, @@ -253,7 +253,7 @@ export default class SoapChargingStationClient extends ChargingStationClient { const { error, result, envelope } = await this.client.ClearCache({ clearCacheRequest: {} }); if (error) { // Log - await Logging.logError({ + Logging.beError()?.log({ tenantID: this.tenant.id, action: ServerAction.CHARGING_STATION_CLEAR_CACHE, siteID: this.chargingStation.siteID, @@ -300,7 +300,7 @@ export default class SoapChargingStationClient extends ChargingStationClient { const { error, result, envelope } = await this.client.GetConfiguration(request); if (error) { // Log - await Logging.logError({ + Logging.beError()?.log({ tenantID: this.tenant.id, action: ServerAction.CHARGING_STATION_GET_CONFIGURATION, siteID: this.chargingStation.siteID, @@ -344,7 +344,7 @@ export default class SoapChargingStationClient extends ChargingStationClient { }); if (error) { // Log - await Logging.logError({ + Logging.beError()?.log({ tenantID: this.tenant.id, siteID: this.chargingStation.siteID, siteAreaID: this.chargingStation.siteAreaID, diff --git a/src/client/oicp/CpoOICPClient.ts b/src/client/oicp/CpoOICPClient.ts index 284e30a356..f77e9b23a6 100644 --- a/src/client/oicp/CpoOICPClient.ts +++ b/src/client/oicp/CpoOICPClient.ts @@ -80,7 +80,7 @@ export default class CpoOICPClient extends OICPClient { transaction.oicpData = { session: oicpSession }; - await Logging.logDebug({ + Logging.beDebug()?.log({ ...LoggingHelper.getTransactionProperties(transaction), tenantID: this.tenant.id, action: ServerAction.OICP_PUSH_SESSIONS, @@ -159,7 +159,7 @@ export default class CpoOICPClient extends OICPClient { // Stop if (transaction.tagID !== OICPDefaultTagId.RemoteIdentification) { const response = await this.authorizeStop(transaction); - await Logging.logInfo({ + Logging.beInfo()?.log({ ...LoggingHelper.getTransactionProperties(transaction), tenantID: this.tenant.id, action: ServerAction.OICP_PUSH_SESSIONS, @@ -533,7 +533,7 @@ export default class CpoOICPClient extends OICPClient { } }); } else { - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: this.tenant.id, action: ServerAction.OICP_PUSH_EVSE_DATA, message: `${evses.length} EVSEs have been pushed successfully`, @@ -575,7 +575,7 @@ export default class CpoOICPClient extends OICPClient { requestError = error; } if (!pushEvseStatusResponse?.Result || pushEvseStatusResponse?.Result !== true) { - await Logging.logError({ + Logging.beError()?.log({ tenantID: this.tenant.id, action: ServerAction.OICP_PUSH_EVSE_STATUSES, message: this.buildOICPChargingNotificationErrorMessage(pushEvseStatusResponse, requestError), @@ -587,7 +587,7 @@ export default class CpoOICPClient extends OICPClient { } }); } else { - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: this.tenant.id, action: ServerAction.OICP_PUSH_EVSE_STATUSES, message: `${evseStatuses.length} EVSE Statuses have been pushed successfully`, @@ -632,7 +632,7 @@ export default class CpoOICPClient extends OICPClient { requestError = error; } if (requestError) { - await Logging.logError({ + Logging.beError()?.log({ tenantID: this.tenant.id, action: ServerAction.OICP_AUTHORIZE_START, message: this.buildOICPChargingNotificationErrorMessage(authorizeResponse, requestError), @@ -645,7 +645,7 @@ export default class CpoOICPClient extends OICPClient { }); } if (authorizeResponse?.AuthorizationStatus !== OICPAuthorizationStatus.Authorized) { - await Logging.logError({ + Logging.beError()?.log({ tenantID: this.tenant.id, action: ServerAction.OICP_AUTHORIZE_START, module: MODULE_NAME, method: 'authorizeStart', @@ -653,7 +653,7 @@ export default class CpoOICPClient extends OICPClient { detailedMessages: { authorize: payload, response: authorizeResponse } }); } else { - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: this.tenant.id, action: ServerAction.OICP_AUTHORIZE_START, message: `OICP Tag ID '${tagID}' has been authorized`, @@ -698,7 +698,7 @@ export default class CpoOICPClient extends OICPClient { requestError = error; } if (requestError) { - await Logging.logError({ + Logging.beError()?.log({ ...LoggingHelper.getTransactionProperties(transaction), tenantID: this.tenant.id, user: user, @@ -713,7 +713,7 @@ export default class CpoOICPClient extends OICPClient { }); } if (authorizeResponse?.AuthorizationStatus !== OICPAuthorizationStatus.Authorized) { - await Logging.logError({ + Logging.beError()?.log({ ...LoggingHelper.getTransactionProperties(transaction), tenantID: this.tenant.id, user: user, @@ -723,7 +723,7 @@ export default class CpoOICPClient extends OICPClient { detailedMessages: { authorize: payload, response: authorizeResponse } }); } else { - await Logging.logInfo({ + Logging.beInfo()?.log({ ...LoggingHelper.getTransactionProperties(transaction), tenantID: this.tenant.id, user: user, @@ -804,7 +804,7 @@ export default class CpoOICPClient extends OICPClient { requestError = error; } if (!pushCdrResponse?.Result || pushCdrResponse?.Result !== true) { - await Logging.logError({ + Logging.beError()?.log({ ...LoggingHelper.getTransactionProperties(transaction), tenantID: this.tenant.id, action: ServerAction.OICP_PUSH_CDRS, @@ -817,7 +817,7 @@ export default class CpoOICPClient extends OICPClient { } }); } else { - await Logging.logInfo({ + Logging.beInfo()?.log({ ...LoggingHelper.getTransactionProperties(transaction), tenantID: this.tenant.id, action: ServerAction.OICP_PUSH_CDRS, @@ -875,7 +875,7 @@ export default class CpoOICPClient extends OICPClient { requestError = error; } if (!notificationStartResponse?.Result || notificationStartResponse?.Result !== true) { - await Logging.logWarning({ + Logging.beWarning()?.log({ ...LoggingHelper.getTransactionProperties(transaction), tenantID: this.tenant.id, action: ServerAction.OICP_SEND_CHARGING_NOTIFICATION_START, @@ -888,7 +888,7 @@ export default class CpoOICPClient extends OICPClient { } }); } else { - await Logging.logInfo({ + Logging.beInfo()?.log({ ...LoggingHelper.getTransactionProperties(transaction), tenantID: this.tenant.id, action: ServerAction.OICP_SEND_CHARGING_NOTIFICATION_START, @@ -950,7 +950,7 @@ export default class CpoOICPClient extends OICPClient { } transaction.oicpData.session.last_progress_notification = new Date(); if (!notificationProgressResponse?.Result || notificationProgressResponse?.Result !== true) { - await Logging.logWarning({ + Logging.beWarning()?.log({ ...LoggingHelper.getTransactionProperties(transaction), tenantID: this.tenant.id, action: ServerAction.OICP_SEND_CHARGING_NOTIFICATION_PROGRESS, @@ -963,7 +963,7 @@ export default class CpoOICPClient extends OICPClient { } }); } else { - await Logging.logInfo({ + Logging.beInfo()?.log({ ...LoggingHelper.getTransactionProperties(transaction), tenantID: this.tenant.id, action: ServerAction.OICP_SEND_CHARGING_NOTIFICATION_PROGRESS, @@ -1038,7 +1038,7 @@ export default class CpoOICPClient extends OICPClient { requestError = error; } if (!notificationEndResponse?.Result || notificationEndResponse?.Result !== true) { - await Logging.logWarning({ + Logging.beWarning()?.log({ ...LoggingHelper.getTransactionProperties(transaction), tenantID: this.tenant.id, action: ServerAction.OICP_SEND_CHARGING_NOTIFICATION_END, @@ -1051,7 +1051,7 @@ export default class CpoOICPClient extends OICPClient { } }); } else { - await Logging.logInfo({ + Logging.beInfo()?.log({ ...LoggingHelper.getTransactionProperties(transaction), tenantID: this.tenant.id, action: ServerAction.OICP_SEND_CHARGING_NOTIFICATION_END, @@ -1106,7 +1106,7 @@ export default class CpoOICPClient extends OICPClient { requestError = err; } if (!notificationErrorResponse?.Result || notificationErrorResponse?.Result !== true) { - await Logging.logWarning({ + Logging.beWarning()?.log({ ...LoggingHelper.getTransactionProperties(transaction), tenantID: this.tenant.id, action: ServerAction.OICP_SEND_CHARGING_NOTIFICATION_ERROR, @@ -1146,7 +1146,7 @@ export default class CpoOICPClient extends OICPClient { } private async pingEvseEndpoint(): Promise { - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: this.tenant.id, action: ServerAction.OICP_PUSH_EVSE_DATA, message: `Ping Hubject at ${this.getEndpointUrl('evses',ServerAction.OICP_PUSH_EVSE_DATA)}`, diff --git a/src/client/oicp/OICPClientFactory.ts b/src/client/oicp/OICPClientFactory.ts index 7854998070..25a41c2432 100644 --- a/src/client/oicp/OICPClientFactory.ts +++ b/src/client/oicp/OICPClientFactory.ts @@ -20,7 +20,7 @@ export default class OICPClientFactory { if (Utils.isTenantComponentActive(tenant, TenantComponents.OICP)) { const oicpSettings = await SettingStorage.getOICPSettings(tenant); if (!oicpSettings && oicpSettings.oicp) { - await Logging.logError({ + Logging.beError()?.log({ tenantID: tenant.id, action: ServerAction.OICP_SETTINGS, module: MODULE_NAME, method: 'getOicpClient', @@ -41,7 +41,7 @@ export default class OICPClientFactory { const client = await OICPClientFactory.getOicpClient(tenant, oicpEndpoint); return client as CpoOICPClient; } - await Logging.logError({ + Logging.beError()?.log({ tenantID: tenant.id, action: ServerAction.OICP_SETTINGS, module: MODULE_NAME, method: 'getCpoOicpClient', diff --git a/src/integration/asset/AssetFactory.ts b/src/integration/asset/AssetFactory.ts index e6c5dbf02b..0b55e7871f 100644 --- a/src/integration/asset/AssetFactory.ts +++ b/src/integration/asset/AssetFactory.ts @@ -45,7 +45,7 @@ export default class AssetFactory { return assetIntegrationImpl; } } - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: tenant.id, action: ServerAction.ASSET, module: MODULE_NAME, method: 'getAssetImpl', diff --git a/src/integration/asset/greencom/GreencomAssetIntegration.ts b/src/integration/asset/greencom/GreencomAssetIntegration.ts index f1cb4c0aa6..1b3966081d 100644 --- a/src/integration/asset/greencom/GreencomAssetIntegration.ts +++ b/src/integration/asset/greencom/GreencomAssetIntegration.ts @@ -46,7 +46,7 @@ export default class GreencomAssetIntegration extends AssetIntegration GreenCom web service has been called successfully`, diff --git a/src/integration/asset/iothink/IothinkAssetIntegration.ts b/src/integration/asset/iothink/IothinkAssetIntegration.ts index 82ae80a4c8..0ea28ea43f 100644 --- a/src/integration/asset/iothink/IothinkAssetIntegration.ts +++ b/src/integration/asset/iothink/IothinkAssetIntegration.ts @@ -48,7 +48,7 @@ export default class IothinkAssetIntegration extends AssetIntegration Iothink web service has been called successfully`, diff --git a/src/integration/asset/lacroix/LacroixAssetIntegration.ts b/src/integration/asset/lacroix/LacroixAssetIntegration.ts index eebcfdd767..4c78cf4021 100644 --- a/src/integration/asset/lacroix/LacroixAssetIntegration.ts +++ b/src/integration/asset/lacroix/LacroixAssetIntegration.ts @@ -64,7 +64,7 @@ export default class LacroixAssetIntegration extends AssetIntegration Lacroix web service has been called successfully`, diff --git a/src/integration/asset/schneider/SchneiderAssetIntegration.ts b/src/integration/asset/schneider/SchneiderAssetIntegration.ts index 1530b5f03b..9cf7328075 100644 --- a/src/integration/asset/schneider/SchneiderAssetIntegration.ts +++ b/src/integration/asset/schneider/SchneiderAssetIntegration.ts @@ -43,7 +43,7 @@ export default class SchneiderAssetIntegration extends AssetIntegration Schneider web service has been called successfully`, diff --git a/src/integration/asset/wit/WitAssetIntegration.ts b/src/integration/asset/wit/WitAssetIntegration.ts index dab98f9fbb..105a5aa7ca 100644 --- a/src/integration/asset/wit/WitAssetIntegration.ts +++ b/src/integration/asset/wit/WitAssetIntegration.ts @@ -48,7 +48,7 @@ export default class WitAssetIntegration extends AssetIntegration headers: this.buildAuthHeader(token) } ); - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: this.tenant.id, action: ServerAction.RETRIEVE_ASSET_CONSUMPTION, message: `${asset.name} > WIT web service has been called successfully`, diff --git a/src/integration/billing/BillingFacade.ts b/src/integration/billing/BillingFacade.ts index 62c20d29b1..665e93d2be 100644 --- a/src/integration/billing/BillingFacade.ts +++ b/src/integration/billing/BillingFacade.ts @@ -34,7 +34,7 @@ export default class BillingFacade { }; } catch (error) { const message = `Billing - Start Transaction failed with Transaction ID '${transaction.id}'`; - await Logging.logError({ + Logging.beError()?.log({ ...LoggingHelper.getTransactionProperties(transaction), tenantID: tenant.id, action: ServerAction.BILLING_TRANSACTION, @@ -66,7 +66,7 @@ export default class BillingFacade { } } catch (error) { const message = `Billing - Update Transaction failed with Transaction ID '${transaction.id}'`; - await Logging.logError({ + Logging.beError()?.log({ ...LoggingHelper.getTransactionProperties(transaction), tenantID: tenant.id, action: ServerAction.BILLING_TRANSACTION, @@ -92,7 +92,7 @@ export default class BillingFacade { } } catch (error) { const message = `Billing - Stop Transaction failed with Transaction ID '${transaction.id}'`; - await Logging.logError({ + Logging.beError()?.log({ ...LoggingHelper.getTransactionProperties(transaction), tenantID: tenant.id, action: ServerAction.BILLING_TRANSACTION, @@ -119,7 +119,7 @@ export default class BillingFacade { } } catch (error) { const message = `Billing - End Transaction failed with Transaction ID '${transaction.id}'`; - await Logging.logError({ + Logging.beError()?.log({ ...LoggingHelper.getTransactionProperties(transaction), tenantID: tenant.id, action: ServerAction.BILLING_TRANSACTION, diff --git a/src/integration/billing/BillingFactory.ts b/src/integration/billing/BillingFactory.ts index f4f6543fae..17c8b42981 100644 --- a/src/integration/billing/BillingFactory.ts +++ b/src/integration/billing/BillingFactory.ts @@ -26,7 +26,7 @@ export default class BillingFactory { } return billingIntegrationImpl; } - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: tenant.id, action: ServerAction.BILLING, module: MODULE_NAME, method: 'getBillingImpl', diff --git a/src/integration/billing/BillingIntegration.ts b/src/integration/billing/BillingIntegration.ts index 4f36a2113f..d04a49cd05 100644 --- a/src/integration/billing/BillingIntegration.ts +++ b/src/integration/billing/BillingIntegration.ts @@ -45,7 +45,7 @@ export default abstract class BillingIntegration { let billingUser: BillingUser = null; try { billingUser = await this._synchronizeUser(user); - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: this.tenant.id, actionOnUser: user, action: ServerAction.BILLING_SYNCHRONIZE_USER, @@ -54,7 +54,7 @@ export default abstract class BillingIntegration { }); return billingUser; } catch (error) { - await Logging.logError({ + Logging.beError()?.log({ tenantID: this.tenant.id, actionOnUser: user, action: ServerAction.BILLING_SYNCHRONIZE_USER, @@ -71,14 +71,14 @@ export default abstract class BillingIntegration { try { billingUser = await this._synchronizeUser(user, true /* !forceMode */); if (user?.billingData?.customerID !== billingUser?.billingData?.customerID) { - await Logging.logWarning({ + Logging.beWarning()?.log({ tenantID: this.tenant.id, action: ServerAction.BILLING_FORCE_SYNCHRONIZE_USER, module: MODULE_NAME, method: 'forceSynchronizeUser', message: `CustomerID has been repaired - old value ${user?.billingData?.customerID} - ${billingUser?.billingData?.customerID}` }); } - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: this.tenant.id, action: ServerAction.BILLING_FORCE_SYNCHRONIZE_USER, actionOnUser: user, @@ -86,7 +86,7 @@ export default abstract class BillingIntegration { message: `Successfully forced the synchronization of user: '${user.id}' - '${user.email}'`, }); } catch (error) { - await Logging.logError({ + Logging.beError()?.log({ tenantID: this.tenant.id, actionOnUser: user, action: ServerAction.BILLING_FORCE_SYNCHRONIZE_USER, @@ -132,7 +132,7 @@ export default abstract class BillingIntegration { // Make sure to avoid trying to charge it again too soon if (!taskConfig?.forceOperation && moment(invoice.createdOn).isSame(moment(), 'day')) { actionsDone.inSuccess++; - await Logging.logWarning({ + Logging.beWarning()?.log({ tenantID: this.tenant.id, action: ServerAction.BILLING_PERFORM_OPERATIONS, actionOnUser: invoice.user, @@ -146,7 +146,7 @@ export default abstract class BillingIntegration { // The new invoice may now have a different status - and this impacts the pagination skip--; // This is very important! } - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: this.tenant.id, action: ServerAction.BILLING_PERFORM_OPERATIONS, actionOnUser: invoice.user, @@ -156,7 +156,7 @@ export default abstract class BillingIntegration { actionsDone.inSuccess++; } catch (error) { actionsDone.inError++; - await Logging.logError({ + Logging.beError()?.log({ tenantID: this.tenant.id, action: ServerAction.BILLING_PERFORM_OPERATIONS, actionOnUser: invoice.user, @@ -203,7 +203,7 @@ export default abstract class BillingIntegration { return true; } } catch (error) { - await Logging.logError({ + Logging.beError()?.log({ tenantID: this.tenant.id, action: ServerAction.BILLING_TRANSACTION, actionOnUser: billingInvoice.user, @@ -315,7 +315,7 @@ export default abstract class BillingIntegration { } } catch (error) { // Catch stripe errors and send the information back to the client - await Logging.logError({ + Logging.beError()?.log({ tenantID: this.tenant.id, action: ServerAction.BILLING_CHARGE_INVOICE, actionOnUser: billingInvoice.user, @@ -332,7 +332,7 @@ export default abstract class BillingIntegration { if (!Utils.isDevelopmentEnv()) { const timeSpent = this.computeTimeSpentInSeconds(transaction); if (timeSpent < Constants.AFIREV_MINIMAL_DURATION_THRESHOLD /* 2 minutes */) { - await Logging.logWarning({ + Logging.beWarning()?.log({ ...LoggingHelper.getTransactionProperties(transaction), tenantID: this.tenant.id, user: transaction.userID, @@ -344,7 +344,7 @@ export default abstract class BillingIntegration { return false; } if (transaction.stop.totalConsumptionWh < Constants.AFIREV_MINIMAL_CONSUMPTION_THRESHOLD /* 0.5 kW.h */) { - await Logging.logWarning({ + Logging.beWarning()?.log({ ...LoggingHelper.getTransactionProperties(transaction), tenantID: this.tenant.id, user: transaction.userID, @@ -429,21 +429,21 @@ export default abstract class BillingIntegration { // eslint-disable-next-line @typescript-eslint/member-ordering public async clearTestData(): Promise { // await this.checkConnection(); - stripe connection is useless to cleanup test data - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: this.tenant.id, action: ServerAction.BILLING_TEST_DATA_CLEANUP, module: MODULE_NAME, method: 'clearTestData', message: 'Starting test data cleanup' }); await this.clearAllInvoiceTestData(); - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: this.tenant.id, action: ServerAction.BILLING_TEST_DATA_CLEANUP, module: MODULE_NAME, method: 'clearTestData', message: 'Invoice Test data cleanup has been completed' }); await this.clearAllUsersTestData(); - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: this.tenant.id, action: ServerAction.BILLING_TEST_DATA_CLEANUP, module: MODULE_NAME, method: 'clearTestData', @@ -457,7 +457,7 @@ export default abstract class BillingIntegration { for (const invoice of invoices.result) { try { await this.clearInvoiceTestData(invoice); - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: this.tenant.id, action: ServerAction.BILLING_TEST_DATA_CLEANUP, actionOnUser: invoice.user, @@ -465,7 +465,7 @@ export default abstract class BillingIntegration { message: `Successfully clear test data for invoice '${invoice.id}'` }); } catch (error) { - await Logging.logError({ + Logging.beError()?.log({ tenantID: this.tenant.id, action: ServerAction.BILLING_TEST_DATA_CLEANUP, actionOnUser: invoice.user, @@ -510,7 +510,7 @@ export default abstract class BillingIntegration { // Save to clear billing data await TransactionStorage.saveTransactionBillingData(this.tenant, transaction.id, transaction.billingData); } catch (error) { - await Logging.logError({ + Logging.beError()?.log({ tenantID: this.tenant.id, action: ServerAction.BILLING_TEST_DATA_CLEANUP, module: MODULE_NAME, method: 'clearTransactionsTestData', @@ -527,7 +527,7 @@ export default abstract class BillingIntegration { for (const user of users) { try { await this.clearUserTestBillingData(user); - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: this.tenant.id, action: ServerAction.BILLING_TEST_DATA_CLEANUP, actionOnUser: user, @@ -535,7 +535,7 @@ export default abstract class BillingIntegration { message: `Successfully cleared user test data for Invoice of User ID '${user.id}'` }); } catch (error) { - await Logging.logError({ + Logging.beError()?.log({ tenantID: this.tenant.id, action: ServerAction.BILLING_TEST_DATA_CLEANUP, actionOnUser: user, @@ -743,7 +743,7 @@ export default abstract class BillingIntegration { actionsDone.inSuccess++; } catch (error) { actionsDone.inError++; - await Logging.logError({ + Logging.beError()?.log({ tenantID: this.tenant.id, action: ServerAction.BILLING_TRANSFER_DISPATCH_FUNDS, module: MODULE_NAME, method: 'dispatchCollectedFunds', @@ -777,7 +777,7 @@ export default abstract class BillingIntegration { }; const transferID = await BillingStorage.saveTransfer(this.tenant, transferToSave); await TransactionStorage.updateTransactionsWithTransferData(this.tenant, collectedFundReport.transactionIDs, transferID); - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: this.tenant.id, action: ServerAction.BILLING_TRANSFER_DISPATCH_FUNDS, module: MODULE_NAME, method: 'dispatchCollectedFunds', diff --git a/src/integration/billing/stripe/StripeBillingIntegration.ts b/src/integration/billing/stripe/StripeBillingIntegration.ts index 54b5b484ec..7f48d452e7 100644 --- a/src/integration/billing/stripe/StripeBillingIntegration.ts +++ b/src/integration/billing/stripe/StripeBillingIntegration.ts @@ -226,7 +226,7 @@ export default class StripeBillingIntegration extends BillingIntegration { requestParams.starting_after = taxes[taxes.length - 1].id; } } while (request.has_more); - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: this.tenant.id, action: ServerAction.BILLING_TAXES, module: MODULE_NAME, method: 'getTaxes', @@ -234,7 +234,7 @@ export default class StripeBillingIntegration extends BillingIntegration { }); } catch (error) { // catch stripe errors and send the information back to the client - await Logging.logError({ + Logging.beError()?.log({ tenantID: this.tenant.id, action: ServerAction.BILLING_TAXES, module: MODULE_NAME, method: 'getTaxes', @@ -256,7 +256,7 @@ export default class StripeBillingIntegration extends BillingIntegration { } } catch (error) { // catch stripe errors and send the information back to the client - await Logging.logError({ + Logging.beError()?.log({ tenantID: this.tenant.id, action: ServerAction.BILLING_TAXES, module: MODULE_NAME, method: 'getTaxRate', @@ -442,7 +442,7 @@ export default class StripeBillingIntegration extends BillingIntegration { await BillingStorage.saveInvoice(this.tenant, billingInvoice); throw operationResult.error; } else { - await Logging.logError({ + Logging.beError()?.log({ tenantID: this.tenant.id, action: ServerAction.BILLING_CHARGE_INVOICE, actionOnUser: billingInvoice.user, @@ -539,7 +539,7 @@ export default class StripeBillingIntegration extends BillingIntegration { // Check billing data consistency const customerID = user?.billingData?.customerID; const paymentMethods: BillingPaymentMethod[] = await this.getStripePaymentMethods(user, customerID); - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: this.tenant.id, user, action: ServerAction.BILLING_PAYMENT_METHODS, @@ -574,7 +574,7 @@ export default class StripeBillingIntegration extends BillingIntegration { const setupIntent: Stripe.SetupIntent = await this.stripe.setupIntents.create({ customer: customerID }); - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: this.tenant.id, action: ServerAction.BILLING_SETUP_PAYMENT_METHOD, module: MODULE_NAME, method: 'createSetupIntent', @@ -588,7 +588,7 @@ export default class StripeBillingIntegration extends BillingIntegration { }; } catch (error) { // catch stripe errors and send the information back to the client - await Logging.logError({ + Logging.beError()?.log({ tenantID: this.tenant.id, action: ServerAction.BILLING_SETUP_PAYMENT_METHOD, actionOnUser: user, @@ -617,7 +617,7 @@ export default class StripeBillingIntegration extends BillingIntegration { }; } await this.stripe.paymentMethods.update(paymentMethodId, paymentMethodUpdateParams); - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: this.tenant.id, action: ServerAction.BILLING_SETUP_PAYMENT_METHOD, module: MODULE_NAME, method: 'attachPaymentMethod', @@ -627,7 +627,7 @@ export default class StripeBillingIntegration extends BillingIntegration { await this.stripe.customers.update(customerID, { invoice_settings: { default_payment_method: paymentMethodId } }); - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: this.tenant.id, action: ServerAction.BILLING_SETUP_PAYMENT_METHOD, module: MODULE_NAME, method: 'attachPaymentMethod', @@ -640,7 +640,7 @@ export default class StripeBillingIntegration extends BillingIntegration { }; } catch (error) { // catch stripe errors and send the information back to the client - await Logging.logError({ + Logging.beError()?.log({ tenantID: this.tenant.id, action: ServerAction.BILLING_SETUP_PAYMENT_METHOD, actionOnUser: user, @@ -677,7 +677,7 @@ export default class StripeBillingIntegration extends BillingIntegration { } while (response.has_more); } } catch (error) { - await Logging.logError({ + Logging.beError()?.log({ tenantID: this.tenant.id, action: ServerAction.BILLING_PAYMENT_METHODS, actionOnUser: user, @@ -698,7 +698,7 @@ export default class StripeBillingIntegration extends BillingIntegration { const paymentMethod = await this.stripe.paymentMethods.retrieve(paymentMethodID); return this.convertToBillingPaymentMethod(paymentMethod, asDefault); } catch (error) { - await Logging.logError({ + Logging.beError()?.log({ tenantID: this.tenant.id, action: ServerAction.BILLING_PAYMENT_METHODS, module: MODULE_NAME, method: 'getStripePaymentMethod', @@ -735,7 +735,7 @@ export default class StripeBillingIntegration extends BillingIntegration { } // Detach payment method from the stripe customer const paymentMethod: Stripe.PaymentMethod = await this.stripe.paymentMethods.detach(paymentMethodId); - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: this.tenant.id, action: ServerAction.BILLING_DELETE_PAYMENT_METHOD, module: MODULE_NAME, method: 'detachStripePaymentMethod', @@ -748,7 +748,7 @@ export default class StripeBillingIntegration extends BillingIntegration { }; } catch (error) { // catch stripe errors and send the information back to the client - await Logging.logError({ + Logging.beError()?.log({ tenantID: this.tenant.id, action: ServerAction.BILLING_DELETE_PAYMENT_METHOD, module: MODULE_NAME, method: 'detachStripePaymentMethod', @@ -775,7 +775,7 @@ export default class StripeBillingIntegration extends BillingIntegration { // Well ... when in test mode we may allow to start the transaction if (!customerID) { // Not yet LIVE ... starting a transaction without a STRIPE CUSTOMER is allowed - await Logging.logWarning({ + Logging.beWarning()?.log({ tenantID: this.tenant.id, action: ServerAction.BILLING_TRANSACTION, module: MODULE_NAME, method: 'startTransaction', @@ -958,7 +958,7 @@ export default class StripeBillingIntegration extends BillingIntegration { }; } if (transaction.billingData?.stop?.status === BillingStatus.BILLED) { - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: this.tenant.id, action: ServerAction.BILLING_TRANSACTION, module: MODULE_NAME, method: 'endTransaction', @@ -972,7 +972,7 @@ export default class StripeBillingIntegration extends BillingIntegration { return transaction.billingData.stop; } if (!transaction.stop?.extraInactivityComputed) { - await Logging.logWarning({ + Logging.beWarning()?.log({ tenantID: this.tenant.id, action: ServerAction.BILLING_TRANSACTION, module: MODULE_NAME, method: 'endTransaction', @@ -1010,7 +1010,7 @@ export default class StripeBillingIntegration extends BillingIntegration { const customerID: string = transaction.user?.billingData?.customerID; const customer = await this.getStripeCustomer(customerID); if (customer) { - await Logging.logInfo({ + Logging.beInfo()?.log({ ...LoggingHelper.getTransactionProperties(transaction), tenantID: this.tenant.id, user: transaction.userID, @@ -1034,7 +1034,7 @@ export default class StripeBillingIntegration extends BillingIntegration { }; } } catch (error) { - await Logging.logError({ + Logging.beError()?.log({ ...LoggingHelper.getTransactionProperties(transaction), tenantID: this.tenant.id, user: transaction.userID, @@ -1203,7 +1203,7 @@ export default class StripeBillingIntegration extends BillingIntegration { // Let's try to bill the stripe invoice using the default payment method of the customer operationResult = await this.chargeStripeInvoice(stripeInvoice.id); if (!operationResult?.succeeded && operationResult?.error) { - await Logging.logError({ + Logging.beError()?.log({ tenantID: this.tenant.id, user: user.id, action: ServerAction.BILLING_TRANSACTION, @@ -1364,7 +1364,7 @@ export default class StripeBillingIntegration extends BillingIntegration { status: BillingInvoiceStatus.OPEN, }); if (list && !Utils.isEmptyArray(list.data)) { - await Logging.logError({ + Logging.beError()?.log({ tenantID: this.tenant.id, action: ServerAction.USER_DELETE, actionOnUser: user, @@ -1379,7 +1379,7 @@ export default class StripeBillingIntegration extends BillingIntegration { status: BillingInvoiceStatus.DRAFT, }); if (list && !Utils.isEmptyArray(list.data)) { - await Logging.logError({ + Logging.beError()?.log({ tenantID: this.tenant.id, action: ServerAction.USER_DELETE, actionOnUser: user, @@ -1394,7 +1394,7 @@ export default class StripeBillingIntegration extends BillingIntegration { pending: true, }); if (itemsList && itemsList.data && itemsList.data.length > 0) { - await Logging.logError({ + Logging.beError()?.log({ tenantID: this.tenant.id, action: ServerAction.USER_DELETE, actionOnUser: user, @@ -1541,7 +1541,7 @@ export default class StripeBillingIntegration extends BillingIntegration { try { await this.checkConnection(); } catch (error) { - await Logging.logError({ + Logging.beError()?.log({ tenantID: this.tenant.id, user, action: ServerAction.BILLING, module: MODULE_NAME, method: 'precheckStartTransactionPrerequisites', @@ -1554,7 +1554,7 @@ export default class StripeBillingIntegration extends BillingIntegration { try { await this.checkTaxPrerequisites(); // Checks that the taxID is still valid } catch (error) { - await Logging.logError({ + Logging.beError()?.log({ tenantID: this.tenant.id, user, action: ServerAction.BILLING, module: MODULE_NAME, method: 'precheckStartTransactionPrerequisites', @@ -1571,7 +1571,7 @@ export default class StripeBillingIntegration extends BillingIntegration { // Check whether the customer has a default payment method await this.checkStripePaymentMethod(customer); } catch (error) { - await Logging.logError({ + Logging.beError()?.log({ tenantID: this.tenant.id, user, action: ServerAction.BILLING, module: MODULE_NAME, method: 'precheckStartTransactionPrerequisites', @@ -1674,7 +1674,7 @@ export default class StripeBillingIntegration extends BillingIntegration { // This method is ONLY USED when repairing invoices - c.f.: RepairInvoiceInconsistencies migration task if (!billingInvoice.sessions) { // This should not happen - but it happened once! - await Logging.logError({ + Logging.beError()?.log({ tenantID: this.tenant.id, action: ServerAction.BILLING, actionOnUser: billingInvoice.user, @@ -1706,7 +1706,7 @@ export default class StripeBillingIntegration extends BillingIntegration { } } catch (error) { // Catch stripe errors and send the information back to the client - await Logging.logError({ + Logging.beError()?.log({ tenantID: this.tenant.id, action: ServerAction.BILLING, actionOnUser: billingInvoice.user, diff --git a/src/integration/car-connector/mercedes-connector/MercedesCarConnectorIntegration.ts b/src/integration/car-connector/mercedes-connector/MercedesCarConnectorIntegration.ts index 370f167a55..a4a228ee03 100644 --- a/src/integration/car-connector/mercedes-connector/MercedesCarConnectorIntegration.ts +++ b/src/integration/car-connector/mercedes-connector/MercedesCarConnectorIntegration.ts @@ -76,7 +76,7 @@ export default class MercedesCarConnectorIntegration extends CarConnectorIntegra public async createConnection(userID: string, data: any): Promise { try { - await Logging.logDebug({ + Logging.beDebug()?.log({ user: userID, tenantID: this.tenant.id, module: MODULE_NAME, method: 'createConnection', @@ -95,7 +95,7 @@ export default class MercedesCarConnectorIntegration extends CarConnectorIntegra 'Authorization': `Basic ${Buffer.from(this.connection.mercedesConnection.clientId + ':' + await Cypher.decrypt(this.tenant, this.connection.mercedesConnection.clientSecret)).toString('base64')}` }, }); - await Logging.logDebug({ + Logging.beDebug()?.log({ user: userID, tenantID: this.tenant.id, module: MODULE_NAME, method: 'createConnection', @@ -144,7 +144,7 @@ export default class MercedesCarConnectorIntegration extends CarConnectorIntegra headers: { 'Authorization': 'Bearer ' + connection.data.access_token } } ); - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: this.tenant.id, action: ServerAction.CAR_CONNECTOR, message: `${car.vin} > Mercedes web service has been called successfully`, @@ -201,7 +201,7 @@ export default class MercedesCarConnectorIntegration extends CarConnectorIntegra 'Authorization': `Basic ${Buffer.from(this.connection.mercedesConnection.clientId + ':' + await Cypher.decrypt(this.tenant, this.connection.mercedesConnection.clientSecret)).toString('base64')}` } }); - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: this.tenant.id, user: userID, action: ServerAction.CAR_CONNECTOR, diff --git a/src/integration/car-connector/targa-telematics-connector/TargaTelematicsConnector.ts b/src/integration/car-connector/targa-telematics-connector/TargaTelematicsConnector.ts index aa1e59a1b1..a8aeee9cf1 100644 --- a/src/integration/car-connector/targa-telematics-connector/TargaTelematicsConnector.ts +++ b/src/integration/car-connector/targa-telematics-connector/TargaTelematicsConnector.ts @@ -46,7 +46,7 @@ export default class TargaTelematicsCarConnectorIntegration extends CarConnector headers: { 'Authorization': 'Bearer ' + connectionToken } } ); - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: this.tenant.id, action: ServerAction.CAR_CONNECTOR, message: `${car.vin} > Targa Telematics web service has been called successfully`, diff --git a/src/integration/car-connector/tronity-connector/TronityCarConnectorIntegration.ts b/src/integration/car-connector/tronity-connector/TronityCarConnectorIntegration.ts index 177a07821a..6f71336e13 100644 --- a/src/integration/car-connector/tronity-connector/TronityCarConnectorIntegration.ts +++ b/src/integration/car-connector/tronity-connector/TronityCarConnectorIntegration.ts @@ -38,7 +38,7 @@ export default class TronityCarConnectorIntegration extends CarConnectorIntegrat public async getCurrentSoC(car: Car): Promise { if (Utils.isNullOrUndefined(car.carConnectorData.carConnectorMeterID)) { - await Logging.logError({ + Logging.beError()?.log({ tenantID: this.tenant.id, module: MODULE_NAME, method: 'getCurrentSoC', @@ -57,7 +57,7 @@ export default class TronityCarConnectorIntegration extends CarConnectorIntegrat headers: { 'Authorization': 'Bearer ' + connectionToken } } ); - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: this.tenant.id, action: ServerAction.CAR_CONNECTOR, message: `${car.vin} > Tronity web service has been called successfully`, diff --git a/src/integration/car/CarIntegration.ts b/src/integration/car/CarIntegration.ts index f046b8fa0e..d6b4295c75 100644 --- a/src/integration/car/CarIntegration.ts +++ b/src/integration/car/CarIntegration.ts @@ -41,7 +41,7 @@ export default abstract class CarIntegration { externalCar.id = await CarStorage.saveCarCatalog(externalCar); actionsDone.inSuccess++; // Log - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: Constants.DEFAULT_TENANT_ID, action: ServerAction.SYNCHRONIZE_CAR_CATALOGS, module: MODULE_NAME, method: 'synchronizeCarCatalogs', @@ -75,7 +75,7 @@ export default abstract class CarIntegration { await CarStorage.saveCarCatalog(externalCar); actionsDone.inSuccess++; // Log - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: Constants.DEFAULT_TENANT_ID, action: ServerAction.SYNCHRONIZE_CAR_CATALOGS, module: MODULE_NAME, method: 'synchronizeCarCatalogs', @@ -84,7 +84,7 @@ export default abstract class CarIntegration { } } catch (error) { actionsDone.inError++; - await Logging.logError({ + Logging.beError()?.log({ tenantID: Constants.DEFAULT_TENANT_ID, action: ServerAction.SYNCHRONIZE_CAR_CATALOGS, module: MODULE_NAME, method: 'synchronizeCarCatalogs', diff --git a/src/integration/car/ev-database/EVDatabaseCarIntegration.ts b/src/integration/car/ev-database/EVDatabaseCarIntegration.ts index 6eb573d6ea..7c7917fc98 100644 --- a/src/integration/car/ev-database/EVDatabaseCarIntegration.ts +++ b/src/integration/car/ev-database/EVDatabaseCarIntegration.ts @@ -22,7 +22,7 @@ export default class EVDatabaseCarIntegration extends CarIntegration { public async getCarCatalogs(): Promise { const evDatabaseConfig = Configuration.getEVDatabaseConfig(); if (!evDatabaseConfig) { - await Logging.logWarning({ + Logging.beWarning()?.log({ tenantID: Constants.DEFAULT_TENANT_ID, message: 'No configuration is provided to access the EVDatabase system, skipping', module: MODULE_NAME, method: 'getCarCatalogs', @@ -95,7 +95,7 @@ export default class EVDatabaseCarIntegration extends CarIntegration { const base64Image = Buffer.from(response.data).toString('base64'); image = 'data:' + response.headers['content-type'] + ';base64,' + base64Image; } catch (error) { - await Logging.logError({ + Logging.beError()?.log({ tenantID: Constants.DEFAULT_TENANT_ID, action: ServerAction.SYNCHRONIZE_CAR_CATALOGS, module: MODULE_NAME, method: 'getCarCatalogThumb', @@ -114,7 +114,7 @@ export default class EVDatabaseCarIntegration extends CarIntegration { const encodedImage = await response.getBase64Async(imageMIME); return encodedImage; } catch (error) { - await Logging.logError({ + Logging.beError()?.log({ tenantID: Constants.DEFAULT_TENANT_ID, action: ServerAction.SYNCHRONIZE_CAR_CATALOGS, module: MODULE_NAME, method: 'getCarCatalogImage', diff --git a/src/integration/charging-station-vendor/ChargingStationVendorIntegration.ts b/src/integration/charging-station-vendor/ChargingStationVendorIntegration.ts index 6fb3eae206..ba6c46f984 100644 --- a/src/integration/charging-station-vendor/ChargingStationVendorIntegration.ts +++ b/src/integration/charging-station-vendor/ChargingStationVendorIntegration.ts @@ -37,7 +37,7 @@ export default abstract class ChargingStationVendorIntegration { const numberOfPhases = Utils.getNumberOfConnectedPhases(chargingStation, chargePoint); const numberOfConnectors = chargePoint ? chargePoint.connectorIDs.length : chargingStation.connectors.length; if (chargePoint.excludeFromPowerLimitation) { - await Logging.logWarning({ + Logging.beWarning()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, action: ServerAction.CHARGING_STATION_LIMIT_POWER, @@ -48,7 +48,7 @@ export default abstract class ChargingStationVendorIntegration { return { status: OCPPConfigurationStatus.NOT_SUPPORTED }; } if (!chargePoint.ocppParamForPowerLimitation) { - await Logging.logWarning({ + Logging.beWarning()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, action: ServerAction.CHARGING_STATION_LIMIT_POWER, @@ -88,7 +88,7 @@ export default abstract class ChargingStationVendorIntegration { const ocppLimitAmpValue = this.convertLimitAmpPerPhase(chargingStation, chargePoint, 0, maxAmps * ocppParamValueMultiplier); let result: OCPPChangeConfigurationResponse; try { - await Logging.logDebug({ + Logging.beDebug()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, action: ServerAction.CHARGING_STATION_LIMIT_POWER, @@ -133,7 +133,7 @@ export default abstract class ChargingStationVendorIntegration { const connector = Utils.getConnectorFromID(chargingStation, connectorID); if (connector) { connector.amperageLimit = this.convertLimitAmpToAllPhases(chargingStation, chargePoint, connectorID, Utils.convertToInt(ocppParamValue) / ocppParamValueDivider); - await Logging.logInfo({ + Logging.beInfo()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, action: ServerAction.OCPP_PARAM_UPDATE, @@ -187,7 +187,7 @@ export default abstract class ChargingStationVendorIntegration { }); // Call each connector? if (result.status !== OCPPChargingProfileStatus.ACCEPTED) { - await Logging.logWarning({ + Logging.beWarning()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, action: ServerAction.CHARGING_PROFILE_UPDATE, @@ -214,7 +214,7 @@ export default abstract class ChargingStationVendorIntegration { }); return result; } catch (error) { - await Logging.logError({ + Logging.beError()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, action: ServerAction.CHARGING_PROFILE_UPDATE, @@ -261,7 +261,7 @@ export default abstract class ChargingStationVendorIntegration { }); // Call each connector? if (result.status !== OCPPClearChargingProfileStatus.ACCEPTED) { - await Logging.logWarning({ + Logging.beWarning()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, action: ServerAction.CHARGING_PROFILE_DELETE, @@ -288,7 +288,7 @@ export default abstract class ChargingStationVendorIntegration { }); return result; } catch (error) { - await Logging.logError({ + Logging.beError()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, action: ServerAction.CHARGING_PROFILE_DELETE, @@ -340,7 +340,7 @@ export default abstract class ChargingStationVendorIntegration { result.chargingSchedule = this.convertFromVendorChargingSchedule(chargingStation, chargePoint, result.connectorId, result.chargingSchedule); return result; } catch (error) { - await Logging.logError({ + Logging.beError()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, action: ServerAction.CHARGING_STATION_GET_COMPOSITE_SCHEDULE, @@ -433,7 +433,7 @@ export default abstract class ChargingStationVendorIntegration { limitWatts: Utils.convertAmpToWatt(chargingStation, chargePoint, connectorID, connectorLimitAmps), limitSource: ConnectorCurrentLimitSource.STATIC_LIMITATION, }; - await Logging.logInfo({ + Logging.beInfo()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, action: ServerAction.GET_CONNECTOR_CURRENT_LIMIT, @@ -445,7 +445,7 @@ export default abstract class ChargingStationVendorIntegration { } } } catch (error) { - await Logging.logError({ + Logging.beError()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, action: ServerAction.GET_CONNECTOR_CURRENT_LIMIT, @@ -460,7 +460,7 @@ export default abstract class ChargingStationVendorIntegration { limitWatts: limitDefaultMaxPower, limitSource: ConnectorCurrentLimitSource.CONNECTOR }; - await Logging.logInfo({ + Logging.beInfo()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, action: ServerAction.GET_CONNECTOR_CURRENT_LIMIT, @@ -609,7 +609,7 @@ export default abstract class ChargingStationVendorIntegration { limitWatts: Utils.convertAmpToWatt(chargingStation, chargePoint, connectorID, Utils.convertToInt(schedulePeriod.limit)), limitSource: ConnectorCurrentLimitSource.CHARGING_PROFILE, }; - await Logging.logInfo({ + Logging.beInfo()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, action: ServerAction.GET_CONNECTOR_CURRENT_LIMIT, @@ -627,7 +627,7 @@ export default abstract class ChargingStationVendorIntegration { limitWatts: Utils.convertAmpToWatt(chargingStation, chargePoint, connectorID, Utils.convertToInt(lastButOneSchedule.limit)), limitSource: ConnectorCurrentLimitSource.CHARGING_PROFILE, }; - await Logging.logInfo({ + Logging.beInfo()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, action: ServerAction.GET_CONNECTOR_CURRENT_LIMIT, @@ -646,7 +646,7 @@ export default abstract class ChargingStationVendorIntegration { limitWatts: Utils.convertAmpToWatt(chargingStation, chargePoint, connectorID, Utils.convertToInt(lastButOneSchedule.limit)), limitSource: ConnectorCurrentLimitSource.CHARGING_PROFILE, }; - await Logging.logInfo({ + Logging.beInfo()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, action: ServerAction.GET_CONNECTOR_CURRENT_LIMIT, diff --git a/src/integration/pricing/PricingEngine.ts b/src/integration/pricing/PricingEngine.ts index 61913d75dc..a71b329e50 100644 --- a/src/integration/pricing/PricingEngine.ts +++ b/src/integration/pricing/PricingEngine.ts @@ -25,7 +25,7 @@ export default class PricingEngine { // pricingDefinitions.push(...await PricingEngine.getPricingDefinitions4Entity(tenant, pricingContext, PricingEntity.COMPANY, transaction.companyID)); pricingDefinitions.push(...await PricingEngine.getPricingDefinitions4Entity(tenant, pricingContext, PricingEntity.TENANT, tenant.id)); if (!pricingContext.timezone) { - await Logging.logWarning({ + Logging.beWarning()?.log({ ...LoggingHelper.getPricingContextProperties(pricingContext), tenantID: tenant.id, module: MODULE_NAME, @@ -43,7 +43,7 @@ export default class PricingEngine { }, pricingDefinitions }; - await Logging.logInfo({ + Logging.beInfo()?.log({ ...LoggingHelper.getPricingContextProperties(pricingContext), tenantID: tenant.id, module: MODULE_NAME, @@ -75,7 +75,7 @@ export default class PricingEngine { private static async getPricingDefinitions4Entity(tenant: Tenant, pricingContext: PricingContext, entityType: PricingEntity, entityID: string): Promise { if (!entityID) { - await Logging.logWarning({ + Logging.beWarning()?.log({ ...LoggingHelper.getPricingContextProperties(pricingContext), tenantID: tenant.id, module: MODULE_NAME, @@ -94,7 +94,7 @@ export default class PricingEngine { ).map((pricingDefinition) => PricingEngine.shrinkPricingDefinition(pricingDefinition) ); - await Logging.logDebug({ + Logging.beDebug()?.log({ ...LoggingHelper.getPricingContextProperties(pricingContext), tenantID: tenant.id, module: MODULE_NAME, diff --git a/src/integration/pricing/simple-pricing/BuiltInPricingIntegration.ts b/src/integration/pricing/simple-pricing/BuiltInPricingIntegration.ts index a986caf383..3ba45ba0a8 100644 --- a/src/integration/pricing/simple-pricing/BuiltInPricingIntegration.ts +++ b/src/integration/pricing/simple-pricing/BuiltInPricingIntegration.ts @@ -23,7 +23,7 @@ export default class BuiltInPricingIntegration extends PricingIntegration { const pricedConsumption = await this.computePrice(transaction, consumptionData, chargingStation); - await Logging.logInfo({ + Logging.beInfo()?.log({ ...LoggingHelper.getTransactionProperties(transaction), tenantID: this.tenant.id, module: MODULE_NAME, @@ -41,7 +41,7 @@ export default class BuiltInPricingIntegration extends PricingIntegration { const pricedConsumption = await this.computePrice(transaction, consumptionData, chargingStation); - await Logging.logInfo({ + Logging.beInfo()?.log({ ...LoggingHelper.getTransactionProperties(transaction), tenantID: this.tenant.id, module: MODULE_NAME, @@ -55,7 +55,7 @@ export default class BuiltInPricingIntegration extends PricingIntegration { const pricedConsumption = await this.computePrice(transaction, consumptionData, chargingStation); - await Logging.logInfo({ + Logging.beInfo()?.log({ ...LoggingHelper.getTransactionProperties(transaction), tenantID: this.tenant.id, module: MODULE_NAME, @@ -69,7 +69,7 @@ export default class BuiltInPricingIntegration extends PricingIntegration { if (!PricingHelper.checkContextConsistency(pricingContext)) { - await Logging.logError({ + Logging.beError()?.log({ ...LoggingHelper.getPricingContextProperties(pricingContext), tenantID: this.tenant.id, module: MODULE_NAME, diff --git a/src/integration/refund/RefundFactory.ts b/src/integration/refund/RefundFactory.ts index 4877679987..37997af5a0 100644 --- a/src/integration/refund/RefundFactory.ts +++ b/src/integration/refund/RefundFactory.ts @@ -25,7 +25,7 @@ export default class RefundFactory { } return refundIntegrationImpl; } - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: tenant.id, action: ServerAction.REFUND, module: MODULE_NAME, diff --git a/src/integration/refund/sap-concur/SapConcurRefundIntegration.ts b/src/integration/refund/sap-concur/SapConcurRefundIntegration.ts index 14d357fcda..42459ddfab 100644 --- a/src/integration/refund/sap-concur/SapConcurRefundIntegration.ts +++ b/src/integration/refund/sap-concur/SapConcurRefundIntegration.ts @@ -106,7 +106,7 @@ export default class SapConcurRefundIntegration extends RefundIntegration { try { - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: this.tenant.id, module: MODULE_NAME, method: 'createConnection', action: ServerAction.REFUND, message: `Request Concur access token for User ID '${userID}'` @@ -125,7 +125,7 @@ export default class SapConcurRefundIntegration extends RefundIntegration chargingStation.siteAreaID === siteArea.id); } } else { - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: this.tenant.id, action: ServerAction.SMART_CHARGING, message: `${sourceSiteArea.name} > No charging station used, so no need to call the Smart Charging service`, @@ -116,7 +116,7 @@ export default class SapSmartChargingIntegration extends SmartChargingIntegratio const url = await this.buildOptimizerUrl(sourceSiteArea); // Check at least one car if (request.state.cars.length === 0) { - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: this.tenant.id, action: ServerAction.SMART_CHARGING, message: `${sourceSiteArea.name} > No car connected so no need to call the SAP Smart Charging service`, @@ -125,7 +125,7 @@ export default class SapSmartChargingIntegration extends SmartChargingIntegratio }); return; } - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: this.tenant.id, action: ServerAction.SMART_CHARGING, message: `${sourceSiteArea.name} > Call the SAP Smart Charging service...`, @@ -138,7 +138,7 @@ export default class SapSmartChargingIntegration extends SmartChargingIntegratio Accept: 'application/json', } }); - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: this.tenant.id, action: ServerAction.SMART_CHARGING, message: `${sourceSiteArea.name} > SAP Smart Charging service has been called successfully`, @@ -148,7 +148,7 @@ export default class SapSmartChargingIntegration extends SmartChargingIntegratio // Build charging profiles from result const chargingProfiles = await this.buildChargingProfilesFromOptimizerResponse( sourceSiteArea, siteAreas.result, response.data); - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: this.tenant.id, action: ServerAction.SMART_CHARGING, message: `${sourceSiteArea.name} > Charging Profiles have been built successfully`, @@ -338,7 +338,7 @@ export default class SapSmartChargingIntegration extends SmartChargingIntegratio // Transaction in progress? if (!connector.currentTransactionID) { // Should not happen - await Logging.logError({ + Logging.beError()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: this.tenant.id, action: ServerAction.SMART_CHARGING, @@ -352,7 +352,7 @@ export default class SapSmartChargingIntegration extends SmartChargingIntegratio const currentTransaction = transactions.find((transaction) => transaction.id === connector.currentTransactionID); if (!currentTransaction) { // Should not happen - await Logging.logError({ + Logging.beError()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: this.tenant.id, action: ServerAction.SMART_CHARGING, @@ -370,7 +370,7 @@ export default class SapSmartChargingIntegration extends SmartChargingIntegratio // Get Asset consumption const assetConsumptionInWatts = await this.getAssetConsumptionInWatts(siteArea); if (siteArea.maximumPower !== siteArea.maximumPower - assetConsumptionInWatts) { - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: this.tenant.id, action: ServerAction.SMART_CHARGING, message: `${siteArea.name} > limit of ${siteArea.maximumPower} W has been adjusted to ${Math.round(siteArea.maximumPower - assetConsumptionInWatts)} W due Asset Consumption`, @@ -482,7 +482,7 @@ export default class SapSmartChargingIntegration extends SmartChargingIntegratio } // Found unsupported chargers if (siteMaxAmps !== rootFuse.fusePhase1 + rootFuse.fusePhase2 + rootFuse.fusePhase3) { - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: this.tenant.id, action: ServerAction.SMART_CHARGING, message: `${siteArea.name} > limit of ${siteMaxAmps} Amps has been lowered to ${Math.round(rootFuse.fusePhase1 + rootFuse.fusePhase2 + rootFuse.fusePhase3)} Amps due to unsupported charging stations currently being used`, @@ -935,7 +935,7 @@ export default class SapSmartChargingIntegration extends SmartChargingIntegratio } } if (removedChargingProfiles > 0) { - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: this.tenant.id, action: ServerAction.SMART_CHARGING, message: `${siteArea.name} > ${removedChargingProfiles} Charging Profiles have been already applied and will be removed from charging profile schedule`, diff --git a/src/locking/LockingManager.ts b/src/locking/LockingManager.ts index 6101cdb430..fbea696984 100644 --- a/src/locking/LockingManager.ts +++ b/src/locking/LockingManager.ts @@ -16,7 +16,7 @@ export default class LockingManager { public static async acquire(lock: Lock, timeoutSecs = 0, retry = true): Promise { try { - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: lock.tenantID, module: MODULE_NAME, method: 'acquire', action: ServerAction.LOCKING, @@ -36,7 +36,7 @@ export default class LockingManager { detailedMessages: { lock, timeoutSecs, retry } }); } - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: lock.tenantID, module: MODULE_NAME, method: 'acquire', action: ServerAction.LOCKING, @@ -50,7 +50,7 @@ export default class LockingManager { if (retry && await LockingManager.checkAndReleaseExpiredLock(lock)) { return LockingManager.acquire(lock, timeoutSecs, false); } - await Logging.logWarning({ + Logging.beWarning()?.log({ tenantID: lock.tenantID, module: MODULE_NAME, method: 'acquire', action: ServerAction.LOCKING, @@ -66,7 +66,7 @@ export default class LockingManager { // Delete const result = await LockingStorage.deleteLock(lock.id); if (!result) { - await Logging.logWarning({ + Logging.beWarning()?.log({ tenantID: lock.tenantID, module: MODULE_NAME, method: 'release', action: ServerAction.LOCKING, @@ -75,7 +75,7 @@ export default class LockingManager { }); return false; } - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: lock.tenantID, module: MODULE_NAME, method: 'release', action: ServerAction.LOCKING, @@ -156,7 +156,7 @@ export default class LockingManager { try { // Remove the lock await LockingManager.release(lockInDB); - await Logging.logWarning({ + Logging.beWarning()?.log({ tenantID: lock.tenantID, module: MODULE_NAME, method: 'acquire', action: ServerAction.LOCKING, @@ -166,7 +166,7 @@ export default class LockingManager { Utils.isDevelopmentEnv() && Logging.logConsoleWarning(`The lock '${lock.entity}' ('${lock.key}') of type '${lock.type}' in Tenant ID ${lock.tenantID} has expired and was released successfully`); return true; } catch (error) { - await Logging.logError({ + Logging.beError()?.log({ tenantID: lock.tenantID, module: MODULE_NAME, method: 'acquire', action: ServerAction.LOCKING, diff --git a/src/migration/MigrationHandler.ts b/src/migration/MigrationHandler.ts index 5bf4955c55..4eb4b2290b 100644 --- a/src/migration/MigrationHandler.ts +++ b/src/migration/MigrationHandler.ts @@ -18,7 +18,7 @@ export default class MigrationHandler { if (await LockingManager.acquire(migrationLock)) { try { const startTime = moment(); - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: Constants.DEFAULT_TENANT_ID, action: ServerAction.MIGRATION, module: MODULE_NAME, method: 'migrate', @@ -49,14 +49,14 @@ export default class MigrationHandler { } // Log Total Processing Time const totalTimeSecs = moment.duration(moment().diff(startTime)).asSeconds(); - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: Constants.DEFAULT_TENANT_ID, action: ServerAction.MIGRATION, module: MODULE_NAME, method: 'migrate', message: `The ${processAsyncTasksOnly ? 'asynchronous' : 'synchronous'} migration has been run in ${totalTimeSecs} secs` }); } catch (error) { - await Logging.logError({ + Logging.beError()?.log({ tenantID: Constants.DEFAULT_TENANT_ID, action: ServerAction.MIGRATION, module: MODULE_NAME, method: 'migrate', @@ -80,7 +80,7 @@ export default class MigrationHandler { try { // Log Start Task let logMsg = `${currentMigrationTask.isAsynchronous() ? 'Asynchronous' : 'Synchronous'} Migration Task '${currentMigrationTask.getName()}' Version '${currentMigrationTask.getVersion()}' is running...`; - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: Constants.DEFAULT_TENANT_ID, action: ServerAction.MIGRATION, module: MODULE_NAME, method: 'executeTask', @@ -104,7 +104,7 @@ export default class MigrationHandler { durationSecs: totalTaskTimeSecs }); logMsg = `${currentMigrationTask.isAsynchronous() ? 'Asynchronous' : 'Synchronous'} Migration Task '${currentMigrationTask.getName()}' Version '${currentMigrationTask.getVersion()}' has run with success in ${totalTaskTimeSecs} secs`; - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: Constants.DEFAULT_TENANT_ID, action: ServerAction.MIGRATION, module: MODULE_NAME, method: 'executeTask', @@ -114,7 +114,7 @@ export default class MigrationHandler { Utils.isDevelopmentEnv() && Logging.logConsoleDebug(logMsg); } catch (error) { const logMsg = `${currentMigrationTask.isAsynchronous() ? 'Asynchronous' : 'Synchronous'} Migration Task '${currentMigrationTask.getName()}' Version '${currentMigrationTask.getVersion()}' has failed with error: ${error.message as string}`; - await Logging.logError({ + Logging.beError()?.log({ tenantID: Constants.DEFAULT_TENANT_ID, action: ServerAction.MIGRATION, module: MODULE_NAME, method: 'executeTask', diff --git a/src/migration/TenantMigrationTask.ts b/src/migration/TenantMigrationTask.ts index 578f5628d6..22c5b74e72 100644 --- a/src/migration/TenantMigrationTask.ts +++ b/src/migration/TenantMigrationTask.ts @@ -15,7 +15,7 @@ export default abstract class TenantMigrationTask extends MigrationTask { for (const tenant of tenants.result) { const tenantCorrelationID = Utils.generateShortNonUniqueID(); const startTimeInTenant = moment(); - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: Constants.DEFAULT_TENANT_ID, action: ServerAction.MIGRATION, module: MODULE_NAME, method: 'migrate', @@ -25,7 +25,7 @@ export default abstract class TenantMigrationTask extends MigrationTask { // Migrate await this.migrateTenant(tenant); } catch (error) { - await Logging.logError({ + Logging.beError()?.log({ tenantID: Constants.DEFAULT_TENANT_ID, action: ServerAction.MIGRATION, module: MODULE_NAME, method: 'migrate', @@ -35,7 +35,7 @@ export default abstract class TenantMigrationTask extends MigrationTask { } // Log Total Processing Time const totalTimeSecsInTenant = moment.duration(moment().diff(startTimeInTenant)).asSeconds(); - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: Constants.DEFAULT_TENANT_ID, action: ServerAction.MIGRATION, module: MODULE_NAME, method: 'migrate', diff --git a/src/migration/tasks/AddCompanyIDToChargingStationsTask.ts b/src/migration/tasks/AddCompanyIDToChargingStationsTask.ts index 7ccaf443ec..fe310260c2 100644 --- a/src/migration/tasks/AddCompanyIDToChargingStationsTask.ts +++ b/src/migration/tasks/AddCompanyIDToChargingStationsTask.ts @@ -49,7 +49,7 @@ export default class AddCompanyIDToChargingStationsTask extends TenantMigrationT } // Log in the default tenant if (updated > 0) { - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: Constants.DEFAULT_TENANT_ID, module: MODULE_NAME, method: 'migrateTenant', action: ServerAction.MIGRATION, diff --git a/src/migration/tasks/AddCompanyIDToTransactionsTask.ts b/src/migration/tasks/AddCompanyIDToTransactionsTask.ts index 0b3bed5724..f29df87978 100644 --- a/src/migration/tasks/AddCompanyIDToTransactionsTask.ts +++ b/src/migration/tasks/AddCompanyIDToTransactionsTask.ts @@ -49,7 +49,7 @@ export default class AddCompanyIDToTransactionsTask extends TenantMigrationTask } // Log in the default tenant if (updated > 0) { - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: Constants.DEFAULT_TENANT_ID, module: MODULE_NAME, method: 'migrateTenant', action: ServerAction.MIGRATION, diff --git a/src/migration/tasks/AddLevelTemplateToChargingStationTemplateTask.ts b/src/migration/tasks/AddLevelTemplateToChargingStationTemplateTask.ts index 8885317dd9..d4bb559f08 100644 --- a/src/migration/tasks/AddLevelTemplateToChargingStationTemplateTask.ts +++ b/src/migration/tasks/AddLevelTemplateToChargingStationTemplateTask.ts @@ -17,7 +17,7 @@ export default class AddLevelTemplateToChargingStationTemplateTask extends Migra for (const template of templates) { if (template.template) { // skip this one as it has already ran - continue + continue; } // Put _id in id const and get template without id const { @@ -47,7 +47,7 @@ export default class AddLevelTemplateToChargingStationTemplateTask extends Migra }, ); } - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: Constants.DEFAULT_TENANT_ID, module: MODULE_NAME, method: 'migrate', action: ServerAction.MIGRATION, diff --git a/src/migration/tasks/AddUserIDToCarsTask.ts b/src/migration/tasks/AddUserIDToCarsTask.ts index 11af90b226..562f07de48 100644 --- a/src/migration/tasks/AddUserIDToCarsTask.ts +++ b/src/migration/tasks/AddUserIDToCarsTask.ts @@ -35,7 +35,7 @@ export default class AddUserIDToCarsTask extends TenantMigrationTask { } // Log in the default tenant if (updated > 0) { - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: Constants.DEFAULT_TENANT_ID, module: MODULE_NAME, method: 'migrateTenant', action: ServerAction.MIGRATION, diff --git a/src/migration/tasks/AlignEntitiesWithOrganizationIDsTask.ts b/src/migration/tasks/AlignEntitiesWithOrganizationIDsTask.ts index 55b33f3823..7ebafa767b 100644 --- a/src/migration/tasks/AlignEntitiesWithOrganizationIDsTask.ts +++ b/src/migration/tasks/AlignEntitiesWithOrganizationIDsTask.ts @@ -30,7 +30,7 @@ export default class AlignEntitiesWithOrganizationIDsTask extends TenantMigratio updated += await SiteAreaStorage.updateEntitiesWithOrganizationIDs( tenant, foundSite.companyID.toString(), siteArea.siteID.toString(), siteArea._id.toString()); } else { - await Logging.logError({ + Logging.beError()?.log({ tenantID: Constants.DEFAULT_TENANT_ID, module: MODULE_NAME, method: 'migrateTenant', action: ServerAction.MIGRATION, @@ -41,7 +41,7 @@ export default class AlignEntitiesWithOrganizationIDsTask extends TenantMigratio } // Log in the default tenant if (updated > 0) { - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: Constants.DEFAULT_TENANT_ID, module: MODULE_NAME, method: 'migrateTenant', action: ServerAction.MIGRATION, diff --git a/src/migration/tasks/MigrateSimplePricing.ts b/src/migration/tasks/MigrateSimplePricing.ts index 254ad75eac..4b3aca90d3 100644 --- a/src/migration/tasks/MigrateSimplePricing.ts +++ b/src/migration/tasks/MigrateSimplePricing.ts @@ -17,7 +17,7 @@ export default class SimplePricingMigrationTask extends TenantMigrationTask { const pricingSetting = await SettingStorage.getSettingByIdentifier(tenant, TenantComponents.PRICING); if (pricingSetting?.content?.type === PricingSettingsType.SIMPLE) { await this.createDefaultPricingDefinition(tenant, pricingSetting.content.simple); - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: Constants.DEFAULT_TENANT_ID, module: MODULE_NAME, method: 'migrateTenant', action: ServerAction.MIGRATION, diff --git a/src/migration/tasks/RemoveDuplicateTagVisualIDsTask.ts b/src/migration/tasks/RemoveDuplicateTagVisualIDsTask.ts index b30e494b9d..df35d90735 100644 --- a/src/migration/tasks/RemoveDuplicateTagVisualIDsTask.ts +++ b/src/migration/tasks/RemoveDuplicateTagVisualIDsTask.ts @@ -49,7 +49,7 @@ export default class RemoveDuplicateTagVisualIDsTask extends TenantMigrationTask } // Log in the default tenant if (updated > 0) { - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: Constants.DEFAULT_TENANT_ID, module: MODULE_NAME, method: 'migrateTenant', action: ServerAction.MIGRATION, diff --git a/src/migration/tasks/RepairInvoiceInconsistencies.ts b/src/migration/tasks/RepairInvoiceInconsistencies.ts index 3dbef59364..2534ba41e2 100644 --- a/src/migration/tasks/RepairInvoiceInconsistencies.ts +++ b/src/migration/tasks/RepairInvoiceInconsistencies.ts @@ -18,7 +18,7 @@ export default class RepairInvoiceInconsistencies extends TenantMigrationTask { const billingImpl = await BillingFactory.getBillingImpl(tenant); if (billingImpl && billingImpl instanceof StripeBillingIntegration) { await this.repairInvoices(tenant, billingImpl); - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: Constants.DEFAULT_TENANT_ID, module: MODULE_NAME, method: 'migrateTenant', action: ServerAction.MIGRATION, @@ -26,7 +26,7 @@ export default class RepairInvoiceInconsistencies extends TenantMigrationTask { }); } } catch (error) { - await Logging.logError({ + Logging.beError()?.log({ tenantID: tenant.id, action: ServerAction.BILLING_PERFORM_OPERATIONS, module: MODULE_NAME, method: 'repairInvoices', @@ -68,7 +68,7 @@ export default class RepairInvoiceInconsistencies extends TenantMigrationTask { try { // Skip invoices that are already PAID or not relevant for the current billing process if (!billingInvoice.sessions) { - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: tenant.id, action: ServerAction.BILLING_PERFORM_OPERATIONS, actionOnUser: billingInvoice.user, @@ -76,7 +76,7 @@ export default class RepairInvoiceInconsistencies extends TenantMigrationTask { message: `Attempt to repair invoice: '${billingInvoice.id}' - '${billingInvoice.number}' ` }); await billingImpl.repairInvoice(billingInvoice); - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: tenant.id, action: ServerAction.BILLING_PERFORM_OPERATIONS, actionOnUser: billingInvoice.user, @@ -85,7 +85,7 @@ export default class RepairInvoiceInconsistencies extends TenantMigrationTask { }); } } catch (error) { - await Logging.logError({ + Logging.beError()?.log({ tenantID: tenant.id, action: ServerAction.BILLING_PERFORM_OPERATIONS, actionOnUser: billingInvoice.user, diff --git a/src/migration/tasks/RepairTransactionBillingData.ts b/src/migration/tasks/RepairTransactionBillingData.ts index d9855e3589..ad608bf579 100644 --- a/src/migration/tasks/RepairTransactionBillingData.ts +++ b/src/migration/tasks/RepairTransactionBillingData.ts @@ -18,7 +18,7 @@ export default class RepairTransactionBillingData extends TenantMigrationTask { const billingImpl = await BillingFactory.getBillingImpl(tenant); if (billingImpl && billingImpl instanceof StripeBillingIntegration) { await this.repairTransactionsBillingData(tenant, billingImpl); - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: Constants.DEFAULT_TENANT_ID, module: MODULE_NAME, method: 'migrateTenant', action: ServerAction.MIGRATION, @@ -26,7 +26,7 @@ export default class RepairTransactionBillingData extends TenantMigrationTask { }); } } catch (error) { - await Logging.logError({ + Logging.beError()?.log({ tenantID: tenant.id, action: ServerAction.BILLING_PERFORM_OPERATIONS, module: MODULE_NAME, method: 'repairInvoices', @@ -66,7 +66,7 @@ export default class RepairTransactionBillingData extends TenantMigrationTask { skip += limit; for (const billingInvoice of invoices.result) { try { - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: tenant.id, action: ServerAction.BILLING_PERFORM_OPERATIONS, actionOnUser: billingInvoice.user, @@ -74,7 +74,7 @@ export default class RepairTransactionBillingData extends TenantMigrationTask { message: `Attempt to repair transaction's billing data for invoice: '${billingInvoice.id}' - '${billingInvoice.number}' ` }); await billingImpl.repairTransactionsBillingData(billingInvoice); - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: tenant.id, action: ServerAction.BILLING_PERFORM_OPERATIONS, actionOnUser: billingInvoice.user, @@ -82,7 +82,7 @@ export default class RepairTransactionBillingData extends TenantMigrationTask { message: `Transaction's billing data has been repaired for invoice: '${billingInvoice.id}' - '${billingInvoice.number}' ` }); } catch (error) { - await Logging.logError({ + Logging.beError()?.log({ tenantID: tenant.id, action: ServerAction.BILLING_PERFORM_OPERATIONS, actionOnUser: billingInvoice.user, diff --git a/src/migration/tasks/RepairTransactionPricedAtZeroTask.ts b/src/migration/tasks/RepairTransactionPricedAtZeroTask.ts index 39ead9fc19..428a5b31d7 100644 --- a/src/migration/tasks/RepairTransactionPricedAtZeroTask.ts +++ b/src/migration/tasks/RepairTransactionPricedAtZeroTask.ts @@ -46,7 +46,7 @@ export default class RepairTransactionPricedAtZero extends TenantMigrationTask { await this.loadSimplePricingSettings(tenant); if (transactionsMDB.length > 0 && this.pricingSettings?.simple?.price > 0) { let message = `${transactionsMDB.length} Transaction(s) are going to be repaired in Tenant ${Utils.buildTenantName(tenant)}...`; - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: Constants.DEFAULT_TENANT_ID, action: ServerAction.MIGRATION, module: MODULE_NAME, method: 'migrateTenant', @@ -57,7 +57,7 @@ export default class RepairTransactionPricedAtZero extends TenantMigrationTask { const numberOfProcessedTransactions = transactionsUpdated.inError + transactionsUpdated.inSuccess; if (numberOfProcessedTransactions > 0 && (numberOfProcessedTransactions % 100) === 0) { message = `> ${transactionsUpdated.inError + transactionsUpdated.inSuccess}/${transactionsMDB.length} - Transaction consumptions recomputed in Tenant ${Utils.buildTenantName(tenant)}`; - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: Constants.DEFAULT_TENANT_ID, action: ServerAction.MIGRATION, module: MODULE_NAME, method: 'migrateTenant', @@ -78,7 +78,7 @@ export default class RepairTransactionPricedAtZero extends TenantMigrationTask { transactionsUpdated.inSuccess++; } catch (error) { transactionsUpdated.inError++; - await Logging.logError({ + Logging.beError()?.log({ tenantID: Constants.DEFAULT_TENANT_ID, action: ServerAction.MIGRATION, module: MODULE_NAME, method: 'migrateTenant', diff --git a/src/migration/tasks/RestoreDataIntegrityInSiteUsersTask.ts b/src/migration/tasks/RestoreDataIntegrityInSiteUsersTask.ts index 246bf41044..e1b88a9c48 100644 --- a/src/migration/tasks/RestoreDataIntegrityInSiteUsersTask.ts +++ b/src/migration/tasks/RestoreDataIntegrityInSiteUsersTask.ts @@ -47,7 +47,7 @@ export default class RestoreDataIntegrityInSiteUsersTask extends TenantMigration } // Log in the default tenant if (deleted > 0) { - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: Constants.DEFAULT_TENANT_ID, module: MODULE_NAME, method: 'migrateTenant', action: ServerAction.MIGRATION, diff --git a/src/migration/tasks/UpdateEmailsToLowercaseTask.ts b/src/migration/tasks/UpdateEmailsToLowercaseTask.ts index 86889ca148..4cd636e746 100644 --- a/src/migration/tasks/UpdateEmailsToLowercaseTask.ts +++ b/src/migration/tasks/UpdateEmailsToLowercaseTask.ts @@ -22,7 +22,7 @@ export default class UpdateEmailsToLowercaseTask extends TenantMigrationTask { ) as UpdateResult; if (updateResult.modifiedCount > 0) { // Log in the default tenant - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: Constants.DEFAULT_TENANT_ID, module: MODULE_NAME, method: 'migrateTenant', action: ServerAction.MIGRATION, diff --git a/src/monitoring/prometheus/PrometheusMonitoringServer.ts b/src/monitoring/prometheus/PrometheusMonitoringServer.ts index fe3771150b..01652aacc3 100644 --- a/src/monitoring/prometheus/PrometheusMonitoringServer.ts +++ b/src/monitoring/prometheus/PrometheusMonitoringServer.ts @@ -2,11 +2,11 @@ import { Application, NextFunction, Request, Response } from 'express'; import { ServerAction, ServerType } from '../../types/Server'; import client, { Gauge } from 'prom-client'; +import { ComposedMonitoringMetric } from '../ComposedMonitoringMetric'; import Constants from '../../utils/Constants'; import ExpressUtils from '../../server/ExpressUtils'; import Logging from '../../utils/Logging'; import MonitoringConfiguration from '../../types/configuration/MonitoringConfiguration'; -import { ComposedMonitoringMetric } from '../ComposedMonitoringMetric'; import MonitoringServer from '../MonitoringServer'; import { ServerUtils } from '../../server/ServerUtils'; import global from '../../types/GlobalType'; @@ -32,10 +32,10 @@ export default class PrometheusMonitoringServer extends MonitoringServer { if (process.env.K8S) { this.createGaugeMetric(Constants.WEB_SOCKET_OCPP_CONNECTIONS_COUNT, 'The number of ocpp web sockets'); this.createGaugeMetric(Constants.WEB_SOCKET_REST_CONNECTIONS_COUNT, 'The number of rest web sockets'); - this.createGaugeMetric(Constants.WEB_SOCKET_QUEUED_REQUEST, 'The number of web sockets that are queued'); - this.createGaugeMetric(Constants.WEB_SOCKET_RUNNING_REQUEST, 'The number of web sockets that are running'); + // this.createGaugeMetric(Constants.WEB_SOCKET_QUEUED_REQUEST, 'The number of web sockets that are queued'); + // this.createGaugeMetric(Constants.WEB_SOCKET_RUNNING_REQUEST, 'The number of web sockets that are running'); this.createGaugeMetric(Constants.WEB_SOCKET_RUNNING_REQUEST_RESPONSE, 'The number of web sockets request + response that are running'); - this.createGaugeMetric(Constants.WEB_SOCKET_CURRRENT_REQUEST, 'JSON WS Requests in cache'); + this.createGaugeMetric(Constants.WEB_SOCKET_CURRENT_REQUEST, 'JSON WS Requests in cache'); this.createGaugeMetric(Constants.MONGODB_CONNECTION_READY, 'The number of connection that are ready'); this.createGaugeMetric(Constants.MONGODB_CONNECTION_CREATED, 'The number of connection created'); this.createGaugeMetric(Constants.MONGODB_CONNECTION_CLOSED, 'The number of connection closed'); @@ -44,19 +44,25 @@ export default class PrometheusMonitoringServer extends MonitoringServer { this.expressApplication = ExpressUtils.initApplication(); // Handle requests this.expressApplication.use( - // eslint-disable-next-line @typescript-eslint/no-misused-promises - '/metrics', async (req: Request, res: Response, next: NextFunction) => { + '/metrics', (req: Request, res: Response, next: NextFunction) => { // Trace Request - await Logging.traceExpressRequest(req, res, next, ServerAction.MONITORING); + Logging.traceExpressRequest(req, res, next, ServerAction.MONITORING).then(() => { // Process - res.setHeader('Content-Type', this.clientRegistry.contentType); - res.end(await this.clientRegistry.metrics()); - for (const val of this.mapComposedMetric.values()) { - val.clear(); - } - next(); - // Trace Response - Logging.traceExpressResponse(req, res, next, ServerAction.MONITORING); + res.setHeader('Content-Type', this.clientRegistry.contentType); + this.clientRegistry.metrics().then((s) => { + res.end(s); + for (const val of this.mapComposedMetric.values()) { + val.clear(); + } + next(); + // Trace Response + Logging.traceExpressResponse(req, res, next, ServerAction.MONITORING); + }).catch((error) => { + Logging.logPromiseError(error); + }); + }).catch((error) => { + Logging.logPromiseError(error); + }); } ); // Post init diff --git a/src/notification/NotificationHandler.ts b/src/notification/NotificationHandler.ts index f0eb1006ce..950e147218 100644 --- a/src/notification/NotificationHandler.ts +++ b/src/notification/NotificationHandler.ts @@ -70,7 +70,7 @@ export default class NotificationHandler { } return false; } catch (error) { - await Logging.logActionExceptionMessage(tenant.id, ServerAction.NOTIFICATION, error); + Logging.logActionExceptionMessage(tenant.id, ServerAction.NOTIFICATION, error); } } @@ -87,7 +87,7 @@ export default class NotificationHandler { ); return notifications.count > 0; } catch (error) { - await Logging.logActionExceptionMessage(tenant.id, ServerAction.NOTIFICATION, error); + Logging.logActionExceptionMessage(tenant.id, ServerAction.NOTIFICATION, error); } } @@ -119,7 +119,7 @@ export default class NotificationHandler { await notificationSource.notificationTask.sendEndOfCharge(sourceData, user, tenant, NotificationSeverity.INFO); } } else { - await Logging.logDebug({ + Logging.beDebug()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, module: MODULE_NAME, method: 'sendEndOfCharge', @@ -129,7 +129,7 @@ export default class NotificationHandler { }); } } catch (error) { - await Logging.logActionExceptionMessage(tenant.id, ServerAction.END_OF_CHARGE, error); + Logging.logActionExceptionMessage(tenant.id, ServerAction.END_OF_CHARGE, error); } } } @@ -164,7 +164,7 @@ export default class NotificationHandler { await notificationSource.notificationTask.sendOptimalChargeReached(sourceData, user, tenant, NotificationSeverity.INFO); } } else { - await Logging.logDebug({ + Logging.beDebug()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, module: MODULE_NAME, method: 'sendOptimalChargeReached', @@ -174,7 +174,7 @@ export default class NotificationHandler { }); } } catch (error) { - await Logging.logActionExceptionMessage(tenant.id, ServerAction.OPTIMAL_CHARGE_REACHED, error); + Logging.logActionExceptionMessage(tenant.id, ServerAction.OPTIMAL_CHARGE_REACHED, error); } } } @@ -209,7 +209,7 @@ export default class NotificationHandler { await notificationSource.notificationTask.sendEndOfSession(sourceData, user, tenant, NotificationSeverity.INFO); } } else { - await Logging.logDebug({ + Logging.beDebug()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, module: MODULE_NAME, method: 'sendEndOfSession', @@ -219,7 +219,7 @@ export default class NotificationHandler { }); } } catch (error) { - await Logging.logActionExceptionMessage(tenant.id, ServerAction.END_OF_SESSION, error); + Logging.logActionExceptionMessage(tenant.id, ServerAction.END_OF_SESSION, error); } } } @@ -254,7 +254,7 @@ export default class NotificationHandler { await notificationSource.notificationTask.sendEndOfSignedSession(sourceData, user, tenant, NotificationSeverity.INFO); } } else { - await Logging.logDebug({ + Logging.beDebug()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, module: MODULE_NAME, method: 'sendEndOfSignedSession', @@ -264,7 +264,7 @@ export default class NotificationHandler { }); } } catch (error) { - await Logging.logActionExceptionMessage(tenant.id, ServerAction.END_OF_SESSION, error); + Logging.logActionExceptionMessage(tenant.id, ServerAction.END_OF_SESSION, error); } } } @@ -285,7 +285,7 @@ export default class NotificationHandler { await notificationSource.notificationTask.sendRequestPassword( sourceData, user, tenant, NotificationSeverity.INFO); } catch (error) { - await Logging.logActionExceptionMessage(tenant.id, ServerAction.REQUEST_PASSWORD, error); + Logging.logActionExceptionMessage(tenant.id, ServerAction.REQUEST_PASSWORD, error); } } } @@ -309,7 +309,7 @@ export default class NotificationHandler { sourceData, user, tenant, NotificationSeverity.WARNING); } } catch (error) { - await Logging.logActionExceptionMessage(tenant.id, ServerAction.USER_ACCOUNT_STATUS_CHANGED, error); + Logging.logActionExceptionMessage(tenant.id, ServerAction.USER_ACCOUNT_STATUS_CHANGED, error); } } } @@ -331,7 +331,7 @@ export default class NotificationHandler { await notificationSource.notificationTask.sendNewRegisteredUser( sourceData, user, tenant, NotificationSeverity.INFO); } catch (error) { - await Logging.logActionExceptionMessage(tenant.id, ServerAction.NEW_REGISTERED_USER, error); + Logging.logActionExceptionMessage(tenant.id, ServerAction.NEW_REGISTERED_USER, error); } } } @@ -352,7 +352,7 @@ export default class NotificationHandler { await notificationSource.notificationTask.sendAccountVerificationNotification( sourceData, user, tenant, NotificationSeverity.INFO); } catch (error) { - await Logging.logActionExceptionMessage(tenant.id, ServerAction.USER_ACCOUNT_VERIFICATION, error); + Logging.logActionExceptionMessage(tenant.id, ServerAction.USER_ACCOUNT_VERIFICATION, error); } } } @@ -388,7 +388,7 @@ export default class NotificationHandler { sourceData, adminUser, tenant, NotificationSeverity.INFO); } } catch (error) { - await Logging.logActionExceptionMessage(tenant.id, ServerAction.ADMIN_ACCOUNT_VERIFICATION, error); + Logging.logActionExceptionMessage(tenant.id, ServerAction.ADMIN_ACCOUNT_VERIFICATION, error); } } } @@ -417,7 +417,7 @@ export default class NotificationHandler { await notificationSource.notificationTask.sendVerificationEmail( sourceData, user, tenant, NotificationSeverity.INFO); } else { - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: tenant.id, module: MODULE_NAME, method: 'sendVerificationEmail', action: ServerAction.VERIFY_EMAIL, @@ -426,7 +426,7 @@ export default class NotificationHandler { }); } } catch (error) { - await Logging.logActionExceptionMessage(tenant.id, ServerAction.VERIFY_EMAIL, error); + Logging.logActionExceptionMessage(tenant.id, ServerAction.VERIFY_EMAIL, error); } } } @@ -450,7 +450,7 @@ export default class NotificationHandler { await notificationSource.notificationTask.sendVerificationEmailUserImport( sourceData, user, tenant, NotificationSeverity.INFO); } catch (error) { - await Logging.logActionExceptionMessage(tenant.id, ServerAction.VERIFICATION_EMAIL_USER_IMPORT, error); + Logging.logActionExceptionMessage(tenant.id, ServerAction.VERIFICATION_EMAIL_USER_IMPORT, error); } } } @@ -490,7 +490,7 @@ export default class NotificationHandler { sourceData, adminUser, tenant, NotificationSeverity.ERROR); } } else { - await Logging.logDebug({ + Logging.beDebug()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, module: MODULE_NAME, method: 'sendChargingStationStatusError', @@ -499,7 +499,7 @@ export default class NotificationHandler { }); } } catch (error) { - await Logging.logActionExceptionMessage(tenant.id, ServerAction.CHARGING_STATION_STATUS_ERROR, error); + Logging.logActionExceptionMessage(tenant.id, ServerAction.CHARGING_STATION_STATUS_ERROR, error); } } } @@ -527,7 +527,7 @@ export default class NotificationHandler { sourceData, adminUser, tenant, NotificationSeverity.WARNING); } } catch (error) { - await Logging.logActionExceptionMessage(tenant.id, ServerAction.CHARGING_STATION_REGISTERED, error); + Logging.logActionExceptionMessage(tenant.id, ServerAction.CHARGING_STATION_REGISTERED, error); } } } @@ -555,7 +555,7 @@ export default class NotificationHandler { sourceData, adminUser, tenant, NotificationSeverity.WARNING); } } catch (error) { - await Logging.logActionExceptionMessage(tenant.id, ServerAction.UNKNOWN_USER_BADGED, error); + Logging.logActionExceptionMessage(tenant.id, ServerAction.UNKNOWN_USER_BADGED, error); } } } @@ -593,7 +593,7 @@ export default class NotificationHandler { sourceData, user, tenant, NotificationSeverity.INFO); } } else { - await Logging.logDebug({ + Logging.beDebug()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, module: MODULE_NAME, method: 'sendSessionStarted', @@ -603,7 +603,7 @@ export default class NotificationHandler { }); } } catch (error) { - await Logging.logActionExceptionMessage(tenant.id, ServerAction.TRANSACTION_STARTED, error); + Logging.logActionExceptionMessage(tenant.id, ServerAction.TRANSACTION_STARTED, error); } } } @@ -643,7 +643,7 @@ export default class NotificationHandler { } } } else { - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: tenant.id, module: MODULE_NAME, method: 'sendOCPIPatchChargingStationsStatusesError', action: ServerAction.PATCH_EVSE_STATUS_ERROR, @@ -651,7 +651,7 @@ export default class NotificationHandler { }); } } catch (error) { - await Logging.logActionExceptionMessage(tenant.id, ServerAction.PATCH_EVSE_STATUS_ERROR, error); + Logging.logActionExceptionMessage(tenant.id, ServerAction.PATCH_EVSE_STATUS_ERROR, error); } } } @@ -687,7 +687,7 @@ export default class NotificationHandler { } } } else { - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: tenant.id, module: MODULE_NAME, method: 'sendOICPPatchChargingStationsStatusesError', action: ServerAction.PATCH_EVSE_STATUS_ERROR, @@ -695,7 +695,7 @@ export default class NotificationHandler { }); } } catch (error) { - await Logging.logActionExceptionMessage(tenant.id, ServerAction.PATCH_EVSE_STATUS_ERROR, error); + Logging.logActionExceptionMessage(tenant.id, ServerAction.PATCH_EVSE_STATUS_ERROR, error); } } } @@ -731,7 +731,7 @@ export default class NotificationHandler { } } } else { - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: tenant.id, module: MODULE_NAME, method: 'sendOICPPatchChargingStationsError', action: ServerAction.PATCH_EVSE_ERROR, @@ -739,7 +739,7 @@ export default class NotificationHandler { }); } } catch (error) { - await Logging.logActionExceptionMessage(tenant.id, ServerAction.PATCH_EVSE_ERROR, error); + Logging.logActionExceptionMessage(tenant.id, ServerAction.PATCH_EVSE_ERROR, error); } } } @@ -766,7 +766,7 @@ export default class NotificationHandler { await notificationSource.notificationTask.sendUserAccountInactivity( sourceData, user, tenant, NotificationSeverity.INFO); } else { - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: tenant.id, module: MODULE_NAME, method: 'sendUserAccountInactivity', action: ServerAction.USER_ACCOUNT_INACTIVITY, @@ -775,7 +775,7 @@ export default class NotificationHandler { }); } } catch (error) { - await Logging.logActionExceptionMessage(tenant.id, ServerAction.USER_ACCOUNT_INACTIVITY, error); + Logging.logActionExceptionMessage(tenant.id, ServerAction.USER_ACCOUNT_INACTIVITY, error); } } } @@ -810,7 +810,7 @@ export default class NotificationHandler { await notificationSource.notificationTask.sendPreparingSessionNotStarted(sourceData, user, tenant, NotificationSeverity.INFO); } } else { - await Logging.logDebug({ + Logging.beDebug()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, module: MODULE_NAME, method: 'sendPreparingSessionNotStarted', @@ -820,7 +820,7 @@ export default class NotificationHandler { }); } } catch (error) { - await Logging.logActionExceptionMessage(tenant.id, ServerAction.PREPARING_SESSION_NOT_STARTED, error); + Logging.logActionExceptionMessage(tenant.id, ServerAction.PREPARING_SESSION_NOT_STARTED, error); } } } @@ -855,7 +855,7 @@ export default class NotificationHandler { } } } else { - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: tenant.id, module: MODULE_NAME, method: 'sendOfflineChargingStations', action: ServerAction.OFFLINE_CHARGING_STATIONS, @@ -863,7 +863,7 @@ export default class NotificationHandler { }); } } catch (error) { - await Logging.logActionExceptionMessage(tenant.id, ServerAction.OFFLINE_CHARGING_STATIONS, error); + Logging.logActionExceptionMessage(tenant.id, ServerAction.OFFLINE_CHARGING_STATIONS, error); } } } @@ -898,7 +898,7 @@ export default class NotificationHandler { } } } else { - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: tenant.id, module: MODULE_NAME, method: 'sendBillingSynchronizationFailed', action: ServerAction.BILLING_USER_SYNCHRONIZATION_FAILED, @@ -906,7 +906,7 @@ export default class NotificationHandler { }); } } catch (error) { - await Logging.logActionExceptionMessage(tenant.id, ServerAction.BILLING_USER_SYNCHRONIZATION_FAILED, error); + Logging.logActionExceptionMessage(tenant.id, ServerAction.BILLING_USER_SYNCHRONIZATION_FAILED, error); } } } @@ -941,7 +941,7 @@ export default class NotificationHandler { } } } else { - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: tenant.id, module: MODULE_NAME, method: 'sendBillingInvoicesSynchronizationFailed', action: ServerAction.BILLING_INVOICE_SYNCHRONIZATION_FAILED, @@ -949,7 +949,7 @@ export default class NotificationHandler { }); } } catch (error) { - await Logging.logActionExceptionMessage(tenant.id, ServerAction.BILLING_USER_SYNCHRONIZATION_FAILED, error); + Logging.logActionExceptionMessage(tenant.id, ServerAction.BILLING_USER_SYNCHRONIZATION_FAILED, error); } } } @@ -984,7 +984,7 @@ export default class NotificationHandler { } } } else { - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: tenant.id, module: MODULE_NAME, method: 'sendBillingPeriodicOperationFailed', action: ServerAction.BILLING_PERFORM_OPERATIONS, @@ -992,7 +992,7 @@ export default class NotificationHandler { }); } } catch (error) { - await Logging.logActionExceptionMessage(tenant.id, ServerAction.BILLING_PERFORM_OPERATIONS, error); + Logging.logActionExceptionMessage(tenant.id, ServerAction.BILLING_PERFORM_OPERATIONS, error); } } } @@ -1027,7 +1027,7 @@ export default class NotificationHandler { } } } else { - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: Constants.DEFAULT_TENANT_OBJECT.id, module: MODULE_NAME, method: 'sendCarsSynchronizationFailed', action: ServerAction.CAR_CATALOG_SYNCHRONIZATION_FAILED, @@ -1035,7 +1035,7 @@ export default class NotificationHandler { }); } } catch (error) { - await Logging.logActionExceptionMessage(Constants.DEFAULT_TENANT_ID, ServerAction.CAR_CATALOG_SYNCHRONIZATION_FAILED, error); + Logging.logActionExceptionMessage(Constants.DEFAULT_TENANT_ID, ServerAction.CAR_CATALOG_SYNCHRONIZATION_FAILED, error); } } } @@ -1071,7 +1071,7 @@ export default class NotificationHandler { } } } else { - await Logging.logDebug({ + Logging.beDebug()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, module: MODULE_NAME, method: 'sendComputeAndApplyChargingProfilesFailed', @@ -1080,7 +1080,7 @@ export default class NotificationHandler { }); } } catch (error) { - await Logging.logActionExceptionMessage(tenant.id, ServerAction.COMPUTE_AND_APPLY_CHARGING_PROFILES_FAILED, error); + Logging.logActionExceptionMessage(tenant.id, ServerAction.COMPUTE_AND_APPLY_CHARGING_PROFILES_FAILED, error); } } } @@ -1114,7 +1114,7 @@ export default class NotificationHandler { } } } catch (error) { - await Logging.logActionExceptionMessage(tenant.id, ServerAction.END_USER_REPORT_ERROR, error); + Logging.logActionExceptionMessage(tenant.id, ServerAction.END_USER_REPORT_ERROR, error); } } } @@ -1146,7 +1146,7 @@ export default class NotificationHandler { await notificationSource.notificationTask.sendSessionNotStarted(sourceData, sourceData.user, tenant, NotificationSeverity.INFO); } } else { - await Logging.logDebug({ + Logging.beDebug()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, module: MODULE_NAME, method: 'sendSessionNotStarted', @@ -1155,7 +1155,7 @@ export default class NotificationHandler { }); } } catch (error) { - await Logging.logActionExceptionMessage(tenant.id, ServerAction.SESSION_NOT_STARTED_AFTER_AUTHORIZE, error); + Logging.logActionExceptionMessage(tenant.id, ServerAction.SESSION_NOT_STARTED_AFTER_AUTHORIZE, error); } } } @@ -1185,7 +1185,7 @@ export default class NotificationHandler { } } } else { - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: tenant.id, module: MODULE_NAME, method: 'sendBillingNewInvoiceNotification', action: ServerAction.BILLING_NEW_INVOICE, @@ -1194,7 +1194,7 @@ export default class NotificationHandler { }); } } catch (error) { - await Logging.logActionExceptionMessage(tenant.id, ServerAction.BILLING_NEW_INVOICE, error); + Logging.logActionExceptionMessage(tenant.id, ServerAction.BILLING_NEW_INVOICE, error); } } } @@ -1216,7 +1216,7 @@ export default class NotificationHandler { await notificationSource.notificationTask.sendBillingAccountCreationLink( sourceData, user, tenant, NotificationSeverity.INFO); } catch (error) { - await Logging.logActionExceptionMessage(tenant.id, ServerAction.BILLING_ACCOUNT_CREATE, error); + Logging.logActionExceptionMessage(tenant.id, ServerAction.BILLING_ACCOUNT_CREATE, error); } } } @@ -1238,7 +1238,7 @@ export default class NotificationHandler { await notificationSource.notificationTask.sendBillingAccountActivationNotification( sourceData, user, tenant, NotificationSeverity.INFO); } catch (error) { - await Logging.logActionExceptionMessage(tenant.id, ServerAction.BILLING_ACCOUNT_ACTIVATE, error); + Logging.logActionExceptionMessage(tenant.id, ServerAction.BILLING_ACCOUNT_ACTIVATE, error); } } } @@ -1260,7 +1260,7 @@ export default class NotificationHandler { // Success if (extraParams.user) { // User - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: tenant.id, siteID: extraParams.chargingStation?.siteID, siteAreaID: extraParams.chargingStation?.siteAreaID, @@ -1273,7 +1273,7 @@ export default class NotificationHandler { }); } else { // Admin - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: tenant.id, siteID: extraParams.chargingStation?.siteID, siteAreaID: extraParams.chargingStation?.siteAreaID, diff --git a/src/notification/email/EMailNotificationTask.ts b/src/notification/email/EMailNotificationTask.ts index d32bf0eb06..8fba4c1125 100644 --- a/src/notification/email/EMailNotificationTask.ts +++ b/src/notification/email/EMailNotificationTask.ts @@ -243,7 +243,7 @@ export default class EMailNotificationTask implements NotificationTask { // Email configuration sanity checks if (!this.smtpMainClientInstance) { // No suitable main SMTP server configuration found to send the email - await Logging.logError({ + Logging.beError()?.log({ tenantID: tenant.id, siteID: data?.siteID, siteAreaID: data?.siteAreaID, @@ -258,7 +258,7 @@ export default class EMailNotificationTask implements NotificationTask { } if (useSmtpClientBackup && !this.smtpBackupClientInstance) { // No suitable backup SMTP server configuration found or activated to send the email - await Logging.logError({ + Logging.beError()?.log({ tenantID: tenant.id, siteID: data?.siteID, siteAreaID: data?.siteAreaID, @@ -285,7 +285,7 @@ export default class EMailNotificationTask implements NotificationTask { }); if (Utils.isDevelopmentEnv()) { // Do not send mail in Dev mode - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: tenant.id ? tenant.id : Constants.DEFAULT_TENANT_ID, action: ServerAction.EMAIL_NOTIFICATION, module: MODULE_NAME, method: 'sendEmail', @@ -306,7 +306,7 @@ export default class EMailNotificationTask implements NotificationTask { // Send the message const messageSent: Message = await smtpClient.sendAsync(messageToSend); // Email sent successfully - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: tenant.id ? tenant.id : Constants.DEFAULT_TENANT_ID, siteID: data?.siteID, siteAreaID: data?.siteAreaID, @@ -323,7 +323,7 @@ export default class EMailNotificationTask implements NotificationTask { } }); } catch (error) { - await Logging.logError({ + Logging.beError()?.log({ tenantID: tenant.id ? tenant.id : Constants.DEFAULT_TENANT_ID, siteID: data?.siteID, siteAreaID: data?.siteAreaID, @@ -425,7 +425,7 @@ export default class EMailNotificationTask implements NotificationTask { html: emailContent.html, }; } catch (error) { - await Logging.logError({ + Logging.beError()?.log({ tenantID: tenant.id, ...LoggingHelper.getSourceDataProperties(sourceData), action: ServerAction.EMAIL_NOTIFICATION, diff --git a/src/notification/remote-push-notification/RemotePushNotificationTask.ts b/src/notification/remote-push-notification/RemotePushNotificationTask.ts index f10397e10e..9bafddfd8e 100644 --- a/src/notification/remote-push-notification/RemotePushNotificationTask.ts +++ b/src/notification/remote-push-notification/RemotePushNotificationTask.ts @@ -59,7 +59,7 @@ export default class RemotePushNotificationTask implements NotificationTask { } this.initialized = true; } catch (error) { - void Logging.logError({ + Logging.beError()?.log({ tenantID: Constants.DEFAULT_TENANT_ID, action: ServerAction.REMOTE_PUSH_NOTIFICATION, module: MODULE_NAME, method: 'constructor', @@ -119,11 +119,11 @@ export default class RemotePushNotificationTask implements NotificationTask { // Set the locale const i18nManager = I18nManager.getInstanceForLocale(user.locale); // TODO - old stuff - to be removed asap - data.chargeBoxIDs = data.chargingStationIDs.join(", "); + data.chargeBoxIDs = data.chargingStationIDs.join(', '); // Populate the context to have a human-readable message data.nbChargingStationIDs = data.chargingStationIDs?.length || 0; // Show only the ten first charging stations - data.tenFirstChargingStationIDs = data.chargingStationIDs.slice(0, 10).join(", ") + "..."; + data.tenFirstChargingStationIDs = data.chargingStationIDs.slice(0, 10).join(', ') + '...'; // Get Message Text const title = i18nManager.translate('notifications.offlineChargingStation.title'); const body = i18nManager.translate('notifications.offlineChargingStation.body', @@ -477,7 +477,7 @@ export default class RemotePushNotificationTask implements NotificationTask { return Promise.resolve(); } if (!user?.mobileData?.mobileToken) { - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: tenant.id, siteID: data?.siteID, siteAreaID: data?.siteAreaID, @@ -511,7 +511,7 @@ export default class RemotePushNotificationTask implements NotificationTask { ); // Error if (response.failureCount > 0) { - void Logging.logError({ + Logging.beWarning()?.log({ tenantID: tenant.id, siteID: data?.siteID, siteAreaID: data?.siteAreaID, @@ -527,7 +527,7 @@ export default class RemotePushNotificationTask implements NotificationTask { } else { // Stop sending notification notificationSent = true; - void Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: tenant.id, siteID: data?.siteID, siteAreaID: data?.siteAreaID, @@ -541,7 +541,7 @@ export default class RemotePushNotificationTask implements NotificationTask { }); } } catch (error) { - void Logging.logError({ + Logging.beError()?.log({ tenantID: tenant.id, siteID: data?.siteID, siteAreaID: data?.siteAreaID, diff --git a/src/scheduler/SchedulerManager.ts b/src/scheduler/SchedulerManager.ts index bb8f7e3d0c..ae78cf3248 100644 --- a/src/scheduler/SchedulerManager.ts +++ b/src/scheduler/SchedulerManager.ts @@ -43,7 +43,7 @@ export default class SchedulerManager { // Keep the conf SchedulerManager.schedulerConfig = schedulerConfig; // Log - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: Constants.DEFAULT_TENANT_ID, action: ServerAction.SCHEDULER, module: MODULE_NAME, method: 'init', @@ -53,7 +53,7 @@ export default class SchedulerManager { for (const task of SchedulerManager.schedulerConfig.tasks) { // Active? if (!task.active) { - await Logging.logWarning({ + Logging.beWarning()?.log({ tenantID: Constants.DEFAULT_TENANT_ID, action: ServerAction.SCHEDULER, module: MODULE_NAME, method: 'init', @@ -65,7 +65,7 @@ export default class SchedulerManager { if (schedulerTask) { // Register task to cron engine cron.schedule(task.periodicity, () => SchedulerManager.runTask(schedulerTask, task)); - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: Constants.DEFAULT_TENANT_ID, action: ServerAction.SCHEDULER, module: MODULE_NAME, method: 'init', @@ -146,7 +146,7 @@ export default class SchedulerManager { case 'DispatchCollectedFundsTask': return new DispatchCollectedFundsTask(); default: - await Logging.logError({ + Logging.beError()?.log({ tenantID: Constants.DEFAULT_TENANT_ID, action: ServerAction.SCHEDULER, module: MODULE_NAME, method: 'createTask', diff --git a/src/scheduler/SchedulerTask.ts b/src/scheduler/SchedulerTask.ts index 8410143fd6..6ff7e3db8b 100644 --- a/src/scheduler/SchedulerTask.ts +++ b/src/scheduler/SchedulerTask.ts @@ -21,7 +21,7 @@ export default abstract class SchedulerTask { if (scheduledTaskLock) { try { const startTime = moment(); - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: Constants.DEFAULT_TENANT_ID, action: ServerAction.SCHEDULER, module: MODULE_NAME, method: 'run', @@ -35,7 +35,7 @@ export default abstract class SchedulerTask { // Hook await this.afterTaskRun(config); } catch (error) { - await Logging.logError({ + Logging.beError()?.log({ tenantID: Constants.DEFAULT_TENANT_ID, action: ServerAction.SCHEDULER, module: MODULE_NAME, method: 'run', @@ -45,7 +45,7 @@ export default abstract class SchedulerTask { } // Log Total Processing Time const totalTimeSecs = moment.duration(moment().diff(startTime)).asSeconds(); - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: Constants.DEFAULT_TENANT_ID, action: ServerAction.SCHEDULER, module: MODULE_NAME, method: 'run', diff --git a/src/scheduler/TenantSchedulerTask.ts b/src/scheduler/TenantSchedulerTask.ts index ffee0dbd70..1a1f2014a8 100644 --- a/src/scheduler/TenantSchedulerTask.ts +++ b/src/scheduler/TenantSchedulerTask.ts @@ -23,7 +23,7 @@ export default abstract class TenantSchedulerTask extends SchedulerTask { (taskSettings.task.disableAllTasks || !Utils.isEmptyArray(taskSettings.task.disableTasksInEnv) && taskSettings.task.disableTasksInEnv.includes(currentTaskEnv))) { // Tasks are disabled for this environment isTaskExecutionDisabled = true; - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: Constants.DEFAULT_TENANT_ID, action: ServerAction.SCHEDULER, module: MODULE_NAME, method: 'processTask', @@ -43,7 +43,7 @@ export default abstract class TenantSchedulerTask extends SchedulerTask { } // Check if tenant task needs to run on a specific environment if (tenant.taskExecutionEnv && tenant.taskExecutionEnv !== currentTaskEnv) { - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: Constants.DEFAULT_TENANT_ID, action: ServerAction.SCHEDULER, module: MODULE_NAME, method: 'processTask', @@ -54,13 +54,13 @@ export default abstract class TenantSchedulerTask extends SchedulerTask { } const tenantCorrelationID = Utils.generateShortNonUniqueID(); const startTimeInTenant = moment(); - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: Constants.DEFAULT_TENANT_ID, action: ServerAction.SCHEDULER, module: MODULE_NAME, method: 'processTask', message: `The Task '${this.getName()}~${this.getCorrelationID()}~${tenantCorrelationID}' is running for Tenant ${Utils.buildTenantName(tenant)}...` }); - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: tenant.id, action: ServerAction.SCHEDULER, module: MODULE_NAME, method: 'processTask', @@ -74,14 +74,14 @@ export default abstract class TenantSchedulerTask extends SchedulerTask { // Hook await this.afterProcessTenant(tenant, config); } catch (error) { - await Logging.logError({ + Logging.beError()?.log({ tenantID: Constants.DEFAULT_TENANT_ID, action: ServerAction.SCHEDULER, module: MODULE_NAME, method: 'processTask', message: `Error while running the Task '${this.getName()}~${this.getCorrelationID()}~${tenantCorrelationID}' for Tenant ${Utils.buildTenantName(tenant)}: ${error.message as string}`, detailedMessages: { error: error.stack } }); - await Logging.logError({ + Logging.beError()?.log({ tenantID: tenant.id, action: ServerAction.SCHEDULER, module: MODULE_NAME, method: 'processTask', @@ -91,13 +91,13 @@ export default abstract class TenantSchedulerTask extends SchedulerTask { } // Log Total Processing Time in Tenant const totalTimeSecsInTenant = moment.duration(moment().diff(startTimeInTenant)).asSeconds(); - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: Constants.DEFAULT_TENANT_ID, action: ServerAction.SCHEDULER, module: MODULE_NAME, method: 'processTask', message: `The Task '${this.getName()}~${this.getCorrelationID()}~${tenantCorrelationID}' has been run successfully in ${totalTimeSecsInTenant} secs for Tenant ${Utils.buildTenantName(tenant)}` }); - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: tenant.id, action: ServerAction.SCHEDULER, module: MODULE_NAME, method: 'processTask', diff --git a/src/scheduler/tasks/AssetGetConsumptionTask.ts b/src/scheduler/tasks/AssetGetConsumptionTask.ts index 8344dae8d2..214d2e081b 100644 --- a/src/scheduler/tasks/AssetGetConsumptionTask.ts +++ b/src/scheduler/tasks/AssetGetConsumptionTask.ts @@ -89,7 +89,7 @@ export default class AssetGetConsumptionTask extends TenantSchedulerTask { } } catch (error) { // Log error - await Logging.logActionExceptionMessage(tenant.id, ServerAction.RETRIEVE_ASSET_CONSUMPTION, error); + Logging.logActionExceptionMessage(tenant.id, ServerAction.RETRIEVE_ASSET_CONSUMPTION, error); } finally { // Release the lock await LockingManager.release(assetLock); diff --git a/src/scheduler/tasks/BillPendingTransactionTask.ts b/src/scheduler/tasks/BillPendingTransactionTask.ts index dad30128c8..d01610f81e 100644 --- a/src/scheduler/tasks/BillPendingTransactionTask.ts +++ b/src/scheduler/tasks/BillPendingTransactionTask.ts @@ -43,7 +43,7 @@ export default class BillPendingTransactionTask extends TenantSchedulerTask { } ]).toArray(); if (!Utils.isEmptyArray(transactionsMDB)) { - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: tenant.id, action: ServerAction.BILLING_BILL_PENDING_TRANSACTION, module: MODULE_NAME, method: 'processTenant', @@ -56,7 +56,7 @@ export default class BillPendingTransactionTask extends TenantSchedulerTask { // Get Transaction const transaction = await TransactionStorage.getTransaction(tenant, transactionMDB._id, { withUser: true, withChargingStation: true }); if (!transaction) { - await Logging.logError({ + Logging.beError()?.log({ tenantID: tenant.id, action: ServerAction.BILLING_BILL_PENDING_TRANSACTION, module: MODULE_NAME, method: 'processTenant', @@ -67,7 +67,7 @@ export default class BillPendingTransactionTask extends TenantSchedulerTask { // Get Charging Station const chargingStation = transaction.chargeBox; if (!chargingStation) { - await Logging.logError({ + Logging.beError()?.log({ tenantID: tenant.id, action: ServerAction.BILLING_BILL_PENDING_TRANSACTION, module: MODULE_NAME, method: 'processTenant', @@ -87,7 +87,7 @@ export default class BillPendingTransactionTask extends TenantSchedulerTask { } // Check for the billing status if (transaction.billingData?.stop?.status !== BillingStatus.PENDING) { - await Logging.logWarning({ + Logging.beWarning()?.log({ tenantID: tenant.id, action: ServerAction.BILLING_BILL_PENDING_TRANSACTION, module: MODULE_NAME, method: 'processTenant', @@ -97,7 +97,7 @@ export default class BillPendingTransactionTask extends TenantSchedulerTask { } // Avoid billing again! if (transaction.billingData?.stop?.invoiceID) { - await Logging.logWarning({ + Logging.beWarning()?.log({ tenantID: tenant.id, action: ServerAction.BILLING_BILL_PENDING_TRANSACTION, module: MODULE_NAME, method: 'processTenant', @@ -112,7 +112,7 @@ export default class BillPendingTransactionTask extends TenantSchedulerTask { await BillingFacade.processEndTransaction(tenant, transaction, transaction.user); // Save await TransactionStorage.saveTransaction(tenant, transaction); - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: tenant.id, action: ServerAction.BILLING_BILL_PENDING_TRANSACTION, actionOnUser: transaction.user, @@ -120,7 +120,7 @@ export default class BillPendingTransactionTask extends TenantSchedulerTask { message: `The billing process has been started for transaction '${transaction.id}'`, }); } catch (error) { - await Logging.logError({ + Logging.beError()?.log({ tenantID: tenant.id, action: ServerAction.BILLING_BILL_PENDING_TRANSACTION, module: MODULE_NAME, method: 'processTenant', @@ -142,7 +142,7 @@ export default class BillPendingTransactionTask extends TenantSchedulerTask { } } } catch (error) { - await Logging.logActionExceptionMessage(tenant.id, ServerAction.BILLING_BILL_PENDING_TRANSACTION, error); + Logging.logActionExceptionMessage(tenant.id, ServerAction.BILLING_BILL_PENDING_TRANSACTION, error); } } } diff --git a/src/scheduler/tasks/BillingPeriodicOperationTask.ts b/src/scheduler/tasks/BillingPeriodicOperationTask.ts index 3910b3653e..0ddf82fc38 100644 --- a/src/scheduler/tasks/BillingPeriodicOperationTask.ts +++ b/src/scheduler/tasks/BillingPeriodicOperationTask.ts @@ -34,7 +34,7 @@ export default class BillingPeriodicOperationTask extends TenantSchedulerTask { } } catch (error) { // Log error - await Logging.logActionExceptionMessage(tenant.id, ServerAction.BILLING_PERFORM_OPERATIONS, error as Error); + Logging.logActionExceptionMessage(tenant.id, ServerAction.BILLING_PERFORM_OPERATIONS, error as Error); } finally { // Release the lock await LockingManager.release(billingLock); diff --git a/src/scheduler/tasks/CheckAndComputeSmartChargingTask.ts b/src/scheduler/tasks/CheckAndComputeSmartChargingTask.ts index 8b7d4e92b9..37bfccf9d1 100644 --- a/src/scheduler/tasks/CheckAndComputeSmartChargingTask.ts +++ b/src/scheduler/tasks/CheckAndComputeSmartChargingTask.ts @@ -29,7 +29,7 @@ export default class CheckAndComputeSmartChargingTask extends TenantSchedulerTas const smartCharging = await SmartChargingFactory.getSmartChargingImpl(tenant); if (!smartCharging) { // Log - await Logging.logError({ + Logging.beError()?.log({ tenantID: tenant.id, module: MODULE_NAME, method: 'processTenant', action: ServerAction.CHECK_AND_APPLY_SMART_CHARGING, @@ -40,7 +40,7 @@ export default class CheckAndComputeSmartChargingTask extends TenantSchedulerTas await smartCharging.computeAndApplyChargingProfiles(siteArea); } catch (error) { // Log error - await Logging.logError({ + Logging.beError()?.log({ tenantID: tenant.id, module: MODULE_NAME, method: 'processTenant', action: ServerAction.CHECK_AND_APPLY_SMART_CHARGING, @@ -53,7 +53,7 @@ export default class CheckAndComputeSmartChargingTask extends TenantSchedulerTas } } } - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: Constants.DEFAULT_TENANT_ID, module: MODULE_NAME, method: 'processTenant', action: ServerAction.CHECK_AND_APPLY_SMART_CHARGING, diff --git a/src/scheduler/tasks/CheckChargingStationTemplateTask.ts b/src/scheduler/tasks/CheckChargingStationTemplateTask.ts index 61d4650bc7..b2e8ac039d 100644 --- a/src/scheduler/tasks/CheckChargingStationTemplateTask.ts +++ b/src/scheduler/tasks/CheckChargingStationTemplateTask.ts @@ -22,7 +22,7 @@ export default class CheckChargingStationTemplateTask extends TenantSchedulerTas await this.applyTemplateToChargingStations(tenant); } catch (error) { // Log error - await Logging.logActionExceptionMessage(tenant.id, ServerAction.UPDATE_CHARGING_STATION_WITH_TEMPLATE, error); + Logging.logActionExceptionMessage(tenant.id, ServerAction.UPDATE_CHARGING_STATION_WITH_TEMPLATE, error); } finally { // Release the lock await LockingManager.release(checkChargingStationTemplateLock); @@ -34,7 +34,7 @@ export default class CheckChargingStationTemplateTask extends TenantSchedulerTas let updated = 0; // Bypass perf tenant if (tenant.subdomain === 'testperf') { - await Logging.logWarning({ + Logging.beWarning()?.log({ tenantID: tenant.id, action: ServerAction.UPDATE_CHARGING_STATION_WITH_TEMPLATE, module: MODULE_NAME, method: 'applyTemplateToChargingStations', @@ -57,7 +57,7 @@ export default class CheckChargingStationTemplateTask extends TenantSchedulerTas updated++; } } catch (error) { - await Logging.logError({ + Logging.beError()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, action: ServerAction.UPDATE_CHARGING_STATION_WITH_TEMPLATE, @@ -68,7 +68,7 @@ export default class CheckChargingStationTemplateTask extends TenantSchedulerTas } } if (updated > 0) { - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: tenant.id, action: ServerAction.UPDATE_CHARGING_STATION_WITH_TEMPLATE, module: MODULE_NAME, method: 'applyTemplateToChargingStations', diff --git a/src/scheduler/tasks/CheckOfflineChargingStationsTask.ts b/src/scheduler/tasks/CheckOfflineChargingStationsTask.ts index 68651c1551..27a47e7c9b 100644 --- a/src/scheduler/tasks/CheckOfflineChargingStationsTask.ts +++ b/src/scheduler/tasks/CheckOfflineChargingStationsTask.ts @@ -45,7 +45,7 @@ export default class CheckOfflineChargingStationsTask extends TenantSchedulerTas } // Charging Station is still connected: ignore it if (ocppHeartbeatConfiguration) { - await Logging.logInfo({ + Logging.beInfo()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, action: ServerAction.OFFLINE_CHARGING_STATION, @@ -81,7 +81,7 @@ export default class CheckOfflineChargingStationsTask extends TenantSchedulerTas } } catch (error) { // Log error - await Logging.logActionExceptionMessage(tenant.id, ServerAction.OFFLINE_CHARGING_STATION, error); + Logging.logActionExceptionMessage(tenant.id, ServerAction.OFFLINE_CHARGING_STATION, error); } finally { // Release the lock await LockingManager.release(offlineChargingStationLock); diff --git a/src/scheduler/tasks/CheckPreparingSessionNotStartedTask.ts b/src/scheduler/tasks/CheckPreparingSessionNotStartedTask.ts index afbe7a6203..7fbfa3c80b 100644 --- a/src/scheduler/tasks/CheckPreparingSessionNotStartedTask.ts +++ b/src/scheduler/tasks/CheckPreparingSessionNotStartedTask.ts @@ -52,7 +52,7 @@ export default class CheckPreparingSessionNotStartedTask extends TenantScheduler } } catch (error) { // Log error - await Logging.logActionExceptionMessage(tenant.id, ServerAction.PREPARING_SESSION_NOT_STARTED, error); + Logging.logActionExceptionMessage(tenant.id, ServerAction.PREPARING_SESSION_NOT_STARTED, error); } finally { // Release the lock await LockingManager.release(sessionNotStartedLock); diff --git a/src/scheduler/tasks/CheckSessionNotStartedAfterAuthorizeTask.ts b/src/scheduler/tasks/CheckSessionNotStartedAfterAuthorizeTask.ts index 3260ce8b0c..56a22ff60d 100644 --- a/src/scheduler/tasks/CheckSessionNotStartedAfterAuthorizeTask.ts +++ b/src/scheduler/tasks/CheckSessionNotStartedAfterAuthorizeTask.ts @@ -39,7 +39,7 @@ export default class CheckSessionNotStartedAfterAuthorizeTask extends TenantSche } } catch (error) { // Log error - await Logging.logActionExceptionMessage(tenant.id, ServerAction.PREPARING_SESSION_NOT_STARTED, error); + Logging.logActionExceptionMessage(tenant.id, ServerAction.PREPARING_SESSION_NOT_STARTED, error); } finally { // Release the lock await LockingManager.release(sessionNotStartedLock); diff --git a/src/scheduler/tasks/CheckUserAccountInactivityTask.ts b/src/scheduler/tasks/CheckUserAccountInactivityTask.ts index 5456695b93..ce6876c95c 100644 --- a/src/scheduler/tasks/CheckUserAccountInactivityTask.ts +++ b/src/scheduler/tasks/CheckUserAccountInactivityTask.ts @@ -42,7 +42,7 @@ export default class CheckUserAccountInactivityTask extends TenantSchedulerTask } } catch (error) { // Log error - await Logging.logActionExceptionMessage(tenant.id, ServerAction.USER_ACCOUNT_INACTIVITY, error); + Logging.logActionExceptionMessage(tenant.id, ServerAction.USER_ACCOUNT_INACTIVITY, error); } finally { // Release the lock await LockingManager.release(accountInactivityLock); diff --git a/src/scheduler/tasks/CloseTransactionsInProgressTask.ts b/src/scheduler/tasks/CloseTransactionsInProgressTask.ts index a5d8983545..9cf23a89d3 100644 --- a/src/scheduler/tasks/CloseTransactionsInProgressTask.ts +++ b/src/scheduler/tasks/CloseTransactionsInProgressTask.ts @@ -34,7 +34,7 @@ export default class CloseTransactionsInProgressTask extends TenantSchedulerTask // Soft stop transaction await ocppService.softStopTransaction(tenant, transaction, transaction.chargeBox, transaction.siteArea); result.inSuccess++; - await Logging.logInfo({ + Logging.beInfo()?.log({ ...LoggingHelper.getTransactionProperties(transaction), tenantID: tenant.id, actionOnUser: transaction.userID, @@ -45,7 +45,7 @@ export default class CloseTransactionsInProgressTask extends TenantSchedulerTask }); } catch (error) { result.inError++; - await Logging.logError({ + Logging.beError()?.log({ ...LoggingHelper.getTransactionProperties(transaction), tenantID: tenant.id, action: ServerAction.TRANSACTION_SOFT_STOP, @@ -64,7 +64,7 @@ export default class CloseTransactionsInProgressTask extends TenantSchedulerTask `No Transaction have been soft stopped in ${executionDurationSecs}s in Tenant ${Utils.buildTenantName(tenant)}` ); } catch (error) { - await Logging.logActionExceptionMessage(tenant.id, ServerAction.TRANSACTION_SOFT_STOP, error); + Logging.logActionExceptionMessage(tenant.id, ServerAction.TRANSACTION_SOFT_STOP, error); } finally { // Release the lock await LockingManager.release(transactionsCloseLock); diff --git a/src/scheduler/tasks/DispatchCollectedFundsTask.ts b/src/scheduler/tasks/DispatchCollectedFundsTask.ts index c3c5006f2f..ed9a967c18 100644 --- a/src/scheduler/tasks/DispatchCollectedFundsTask.ts +++ b/src/scheduler/tasks/DispatchCollectedFundsTask.ts @@ -34,7 +34,7 @@ export default class DispatchCollectedFundsTask extends TenantSchedulerTask { } } catch (error) { // Log error - await Logging.logActionExceptionMessage(tenant.id, ServerAction.BILLING_TRANSFER_DISPATCH_FUNDS, error as Error); + Logging.logActionExceptionMessage(tenant.id, ServerAction.BILLING_TRANSFER_DISPATCH_FUNDS, error as Error); } finally { // Release the lock await LockingManager.release(billingLock); diff --git a/src/scheduler/tasks/LoggingDatabaseTableCleanupTask.ts b/src/scheduler/tasks/LoggingDatabaseTableCleanupTask.ts index b4e5bd2022..a22598b055 100644 --- a/src/scheduler/tasks/LoggingDatabaseTableCleanupTask.ts +++ b/src/scheduler/tasks/LoggingDatabaseTableCleanupTask.ts @@ -47,14 +47,14 @@ export default class LoggingDatabaseTableCleanupTask extends TenantSchedulerTask // Delete const result = await LogStorage.deleteLogs(tenant, deleteUpToDate); if (result.acknowledged) { - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: tenant.id, action: ServerAction.LOGS_CLEANUP, module: MODULE_NAME, method: 'deleteLogs', message: `${result.deletedCount} Log(s) have been deleted before '${moment(deleteUpToDate).format('DD/MM/YYYY h:mm A')}'` }); } else { - await Logging.logError({ + Logging.beError()?.log({ tenantID: tenant.id, action: ServerAction.LOGS_CLEANUP, module: MODULE_NAME, method: 'deleteLogs', @@ -63,7 +63,7 @@ export default class LoggingDatabaseTableCleanupTask extends TenantSchedulerTask }); } } catch (error) { - await Logging.logActionExceptionMessage(tenant.id, ServerAction.LOGS_CLEANUP, error); + Logging.logActionExceptionMessage(tenant.id, ServerAction.LOGS_CLEANUP, error); } finally { await LockingManager.release(logsCleanUpLock); } @@ -90,14 +90,14 @@ export default class LoggingDatabaseTableCleanupTask extends TenantSchedulerTask // Delete Logs const result = await PerformanceStorage.deletePerformanceRecords({ deleteUpToDate }); if (result.acknowledged) { - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: tenant.id, action: ServerAction.PERFORMANCES_CLEANUP, module: MODULE_NAME, method: 'deletePerformanceRecords', message: `${result.deletedCount} Performance Record(s) have been deleted before '${moment(deleteUpToDate).format('DD/MM/YYYY h:mm A')}'` }); } else { - await Logging.logError({ + Logging.beError()?.log({ tenantID: tenant.id, action: ServerAction.PERFORMANCES_CLEANUP, module: MODULE_NAME, method: 'deletePerformanceRecords', @@ -106,7 +106,7 @@ export default class LoggingDatabaseTableCleanupTask extends TenantSchedulerTask }); } } catch (error) { - await Logging.logActionExceptionMessage(tenant.id, ServerAction.PERFORMANCES_CLEANUP, error); + Logging.logActionExceptionMessage(tenant.id, ServerAction.PERFORMANCES_CLEANUP, error); } finally { // Release the lock await LockingManager.release(performanceCleanUpLock); diff --git a/src/scheduler/tasks/SynchronizeCarsTask.ts b/src/scheduler/tasks/SynchronizeCarsTask.ts index a57c0b5ac8..df7a8ebce4 100644 --- a/src/scheduler/tasks/SynchronizeCarsTask.ts +++ b/src/scheduler/tasks/SynchronizeCarsTask.ts @@ -30,7 +30,7 @@ export default class SynchronizeCarsTask extends SchedulerTask { } } catch (error) { // Log error - await Logging.logActionExceptionMessage(Constants.DEFAULT_TENANT_ID, ServerAction.SYNCHRONIZE_CAR_CATALOGS, error); + Logging.logActionExceptionMessage(Constants.DEFAULT_TENANT_ID, ServerAction.SYNCHRONIZE_CAR_CATALOGS, error); } finally { // Release the lock await LockingManager.release(syncCarCatalogLock); diff --git a/src/scheduler/tasks/SynchronizeRefundTransactionsTask.ts b/src/scheduler/tasks/SynchronizeRefundTransactionsTask.ts index 98e49ed8ab..7847be165b 100644 --- a/src/scheduler/tasks/SynchronizeRefundTransactionsTask.ts +++ b/src/scheduler/tasks/SynchronizeRefundTransactionsTask.ts @@ -17,7 +17,7 @@ const MODULE_NAME = 'SynchronizeRefundTransactionsTask'; export default class SynchronizeRefundTransactionsTask extends TenantSchedulerTask { public async processTenant(tenant: Tenant, config: TaskConfig): Promise { if (!Utils.isTenantComponentActive(tenant, TenantComponents.REFUND)) { - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: tenant.id, action: ServerAction.SYNCHRONIZE_REFUND, module: MODULE_NAME, method: 'run', @@ -28,7 +28,7 @@ export default class SynchronizeRefundTransactionsTask extends TenantSchedulerTa // Get Concur Settings const refundConnector = await RefundFactory.getRefundImpl(tenant); if (!refundConnector) { - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: tenant.id, action: ServerAction.SYNCHRONIZE_REFUND, module: MODULE_NAME, method: 'run', @@ -46,7 +46,7 @@ export default class SynchronizeRefundTransactionsTask extends TenantSchedulerTa { ...Constants.DB_PARAMS_MAX_LIMIT, sort: { 'userID': 1, 'refundData.reportId': 1 } }); if (!Utils.isEmptyArray(transactions.result)) { // Process them - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: tenant.id, action: ServerAction.SYNCHRONIZE_REFUND, module: MODULE_NAME, method: 'processTenant', @@ -74,11 +74,11 @@ export default class SynchronizeRefundTransactionsTask extends TenantSchedulerTa } } catch (error) { actionsDone.error++; - await Logging.logActionExceptionMessage(tenant.id, ServerAction.SYNCHRONIZE_REFUND, error); + Logging.logActionExceptionMessage(tenant.id, ServerAction.SYNCHRONIZE_REFUND, error); } } // Log result - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: tenant.id, action: ServerAction.SYNCHRONIZE_REFUND, module: MODULE_NAME, method: 'processTenant', @@ -86,7 +86,7 @@ export default class SynchronizeRefundTransactionsTask extends TenantSchedulerTa }); } else { // Process them - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: tenant.id, action: ServerAction.SYNCHRONIZE_REFUND, module: MODULE_NAME, method: 'processTenant', @@ -95,7 +95,7 @@ export default class SynchronizeRefundTransactionsTask extends TenantSchedulerTa } } catch (error) { // Log error - await Logging.logActionExceptionMessage(tenant.id, ServerAction.SYNCHRONIZE_REFUND, error); + Logging.logActionExceptionMessage(tenant.id, ServerAction.SYNCHRONIZE_REFUND, error); } finally { // Release the lock await LockingManager.release(refundLock); diff --git a/src/scheduler/tasks/ocpi/OCPICheckCdrsTask.ts b/src/scheduler/tasks/ocpi/OCPICheckCdrsTask.ts index 76027bc2eb..dae33530e9 100644 --- a/src/scheduler/tasks/ocpi/OCPICheckCdrsTask.ts +++ b/src/scheduler/tasks/ocpi/OCPICheckCdrsTask.ts @@ -29,7 +29,7 @@ export default class OCPICheckCdrsTask extends TenantSchedulerTask { } } catch (error) { // Log error - await Logging.logActionExceptionMessage(tenant.id, ServerAction.OCPI_CPO_CHECK_CDRS, error); + Logging.logActionExceptionMessage(tenant.id, ServerAction.OCPI_CPO_CHECK_CDRS, error); } } @@ -40,7 +40,7 @@ export default class OCPICheckCdrsTask extends TenantSchedulerTask { try { // Check if OCPI endpoint is registered if (ocpiEndpoint.status !== OCPIRegistrationStatus.REGISTERED) { - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: tenant.id, module: MODULE_NAME, method: 'processOCPIEndpoint', action: ServerAction.OCPI_CPO_CHECK_CDRS, @@ -49,7 +49,7 @@ export default class OCPICheckCdrsTask extends TenantSchedulerTask { return; } if (!ocpiEndpoint.backgroundPatchJob) { - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: tenant.id, module: MODULE_NAME, method: 'processOCPIEndpoint', action: ServerAction.OCPI_CPO_CHECK_CDRS, @@ -57,7 +57,7 @@ export default class OCPICheckCdrsTask extends TenantSchedulerTask { }); return; } - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: tenant.id, module: MODULE_NAME, method: 'processOCPIEndpoint', action: ServerAction.OCPI_CPO_CHECK_CDRS, @@ -67,7 +67,7 @@ export default class OCPICheckCdrsTask extends TenantSchedulerTask { const ocpiClient = await OCPIClientFactory.getCpoOcpiClient(tenant, ocpiEndpoint); // Check CDRs const result = await ocpiClient.checkCdrs(); - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: tenant.id, module: MODULE_NAME, method: 'processOCPIEndpoint', action: ServerAction.OCPI_CPO_CHECK_CDRS, @@ -75,7 +75,7 @@ export default class OCPICheckCdrsTask extends TenantSchedulerTask { detailedMessages: { result } }); } catch (error) { - await Logging.logActionExceptionMessage(tenant.id, ServerAction.OCPI_CPO_CHECK_CDRS, error); + Logging.logActionExceptionMessage(tenant.id, ServerAction.OCPI_CPO_CHECK_CDRS, error); } finally { await LockingManager.release(ocpiLock); } diff --git a/src/scheduler/tasks/ocpi/OCPICheckLocationsTask.ts b/src/scheduler/tasks/ocpi/OCPICheckLocationsTask.ts index f9f97eb453..bf30916b88 100644 --- a/src/scheduler/tasks/ocpi/OCPICheckLocationsTask.ts +++ b/src/scheduler/tasks/ocpi/OCPICheckLocationsTask.ts @@ -29,7 +29,7 @@ export default class OCPICheckLocationsTask extends TenantSchedulerTask { } } catch (error) { // Log error - await Logging.logActionExceptionMessage(tenant.id, ServerAction.OCPI_CPO_CHECK_SESSIONS, error); + Logging.logActionExceptionMessage(tenant.id, ServerAction.OCPI_CPO_CHECK_SESSIONS, error); } } @@ -40,7 +40,7 @@ export default class OCPICheckLocationsTask extends TenantSchedulerTask { try { // Check if OCPI endpoint is registered if (ocpiEndpoint.status !== OCPIRegistrationStatus.REGISTERED) { - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: tenant.id, module: MODULE_NAME, method: 'processOCPIEndpoint', action: ServerAction.OCPI_CPO_CHECK_SESSIONS, @@ -49,7 +49,7 @@ export default class OCPICheckLocationsTask extends TenantSchedulerTask { return; } if (!ocpiEndpoint.backgroundPatchJob) { - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: tenant.id, module: MODULE_NAME, method: 'processOCPIEndpoint', action: ServerAction.OCPI_CPO_CHECK_SESSIONS, @@ -57,7 +57,7 @@ export default class OCPICheckLocationsTask extends TenantSchedulerTask { }); return; } - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: tenant.id, module: MODULE_NAME, method: 'processOCPIEndpoint', action: ServerAction.OCPI_CPO_CHECK_SESSIONS, @@ -67,7 +67,7 @@ export default class OCPICheckLocationsTask extends TenantSchedulerTask { const ocpiClient = await OCPIClientFactory.getCpoOcpiClient(tenant, ocpiEndpoint); // Check Locations const result = await ocpiClient.checkLocations(); - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: tenant.id, module: MODULE_NAME, method: 'processOCPIEndpoint', action: ServerAction.OCPI_CPO_CHECK_SESSIONS, @@ -75,7 +75,7 @@ export default class OCPICheckLocationsTask extends TenantSchedulerTask { detailedMessages: { result } }); } catch (error) { - await Logging.logActionExceptionMessage(tenant.id, ServerAction.OCPI_CPO_CHECK_LOCATIONS, error); + Logging.logActionExceptionMessage(tenant.id, ServerAction.OCPI_CPO_CHECK_LOCATIONS, error); } finally { await LockingManager.release(ocpiLock); } diff --git a/src/scheduler/tasks/ocpi/OCPICheckSessionsTask.ts b/src/scheduler/tasks/ocpi/OCPICheckSessionsTask.ts index 1cc32f4389..944ef33f63 100644 --- a/src/scheduler/tasks/ocpi/OCPICheckSessionsTask.ts +++ b/src/scheduler/tasks/ocpi/OCPICheckSessionsTask.ts @@ -29,7 +29,7 @@ export default class OCPICheckSessionsTask extends TenantSchedulerTask { } } catch (error) { // Log error - await Logging.logActionExceptionMessage(tenant.id, ServerAction.OCPI_CPO_CHECK_SESSIONS, error); + Logging.logActionExceptionMessage(tenant.id, ServerAction.OCPI_CPO_CHECK_SESSIONS, error); } } @@ -40,7 +40,7 @@ export default class OCPICheckSessionsTask extends TenantSchedulerTask { try { // Check if OCPI endpoint is registered if (ocpiEndpoint.status !== OCPIRegistrationStatus.REGISTERED) { - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: tenant.id, module: MODULE_NAME, method: 'processOCPIEndpoint', action: ServerAction.OCPI_CPO_CHECK_SESSIONS, @@ -49,7 +49,7 @@ export default class OCPICheckSessionsTask extends TenantSchedulerTask { return; } if (!ocpiEndpoint.backgroundPatchJob) { - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: tenant.id, module: MODULE_NAME, method: 'processOCPIEndpoint', action: ServerAction.OCPI_CPO_CHECK_SESSIONS, @@ -57,7 +57,7 @@ export default class OCPICheckSessionsTask extends TenantSchedulerTask { }); return; } - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: tenant.id, module: MODULE_NAME, method: 'processOCPIEndpoint', action: ServerAction.OCPI_CPO_CHECK_SESSIONS, @@ -67,7 +67,7 @@ export default class OCPICheckSessionsTask extends TenantSchedulerTask { const ocpiClient = await OCPIClientFactory.getCpoOcpiClient(tenant, ocpiEndpoint); // Check Sessions const result = await ocpiClient.checkSessions(); - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: tenant.id, module: MODULE_NAME, method: 'processOCPIEndpoint', action: ServerAction.OCPI_CPO_CHECK_SESSIONS, @@ -75,7 +75,7 @@ export default class OCPICheckSessionsTask extends TenantSchedulerTask { detailedMessages: { result } }); } catch (error) { - await Logging.logActionExceptionMessage(tenant.id, ServerAction.OCPI_CPO_CHECK_SESSIONS, error); + Logging.logActionExceptionMessage(tenant.id, ServerAction.OCPI_CPO_CHECK_SESSIONS, error); } finally { await LockingManager.release(ocpiLock); } diff --git a/src/scheduler/tasks/ocpi/OCPIPullCdrsTask.ts b/src/scheduler/tasks/ocpi/OCPIPullCdrsTask.ts index 26aafb2278..a8cacb6987 100644 --- a/src/scheduler/tasks/ocpi/OCPIPullCdrsTask.ts +++ b/src/scheduler/tasks/ocpi/OCPIPullCdrsTask.ts @@ -29,7 +29,7 @@ export default class OCPIPullCdrsTask extends TenantSchedulerTask { } } catch (error) { // Log error - await Logging.logActionExceptionMessage(tenant.id, ServerAction.OCPI_EMSP_GET_CDRS, error); + Logging.logActionExceptionMessage(tenant.id, ServerAction.OCPI_EMSP_GET_CDRS, error); } } @@ -41,7 +41,7 @@ export default class OCPIPullCdrsTask extends TenantSchedulerTask { try { // Check if OCPI endpoint is registered if (ocpiEndpoint.status !== OCPIRegistrationStatus.REGISTERED) { - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: tenant.id, action: ServerAction.OCPI_EMSP_GET_CDRS, module: MODULE_NAME, method: 'processOCPIEndpoint', @@ -50,7 +50,7 @@ export default class OCPIPullCdrsTask extends TenantSchedulerTask { return; } if (!ocpiEndpoint.backgroundPatchJob) { - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: tenant.id, action: ServerAction.OCPI_EMSP_GET_CDRS, module: MODULE_NAME, method: 'processOCPIEndpoint', @@ -58,7 +58,7 @@ export default class OCPIPullCdrsTask extends TenantSchedulerTask { }); return; } - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: tenant.id, action: ServerAction.OCPI_EMSP_GET_CDRS, module: MODULE_NAME, method: 'processOCPIEndpointatch', @@ -68,7 +68,7 @@ export default class OCPIPullCdrsTask extends TenantSchedulerTask { const ocpiClient = await OCPIClientFactory.getEmspOcpiClient(tenant, ocpiEndpoint); // Pull CDRs const result = await ocpiClient.pullCdrs(true); - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: tenant.id, action: ServerAction.OCPI_EMSP_GET_CDRS, module: MODULE_NAME, method: 'processOCPIEndpoint', @@ -76,7 +76,7 @@ export default class OCPIPullCdrsTask extends TenantSchedulerTask { detailedMessages: { result } }); } catch (error) { - await Logging.logActionExceptionMessage(tenant.id, ServerAction.OCPI_EMSP_GET_CDRS, error); + Logging.logActionExceptionMessage(tenant.id, ServerAction.OCPI_EMSP_GET_CDRS, error); } finally { await LockingManager.release(ocpiLock); } diff --git a/src/scheduler/tasks/ocpi/OCPIPullLocationsTask.ts b/src/scheduler/tasks/ocpi/OCPIPullLocationsTask.ts index fad3084a51..72ef8cb1ab 100644 --- a/src/scheduler/tasks/ocpi/OCPIPullLocationsTask.ts +++ b/src/scheduler/tasks/ocpi/OCPIPullLocationsTask.ts @@ -29,7 +29,7 @@ export default class OCPIPullLocationsTask extends TenantSchedulerTask { } } catch (error) { // Log error - await Logging.logActionExceptionMessage(tenant.id, ServerAction.OCPI_EMSP_GET_LOCATIONS, error); + Logging.logActionExceptionMessage(tenant.id, ServerAction.OCPI_EMSP_GET_LOCATIONS, error); } } @@ -40,7 +40,7 @@ export default class OCPIPullLocationsTask extends TenantSchedulerTask { try { // Check if OCPI endpoint is registered if (ocpiEndpoint.status !== OCPIRegistrationStatus.REGISTERED) { - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: tenant.id, action: ServerAction.OCPI_EMSP_GET_LOCATIONS, module: MODULE_NAME, method: 'processOCPIEndpoint', @@ -49,7 +49,7 @@ export default class OCPIPullLocationsTask extends TenantSchedulerTask { return; } if (!ocpiEndpoint.backgroundPatchJob) { - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: tenant.id, action: ServerAction.OCPI_EMSP_GET_LOCATIONS, module: MODULE_NAME, method: 'processOCPIEndpoint', @@ -57,7 +57,7 @@ export default class OCPIPullLocationsTask extends TenantSchedulerTask { }); return; } - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: tenant.id, action: ServerAction.OCPI_EMSP_GET_LOCATIONS, module: MODULE_NAME, method: 'processOCPIEndpoint', @@ -67,7 +67,7 @@ export default class OCPIPullLocationsTask extends TenantSchedulerTask { const ocpiClient = await OCPIClientFactory.getEmspOcpiClient(tenant, ocpiEndpoint); // Pull Locations const result = await ocpiClient.pullLocations(config.partial); - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: tenant.id, action: ServerAction.OCPI_EMSP_GET_LOCATIONS, module: MODULE_NAME, method: 'processOCPIEndpoint', @@ -75,7 +75,7 @@ export default class OCPIPullLocationsTask extends TenantSchedulerTask { detailedMessages: { result } }); } catch (error) { - await Logging.logActionExceptionMessage(tenant.id, ServerAction.OCPI_EMSP_GET_LOCATIONS, error); + Logging.logActionExceptionMessage(tenant.id, ServerAction.OCPI_EMSP_GET_LOCATIONS, error); } finally { await LockingManager.release(ocpiLock); } diff --git a/src/scheduler/tasks/ocpi/OCPIPullSessionsTask.ts b/src/scheduler/tasks/ocpi/OCPIPullSessionsTask.ts index d0e1ddfaa9..03c7772858 100644 --- a/src/scheduler/tasks/ocpi/OCPIPullSessionsTask.ts +++ b/src/scheduler/tasks/ocpi/OCPIPullSessionsTask.ts @@ -29,7 +29,7 @@ export default class OCPIPullSessionsTask extends TenantSchedulerTask { } } catch (error) { // Log error - await Logging.logActionExceptionMessage(tenant.id, ServerAction.OCPI_EMSP_GET_SESSION, error); + Logging.logActionExceptionMessage(tenant.id, ServerAction.OCPI_EMSP_GET_SESSION, error); } } @@ -40,7 +40,7 @@ export default class OCPIPullSessionsTask extends TenantSchedulerTask { try { // Check if OCPI endpoint is registered if (ocpiEndpoint.status !== OCPIRegistrationStatus.REGISTERED) { - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: tenant.id, module: MODULE_NAME, method: 'processOCPIEndpoint', action: ServerAction.OCPI_EMSP_GET_SESSION, @@ -49,7 +49,7 @@ export default class OCPIPullSessionsTask extends TenantSchedulerTask { return; } if (!ocpiEndpoint.backgroundPatchJob) { - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: tenant.id, module: MODULE_NAME, method: 'processOCPIEndpoint', action: ServerAction.OCPI_EMSP_GET_SESSION, @@ -57,7 +57,7 @@ export default class OCPIPullSessionsTask extends TenantSchedulerTask { }); return; } - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: tenant.id, module: MODULE_NAME, method: 'processOCPIEndpoint', action: ServerAction.OCPI_EMSP_GET_SESSION, @@ -67,7 +67,7 @@ export default class OCPIPullSessionsTask extends TenantSchedulerTask { const ocpiClient = await OCPIClientFactory.getEmspOcpiClient(tenant, ocpiEndpoint); // Pull Sessions const result = await ocpiClient.pullSessions(true); - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: tenant.id, module: MODULE_NAME, method: 'processOCPIEndpoint', action: ServerAction.OCPI_EMSP_GET_SESSION, @@ -75,7 +75,7 @@ export default class OCPIPullSessionsTask extends TenantSchedulerTask { detailedMessages: { result } }); } catch (error) { - await Logging.logActionExceptionMessage(tenant.id, ServerAction.OCPI_EMSP_GET_SESSION, error); + Logging.logActionExceptionMessage(tenant.id, ServerAction.OCPI_EMSP_GET_SESSION, error); } finally { await LockingManager.release(ocpiLock); } diff --git a/src/scheduler/tasks/ocpi/OCPIPullTokensTask.ts b/src/scheduler/tasks/ocpi/OCPIPullTokensTask.ts index a453172eee..04076b174e 100644 --- a/src/scheduler/tasks/ocpi/OCPIPullTokensTask.ts +++ b/src/scheduler/tasks/ocpi/OCPIPullTokensTask.ts @@ -29,7 +29,7 @@ export default class OCPIPullTokensTask extends TenantSchedulerTask { } } catch (error) { // Log error - await Logging.logActionExceptionMessage(tenant.id, ServerAction.OCPI_CPO_GET_TOKENS, error); + Logging.logActionExceptionMessage(tenant.id, ServerAction.OCPI_CPO_GET_TOKENS, error); } } @@ -40,7 +40,7 @@ export default class OCPIPullTokensTask extends TenantSchedulerTask { try { // Check if OCPI endpoint is registered if (ocpiEndpoint.status !== OCPIRegistrationStatus.REGISTERED) { - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: tenant.id, module: MODULE_NAME, method: 'processOCPIEndpoint', action: ServerAction.OCPI_CPO_GET_TOKENS, @@ -49,7 +49,7 @@ export default class OCPIPullTokensTask extends TenantSchedulerTask { return; } if (!ocpiEndpoint.backgroundPatchJob) { - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: tenant.id, module: MODULE_NAME, method: 'processOCPIEndpoint', action: ServerAction.OCPI_CPO_GET_TOKENS, @@ -57,7 +57,7 @@ export default class OCPIPullTokensTask extends TenantSchedulerTask { }); return; } - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: tenant.id, module: MODULE_NAME, method: 'processOCPIEndpoint', action: ServerAction.OCPI_CPO_GET_TOKENS, @@ -67,7 +67,7 @@ export default class OCPIPullTokensTask extends TenantSchedulerTask { const ocpiClient = await OCPIClientFactory.getCpoOcpiClient(tenant, ocpiEndpoint); // Pull Tokens const result = await ocpiClient.pullTokens(config.partial); - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: tenant.id, module: MODULE_NAME, method: 'processOCPIEndpoint', action: ServerAction.OCPI_CPO_GET_TOKENS, @@ -75,7 +75,7 @@ export default class OCPIPullTokensTask extends TenantSchedulerTask { detailedMessages: { result } }); } catch (error) { - await Logging.logActionExceptionMessage(tenant.id, ServerAction.OCPI_CPO_GET_TOKENS, error); + Logging.logActionExceptionMessage(tenant.id, ServerAction.OCPI_CPO_GET_TOKENS, error); } finally { await LockingManager.release(ocpiLock); } diff --git a/src/scheduler/tasks/ocpi/OCPIPushCdrsTask.ts b/src/scheduler/tasks/ocpi/OCPIPushCdrsTask.ts index 7c2906f901..42ac280091 100644 --- a/src/scheduler/tasks/ocpi/OCPIPushCdrsTask.ts +++ b/src/scheduler/tasks/ocpi/OCPIPushCdrsTask.ts @@ -41,7 +41,7 @@ export default class OCPIPushCdrsTask extends TenantSchedulerTask { } ]).toArray(); if (!Utils.isEmptyArray(transactionsMDB)) { - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: tenant.id, action: ServerAction.OCPI_CPO_PUSH_CDRS, module: MODULE_NAME, method: 'processTenant', @@ -55,7 +55,7 @@ export default class OCPIPushCdrsTask extends TenantSchedulerTask { // Get Transaction const transaction = await TransactionStorage.getTransaction(tenant, transactionMDB._id, { withUser: true }); if (!transaction) { - await Logging.logError({ + Logging.beError()?.log({ tenantID: tenant.id, action: ServerAction.OCPI_CPO_PUSH_CDRS, module: MODULE_NAME, method: 'processTenant', @@ -64,7 +64,7 @@ export default class OCPIPushCdrsTask extends TenantSchedulerTask { continue; } if (transaction.ocpiData?.cdr) { - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: tenant.id, action: ServerAction.OCPI_CPO_PUSH_CDRS, module: MODULE_NAME, method: 'processTenant', @@ -75,7 +75,7 @@ export default class OCPIPushCdrsTask extends TenantSchedulerTask { // Get Charging Station const chargingStation = await ChargingStationStorage.getChargingStation(tenant, transaction.chargeBoxID, { withSiteArea: true }); if (!chargingStation) { - await Logging.logError({ + Logging.beError()?.log({ tenantID: tenant.id, action: ServerAction.OCPI_CPO_PUSH_CDRS, module: MODULE_NAME, method: 'processTenant', @@ -86,7 +86,7 @@ export default class OCPIPushCdrsTask extends TenantSchedulerTask { // Get Tag const tag = await TagStorage.getTag(tenant, transaction.tagID); if (!tag) { - await Logging.logError({ + Logging.beError()?.log({ tenantID: tenant.id, action: ServerAction.OCPI_CPO_PUSH_CDRS, module: MODULE_NAME, method: 'processTenant', @@ -98,7 +98,7 @@ export default class OCPIPushCdrsTask extends TenantSchedulerTask { await OCPIFacade.processEndTransaction(tenant, transaction, chargingStation, chargingStation.siteArea, transaction.user, ServerAction.OCPI_CPO_PUSH_CDRS); // Save await TransactionStorage.saveTransactionOcpiData(tenant, transaction.id, transaction.ocpiData); - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: tenant.id, action: ServerAction.OCPI_CPO_PUSH_CDRS, actionOnUser: (transaction.user ? transaction.user : null), @@ -107,7 +107,7 @@ export default class OCPIPushCdrsTask extends TenantSchedulerTask { detailedMessages: { cdr: transaction.ocpiData.cdr } }); } catch (error) { - await Logging.logError({ + Logging.beError()?.log({ tenantID: tenant.id, action: ServerAction.OCPI_CPO_PUSH_CDRS, module: MODULE_NAME, method: 'processTenant', @@ -126,7 +126,7 @@ export default class OCPIPushCdrsTask extends TenantSchedulerTask { } } } catch (error) { - await Logging.logActionExceptionMessage(tenant.id, ServerAction.OCPI_CPO_PUSH_CDRS, error); + Logging.logActionExceptionMessage(tenant.id, ServerAction.OCPI_CPO_PUSH_CDRS, error); } } } diff --git a/src/scheduler/tasks/ocpi/OCPIPushEVSEStatusesTask.ts b/src/scheduler/tasks/ocpi/OCPIPushEVSEStatusesTask.ts index 6e8fb59dc3..3b2183b1d2 100644 --- a/src/scheduler/tasks/ocpi/OCPIPushEVSEStatusesTask.ts +++ b/src/scheduler/tasks/ocpi/OCPIPushEVSEStatusesTask.ts @@ -29,7 +29,7 @@ export default class OCPIPushEVSEStatusesTask extends TenantSchedulerTask { } } catch (error) { // Log error - await Logging.logActionExceptionMessage(tenant.id, ServerAction.OCPI_CPO_PUSH_EVSE_STATUSES, error); + Logging.logActionExceptionMessage(tenant.id, ServerAction.OCPI_CPO_PUSH_EVSE_STATUSES, error); } } @@ -40,7 +40,7 @@ export default class OCPIPushEVSEStatusesTask extends TenantSchedulerTask { try { // Check if OCPI endpoint is registered if (ocpiEndpoint.status !== OCPIRegistrationStatus.REGISTERED) { - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: tenant.id, module: MODULE_NAME, method: 'processOCPIEndpoint', action: ServerAction.OCPI_CPO_PUSH_EVSE_STATUSES, @@ -49,7 +49,7 @@ export default class OCPIPushEVSEStatusesTask extends TenantSchedulerTask { return; } if (!ocpiEndpoint.backgroundPatchJob) { - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: tenant.id, module: MODULE_NAME, method: 'processOCPIEndpoint', action: ServerAction.OCPI_CPO_PUSH_EVSE_STATUSES, @@ -57,7 +57,7 @@ export default class OCPIPushEVSEStatusesTask extends TenantSchedulerTask { }); return; } - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: tenant.id, module: MODULE_NAME, method: 'processOCPIEndpoint', action: ServerAction.OCPI_CPO_PUSH_EVSE_STATUSES, @@ -67,14 +67,14 @@ export default class OCPIPushEVSEStatusesTask extends TenantSchedulerTask { const ocpiClient = await OCPIClientFactory.getCpoOcpiClient(tenant, ocpiEndpoint); // Push EVSE statuses const sendResult = await ocpiClient.pushChargingStationStatuses(config.partial); - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: tenant.id, module: MODULE_NAME, method: 'processOCPIEndpoint', action: ServerAction.OCPI_CPO_PUSH_EVSE_STATUSES, message: `Push of Locations process for endpoint '${ocpiEndpoint.name}' is completed (Success: ${sendResult.success} / Failure: ${sendResult.failure})` }); } catch (error) { - await Logging.logActionExceptionMessage(tenant.id, ServerAction.OCPI_CPO_PUSH_EVSE_STATUSES, error); + Logging.logActionExceptionMessage(tenant.id, ServerAction.OCPI_CPO_PUSH_EVSE_STATUSES, error); } finally { await LockingManager.release(ocpiLock); } diff --git a/src/scheduler/tasks/ocpi/OCPIPushTokensTask.ts b/src/scheduler/tasks/ocpi/OCPIPushTokensTask.ts index 54a864ebaa..d4b2f1f2b9 100644 --- a/src/scheduler/tasks/ocpi/OCPIPushTokensTask.ts +++ b/src/scheduler/tasks/ocpi/OCPIPushTokensTask.ts @@ -29,7 +29,7 @@ export default class OCPIPushTokensTask extends TenantSchedulerTask { } } catch (error) { // Log error - await Logging.logActionExceptionMessage(tenant.id, ServerAction.OCPI_EMSP_UPDATE_TOKENS, error); + Logging.logActionExceptionMessage(tenant.id, ServerAction.OCPI_EMSP_UPDATE_TOKENS, error); } } @@ -40,7 +40,7 @@ export default class OCPIPushTokensTask extends TenantSchedulerTask { try { // Check if OCPI endpoint is registered if (ocpiEndpoint.status !== OCPIRegistrationStatus.REGISTERED) { - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: tenant.id, action: ServerAction.OCPI_EMSP_UPDATE_TOKENS, module: MODULE_NAME, method: 'processOCPIEndpoint', @@ -49,7 +49,7 @@ export default class OCPIPushTokensTask extends TenantSchedulerTask { return; } if (!ocpiEndpoint.backgroundPatchJob) { - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: tenant.id, action: ServerAction.OCPI_EMSP_UPDATE_TOKENS, module: MODULE_NAME, method: 'processOCPIEndpoint', @@ -57,7 +57,7 @@ export default class OCPIPushTokensTask extends TenantSchedulerTask { }); return; } - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: tenant.id, action: ServerAction.OCPI_EMSP_UPDATE_TOKENS, module: MODULE_NAME, method: 'processOCPIEndpoint', @@ -67,7 +67,7 @@ export default class OCPIPushTokensTask extends TenantSchedulerTask { const ocpiClient = await OCPIClientFactory.getEmspOcpiClient(tenant, ocpiEndpoint); // Push Tokens const result = await ocpiClient.pushTokens(config.partial); - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: tenant.id, action: ServerAction.OCPI_EMSP_UPDATE_TOKENS, module: MODULE_NAME, method: 'processOCPIEndpoint', @@ -75,7 +75,7 @@ export default class OCPIPushTokensTask extends TenantSchedulerTask { detailedMessages: { result } }); } catch (error) { - await Logging.logActionExceptionMessage(tenant.id, ServerAction.OCPI_EMSP_UPDATE_TOKENS, error); + Logging.logActionExceptionMessage(tenant.id, ServerAction.OCPI_EMSP_UPDATE_TOKENS, error); } finally { await LockingManager.release(ocpiLock); } diff --git a/src/scheduler/tasks/oicp/OICPPushEvseDataTask.ts b/src/scheduler/tasks/oicp/OICPPushEvseDataTask.ts index 0ebec59080..15b9a21932 100644 --- a/src/scheduler/tasks/oicp/OICPPushEvseDataTask.ts +++ b/src/scheduler/tasks/oicp/OICPPushEvseDataTask.ts @@ -29,7 +29,7 @@ export default class OICPPushEvseDataTask extends TenantSchedulerTask { } } catch (error) { // Log error - await Logging.logActionExceptionMessage(tenant.id, ServerAction.OICP_PUSH_EVSE_DATA, error); + Logging.logActionExceptionMessage(tenant.id, ServerAction.OICP_PUSH_EVSE_DATA, error); } } @@ -40,7 +40,7 @@ export default class OICPPushEvseDataTask extends TenantSchedulerTask { try { // Check if OICP endpoint is registered if (oicpEndpoint.status !== OICPRegistrationStatus.REGISTERED) { - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: tenant.id, module: MODULE_NAME, method: 'processOICPEndpoint', action: ServerAction.OICP_PUSH_EVSE_DATA, @@ -49,7 +49,7 @@ export default class OICPPushEvseDataTask extends TenantSchedulerTask { return; } if (!oicpEndpoint.backgroundPatchJob) { - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: tenant.id, module: MODULE_NAME, method: 'processOICPEndpoint', action: ServerAction.OICP_PUSH_EVSE_DATA, @@ -57,7 +57,7 @@ export default class OICPPushEvseDataTask extends TenantSchedulerTask { }); return; } - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: tenant.id, module: MODULE_NAME, method: 'processOICPEndpoint', action: ServerAction.OICP_PUSH_EVSE_DATA, @@ -67,7 +67,7 @@ export default class OICPPushEvseDataTask extends TenantSchedulerTask { const oicpClient = await OICPClientFactory.getCpoOicpClient(tenant, oicpEndpoint); // Send EVSEs const sendEVSEDataResult = await oicpClient.sendEVSEs(!Utils.isUndefined(config.partial) ? config.partial : false); - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: tenant.id, module: MODULE_NAME, method: 'processOICPEndpoint', action: ServerAction.OICP_PUSH_EVSE_DATA, @@ -75,7 +75,7 @@ export default class OICPPushEvseDataTask extends TenantSchedulerTask { }); } catch (error) { // Log error - await Logging.logActionExceptionMessage(tenant.id, ServerAction.OICP_PUSH_EVSE_DATA, error); + Logging.logActionExceptionMessage(tenant.id, ServerAction.OICP_PUSH_EVSE_DATA, error); } finally { // Release the lock await LockingManager.release(oicpLock); diff --git a/src/scheduler/tasks/oicp/OICPPushEvseStatusTask.ts b/src/scheduler/tasks/oicp/OICPPushEvseStatusTask.ts index b118cad2a4..90b698fd48 100644 --- a/src/scheduler/tasks/oicp/OICPPushEvseStatusTask.ts +++ b/src/scheduler/tasks/oicp/OICPPushEvseStatusTask.ts @@ -29,7 +29,7 @@ export default class OICPPushEvseStatusTask extends TenantSchedulerTask { } } catch (error) { // Log error - await Logging.logActionExceptionMessage(tenant.id, ServerAction.OICP_PUSH_EVSE_STATUSES, error); + Logging.logActionExceptionMessage(tenant.id, ServerAction.OICP_PUSH_EVSE_STATUSES, error); } } @@ -40,7 +40,7 @@ export default class OICPPushEvseStatusTask extends TenantSchedulerTask { try { // Check if OICP endpoint is registered if (oicpEndpoint.status !== OICPRegistrationStatus.REGISTERED) { - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: tenant.id, module: MODULE_NAME, method: 'processOICPEndpoint', action: ServerAction.OICP_PUSH_EVSE_STATUSES, @@ -49,7 +49,7 @@ export default class OICPPushEvseStatusTask extends TenantSchedulerTask { return; } if (!oicpEndpoint.backgroundPatchJob) { - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: tenant.id, module: MODULE_NAME, method: 'processOICPEndpoint', action: ServerAction.OICP_PUSH_EVSE_STATUSES, @@ -57,7 +57,7 @@ export default class OICPPushEvseStatusTask extends TenantSchedulerTask { }); return; } - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: tenant.id, module: MODULE_NAME, method: 'processOICPEndpoint', action: ServerAction.OICP_PUSH_EVSE_STATUSES, @@ -67,7 +67,7 @@ export default class OICPPushEvseStatusTask extends TenantSchedulerTask { const oicpClient = await OICPClientFactory.getCpoOicpClient(tenant, oicpEndpoint); // Send EVSE statuses const sendEVSEStatusResult = await oicpClient.sendEVSEStatuses(config.partial); - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: tenant.id, module: MODULE_NAME, method: 'processOICPEndpoint', action: ServerAction.OICP_PUSH_EVSE_STATUSES, @@ -75,7 +75,7 @@ export default class OICPPushEvseStatusTask extends TenantSchedulerTask { }); } catch (error) { // Log error - await Logging.logActionExceptionMessage(tenant.id, ServerAction.OICP_PUSH_EVSE_STATUSES, error); + Logging.logActionExceptionMessage(tenant.id, ServerAction.OICP_PUSH_EVSE_STATUSES, error); } finally { // Release the lock await LockingManager.release(oicpLock); diff --git a/src/server/ExpressUtils.ts b/src/server/ExpressUtils.ts index bb5a9494f5..3ea9cf3d11 100644 --- a/src/server/ExpressUtils.ts +++ b/src/server/ExpressUtils.ts @@ -1,3 +1,4 @@ +import FeatureToggles, { Feature } from '../utils/FeatureToggles'; import express, { Application, NextFunction, Request, Response } from 'express'; import Constants from '../utils/Constants'; @@ -51,7 +52,7 @@ export default class ExpressUtils { limit: bodyLimit })); // Health Check Handling - app.get(Constants.HEALTH_CHECK_ROUTE, ExpressUtils.healthCheckService.bind(this)); + app.get(Constants.HEALTH_CHECK_ROUTE, (req: Request, res: Response, next: NextFunction) => ExpressUtils.healthCheckService(req, res, next)); // Use app.use(locale(Constants.SUPPORTED_LOCALES)); return app; @@ -62,12 +63,19 @@ export default class ExpressUtils { expressApplication.use(Logging.traceExpressError.bind(this)); } - private static async healthCheckService(req: Request, res: Response, next: NextFunction): Promise { - const pingSuccess = await global.database.ping(); - if (pingSuccess) { - res.sendStatus(StatusCodes.OK); + // eslint-disable-next-line @typescript-eslint/no-unused-vars + private static healthCheckService(req: Request, res: Response, next: NextFunction): void { + if (FeatureToggles.isFeatureActive(Feature.HEALTH_CHECK_PING_DATABASE)) { + global.database.ping().then((pingSuccess) => { + if (pingSuccess) { + res.sendStatus(StatusCodes.OK); + } else { + res.sendStatus(StatusCodes.INTERNAL_SERVER_ERROR); + } + }).catch(() => { /* Intentional */ }); } else { - res.sendStatus(StatusCodes.INTERNAL_SERVER_ERROR); + // TODO - FIND ANOTHER METRIC TO CHECK THE READINESS and LIVENESS PROBE + res.sendStatus(StatusCodes.OK); } } } diff --git a/src/server/ServerUtils.ts b/src/server/ServerUtils.ts index 62b246a69b..c4191c1d37 100644 --- a/src/server/ServerUtils.ts +++ b/src/server/ServerUtils.ts @@ -12,7 +12,7 @@ export class ServerUtils { protocol: ServerProtocol, hostname: string, port: number): Promise { const logMsg = `${serverType} Server listening on '${protocol}://${hostname}:${port}'`; // Log - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: Constants.DEFAULT_TENANT_ID, module: serverModuleName, method: methodName, action: ServerAction.STARTUP, diff --git a/src/server/ocpi/OCPIFacade.ts b/src/server/ocpi/OCPIFacade.ts index 17a958eddd..ce229de5bb 100644 --- a/src/server/ocpi/OCPIFacade.ts +++ b/src/server/ocpi/OCPIFacade.ts @@ -52,7 +52,7 @@ export default class OCPIFacade { // Update OCPI Session await ocpiClient.updateSession(transaction); } catch (error) { - await Logging.logWarning({ + Logging.beWarning()?.log({ ...LoggingHelper.getTransactionProperties(transaction), tenantID: tenant.id, action, module: MODULE_NAME, method: 'processUpdateTransaction', @@ -120,7 +120,7 @@ export default class OCPIFacade { } } } catch (error) { - await Logging.logError({ + Logging.beError()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, module: MODULE_NAME, method: 'updateConnectorStatus', diff --git a/src/server/ocpi/OCPIServer.ts b/src/server/ocpi/OCPIServer.ts index af22dbb1a5..1cf4e996b6 100644 --- a/src/server/ocpi/OCPIServer.ts +++ b/src/server/ocpi/OCPIServer.ts @@ -44,7 +44,7 @@ export default class OCPIServer { message: `Endpoint '${req.path}' not implemented`, ocpiError: OCPIStatusCode.CODE_3000_GENERIC_SERVER_ERROR }); - void Logging.logActionExceptionMessage(req.tenant?.id ?? Constants.DEFAULT_TENANT_ID, error.params?.action ?? ServerAction.OCPI_ENDPOINT, error); + Logging.logActionExceptionMessage(req.tenant?.id ?? Constants.DEFAULT_TENANT_ID, error.params?.action ?? ServerAction.OCPI_ENDPOINT, error); res.status(HTTPError.NOT_IMPLEMENTED_ERROR).json(OCPIUtils.toErrorResponse(error)); } }); @@ -135,7 +135,7 @@ export default class OCPIServer { } next(); } catch (error) { - await Logging.logActionExceptionMessage(req.tenant?.id ?? Constants.DEFAULT_TENANT_ID, error.params?.action ?? ServerAction.OCPI_ENDPOINT, error); + Logging.logActionExceptionMessage(req.tenant?.id ?? Constants.DEFAULT_TENANT_ID, error.params?.action ?? ServerAction.OCPI_ENDPOINT, error); res.status(error.params?.errorCode ?? HTTPError.GENERAL_ERROR).json(OCPIUtils.toErrorResponse(error)); } } diff --git a/src/server/ocpi/OCPIUtils.ts b/src/server/ocpi/OCPIUtils.ts index 12387bf34b..296818addf 100644 --- a/src/server/ocpi/OCPIUtils.ts +++ b/src/server/ocpi/OCPIUtils.ts @@ -239,7 +239,7 @@ export default class OCPIUtils { try { await OCPIUtils.updateCreateChargingStationWithEmspLocation(tenant, location, site, siteArea, evse, action); } catch (error) { - await Logging.logError({ + Logging.beError()?.log({ tenantID: tenant.id, action, module: MODULE_NAME, method: 'processEMSPLocationChargingStations', message: `Error while processing the EVSE UID '${evse.uid}' (ID '${evse.evse_id}') in Location '${location.name}'`, @@ -265,7 +265,7 @@ export default class OCPIUtils { // Delete Charging Station if (currentChargingStation && evse.status === OCPIEvseStatus.REMOVED) { await ChargingStationStorage.deleteChargingStation(tenant, currentChargingStation.id); - await Logging.logDebug({ + Logging.beDebug()?.log({ ...LoggingHelper.getChargingStationProperties(currentChargingStation), tenantID: tenant.id, action, module: MODULE_NAME, method: 'processEMSPLocationChargingStation', @@ -278,7 +278,7 @@ export default class OCPIUtils { currentChargingStation, evse, location, site, siteArea, action); await ChargingStationStorage.saveChargingStation(tenant, chargingStation); await ChargingStationStorage.saveChargingStationOcpiData(tenant, chargingStation.id, chargingStation.ocpiData); - await Logging.logDebug({ + Logging.beDebug()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, action, module: MODULE_NAME, method: 'processEMSPLocationChargingStation', diff --git a/src/server/ocpi/service/OCPIUtilsService.ts b/src/server/ocpi/service/OCPIUtilsService.ts index b25fe7c97d..6119dd29c4 100644 --- a/src/server/ocpi/service/OCPIUtilsService.ts +++ b/src/server/ocpi/service/OCPIUtilsService.ts @@ -321,7 +321,7 @@ export default class OCPIUtilsService { } // Check the CDR if (transaction?.ocpiData?.cdr?.id) { - await Logging.logWarning({ + Logging.beWarning()?.log({ ...LoggingHelper.getTransactionProperties(transaction), tenantID: tenant.id, actionOnUser: transaction.userID, @@ -333,7 +333,7 @@ export default class OCPIUtilsService { } // Check the Session Status if (transaction?.ocpiData?.session?.status === OCPISessionStatus.COMPLETED) { - await Logging.logWarning({ + Logging.beWarning()?.log({ ...LoggingHelper.getTransactionProperties(transaction), tenantID: tenant.id, actionOnUser: transaction.userID, @@ -445,7 +445,7 @@ export default class OCPIUtilsService { } // Session in the past if (moment(session.last_updated).isBefore(transaction.lastConsumption.timestamp)) { - await Logging.logError({ + Logging.beError()?.log({ ...LoggingHelper.getTransactionProperties(transaction), tenantID: tenant.id, actionOnUser: transaction.userID, diff --git a/src/server/ocpi/service/common/v2.1.1/CPOEMSPCredentialsService.ts b/src/server/ocpi/service/common/v2.1.1/CPOEMSPCredentialsService.ts index 7de3403615..43e7c1bc55 100644 --- a/src/server/ocpi/service/common/v2.1.1/CPOEMSPCredentialsService.ts +++ b/src/server/ocpi/service/common/v2.1.1/CPOEMSPCredentialsService.ts @@ -25,7 +25,7 @@ export default class CPOEMSPCredentialsService { token = req.headers.authorization.split(' ')[1]; } // Log body - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: tenant.id, module: MODULE_NAME, method: 'handleDeleteCredentials', action, message: 'Received OCPI unregister endpoint', @@ -52,7 +52,7 @@ export default class CPOEMSPCredentialsService { const { tenant, ocpiEndpoint } = req; // Get payload const credential = req.body as OCPICredential; - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: tenant.id, module: MODULE_NAME, method: 'handleUpdateCreateCredentials', action, message: 'Received credential object', @@ -73,7 +73,7 @@ export default class CPOEMSPCredentialsService { token = req.headers.authorization.split(' ')[1]; } // Log body - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: tenant.id, module: MODULE_NAME, method: 'handleUpdateCreateCredentials', action, message: 'Received token', @@ -86,7 +86,7 @@ export default class CPOEMSPCredentialsService { ocpiEndpoint.partyId = credential.party_id; ocpiEndpoint.businessDetails = credential.business_details; // Log updated ocpi endpoint - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: tenant.id, module: MODULE_NAME, method: 'handleUpdateCreateCredentials', action, message: 'OCPI Server found and updated with credential object', @@ -102,7 +102,7 @@ export default class CPOEMSPCredentialsService { }, }); // Log available OCPI Versions - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: tenant.id, module: MODULE_NAME, method: 'handleUpdateCreateCredentials', action, message: 'Available OCPI Versions', @@ -125,7 +125,7 @@ export default class CPOEMSPCredentialsService { ocpiEndpoint.version = version.version; ocpiEndpoint.versionUrl = version.url; // Log correct OCPI service found - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: tenant.id, module: MODULE_NAME, method: 'handleUpdateCreateCredentials', action, message: 'Correct OCPI version found', @@ -149,7 +149,7 @@ export default class CPOEMSPCredentialsService { } }); // Log available OCPI services - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: tenant.id, module: MODULE_NAME, method: 'handleUpdateCreateCredentials', action, message: 'Available OCPI services', @@ -184,7 +184,7 @@ export default class CPOEMSPCredentialsService { // Build credential object const respCredential = await OCPIUtils.buildOcpiCredentialObject(tenant, ocpiEndpoint.localToken, ocpiEndpoint.role, versionUrl); // Log available OCPI Versions - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: tenant.id, module: MODULE_NAME, method: 'handleUpdateCreateCredentials', action, message: 'Response with credential object', diff --git a/src/server/ocpi/service/cpo/v2.1.1/CPOCommandsService.ts b/src/server/ocpi/service/cpo/v2.1.1/CPOCommandsService.ts index 35e3a31544..ff911b51ea 100644 --- a/src/server/ocpi/service/cpo/v2.1.1/CPOCommandsService.ts +++ b/src/server/ocpi/service/cpo/v2.1.1/CPOCommandsService.ts @@ -92,7 +92,7 @@ export default class CPOCommandsService { localToken = await OCPIUtilsService.updateCreateTagWithEmspToken(tenant, startSession.token, localToken, emspUser, action); } if (!localToken?.active || !localToken.ocpiToken?.valid) { - await Logging.logError({ + Logging.beError()?.log({ tenantID: tenant.id, module: MODULE_NAME, method: 'remoteStartSession', action, message: `Token ID '${startSession.token.uid}' is either not active or invalid`, @@ -101,7 +101,7 @@ export default class CPOCommandsService { return CPOCommandsService.buildOCPIResponse(OCPICommandResponseType.REJECTED); } if (Utils.isNullOrUndefined(localToken.user) || localToken.user?.issuer) { - await Logging.logError({ + Logging.beError()?.log({ tenantID: tenant.id, module: MODULE_NAME, method: 'remoteStartSession', action, message: `Invalid user associated to Token ID '${startSession.token.uid}'`, @@ -113,7 +113,7 @@ export default class CPOCommandsService { const chargingStation = await ChargingStationStorage.getChargingStationByOcpiLocationEvseUid( tenant, startSession.location_id, startSession.evse_uid); if (!chargingStation) { - await Logging.logError({ + Logging.beError()?.log({ tenantID: tenant.id, module: MODULE_NAME, method: 'remoteStartSession', action, message: `Charging Station with EVSE ID '${startSession.evse_uid}' and Location ID '${startSession.location_id}' does not exist`, @@ -125,7 +125,7 @@ export default class CPOCommandsService { const connectorID = Utils.convertToInt(OCPIUtils.getConnectorIDFromEvseID(startSession.evse_uid)); const connector = Utils.getConnectorFromID(chargingStation, connectorID); if (!connector) { - await Logging.logError({ + Logging.beError()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, module: MODULE_NAME, method: 'remoteStartSession', action, @@ -135,7 +135,7 @@ export default class CPOCommandsService { return CPOCommandsService.buildOCPIResponse(OCPICommandResponseType.REJECTED); } if (!chargingStation.issuer || !chargingStation.public) { - await Logging.logError({ + Logging.beError()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, module: MODULE_NAME, method: 'remoteStartSession', action, @@ -146,7 +146,7 @@ export default class CPOCommandsService { } if (connector.status !== ChargePointStatus.AVAILABLE && connector.status !== ChargePointStatus.PREPARING) { - await Logging.logError({ + Logging.beError()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, module: MODULE_NAME, method: 'remoteStartSession', action, @@ -162,7 +162,7 @@ export default class CPOCommandsService { (authorization) => authorization.connectorId === connector.connectorId); if (existingAuthorization) { if (OCPIUtils.isAuthorizationValid(existingAuthorization.timestamp)) { - await Logging.logError({ + Logging.beError()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, module: MODULE_NAME, method: 'remoteStartSession', action, @@ -203,7 +203,7 @@ export default class CPOCommandsService { } const transaction = await TransactionStorage.getOCPITransactionBySessionID(tenant, stopSession.session_id); if (!transaction) { - await Logging.logError({ + Logging.beError()?.log({ tenantID: tenant.id, module: MODULE_NAME, method: 'remoteStopSession', action, message: `Transaction with Session ID '${stopSession.session_id}' does not exists`, @@ -212,7 +212,7 @@ export default class CPOCommandsService { return CPOCommandsService.buildOCPIResponse(OCPICommandResponseType.REJECTED); } if (!transaction.issuer) { - await Logging.logError({ + Logging.beError()?.log({ ...LoggingHelper.getTransactionProperties(transaction), tenantID: tenant.id, module: MODULE_NAME, method: 'remoteStopSession', action, @@ -222,7 +222,7 @@ export default class CPOCommandsService { return CPOCommandsService.buildOCPIResponse(OCPICommandResponseType.REJECTED); } if (transaction.stop) { - await Logging.logError({ + Logging.beError()?.log({ ...LoggingHelper.getTransactionProperties(transaction), tenantID: tenant.id, module: MODULE_NAME, method: 'remoteStopSession', action, @@ -233,7 +233,7 @@ export default class CPOCommandsService { } const chargingStation = await ChargingStationStorage.getChargingStation(tenant, transaction.chargeBoxID); if (!chargingStation) { - await Logging.logError({ + Logging.beError()?.log({ ...LoggingHelper.getTransactionProperties(transaction), tenantID: tenant.id, module: MODULE_NAME, method: 'remoteStopSession', action, @@ -278,7 +278,7 @@ export default class CPOCommandsService { try { const chargingStationClient = await ChargingStationClientFactory.getChargingStationClient(tenant, chargingStation); if (!chargingStationClient) { - await Logging.logError({ + Logging.beError()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, module: MODULE_NAME, method: 'remoteStartTransaction', action, @@ -296,7 +296,7 @@ export default class CPOCommandsService { await CPOCommandsService.sendCommandResponse(tenant, action, startSession.response_url, OCPICommandResponseType.REJECTED, ocpiEndpoint); } } catch (error) { - await Logging.logError({ + Logging.beError()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, module: MODULE_NAME, method: 'remoteStartTransaction', action, @@ -311,7 +311,7 @@ export default class CPOCommandsService { try { const chargingStationClient = await ChargingStationClientFactory.getChargingStationClient(tenant, chargingStation); if (!chargingStationClient) { - await Logging.logError({ + Logging.beError()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, module: MODULE_NAME, method: 'remoteStopTransaction', action, @@ -328,7 +328,7 @@ export default class CPOCommandsService { await CPOCommandsService.sendCommandResponse(tenant, action, stopSession.response_url, OCPICommandResponseType.REJECTED, ocpiEndpoint); } } catch (error) { - await Logging.logError({ + Logging.beError()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, module: MODULE_NAME, method: 'remoteStopTransaction', action, @@ -343,7 +343,7 @@ export default class CPOCommandsService { const payload: OCPICommandResponse = { result: responseType }; - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: tenant.id, module: MODULE_NAME, method: 'sendCommandResponse', action, message: `Post command response at ${responseUrl}`, diff --git a/src/server/ocpi/service/emsp/v2.1.1/EMSPCommandsService.ts b/src/server/ocpi/service/emsp/v2.1.1/EMSPCommandsService.ts index 6f70ce7f35..4e9002357d 100644 --- a/src/server/ocpi/service/emsp/v2.1.1/EMSPCommandsService.ts +++ b/src/server/ocpi/service/emsp/v2.1.1/EMSPCommandsService.ts @@ -39,7 +39,7 @@ export default class EMSPCommandsService { case OCPICommandType.RESERVE_NOW: case OCPICommandType.UNLOCK_CONNECTOR: if (req.body?.result !== OCPICommandResponseType.ACCEPTED) { - await Logging.logError({ + Logging.beError()?.log({ tenantID: tenant.id, action: EMSPCommandsService.getAction(command), message: `OCPI Callback '${req.body?.result as string}' received for Command '${command}' with ID '${commandId}'`, @@ -47,7 +47,7 @@ export default class EMSPCommandsService { detailedMessages: { response: req.body } }); } else { - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: tenant.id, action: EMSPCommandsService.getAction(command), message: `OCPI Callback '${req.body?.result as string}' received for Command '${command}' with ID '${commandId}'`, diff --git a/src/server/ocpp/json/JsonOCPPServer.ts b/src/server/ocpp/json/JsonOCPPServer.ts index 4f295df856..78db745ad5 100644 --- a/src/server/ocpp/json/JsonOCPPServer.ts +++ b/src/server/ocpp/json/JsonOCPPServer.ts @@ -1,6 +1,8 @@ import * as uWS from 'uWebSockets.js'; import { App, HttpRequest, HttpResponse, WebSocket, us_socket_context_t } from 'uWebSockets.js'; +import FeatureToggles, { Feature } from '../../../utils/FeatureToggles'; +import { OCPPIncomingRequest, OCPPIncomingResponse, OCPPMessageType } from '../../../types/ocpp/OCPPCommon'; import { ServerAction, ServerType, WSServerProtocol } from '../../../types/Server'; import { WebSocketAction, WebSocketCloseEventStatusCode, WebSocketPingResult } from '../../../types/WebSocket'; @@ -14,7 +16,6 @@ import JsonRestWSConnection from './web-socket/JsonRestWSConnection'; import JsonWSConnection from './web-socket/JsonWSConnection'; import Logging from '../../../utils/Logging'; import LoggingHelper from '../../../utils/LoggingHelper'; -import { OCPPMessageType } from '../../../types/ocpp/OCPPCommon'; import OCPPServer from '../OCPPServer'; import Tenant from '../../../types/Tenant'; import Utils from '../../../utils/Utils'; @@ -26,96 +27,93 @@ import sizeof from 'object-sizeof'; const MODULE_NAME = 'JsonOCPPServer'; export default class JsonOCPPServer extends OCPPServer { - private waitingWSMessages = 0; private runningWSMessages = 0; - private runningWSRequestsMessages: Record = {}; private jsonWSConnections: Map = new Map(); private jsonRestWSConnections: Map = new Map(); public constructor(centralSystemConfig: CentralSystemConfiguration, chargingStationConfig: ChargingStationConfiguration) { super(centralSystemConfig, chargingStationConfig); - // Start job to clean WS connections - this.checkAndCleanupAllWebSockets(); + if (FeatureToggles.isFeatureActive(Feature.WS_SEND_PING_AUTOMATICALLY)) { + // Nothing to do - the uWS layer takes care to ping the WS for us! + } else { + // Start job to ping and clean WS connections (if necessary) + this.checkAndCleanupAllWebSockets(); + } // Monitor WS activity this.monitorWSConnections(); + // Monitor Memory Usage + if (FeatureToggles.isFeatureActive(Feature.OCPP_MONITOR_MEMORY_USAGE)) { + this.monitorMemoryUsage(); + } } public start(): void { // Keep it global global.centralSystemJsonServer = this; + // uWS can send pings automatically before the idleTimeout is reached + let idleTimeout: number; + const sendPingsAutomatically = FeatureToggles.isFeatureActive(Feature.WS_SEND_PING_AUTOMATICALLY); + if (sendPingsAutomatically) { + idleTimeout = 1 * 60; // closed if inactive + } else { + // idleTimeout = 3600; // 1 hour of inactivity ==> close + idleTimeout = 0; // Never close Web Sockets + } // Start the WS server Logging.logConsoleDebug(`Starting ${ServerType.JSON_SERVER} Server...`); App({}).ws('/*', { compression: uWS.SHARED_COMPRESSOR, maxPayloadLength: 64 * 1024, // 64 KB per request - idleTimeout: 1 * 3600, // 1 hour of inactivity => Close - // eslint-disable-next-line @typescript-eslint/no-misused-promises - upgrade: async (res: HttpResponse, req: HttpRequest, context: us_socket_context_t) => { + idleTimeout, + sendPingsAutomatically, + upgrade: (res: HttpResponse, req: HttpRequest, context: us_socket_context_t) => { // Delegate - await this.onUpgrade(res, req, context); + this.onUpgrade(res, req, context); }, - // eslint-disable-next-line @typescript-eslint/no-misused-promises - open: async (ws: WebSocket) => { + open: (ws: WebSocket) => { // Delegate - await this.onOpen(ws); + this.onOpen(ws); }, - // eslint-disable-next-line @typescript-eslint/no-misused-promises - message: async (ws: WebSocket, message: ArrayBuffer, isBinary: boolean) => { + drain: (ws: WebSocket) => { + this.onDrain(ws); + }, + message: (ws: WebSocket, message: ArrayBuffer, isBinary: boolean) => { // Delegate const messageStr = Utils.convertBufferArrayToString(message); - await this.onMessage(ws, messageStr, isBinary); + this.onMessage(ws, messageStr, isBinary).catch(() => { /* Intentional */ }); }, - // eslint-disable-next-line @typescript-eslint/no-misused-promises - close: async (ws: WebSocket, code: number, message: ArrayBuffer) => { - // Convert right away + close: (ws: WebSocket, code: number, message: ArrayBuffer) => { const reason = Utils.convertBufferArrayToString(message); - const wsWrapper = ws.wsWrapper as WSWrapper; - // Close - wsWrapper.closed = true; - await this.logWSConnectionClosed(wsWrapper, ServerAction.WS_SERVER_CONNECTION_CLOSE, code, - `${WebSocketAction.CLOSE} > WS Connection ID '${wsWrapper.guid}' closed by charging station with code '${code}', reason: '${!Utils.isNullOrEmptyString(reason) ? reason : 'No reason given'}'`); - // Remove connection - await this.removeWSWrapper(WebSocketAction.CLOSE, ServerAction.WS_SERVER_CONNECTION_CLOSE, wsWrapper); + this.onClose(ws, code, reason); }, - // eslint-disable-next-line @typescript-eslint/no-misused-promises - ping: async (ws: WebSocket, message: ArrayBuffer) => { - // Convert + ping: (ws: WebSocket, message: ArrayBuffer) => { + // Convert right away (sometimes not working in the method) const ocppMessage = Utils.convertBufferArrayToString(message); - // Update - if (ws.wsWrapper) { - (ws.wsWrapper as WSWrapper).lastPingDate = new Date(); - } - // Get the WS - if (ws.wsWrapper.wsConnection) { - await ws.wsWrapper.wsConnection.onPing(ocppMessage); - } + this.onPing(ws, ocppMessage); }, - // eslint-disable-next-line @typescript-eslint/no-misused-promises - pong: async (ws: WebSocket, message: ArrayBuffer) => { - // Convert + pong: (ws: WebSocket, message: ArrayBuffer) => { + // Convert right away (sometimes not working in the method) const ocppMessage = Utils.convertBufferArrayToString(message); - // Update - if (ws.wsWrapper) { - (ws.wsWrapper as WSWrapper).lastPongDate = new Date(); - } - // Get the WS - if (ws.wsWrapper.wsConnection) { - await ws.wsWrapper.wsConnection.onPong(ocppMessage); - } + this.onPong(ws, ocppMessage); } - // eslint-disable-next-line @typescript-eslint/no-misused-promises - }).any(Constants.HEALTH_CHECK_ROUTE, async (res: HttpResponse) => { + }).any(Constants.HEALTH_CHECK_ROUTE, (res: HttpResponse) => { res.onAborted(() => { res.aborted = true; }); - const pingSuccess = await global.database.ping(); - if (!res.aborted) { - if (pingSuccess) { - res.end('OK'); - } else { - res.writeStatus('500'); - res.end('KO'); - } + if (FeatureToggles.isFeatureActive(Feature.HEALTH_CHECK_PING_DATABASE)) { + global.database.ping().then((pingSuccess) => { + if (!res.aborted) { + if (pingSuccess) { + res.end('OK'); + } else { + res.writeStatus('500'); + res.end('KO'); + } + } + }).catch(() => { /* Intentional */ }); + } else { + // TODO - FIND ANOTHER METRIC TO CHECK THE READINESS and LIVENESS PROBE + res.end('OK'); } }).any('/*', (res: HttpResponse) => { res.writeStatus('404'); @@ -131,18 +129,18 @@ export default class JsonOCPPServer extends OCPPServer { }); } - public async getChargingStationClient(tenant: Tenant, chargingStation: ChargingStation): Promise { + public getChargingStationClient(tenant: Tenant, chargingStation: ChargingStation): ChargingStationClient { // Get the Json Web Socket const jsonWebSocket = this.jsonWSConnections.get(`${tenant.id}~${chargingStation.id}`); if (!jsonWebSocket) { const message = 'No opened Web Socket connection found'; - await Logging.logError({ + Logging.beError()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, module: MODULE_NAME, method: 'getChargingStationClient', action: ServerAction.WS_SERVER_CONNECTION, message }); - await Logging.logError({ + Logging.beError()?.log({ tenantID: Constants.DEFAULT_TENANT_ID, chargingStationID: chargingStation.id, module: MODULE_NAME, method: 'getChargingStationClient', @@ -158,18 +156,23 @@ export default class JsonOCPPServer extends OCPPServer { return this.jsonWSConnections.has(`${tenant.id}~${chargingStation.id}`); } - private async onUpgrade(res: uWS.HttpResponse, req: uWS.HttpRequest, context: uWS.us_socket_context_t) { - // Check for WS connection over HTTP + private onUpgrade(res: uWS.HttpResponse, req: uWS.HttpRequest, context: uWS.us_socket_context_t) { + /* Keep track of abortions */ + const upgradeAborted = { aborted: false }; + // Copy data here because access to 'req' object no longer valid after an 'await' call const url = req.getUrl(); + const secWebSocketKey = req.getHeader('sec-websocket-key'); + const secWebSocketProtocol = req.getHeader('sec-websocket-protocol'); + const secWebSocketExtensions = req.getHeader('sec-websocket-extensions'); try { // You MUST register an abort handler to know if the upgrade was aborted by peer res.onAborted(() => { - // If no handler here, it crashes!!! + upgradeAborted.aborted = true; }); // INFO: Cannot use Logging in this method as uWebSocket will fail in using req/res objects :S // Check URI (/OCPP16/// or /REST///) if (!url.startsWith('/OCPP16') && !url.startsWith('/REST')) { - await Logging.logError({ + Logging.beError()?.log({ tenantID: Constants.DEFAULT_TENANT_ID, module: MODULE_NAME, method: 'onUpgrade', action: ServerAction.WS_SERVER_CONNECTION, @@ -181,7 +184,7 @@ export default class JsonOCPPServer extends OCPPServer { // Check Protocol (ocpp1.6 / rest) const protocol = req.getHeader('sec-websocket-protocol'); if (url.startsWith('/OCPP16') && (protocol !== WSServerProtocol.OCPP16)) { - await Logging.logError({ + Logging.beError()?.log({ tenantID: Constants.DEFAULT_TENANT_ID, module: MODULE_NAME, method: 'onUpgrade', action: ServerAction.WS_SERVER_CONNECTION, @@ -192,7 +195,7 @@ export default class JsonOCPPServer extends OCPPServer { return; } if (url.startsWith('/REST') && (protocol !== WSServerProtocol.REST)) { - await Logging.logError({ + Logging.beError()?.log({ tenantID: Constants.DEFAULT_TENANT_ID, module: MODULE_NAME, method: 'onUpgrade', action: ServerAction.WS_SERVER_CONNECTION, @@ -202,19 +205,39 @@ export default class JsonOCPPServer extends OCPPServer { res.close(); return; } - res.upgrade( - { url }, - req.getHeader('sec-websocket-key'), - req.getHeader('sec-websocket-protocol'), - req.getHeader('sec-websocket-extensions'), - context - ); + // Check and Create WSWrapper without WebSocket + const wsWrapper = new WSWrapper(url); + // Create Json connection + this.createAndKeepJsonConnection(wsWrapper).then(() => { + // Upgrade to WS + if (!upgradeAborted.aborted) { + res.upgrade( + { url }, + secWebSocketKey, + secWebSocketProtocol, + secWebSocketExtensions, + context + ); + } + }).catch((error) => { + // Wrapper creation failed + const message = `${WebSocketAction.UPGRADE} > New WS Connection with URL '${url}' failed with error: ${error.message as string}`; + res.writeStatus('500'); + res.end(message); + this.isDebug() && Logging.logConsoleDebug(message); + Logging.beError()?.log({ + tenantID: Constants.DEFAULT_TENANT_ID, + action: ServerAction.WS_SERVER_CONNECTION, + module: MODULE_NAME, method: 'onUpgrade', + message, detailedMessages: { error: error.stack } + }); + }); } catch (error) { const message = `${WebSocketAction.UPGRADE} > New WS Connection with URL '${url}' failed with error: ${error.message as string}`; res.writeStatus('500'); res.end(message); this.isDebug() && Logging.logConsoleDebug(message); - await Logging.logError({ + Logging.beError()?.log({ tenantID: Constants.DEFAULT_TENANT_ID, action: ServerAction.WS_SERVER_CONNECTION, module: MODULE_NAME, method: 'onUpgrade', @@ -223,170 +246,207 @@ export default class JsonOCPPServer extends OCPPServer { } } - private async onOpen(ws: uWS.WebSocket) { - // Create WS Wrapper - const wsWrapper = new WSWrapper(ws); - // Keep it on the ws - ws.wsWrapper = wsWrapper; - // Lock incoming WS messages - await this.acquireLockForWSRequest(WebSocketAction.OPEN, ServerAction.WS_SERVER_CONNECTION_OPEN, wsWrapper); - try { - this.runningWSMessages++; - // Path must contain /OCPP16 or /REST as it is already checked during the Upgrade process - // Check OCPP16 connection - if (wsWrapper.url.startsWith('/OCPP16')) { - // Create and Initialize WS Connection - await this.checkAndStoreWSOpenedConnection(WSServerProtocol.OCPP16, wsWrapper); - } - // Check REST connection - if (wsWrapper.url.startsWith('/REST')) { - // Create and Initialize WS Connection - await this.checkAndStoreWSOpenedConnection(WSServerProtocol.REST, wsWrapper); + private resolveAndGetWSWrapper(ws: WebSocket): WSWrapper { + const wsWrapper = ws['wsWrapper'] as WSWrapper; + if (wsWrapper) { + if (!wsWrapper.closed) { + return wsWrapper; } - } catch (error) { - await Logging.logException(error as Error, ServerAction.WS_SERVER_CONNECTION_OPEN, MODULE_NAME, 'onOpen', Constants.DEFAULT_TENANT_ID); - if (wsWrapper.tenantID) { - await Logging.logException(error as Error, ServerAction.WS_SERVER_CONNECTION_OPEN, MODULE_NAME, 'onOpen', wsWrapper.tenantID); + return; + } + // Find the WS Wrapper (only done the first time, next it is attached to the uWS) + const url = ws['url'] as string; + let wsConnections: IterableIterator; + if (url.startsWith('/OCPP16')) { + wsConnections = this.jsonWSConnections.values(); + } + if (url.startsWith('/REST')) { + wsConnections = this.jsonRestWSConnections.values(); + } + // Search for already registered Wrapper set by in the 'onUpgrade' method + if (wsConnections) { + for (const wsConnection of wsConnections) { + if (wsConnection.getOriginalURL() === url) { + // Attach it to the Web Socket + const foundWSWrapper = wsConnection.getWS(); + ws['wsWrapper'] = foundWSWrapper; + foundWSWrapper.setWebSocket(ws); + return foundWSWrapper; + } } - // Close WS - await this.closeWebSocket(WebSocketAction.OPEN, ServerAction.WS_SERVER_CONNECTION_OPEN, wsWrapper, WebSocketCloseEventStatusCode.CLOSE_ABNORMAL, - `${WebSocketAction.OPEN} > WS Connection ID '${wsWrapper.guid}' has been rejected and closed by server due to an exception: ${error.message as string}`); - } finally { - this.runningWSMessages--; - this.releaseLockForWSMessageRequest(wsWrapper); } + // No found: close the connection + ws.end(WebSocketCloseEventStatusCode.CLOSE_ABNORMAL, 'Connection rejected by the backend'); } - private async checkAndStoreWSOpenedConnection(protocol: WSServerProtocol, wsWrapper: WSWrapper): Promise { + private async createAndKeepJsonConnection(wsWrapper: WSWrapper): Promise { let wsConnection: WSConnection; const timeStart = Date.now(); - // Set the protocol - wsWrapper.protocol = protocol; - // Create a WebSocket connection object - if (protocol === WSServerProtocol.OCPP16) { - wsConnection = new JsonWSConnection(wsWrapper); - } - if (protocol === WSServerProtocol.REST) { - wsConnection = new JsonRestWSConnection(wsWrapper); - } - await Logging.logDebug({ - tenantID: Constants.DEFAULT_TENANT_ID, - action: ServerAction.WS_SERVER_CONNECTION_OPEN, module: MODULE_NAME, method: 'checkAndStoreWSOpenedConnection', - message: `${WebSocketAction.OPEN} > WS Connection ID '${wsWrapper.guid}' is being checked ('${wsWrapper.url}')`, - detailedMessages: { wsWrapper: this.getWSWrapperData(wsWrapper) } - }); - // Initialize (check of Tenant, Token, Charging Station -> Can take time) - await wsConnection.initialize(); - // Check if WS is still opened (long time initialization when thousand of WS are connecting at the same time) - if (!wsWrapper.closed) { + try { + // Create a WebSocket connection object + if (wsWrapper.protocol === WSServerProtocol.OCPP16) { + wsConnection = new JsonWSConnection(wsWrapper); + } + if (wsWrapper.protocol === WSServerProtocol.REST) { + wsConnection = new JsonRestWSConnection(wsWrapper); + } + Logging.beDebug()?.log({ + tenantID: wsConnection.getTenantID(), + ...LoggingHelper.getWSConnectionProperties(wsConnection), + action: ServerAction.WS_SERVER_CONNECTION_OPEN, module: MODULE_NAME, method: 'createAndKeepJsonConnection', + message: `${WebSocketAction.OPEN} > WS Connection ID '${wsWrapper.guid}' is being checked ('${wsWrapper.url}')`, + detailedMessages: { + wsWrapper: wsWrapper.toJson() + } + }); + // Initialize (check of Tenant, Token, Charging Station -> Can take time) + await wsConnection.initialize(); // Keep common data (Set here to get Tenant info in case of exception in Logs) - wsWrapper.key = wsConnection.getID(); - wsWrapper.chargingStationID = wsConnection.getChargingStationID(); - wsWrapper.tenantID = wsConnection.getTenantID(); - wsWrapper.tokenID = wsConnection.getTokenID(); - wsWrapper.siteID = wsConnection.getSiteID(); - wsWrapper.siteAreaID = wsConnection.getSiteAreaID(); - wsWrapper.companyID = wsConnection.getCompanyID(); - // Check already existing WS Connection - await this.checkAndCloseIdenticalOpenedWSConnection(wsWrapper, wsConnection); - const message = `${WebSocketAction.OPEN} > WS Connection ID '${wsWrapper.guid}' has been accepted in ${Utils.computeTimeDurationSecs(timeStart)} secs`; - await Logging.logInfo({ - tenantID: Constants.DEFAULT_TENANT_ID, - chargingStationID: wsWrapper.chargingStationID, - action: ServerAction.WS_SERVER_CONNECTION_OPEN, module: MODULE_NAME, method: 'checkAndStoreWSOpenedConnection', - message, detailedMessages: { wsWrapper: this.getWSWrapperData(wsWrapper) } + wsWrapper.setConnection(wsConnection); + // Keep WS connection in cache + if (wsWrapper.protocol === WSServerProtocol.OCPP16) { + this.jsonWSConnections.set(wsConnection.getID(), wsConnection as JsonWSConnection); + } else if (wsWrapper.protocol === WSServerProtocol.REST) { + this.jsonRestWSConnections.set(wsConnection.getID(), wsConnection as JsonRestWSConnection); + } + Logging.beInfo()?.log({ + ...LoggingHelper.getWSWrapperProperties(wsWrapper), + tenantID: wsWrapper.wsConnection?.getTenantID(), + action: ServerAction.WS_SERVER_CONNECTION_OPEN, module: MODULE_NAME, method: 'createAndKeepJsonConnection', + message: `${WebSocketAction.OPEN} > WS ID '${wsWrapper.guid}' is valid (processed in ${Utils.computeTimeDurationSecs(timeStart)} secs)`, + detailedMessages: { wsWrapper: wsWrapper.toJson() } }); - await Logging.logInfo({ + } catch (error) { + wsWrapper.isValid = false; + Logging.beError()?.log({ ...LoggingHelper.getWSWrapperProperties(wsWrapper), - action: ServerAction.WS_SERVER_CONNECTION_OPEN, module: MODULE_NAME, method: 'checkAndStoreWSOpenedConnection', - message, detailedMessages: { wsWrapper: this.getWSWrapperData(wsWrapper) } + tenantID: wsWrapper.wsConnection?.getTenantID(), + action: ServerAction.WS_SERVER_CONNECTION_OPEN, module: MODULE_NAME, method: 'createAndKeepJsonConnection', + message: `${WebSocketAction.OPEN} > WS ID '${wsWrapper.guid}' is invalid (processed in ${Utils.computeTimeDurationSecs(timeStart)} secs)`, + detailedMessages: { wsWrapper: wsWrapper.toJson() } }); - // Keep WS connection in cache - await this.setWSConnection(WebSocketAction.OPEN, ServerAction.WS_SERVER_CONNECTION_OPEN, wsConnection, wsWrapper); - } else { - await this.logWSConnectionClosed(wsWrapper, ServerAction.WS_SERVER_CONNECTION_OPEN, WebSocketCloseEventStatusCode.CLOSE_ABNORMAL, - `${WebSocketAction.OPEN} > WS Connection ID '${wsWrapper.guid}' has been closed during initialization in ${Utils.computeTimeDurationSecs(timeStart)} secs ('${wsWrapper.url}')`); } } - private async checkAndCloseIdenticalOpenedWSConnection(wsWrapper: WSWrapper, wsConnection: WSConnection): Promise { - // Get connection - const existingWSConnection = - this.getWSConnectionFromProtocolAndID(wsConnection.getWS().protocol, wsConnection.getID()); - // Found existing WS Connection? - if (existingWSConnection) { - // Still opened WS? - const existingWSWrapper = existingWSConnection.getWS(); - if (!existingWSWrapper.closed) { - // Ping WS - const result = await this.pingWebSocket(existingWSWrapper); - if (result.ok) { - // Close the old WS and keep the new incoming one - await Logging.logWarning({ - tenantID: Constants.DEFAULT_TENANT_ID, - chargingStationID: wsWrapper.chargingStationID, - action: ServerAction.WS_SERVER_CONNECTION, module: MODULE_NAME, method: 'checkAndCloseIdenticalOpenedWSConnection', - message: `${WebSocketAction.OPEN} > Existing WS Connection ID '${existingWSWrapper.guid}' will be closed and replaced by new incoming one with ID '${wsWrapper.guid}'`, - detailedMessages: { wsWrapper: this.getWSWrapperData(wsWrapper) } - }); - await this.closeWebSocket(WebSocketAction.OPEN, ServerAction.WS_SERVER_CONNECTION_OPEN, existingWSConnection.getWS(), WebSocketCloseEventStatusCode.CLOSE_ABNORMAL, - `${WebSocketAction.OPEN} > Existing WS Connection ID '${existingWSWrapper.guid}' has been closed successfully by the server`); + private onOpen(ws: uWS.WebSocket) { + // Init WS + this.resolveAndGetWSWrapper(ws); + } + + private onDrain(ws: WebSocket) { + // Do not try to resolve the WSWrapper + const wsWrapper = ws['wsWrapper'] as WSWrapper ?? new WSWrapper(ws['url'] as string); + // Just log draining + Logging.beWarning()?.log({ + ...LoggingHelper.getWSWrapperProperties(wsWrapper), + tenantID: Constants.DEFAULT_TENANT_ID, + action: ServerAction.WS_SERVER_CONNECTION_CLOSE, + module: MODULE_NAME, method: 'drain', + message: 'Web Socket drain method called', + detailedMessages: { + wsWrapper: wsWrapper?.toJson() + } + }); + } + + private onClose(ws: WebSocket, code: number, reason: string): void { + // Do not try to resolve the WSWrapper, just get it from the uWS + const wsWrapper = ws['wsWrapper'] as WSWrapper; + if (wsWrapper) { + // Force close + wsWrapper.closed = true; + // Cleanup WS Connection map + if (wsWrapper.wsConnection) { + if (wsWrapper.protocol === WSServerProtocol.OCPP16) { + this.jsonWSConnections.delete(wsWrapper.wsConnection.getID()); + } + if (wsWrapper.protocol === WSServerProtocol.REST) { + this.jsonRestWSConnections.delete(wsWrapper.wsConnection.getID()); } } + this.logWSConnectionClosed(wsWrapper, ServerAction.WS_SERVER_CONNECTION_CLOSE, code, + `${WebSocketAction.CLOSE} > WS ID '${wsWrapper?.guid}' closed by charging station with code '${code}', reason: '${!Utils.isNullOrEmptyString(reason) ? reason : '-'}'`); + } else { + const message = `${WebSocketAction.CLOSE} > WS ID 'N/A' closed by charging station with code '${code}', reason: '${!Utils.isNullOrEmptyString(reason) ? reason : '-'}'`; + Logging.beInfo()?.log({ + tenantID: Constants.DEFAULT_TENANT_ID, + action: ServerAction.WS_SERVER_CONNECTION_CLOSE, + module: MODULE_NAME, method: 'onClose', + message, detailedMessages: { code, reason } + }); + this.isDebug() && Logging.logConsoleDebug(message); } } - private async acquireLockForWSRequest(wsAction: WebSocketAction, action: ServerAction, wsWrapper: WSWrapper, ocppMessageType?: OCPPMessageType): Promise { - // Only lock requests, not responses - if (ocppMessageType && ocppMessageType !== OCPPMessageType.CALL_MESSAGE) { - return; + private onPing(ws: WebSocket, ocppMessage: string): void { + const wsWrapper = this.resolveAndGetWSWrapper(ws); + if (wsWrapper) { + wsWrapper.lastPingDate = new Date(); + // Get the WS + if (wsWrapper.wsConnection) { + wsWrapper.wsConnection.onPing(ocppMessage); + } } - // Wait for Init (avoid WS connection with same URL), ocppMessageType only provided when a WS Message is received - await this.waitForWSLockToRelease(wsAction, action, wsWrapper); - // Lock - this.runningWSRequestsMessages[wsWrapper.url] = true; } - private releaseLockForWSMessageRequest(wsWrapper: WSWrapper, ocppMessageType?: OCPPMessageType): void { - // Only lock requests, not responses - if (ocppMessageType && (ocppMessageType !== OCPPMessageType.CALL_MESSAGE)) { - return; + private onPong(ws: WebSocket, ocppMessage: string): void { + const wsWrapper = this.resolveAndGetWSWrapper(ws); + if (wsWrapper) { + wsWrapper.lastPongDate = new Date(); + // Get the WS + if (wsWrapper.wsConnection) { + wsWrapper.wsConnection.onPong(ocppMessage); + } } - // Unlock - delete this.runningWSRequestsMessages[wsWrapper.url]; } private async onMessage(ws: uWS.WebSocket, message: string, isBinary: boolean): Promise { - const wsWrapper: WSWrapper = ws.wsWrapper; + const wsWrapper = this.resolveAndGetWSWrapper(ws); + if (!wsWrapper) { + Logging.beError()?.log({ + action: ServerAction.WS_SERVER_MESSAGE, + module: MODULE_NAME, method: 'onMessage', + message: `${WebSocketAction.MESSAGE} > WS Connection not found ('${ws['url'] as string}')`, + detailedMessages: { message, isBinary } + }); + ws.end(WebSocketCloseEventStatusCode.CLOSE_ABNORMAL, 'Connection rejected by the backend: No WS Wrapper found'); + return; + } + if (!wsWrapper.isValid) { + Logging.beError()?.log({ + ...LoggingHelper.getWSWrapperProperties(wsWrapper), + action: ServerAction.WS_SERVER_MESSAGE, + module: MODULE_NAME, method: 'onMessage', + message: `${WebSocketAction.MESSAGE} > WS Connection ID '${wsWrapper.guid}' is invalid ('${wsWrapper.url}')`, + detailedMessages: { message, isBinary, wsWrapper: wsWrapper.toJson() } + }); + wsWrapper.close(WebSocketCloseEventStatusCode.CLOSE_ABNORMAL, 'Connection rejected by the backend'); + return; + } try { // Extract the OCPP Message Type - const [ocppMessageType]: [OCPPMessageType] = JSON.parse(message); - // Lock incoming WS messages - await this.acquireLockForWSRequest(WebSocketAction.MESSAGE, ServerAction.WS_SERVER_MESSAGE, wsWrapper, ocppMessageType); + const ocppMessage: OCPPIncomingRequest|OCPPIncomingResponse = JSON.parse(message); try { this.runningWSMessages++; - // Check if connection is available in Map - await this.checkWSConnectionFromOnMessage(wsWrapper); // OCPP Request? - if (ocppMessageType === OCPPMessageType.CALL_MESSAGE) { - if (!wsWrapper.closed) { - // Process the message - if (wsWrapper.wsConnection) { - await wsWrapper.wsConnection.receivedMessage(message, isBinary); - } - } - // Process the message - } else if (wsWrapper.wsConnection) { - await wsWrapper.wsConnection.receivedMessage(message, isBinary); + if (wsWrapper.wsConnection) { + await wsWrapper.wsConnection.handleIncomingOcppMessage(wsWrapper, ocppMessage); + } else { + Logging.beError()?.log({ + ...LoggingHelper.getWSWrapperProperties(wsWrapper), + action: ServerAction.WS_SERVER_MESSAGE, + module: MODULE_NAME, method: 'onMessage', + message: 'Unexpected situation - message is received but wsConnection is not set', + detailedMessages: { message, isBinary, wsWrapper: this.getWSWrapperData(wsWrapper) } + }); } } finally { this.runningWSMessages--; - this.releaseLockForWSMessageRequest(wsWrapper, ocppMessageType); } } catch (error) { const logMessage = `${WebSocketAction.MESSAGE} > WS Connection ID '${wsWrapper.guid}' got error while processing WS Message: ${error.message as string}`; - if (wsWrapper?.tenantID) { - await Logging.logError({ + if (wsWrapper?.wsConnection?.getTenantID()) { + Logging.beError()?.log({ ...LoggingHelper.getWSWrapperProperties(wsWrapper), action: ServerAction.WS_SERVER_MESSAGE, module: MODULE_NAME, method: 'onMessage', @@ -394,153 +454,40 @@ export default class JsonOCPPServer extends OCPPServer { detailedMessages: { message, isBinary, wsWrapper: this.getWSWrapperData(wsWrapper), error: error.stack } }); } - await Logging.logError({ + Logging.beError()?.log({ tenantID: Constants.DEFAULT_TENANT_ID, - chargingStationID: wsWrapper.chargingStationID, + ...LoggingHelper.getWSWrapperProperties(wsWrapper), action: ServerAction.WS_SERVER_MESSAGE, module: MODULE_NAME, method: 'onMessage', - message: logMessage + ` - tenant: ${wsWrapper?.tenantID}`, + message: logMessage + ` - tenant: ${wsWrapper?.wsConnection?.getTenantID()}`, detailedMessages: { message, isBinary, wsWrapper: this.getWSWrapperData(wsWrapper), error: error.stack } }); } } - private async checkWSConnectionFromOnMessage(wsWrapper: WSWrapper) { - // Get WS Connection - const wsConnection = wsWrapper.wsConnection; - if (wsWrapper.closed) { - // Current message is from a charger which should not reach us! - // e.g.: Websocket has been closed during the onOpen because the tenant does not exist - throw new Error('Websocket is already closed'); - } - // Get WS Connection from cache - const wsExistingConnection = - this.getWSConnectionFromProtocolAndID(wsWrapper.protocol, wsWrapper.key); - if (!wsExistingConnection) { - await Logging.logError({ - tenantID: Constants.DEFAULT_TENANT_ID, - chargingStationID: wsWrapper.chargingStationID, - action: ServerAction.WS_SERVER_MESSAGE, - module: MODULE_NAME, method: 'checkWSConnectionFromOnMessage', - message: `${WebSocketAction.MESSAGE} > WS Connection ID '${wsWrapper.guid}' has sent a WS Message on an unreferenced WS Connection, it will be then added in the WS cache`, - detailedMessages: { wsWrapper: this.getWSWrapperData(wsWrapper) } - }); - // Add WS connection from OnMessage in cache - await this.setWSConnection(WebSocketAction.MESSAGE, ServerAction.WS_SERVER_MESSAGE, wsConnection, wsWrapper); - return; - } - // Should have the same GUID - const wsExistingWrapper = wsExistingConnection.getWS(); - if (wsExistingWrapper.guid !== wsWrapper.guid) { - await Logging.logError({ - tenantID: Constants.DEFAULT_TENANT_ID, - chargingStationID: wsWrapper.chargingStationID, - action: ServerAction.WS_SERVER_MESSAGE, - module: MODULE_NAME, method: 'checkWSConnectionFromOnMessage', - message: `${WebSocketAction.MESSAGE} > WS Connection ID '${wsWrapper.guid}' has sent a WS Message on an already referenced WS Connection ID '${wsExistingWrapper.guid}' in WS cache, ping will be performed...`, - detailedMessages: { wsWrapper: this.getWSWrapperData(wsWrapper), wsExistingWrapper: this.getWSWrapperData(wsExistingWrapper) } - }); - // Ping - const result = await this.pingWebSocket(wsExistingWrapper); - if (result.ok) { - await Logging.logError({ - tenantID: Constants.DEFAULT_TENANT_ID, - chargingStationID: wsWrapper.chargingStationID, - action: ServerAction.WS_SERVER_MESSAGE, - module: MODULE_NAME, method: 'checkWSConnectionFromOnMessage', - message: `${WebSocketAction.MESSAGE} > Existing WS Connection ID '${wsExistingWrapper.guid}' ping succeeded meaning multiple WS connections are opened by the same charging station, existing one will be closed and replaced by new one with ID '${wsWrapper.guid}'`, - detailedMessages: { wsExistingWrapper: this.getWSWrapperData(wsExistingWrapper), wsWrapper: this.getWSWrapperData(wsWrapper) } - }); - // Close WS - await this.closeWebSocket(WebSocketAction.MESSAGE, ServerAction.WS_SERVER_MESSAGE, wsExistingWrapper, - WebSocketCloseEventStatusCode.CLOSE_ABNORMAL, `${WebSocketAction.MESSAGE} > Existing WS Connection ID '${wsExistingWrapper.guid}' has been closed successfully by server (duplicate WS Connection)`); - } else { - await Logging.logWarning({ - tenantID: Constants.DEFAULT_TENANT_ID, - chargingStationID: wsWrapper.chargingStationID, - action: ServerAction.WS_SERVER_MESSAGE, - module: MODULE_NAME, method: 'checkWSConnectionFromOnMessage', - message: `${WebSocketAction.MESSAGE} > Existing WS Connection ID '${wsExistingWrapper.guid}' ping failed, new WS Connection ID '${wsWrapper.guid}' will be then added in the WS cache`, - detailedMessages: { wsExistingWrapper: this.getWSWrapperData(wsExistingWrapper), wsWrapper: this.getWSWrapperData(wsWrapper) } - }); - } - // Keep WS connection in cache - await this.setWSConnection(WebSocketAction.MESSAGE, ServerAction.WS_SERVER_MESSAGE, wsConnection, wsWrapper); - } - } - - private async logWSConnectionClosed(wsWrapper: WSWrapper, action: ServerAction, code: number, message: string): Promise { + private logWSConnectionClosed(wsWrapper: WSWrapper, action: ServerAction, code: number, message: string): void { this.isDebug() && Logging.logConsoleDebug(message); - if (wsWrapper.tenantID) { - await Logging.logInfo({ + const tenantID = wsWrapper?.wsConnection?.getTenantID(); + if (tenantID) { + Logging.beInfo()?.log({ + tenantID, ...LoggingHelper.getWSWrapperProperties(wsWrapper), action, module: MODULE_NAME, method: 'logWSConnectionClosed', message: message, detailedMessages: { code, message, wsWrapper: this.getWSWrapperData(wsWrapper) } }); } - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: Constants.DEFAULT_TENANT_ID, - chargingStationID: wsWrapper.chargingStationID, + ...LoggingHelper.getWSWrapperProperties(wsWrapper), action, module: MODULE_NAME, method: 'logWSConnectionClosed', message: message, detailedMessages: { code, message, wsWrapper: this.getWSWrapperData(wsWrapper) } }); } - private async waitForWSLockToRelease(wsAction: WebSocketAction, action: ServerAction, wsWrapper: WSWrapper): Promise { - // Wait for init to handle multiple same WS Connection - if (this.runningWSRequestsMessages[wsWrapper.url]) { - const maxNumberOfTrials = 10; - let numberOfTrials = 0; - const timeStart = Date.now(); - await Logging.logWarning({ - tenantID: Constants.DEFAULT_TENANT_ID, - chargingStationID: wsWrapper.chargingStationID, - action, module: MODULE_NAME, method: 'waitForWSLockToRelease', - message: `${wsAction} > WS Connection ID '${wsWrapper.guid}' - Lock is taken: Wait and try to acquire the lock after ${Constants.WS_LOCK_TIME_OUT_MILLIS} ms...`, - detailedMessages: { wsWrapper: this.getWSWrapperData(wsWrapper) } - }); - this.waitingWSMessages++; - // eslint-disable-next-line no-constant-condition - while (true) { - // Wait - await Utils.sleep(Constants.WS_LOCK_TIME_OUT_MILLIS); - numberOfTrials++; - // Message has been processed - if (!this.runningWSRequestsMessages[wsWrapper.url]) { - await Logging.logInfo({ - tenantID: Constants.DEFAULT_TENANT_ID, - chargingStationID: wsWrapper.chargingStationID, - action, module: MODULE_NAME, method: 'waitForWSLockToRelease', - message: `${wsAction} > WS Connection ID '${wsWrapper.guid}' - Lock has been acquired successfully after ${numberOfTrials} trial(s) and ${Utils.computeTimeDurationSecs(timeStart)} secs`, - detailedMessages: { wsWrapper: this.getWSWrapperData(wsWrapper) } - }); - // Free the lock - this.waitingWSMessages--; - break; - } - // Handle remaining trial - if (numberOfTrials >= maxNumberOfTrials) { - // Abnormal situation: The lock should not be taken for so long! - await Logging.logError({ - tenantID: Constants.DEFAULT_TENANT_ID, - chargingStationID: wsWrapper.chargingStationID, - action, module: MODULE_NAME, method: 'waitForWSLockToRelease', - message: `${wsAction} > WS Connection ID '${wsWrapper.guid}' - Cannot acquire the lock after ${numberOfTrials} trial(s) and ${Utils.computeTimeDurationSecs(timeStart)} secs - Lock will be forced to be released`, - detailedMessages: { wsWrapper: this.getWSWrapperData(wsWrapper) } - }); - // Free the lock - this.waitingWSMessages--; - break; - } - } - } - return true; - } - - private async pingWebSocket(wsWrapper: WSWrapper): Promise { + private pingWebSocket(wsWrapper: WSWrapper): WebSocketPingResult { try { // Ping the WS - wsWrapper.ping(); + wsWrapper.ping('OCPPJ Ping'); // Reset wsWrapper.nbrPingFailed = 0; return { @@ -550,19 +497,19 @@ export default class JsonOCPPServer extends OCPPServer { wsWrapper.nbrPingFailed++; // Close WS if (wsWrapper.nbrPingFailed >= Constants.WS_MAX_NBR_OF_FAILED_PINGS) { - await Logging.logError({ + Logging.beError()?.log({ tenantID: Constants.DEFAULT_TENANT_ID, - chargingStationID: wsWrapper.chargingStationID, + ...LoggingHelper.getWSWrapperProperties(wsWrapper), action: ServerAction.WS_SERVER_CONNECTION_PING, module: MODULE_NAME, method: 'pingWebSocket', message: `${WebSocketAction.PING} > Failed to ping the WS Connection ID '${wsWrapper.guid}' after ${wsWrapper.nbrPingFailed} trial(s), will be removed from WS cache`, detailedMessages: { wsWrapper: this.getWSWrapperData(wsWrapper), error: error.stack } }); - await this.closeWebSocket(WebSocketAction.PING, ServerAction.WS_SERVER_CONNECTION_PING, wsWrapper, + this.closeWebSocket(WebSocketAction.PING, ServerAction.WS_SERVER_CONNECTION_PING, wsWrapper, WebSocketCloseEventStatusCode.CLOSE_ABNORMAL, `${WebSocketAction.PING} > WS Connection ID '${wsWrapper.guid}' has been closed by server after ${wsWrapper.nbrPingFailed} failed ping`); } else { - await Logging.logWarning({ + Logging.beWarning()?.log({ tenantID: Constants.DEFAULT_TENANT_ID, - chargingStationID: wsWrapper.chargingStationID, + ...LoggingHelper.getWSWrapperProperties(wsWrapper), action: ServerAction.WS_SERVER_CONNECTION_PING, module: MODULE_NAME, method: 'pingWebSocket', message: `${WebSocketAction.PING} > Failed to ping the WS Connection ID '${wsWrapper.guid}' after ${wsWrapper.nbrPingFailed} trial(s) (${Constants.WS_MAX_NBR_OF_FAILED_PINGS - wsWrapper.nbrPingFailed} remaining)`, detailedMessages: { wsWrapper: this.getWSWrapperData(wsWrapper), error: error.stack } @@ -576,17 +523,17 @@ export default class JsonOCPPServer extends OCPPServer { } } - private async closeWebSocket(wsAction: WebSocketAction, action: ServerAction, wsWrapper: WSWrapper, code: WebSocketCloseEventStatusCode, message: string): Promise { + private closeWebSocket(wsAction: WebSocketAction, action: ServerAction, wsWrapper: WSWrapper, code: WebSocketCloseEventStatusCode, message: string): void { // Close WS if (!wsWrapper.closed) { try { wsWrapper.close(code, message); - await this.logWSConnectionClosed(wsWrapper, action, code, message); + this.logWSConnectionClosed(wsWrapper, action, code, message); } catch (error) { // Just log and ignore issue - await Logging.logError({ + Logging.beError()?.log({ tenantID: Constants.DEFAULT_TENANT_ID, - chargingStationID: wsWrapper.chargingStationID, + ...LoggingHelper.getWSWrapperProperties(wsWrapper), action, module: MODULE_NAME, method: 'closeWebSocket', message: `${wsAction} > Failed to close WS Connection ID '${wsWrapper.guid}': ${error.message as string}`, detailedMessages: { error: error.stack, wsWrapper: this.getWSWrapperData(wsWrapper) } @@ -594,55 +541,20 @@ export default class JsonOCPPServer extends OCPPServer { } } // Remove connection - await this.removeWSWrapper(wsAction, action, wsWrapper); - } - - private async setWSConnection(wsAction: WebSocketAction, action: ServerAction, wsConnection: WSConnection, wsWrapper: WSWrapper) { - // Reference a Json WebSocket connection object - if (wsWrapper.protocol === WSServerProtocol.OCPP16) { - this.jsonWSConnections.set(wsConnection.getID(), wsConnection as JsonWSConnection); - await Logging.logDebug({ - tenantID: Constants.DEFAULT_TENANT_ID, - chargingStationID: wsWrapper.chargingStationID, - action, module: MODULE_NAME, method: 'setWSConnection', - message: `${wsAction} > WS Connection ID '${wsWrapper.guid}' has been added in the WS cache`, - detailedMessages: { wsWrapper: this.getWSWrapperData(wsWrapper) } - }); - } - if (wsWrapper.protocol === WSServerProtocol.REST) { - this.jsonRestWSConnections.set(wsConnection.getID(), wsConnection as JsonRestWSConnection); - await Logging.logDebug({ - tenantID: Constants.DEFAULT_TENANT_ID, - chargingStationID: wsWrapper.chargingStationID, - action, module: MODULE_NAME, method: 'setWSConnection', - message: `${wsAction} > WS Connection ID '${wsWrapper.guid}' has been added in the WS cache`, - detailedMessages: { wsWrapper: this.getWSWrapperData(wsWrapper) } - }); - } - wsWrapper.wsConnection = wsConnection; - } - - private getWSConnectionFromProtocolAndID(protocol: WSServerProtocol, wsConnectionID: string): WSConnection { - if (protocol === WSServerProtocol.OCPP16) { - return this.jsonWSConnections.get(wsConnectionID); - } - if (protocol === WSServerProtocol.REST) { - return this.jsonRestWSConnections.get(wsConnectionID); - } + this.removeWSWrapper(wsAction, action, wsWrapper); } - private async removeWSWrapper(wsAction: WebSocketAction, action: ServerAction, wsWrapper: WSWrapper): Promise { + private removeWSWrapper(wsAction: WebSocketAction, action: ServerAction, wsWrapper: WSWrapper): void { if (wsWrapper.protocol === WSServerProtocol.OCPP16) { - await this.removeWSConnection( + this.removeWSConnection( wsAction, action, wsWrapper.wsConnection, this.jsonWSConnections); - } - if (wsWrapper.protocol === WSServerProtocol.REST) { - await this.removeWSConnection( + } else if (wsWrapper.protocol === WSServerProtocol.REST) { + this.removeWSConnection( wsAction, action, wsWrapper.wsConnection, this.jsonRestWSConnections); } } - private async removeWSConnection(wsAction: WebSocketAction, action: ServerAction, wsConnection: WSConnection, wsConnections: Map): Promise { + private removeWSConnection(wsAction: WebSocketAction, action: ServerAction, wsConnection: WSConnection, wsConnections: Map): void { if (wsConnection) { const wsWrapper = wsConnection.getWS(); const existingWsConnection = wsConnections.get(wsConnection.getID()); @@ -652,18 +564,18 @@ export default class JsonOCPPServer extends OCPPServer { if (existingWsWrapper.guid === wsWrapper.guid) { // Remove from WS Cache wsConnections.delete(wsConnection.getID()); - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: Constants.DEFAULT_TENANT_ID, - chargingStationID: wsWrapper.chargingStationID, + ...LoggingHelper.getWSWrapperProperties(wsWrapper), action, module: MODULE_NAME, method: 'setWSConnection', message: `${wsAction} > WS Connection ID '${wsWrapper.guid}' has been removed from the WS cache`, detailedMessages: { wsWrapper: this.getWSWrapperData(wsWrapper) } }); } else { // WS Connection not identical - await Logging.logWarning({ + Logging.beWarning()?.log({ tenantID: Constants.DEFAULT_TENANT_ID, - chargingStationID: wsWrapper.chargingStationID, + ...LoggingHelper.getWSWrapperProperties(wsWrapper), action, module: MODULE_NAME, method: 'removeWSConnection', message: `${wsAction} > Failed to remove WS Connection ID '${wsWrapper.guid}' from WS cache due to an already existing WS with different ID '${existingWsWrapper.guid}'`, detailedMessages: { wsWrapper: this.getWSWrapperData(wsWrapper), existingWsWrapper: this.getWSWrapperData(existingWsWrapper) } @@ -671,9 +583,9 @@ export default class JsonOCPPServer extends OCPPServer { } } else { // WS Connection not found - await Logging.logWarning({ + Logging.beWarning()?.log({ tenantID: Constants.DEFAULT_TENANT_ID, - chargingStationID: wsWrapper.chargingStationID, + ...LoggingHelper.getWSWrapperProperties(wsWrapper), action, module: MODULE_NAME, method: 'removeWSConnection', message: `${wsAction} > Failed to remove WS Connection ID '${wsWrapper.guid}' from WS cache as it does not exist anymore in it`, detailedMessages: { wsWrapper: this.getWSWrapperData(wsWrapper) } @@ -690,38 +602,33 @@ export default class JsonOCPPServer extends OCPPServer { setInterval(() => { try { // Log size of WS Json Connections (track leak) - let sizeOfCurrentRequestsBytes = 0, numberOfCurrentRequests = 0; + let sizeOfPendingCommands = 0, numberOfPendingCommands = 0; for (const jsonWSConnection of Array.from(this.jsonWSConnections.values())) { - const currentOcppRequests = jsonWSConnection.getCurrentOcppRequests(); - sizeOfCurrentRequestsBytes += sizeof(currentOcppRequests); - numberOfCurrentRequests += Object.keys(currentOcppRequests).length; + const pendingCommands = jsonWSConnection.getPendingOccpCommands(); + sizeOfPendingCommands += sizeof(pendingCommands); + numberOfPendingCommands += Object.keys(pendingCommands).length; } // Log Stats on number of WS Connections - Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: Constants.DEFAULT_TENANT_ID, action: ServerAction.WS_SERVER_CONNECTION, module: MODULE_NAME, method: 'monitorWSConnections', - message: `${this.jsonWSConnections.size} WS connections, ${this.jsonRestWSConnections.size} REST connections, ${this.runningWSMessages} Messages, ${Object.keys(this.runningWSRequestsMessages).length} Requests, ${this.waitingWSMessages} queued WS Message(s)`, + message: `${this.jsonWSConnections.size} WS connections, ${this.jsonRestWSConnections.size} REST connections, ${this.runningWSMessages} Messages, ${numberOfPendingCommands} pending OCPP commands`, detailedMessages: [ - `${numberOfCurrentRequests} JSON WS Requests cached`, - `${sizeOfCurrentRequestsBytes / 1000} kB used in JSON WS cache` + `${numberOfPendingCommands} pending OCPP commands - ${sizeOfPendingCommands / 1000} kB` ] - }).catch(() => { /* Intentional */ }); + }); if ((global.monitoringServer) && (process.env.K8S)) { global.monitoringServer.getGauge(Constants.WEB_SOCKET_RUNNING_REQUEST_RESPONSE).set(this.runningWSMessages); global.monitoringServer.getGauge(Constants.WEB_SOCKET_OCPP_CONNECTIONS_COUNT).set(this.jsonWSConnections.size); global.monitoringServer.getGauge(Constants.WEB_SOCKET_REST_CONNECTIONS_COUNT).set(this.jsonRestWSConnections.size); - global.monitoringServer.getGauge(Constants.WEB_SOCKET_CURRRENT_REQUEST).set(numberOfCurrentRequests); - global.monitoringServer.getGauge(Constants.WEB_SOCKET_RUNNING_REQUEST).set(Object.keys(this.runningWSRequestsMessages).length); - global.monitoringServer.getGauge(Constants.WEB_SOCKET_QUEUED_REQUEST).set(this.waitingWSMessages); + global.monitoringServer.getGauge(Constants.WEB_SOCKET_CURRENT_REQUEST).set(numberOfPendingCommands); } if (this.isDebug()) { Logging.logConsoleDebug('====================================='); Logging.logConsoleDebug(`** ${this.jsonWSConnections.size} JSON Connection(s)`); - Logging.logConsoleDebug(`** ${numberOfCurrentRequests} JSON WS Requests in cache with a size of ${sizeOfCurrentRequestsBytes / 1000} kB`); + Logging.logConsoleDebug(`** ${numberOfPendingCommands} pending OCPP commands - Size: ${sizeOfPendingCommands / 1000} kB`); Logging.logConsoleDebug(`** ${this.jsonRestWSConnections.size} REST Connection(s)`); - Logging.logConsoleDebug(`** ${Object.keys(this.runningWSRequestsMessages).length} running WS Requests`); Logging.logConsoleDebug(`** ${this.runningWSMessages} running WS Messages (Requests + Responses)`); - Logging.logConsoleDebug(`** ${this.waitingWSMessages} queued WS Message(s)`); Logging.logConsoleDebug('====================================='); } } catch (error) { @@ -730,16 +637,57 @@ export default class JsonOCPPServer extends OCPPServer { }, Configuration.getChargingStationConfig().monitoringIntervalOCPPJSecs * 1000); } + private monitorMemoryUsage() { + setInterval(() => { + try { + // get Node memory usage + const beginDate = new Date().getTime(); + const memoryUsage = process.memoryUsage(); + const elapsedTime = new Date().getTime() - beginDate; + const memoryUsagePercentage = ((memoryUsage.heapUsed / memoryUsage.rss) * 100); + const usagePercentage = memoryUsagePercentage.toFixed(2); + const heapTotal = (memoryUsage.heapTotal / 1024 / 1024).toFixed(2); + const heapUsed = (memoryUsage.heapUsed / 1024 / 1024).toFixed(2); + const external = (memoryUsage.external / 1024 / 1024).toFixed(2); + const rss = (memoryUsage.rss / 1024 / 1024).toFixed(2); // total amount of memory allocated to the process - to be clarified! + const message = `Memory Usage ${usagePercentage}% - total heap: ${heapTotal} MiB - heap used: ${heapUsed} MiB - rss: ${rss} MiB - external: ${external} MiB - elapsed time: ${elapsedTime}`; + const dataToLog = { + tenantID: Constants.DEFAULT_TENANT_ID, + action: ServerAction.PERFORMANCES, module: MODULE_NAME, method: 'monitorMemoryUsage', + message + }; + // TODO - remove it - JUST FOR TROUBLESHOOTING STRESS TESTS + Logging.beError()?.log(dataToLog); + // if (memoryUsagePercentage > 90) { + // Logging.beError()?.log(dataToLog); + // } else if (memoryUsagePercentage > 80) { + // Logging.beWarning()?.log(dataToLog); + // } else { + // Logging.beDebug()?.log(dataToLog); + // } + if (this.isDebug()) { + Logging.logConsoleDebug(message); + } + } catch (error) { + /* Intentional */ + } + }, 5 * 60 * 1000); // every minute - TODO - add new configuration for it! + } + private checkAndCleanupAllWebSockets() { setInterval(() => { - // Check Json connections - this.checkAndCleanupWebSockets(this.jsonWSConnections, 'CS').catch(() => { /* Intentional */ }); - // Check Rest connections - this.checkAndCleanupWebSockets(this.jsonRestWSConnections, 'REST').catch(() => { /* Intentional */ }); + try { + // Check Json connections + this.checkAndCleanupWebSockets(this.jsonWSConnections, 'CS'); + // Check Rest connections + this.checkAndCleanupWebSockets(this.jsonRestWSConnections, 'REST'); + } catch (error) { + /* Intentional */ + } }, Configuration.getChargingStationConfig().pingIntervalOCPPJSecs * 1000); } - private async checkAndCleanupWebSockets(wsConnections: Map, type: 'CS'|'REST') { + private checkAndCleanupWebSockets(wsConnections: Map, type: 'CS'|'REST'): void { const validConnections: Record[] = [], invalidConnections: Record[] = []; const timeStart = Date.now(); const wsConnectionKeys = Array.from(wsConnections.keys()); @@ -750,7 +698,7 @@ export default class JsonOCPPServer extends OCPPServer { // Get the WS const wsWrapper = wsConnection.getWS(); // Check WS - const result = await this.pingWebSocket(wsWrapper); + const result = this.pingWebSocket(wsWrapper); if (result.ok) { validConnections.push(this.getWSWrapperData(wsWrapper)); } else { @@ -762,14 +710,14 @@ export default class JsonOCPPServer extends OCPPServer { const message = `Total of ${wsConnectionKeys.length} ${type} WS connection(s) pinged in ${Utils.computeTimeDurationSecs(timeStart)} secs: ${validConnections.length} valid, ${invalidConnections.length} invalid`; this.isDebug() && Logging.logConsoleDebug(message); if (invalidConnections.length) { - await Logging.logError({ + Logging.beError()?.log({ tenantID: Constants.DEFAULT_TENANT_ID, module: MODULE_NAME, method: 'checkAndCleanupWebSockets', action: ServerAction.WS_SERVER_CONNECTION_PING, - message, detailedMessages: { invalidConnections, /* validConnections */ } + message, /* detailedMessages: { invalidConnections, validConnections } */ }); } else { - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: Constants.DEFAULT_TENANT_ID, module: MODULE_NAME, method: 'checkAndCleanupWebSockets', action: ServerAction.WS_SERVER_CONNECTION_PING, @@ -782,15 +730,12 @@ export default class JsonOCPPServer extends OCPPServer { private getWSWrapperData(wsWrapper: WSWrapper): Record { return { - key: wsWrapper.key, + tenantID: wsWrapper.wsConnection?.getTenantID(), + key: wsWrapper.wsConnection?.getID(), guid: wsWrapper.guid, nbrPingFailed: wsWrapper.nbrPingFailed, - siteID: wsWrapper.siteID, - siteAreaID: wsWrapper.siteAreaID, - companyID: wsWrapper.companyID, - chargingStationID: wsWrapper.chargingStationID, - tenantID: wsWrapper.tenantID, tokenID: wsWrapper.tokenID, + ...LoggingHelper.getWSConnectionProperties(wsWrapper.wsConnection), url: wsWrapper.url, clientIP: wsWrapper.clientIP, closed: wsWrapper.closed, diff --git a/src/server/ocpp/json/services/JsonChargingStationService.ts b/src/server/ocpp/json/services/JsonChargingStationService.ts index f092f4b273..86a555e2e8 100644 --- a/src/server/ocpp/json/services/JsonChargingStationService.ts +++ b/src/server/ocpp/json/services/JsonChargingStationService.ts @@ -88,11 +88,11 @@ export default class JsonChargingStationService { }; } - private async handle(command: Command, headers: OCPPHeader, payload) { + private async handle(command: Command, headers: OCPPHeader, payload): Promise { try { - return this.chargingStationService[`handle${command}`](headers, payload); + return this.chargingStationService[`handle${command}`](headers, payload) as Promise; } catch (error) { - await Logging.logException(error, OCPPUtils.buildServerActionFromOcppCommand(command), MODULE_NAME, command, headers.tenantID); + Logging.logException(error, OCPPUtils.buildServerActionFromOcppCommand(command), MODULE_NAME, command, headers.tenantID); throw error; } } diff --git a/src/server/ocpp/json/web-socket/JsonRestWSConnection.ts b/src/server/ocpp/json/web-socket/JsonRestWSConnection.ts index c4af0cc70f..4caa9b3710 100644 --- a/src/server/ocpp/json/web-socket/JsonRestWSConnection.ts +++ b/src/server/ocpp/json/web-socket/JsonRestWSConnection.ts @@ -1,6 +1,7 @@ import BackendError from '../../../../exception/BackendError'; import ChargingStationStorage from '../../../../storage/mongodb/ChargingStationStorage'; import { Command } from '../../../../types/ChargingStation'; +import LoggingHelper from '../../../../utils/LoggingHelper'; import OCPPUtils from '../../utils/OCPPUtils'; import WSConnection from './WSConnection'; import WSWrapper from './WSWrapper'; @@ -23,10 +24,7 @@ export default class JsonRestWSConnection extends WSConnection { // Check Command if (!this.isValidOcppClientCommand(command)) { throw new BackendError({ - chargingStationID: this.getChargingStationID(), - siteID: this.getSiteID(), - siteAreaID: this.getSiteAreaID(), - companyID: this.getCompanyID(), + ...LoggingHelper.getWSConnectionProperties(this), module: MODULE_NAME, method: 'handleRequest', message: `Command '${command}' is not allowed from REST server`, @@ -37,10 +35,7 @@ export default class JsonRestWSConnection extends WSConnection { const chargingStation = await ChargingStationStorage.getChargingStation(this.getTenant(), this.getChargingStationID()); if (!chargingStation) { throw new BackendError({ - chargingStationID: this.getChargingStationID(), - siteID: this.getSiteID(), - siteAreaID: this.getSiteAreaID(), - companyID: this.getCompanyID(), + ...LoggingHelper.getWSConnectionProperties(this), module: MODULE_NAME, method: 'handleRequest', message: 'Charging Station not found', @@ -48,13 +43,10 @@ export default class JsonRestWSConnection extends WSConnection { }); } // Get the client from JSON Server - const chargingStationClient = await global.centralSystemJsonServer.getChargingStationClient(this.getTenant(), chargingStation); + const chargingStationClient = global.centralSystemJsonServer.getChargingStationClient(this.getTenant(), chargingStation); if (!chargingStationClient) { throw new BackendError({ - chargingStationID: this.getChargingStationID(), - siteID: this.getSiteID(), - siteAreaID: this.getSiteAreaID(), - companyID: this.getCompanyID(), + ...LoggingHelper.getWSConnectionProperties(this), module: MODULE_NAME, method: 'handleRequest', message: 'Charging Station is not connected to the backend', @@ -69,10 +61,7 @@ export default class JsonRestWSConnection extends WSConnection { result = await chargingStationClient[actionMethod](commandPayload); } else { throw new BackendError({ - chargingStationID: this.getChargingStationID(), - siteID: this.getSiteID(), - siteAreaID: this.getSiteAreaID(), - companyID: this.getCompanyID(), + ...LoggingHelper.getWSConnectionProperties(this), module: MODULE_NAME, method: 'handleRequest', message: `'${actionMethod}' is not implemented`, @@ -82,10 +71,10 @@ export default class JsonRestWSConnection extends WSConnection { return result; } - public async onPing(message: string): Promise { + public onPing(message: string): void { } - public async onPong(message: string): Promise { + public onPong(message: string): void { } private isValidOcppClientCommand(command: Command): boolean { diff --git a/src/server/ocpp/json/web-socket/JsonWSConnection.ts b/src/server/ocpp/json/web-socket/JsonWSConnection.ts index e817aa748c..d7cc174397 100644 --- a/src/server/ocpp/json/web-socket/JsonWSConnection.ts +++ b/src/server/ocpp/json/web-socket/JsonWSConnection.ts @@ -1,4 +1,5 @@ import ChargingStation, { Command } from '../../../../types/ChargingStation'; +import FeatureToggles, { Feature } from '../../../../utils/FeatureToggles'; import { OCPPProtocol, OCPPVersion } from '../../../../types/ocpp/OCPPServer'; import BackendError from '../../../../exception/BackendError'; @@ -9,10 +10,12 @@ import Constants from '../../../../utils/Constants'; import JsonChargingStationClient from '../../../../client/ocpp/json/JsonChargingStationClient'; import JsonChargingStationService from '../services/JsonChargingStationService'; import Logging from '../../../../utils/Logging'; +import LoggingHelper from '../../../../utils/LoggingHelper'; import OCPPError from '../../../../exception/OcppError'; import { OCPPErrorType } from '../../../../types/ocpp/OCPPCommon'; import { OCPPHeader } from '../../../../types/ocpp/OCPPHeader'; import OCPPUtils from '../../utils/OCPPUtils'; +import { ServerAction } from '../../../../types/Server'; import WSConnection from './WSConnection'; import WSWrapper from './WSWrapper'; @@ -86,10 +89,11 @@ export default class JsonWSConnection extends WSConnection { // Call it result = await this.chargingStationService[methodName](this.headers, commandPayload); } finally { + // TODO - To be clarified - Why do we clean the header here? // Clean the header - delete this.headers.chargingStation; - delete this.headers.tenant; - delete this.headers.token; + // delete this.headers.chargingStation; + // delete this.headers.tenant; + // delete this.headers.token; // Trace await Logging.traceOcppMessageResponse(Constants.MODULE_JSON_OCPP_SERVER_16, this.getTenant(), this.getChargingStationID(), OCPPUtils.buildServerActionFromOcppCommand(command), commandPayload, result, '<<', @@ -99,10 +103,7 @@ export default class JsonWSConnection extends WSConnection { } else { // Throw Exception throw new OCPPError({ - chargingStationID: this.getChargingStationID(), - siteID: this.getSiteID(), - siteAreaID: this.getSiteAreaID(), - companyID: this.getCompanyID(), + ...LoggingHelper.getWSConnectionProperties(this), module: MODULE_NAME, method: 'handleRequest', code: OCPPErrorType.NOT_IMPLEMENTED, @@ -120,12 +121,28 @@ export default class JsonWSConnection extends WSConnection { super.setChargingStation(chargingStation); } - public async onPing(message: string): Promise { - await this.updateChargingStationLastSeen(); + // eslint-disable-next-line @typescript-eslint/no-unused-vars + public onPing(message: string): void { + this.updateChargingStationLastSeen().catch(() => { /* Intentional */ }); + Logging.beDebug()?.log({ + ...LoggingHelper.getWSConnectionProperties(this), + tenantID: this.getTenantID(), + action: ServerAction.WS_CLIENT_CONNECTION_PING, + module: MODULE_NAME, method: 'onPing', + message: 'Ping received' + }); } - public async onPong(message: string): Promise { - await this.updateChargingStationLastSeen(); + // eslint-disable-next-line @typescript-eslint/no-unused-vars + public onPong(message: string): void { + this.updateChargingStationLastSeen().catch(() => { /* Intentional */ }); + Logging.beDebug()?.log({ + ...LoggingHelper.getWSConnectionProperties(this), + tenantID: this.getTenantID(), + action: ServerAction.WS_CLIENT_CONNECTION_PONG, + module: MODULE_NAME, method: 'onPing', + message: 'Pong received' + }); } private async updateChargingStationLastSeen(): Promise { @@ -134,11 +151,16 @@ export default class JsonWSConnection extends WSConnection { (Date.now() - this.lastSeen.getTime()) > (Configuration.getChargingStationConfig().pingIntervalOCPPJSecs * 1000 / 2)) { // Update last seen this.lastSeen = new Date(); - const chargingStation = await ChargingStationStorage.getChargingStation(this.getTenant(), - this.getChargingStationID(), { issuer: true }, ['id']); - if (chargingStation) { + if (FeatureToggles.isFeatureActive(Feature.OCPP_OPTIMIZE_LAST_SEEN_UPDATE)) { await ChargingStationStorage.saveChargingStationRuntimeData(this.getTenant(), this.getChargingStationID(), { lastSeen: this.lastSeen }); + } else { + const chargingStation = await ChargingStationStorage.getChargingStation(this.getTenant(), + this.getChargingStationID(), { issuer: true }, ['id']); + if (chargingStation) { + await ChargingStationStorage.saveChargingStationRuntimeData(this.getTenant(), this.getChargingStationID(), + { lastSeen: this.lastSeen }); + } } } } diff --git a/src/server/ocpp/json/web-socket/WSConnection.ts b/src/server/ocpp/json/web-socket/WSConnection.ts index cd1133d28e..a496ca7f9a 100644 --- a/src/server/ocpp/json/web-socket/WSConnection.ts +++ b/src/server/ocpp/json/web-socket/WSConnection.ts @@ -1,10 +1,12 @@ +/* eslint-disable @typescript-eslint/member-ordering */ import ChargingStation, { Command } from '../../../../types/ChargingStation'; -import { FctOCPPReject, FctOCPPResponse, OCPPErrorType, OCPPIncomingRequest, OCPPIncomingResponse, OCPPMessageType, OCPPRequest } from '../../../../types/ocpp/OCPPCommon'; +import { FctOCPPReject, FctOCPPResponse, OCPPErrorType, OCPPIncomingRequest, OCPPIncomingResponse, OCPPMessageType, OCPPPayload } from '../../../../types/ocpp/OCPPCommon'; import { ServerAction, WSServerProtocol } from '../../../../types/Server'; import BackendError from '../../../../exception/BackendError'; import Constants from '../../../../utils/Constants'; import Logging from '../../../../utils/Logging'; +import LoggingHelper from '../../../../utils/LoggingHelper'; import OCPPError from '../../../../exception/OcppError'; import OCPPUtils from '../../utils/OCPPUtils'; import Tenant from '../../../../types/Tenant'; @@ -13,6 +15,42 @@ import WSWrapper from './WSWrapper'; const MODULE_NAME = 'WSConnection'; +export class OcppPendingCommand { + private command: Command; + private resolveCallback: FctOCPPResponse; + private rejectCallback: FctOCPPReject; + private timer: NodeJS.Timeout; + + public constructor(command: Command, resolveCallback: FctOCPPResponse, rejectCallback: FctOCPPReject, timer: NodeJS.Timeout) { + this.command = command; + this.resolveCallback = resolveCallback; + this.rejectCallback = rejectCallback; + this.timer = timer; + } + + public getCommand(): Command { + return this.command; + } + + public resolve(payload: Record | string): void { + this.clearTimer(); + this.resolveCallback(payload); + } + + public reject(error: OCPPError): void { + this.clearTimer(); + this.rejectCallback(error); + } + + private clearTimer() { + const timer = this.timer; + if (timer) { + this.timer = null; + clearTimeout(timer); + } + } +} + export default abstract class WSConnection { private siteID: string; private siteAreaID: string; @@ -23,22 +61,22 @@ export default abstract class WSConnection { private tenantSubdomain: string; private tokenID: string; private url: string; - private clientIP: string | string[]; - private ws: WSWrapper; - private ocppRequests: Record = {}; + private originalURL: string; + private wsWrapper: WSWrapper; + private pendingOcppCommands: Record = {}; - public constructor(ws: WSWrapper) { + public constructor(wsWrapper: WSWrapper) { // Init - this.url = ws.url.trim().replace(/\b(\?|&).*/, ''); // Filter trailing URL parameters - this.ws = ws; - this.clientIP = ws.getRemoteAddress(); + this.url = wsWrapper.url.trim().replace(/\b(\?|&).*/, ''); // Filter trailing URL parameters + this.originalURL = wsWrapper.url; + this.wsWrapper = wsWrapper; // Check mandatory fields this.checkMandatoryFieldsInRequest(); } public async initialize(): Promise { // Do not update the lastSeen when the caller is the REST server! - const updateChargingStationData = (this.ws.protocol !== WSServerProtocol.REST); + const updateChargingStationData = (this.wsWrapper.protocol !== WSServerProtocol.REST); // Check and Get Charging Station data const { tenant, chargingStation } = await OCPPUtils.checkAndGetChargingStationConnectionData( ServerAction.WS_SERVER_CONNECTION, @@ -48,198 +86,164 @@ export default abstract class WSConnection { // Set this.setTenant(tenant); this.setChargingStation(chargingStation); + this.wsWrapper.setConnection(this); } - public async sendResponse(messageID: string, command: Command, response: Record): Promise> { - return this.sendMessage(messageID, OCPPMessageType.CALL_RESULT_MESSAGE, command, response); + public sendResponse(messageID: string, command: Command, initialPayload: OCPPPayload, response: OCPPPayload): void { + // Build Message + const messageType = OCPPMessageType.CALL_RESULT_MESSAGE; + const messageToSend = JSON.stringify([messageType, messageID, response]); + Utils.isDevelopmentEnv() && Logging.logConsoleDebug(`Send Response ${messageToSend} for '${this.wsWrapper.url }'`); + this.sendMessageInternal(messageToSend, command, initialPayload); } - public async sendError(messageID: string, error: OCPPError): Promise { - return this.sendMessage(messageID, OCPPMessageType.CALL_ERROR_MESSAGE, null, null, error); + public sendError(messageID: string, + initialCommand: Command, + initialPayload: OCPPPayload, + error: any): void { + // Build Error Message + const messageType = OCPPMessageType.CALL_ERROR_MESSAGE; + const errorCode = error.code ?? OCPPErrorType.GENERIC_ERROR; + const errorMessage = error.message ? error.message : ''; + const errorDetail = error.details ? error.details : {}; + const messageToSend = JSON.stringify([messageType, messageID, errorCode, errorMessage, errorDetail]); + Utils.isDevelopmentEnv() && Logging.logConsoleDebug(`Send Error ${messageToSend} for '${this.wsWrapper.url}'`); + this.sendMessageInternal(messageToSend, initialCommand, initialPayload); } - public async sendMessage(messageID: string, messageType: OCPPMessageType, command?: Command, data?: Record, error?: OCPPError): Promise { - // Create a promise - return new Promise((resolve, reject) => { - let messageToSend: string; - let messageProcessed = false; - let requestTimeout: NodeJS.Timer; + public async sendMessageAndWaitForResult(messageID: string, command: Command, dataToSend: OCPPPayload): Promise { + // Create a pending promise + const pendingPromise = new Promise((resolve, reject) => { + // Send the message to the charging station + const messageType = OCPPMessageType.CALL_MESSAGE; + const messageToSend = JSON.stringify([messageType, messageID, command, dataToSend]); // Function that will receive the request's response - const responseCallback = (payload?: Record | string): void => { - if (!messageProcessed) { - if (requestTimeout) { - clearTimeout(requestTimeout); - } - // Send response - messageProcessed = true; - delete this.ocppRequests[messageID]; - resolve(payload); - } + const responseCallback = (payload?: OCPPPayload | string): void => { + resolve(payload); }; // Function that will receive the request's rejection - const rejectCallback = (reason: string | OCPPError): void => { - if (!messageProcessed) { - if (requestTimeout) { - clearTimeout(requestTimeout); - } - // Send error - messageProcessed = true; - delete this.ocppRequests[messageID]; - const ocppError = reason instanceof OCPPError ? reason : new Error(reason); - reject(ocppError); - } + const rejectCallback = (error: OCPPError): void => { + reject(error); }; - // Type of message - switch (messageType) { - // Request - case OCPPMessageType.CALL_MESSAGE: - // Store Promise callback - this.ocppRequests[messageID] = [responseCallback, rejectCallback, command]; - // Build request - messageToSend = JSON.stringify([messageType, messageID, command, data]); - break; - // Response - case OCPPMessageType.CALL_RESULT_MESSAGE: - // Build response - messageToSend = JSON.stringify([messageType, messageID, data]); - break; - // Error Message - case OCPPMessageType.CALL_ERROR_MESSAGE: - // Build Error Message - messageToSend = JSON.stringify([messageType, messageID, error.code ?? OCPPErrorType.GENERIC_ERROR, error.message ? error.message : '', error.details ? error.details : {}]); - break; + // Make sure to reject automatically if we do not receive anything after 10 seconds + const timeout = setTimeout(() => { + // Remove it from the cache + this.consumePendingOcppCommands(messageID); + // Send some feedback + const timeoutError = new Error(`Timeout after ${Constants.OCPP_SOCKET_TIMEOUT_MILLIS / 1000} secs for Message ID '${messageID}' with content '${messageToSend} - (${this.tenantSubdomain})`); + reject(timeoutError); + }, Constants.OCPP_SOCKET_TIMEOUT_MILLIS); + // Let's send it + Utils.isDevelopmentEnv() && Logging.logConsoleDebug(`Send Message ${messageToSend} for '${this.wsWrapper.url }'`); + // Keep track of the pending promise + this.pendingOcppCommands[messageID] = new OcppPendingCommand(command, responseCallback, rejectCallback, timeout); + // Send the message + if (!this.sendMessageInternal(messageToSend)) { + // Well - we have not been able to send the message - Remove the pending promise from the cache + this.consumePendingOcppCommands(messageID); + // send some feedback + const unexpectedError = new Error(`Unexpected situation - Failed to send Message ID '${messageID}' with content '${messageToSend} - (${this.tenantSubdomain})`); + reject(unexpectedError); } - Utils.isDevelopmentEnv() && Logging.logConsoleDebug(`Send Message ${messageToSend} for '${this.ws.url }'`); - try { - // Send Message - if (!this.ws.send(messageToSend)) { - // Not always an error with uWebSocket: check BackPressure example - const message = `Error when sending message '${messageToSend}' to Web Socket`; - void Logging.logError({ - tenantID: this.tenantID, - chargingStationID: this.chargingStationID, - companyID: this.companyID, - siteID: this.siteID, - siteAreaID: this.siteAreaID, - module: MODULE_NAME, method: 'sendMessage', - action: ServerAction.WS_SERVER_CONNECTION_ERROR, - message, detailedMessages: { message: messageToSend } - }); - Utils.isDevelopmentEnv() && Logging.logConsoleError(message); - } - } catch (wsError) { - // Invalid Web Socket - const message = `Error when sending message '${messageToSend}' to Web Socket: ${wsError?.message as string}`; + }); + // This promise is pending and will be resolved as soon as we get a response/error from the charging station + return pendingPromise; + } + + private sendMessageInternal( + messageToSend: string, + initialCommand: Command = null, + initialCommandPayload: OCPPPayload = null): boolean { + let sent = false ; + try { + // Send Message + if (this.wsWrapper.send(messageToSend, initialCommand, initialCommandPayload)) { + sent = true; + } else { + // Not always an error with uWebSocket: check BackPressure example + const message = `Error when sending error '${messageToSend}' to Web Socket`; void Logging.logError({ tenantID: this.tenantID, chargingStationID: this.chargingStationID, companyID: this.companyID, siteID: this.siteID, siteAreaID: this.siteAreaID, - module: MODULE_NAME, method: 'sendMessage', + module: MODULE_NAME, method: 'sendError', action: ServerAction.WS_SERVER_CONNECTION_ERROR, - message, detailedMessages: { message: messageToSend, error: wsError?.stack } + message, detailedMessages: { message: messageToSend } }); Utils.isDevelopmentEnv() && Logging.logConsoleError(message); } - // Response? - if (messageType !== OCPPMessageType.CALL_MESSAGE) { - responseCallback(); + } catch (wsError) { + // Invalid Web Socket + const message = `Error when sending message '${messageToSend}' to Web Socket: ${wsError?.message as string}`; + void Logging.logError({ + tenantID: this.tenantID, + chargingStationID: this.chargingStationID, + companyID: this.companyID, + siteID: this.siteID, + siteAreaID: this.siteAreaID, + module: MODULE_NAME, method: 'sendPayload', + action: ServerAction.WS_SERVER_CONNECTION_ERROR, + message, detailedMessages: { message: messageToSend, error: wsError?.stack } + }); + Utils.isDevelopmentEnv() && Logging.logConsoleError(message); + } + return sent; + } + + public async handleIncomingOcppMessage(wsWrapper: WSWrapper, ocppMessage: OCPPIncomingRequest|OCPPIncomingResponse): Promise { + const ocppMessageType = ocppMessage[0]; + try { + if (ocppMessageType === OCPPMessageType.CALL_MESSAGE) { + await wsWrapper.wsConnection.handleIncomingOcppRequest(wsWrapper, ocppMessage as OCPPIncomingRequest); + } else if (ocppMessageType === OCPPMessageType.CALL_RESULT_MESSAGE) { + wsWrapper.wsConnection.handleIncomingOcppResponse(ocppMessage as OCPPIncomingResponse); + } else if (ocppMessageType === OCPPMessageType.CALL_ERROR_MESSAGE) { + wsWrapper.wsConnection.handleIncomingOcppError(ocppMessage as OCPPIncomingResponse); } else { - // Trigger timeout - requestTimeout = setTimeout(() => { - rejectCallback(`Timeout after ${Constants.OCPP_SOCKET_TIMEOUT_MILLIS / 1000} secs for Message ID '${messageID}' with content '${messageToSend} (${this.tenantSubdomain})`); - }, Constants.OCPP_SOCKET_TIMEOUT_MILLIS); + Logging.beError()?.log({ + tenantID: this.tenantID, + siteID: this.siteID, + siteAreaID: this.siteAreaID, + companyID: this.companyID, + chargingStationID: this.chargingStationID, + action: ServerAction.UNKNOWN_ACTION, + message: `Wrong OCPP Message Type in '${JSON.stringify(ocppMessage)}'`, + module: MODULE_NAME, method: 'handleIncomingOcppMessage', + }); } - }); + } catch (error) { + Logging.beError()?.log({ + tenantID: this.tenantID, + siteID: this.siteID, + siteAreaID: this.siteAreaID, + companyID: this.companyID, + chargingStationID: this.chargingStationID, + action: ServerAction.UNKNOWN_ACTION, + message: `${error.message as string}`, + module: MODULE_NAME, method: 'handleIncomingOcppMessage', + detailedMessages: { data: JSON.stringify(ocppMessage), error: error.stack } + }); + } } - public async receivedMessage(message: string, isBinary: boolean): Promise { - let responseCallback: FctOCPPResponse; - let rejectCallback: FctOCPPReject; - let command: Command, commandPayload: Record, errorDetails: Record; + public async handleIncomingOcppRequest(wsWrapper: WSWrapper, ocppMessage: OCPPIncomingRequest): Promise { + if (wsWrapper.closed || !wsWrapper.isValid) { + return; + } // Parse the data - const ocppMessage: OCPPIncomingRequest|OCPPIncomingResponse = JSON.parse(message); - const [messageType, messageID] = ocppMessage; - let result: any; + // eslint-disable-next-line @typescript-eslint/no-unused-vars + const [messageType, messageID, command, commandPayload] = ocppMessage; try { - // Check the Type of message - switch (messageType) { - // Received Ocpp Request - case OCPPMessageType.CALL_MESSAGE: - // Get the data - [,,command,commandPayload] = ocppMessage as OCPPIncomingRequest; - try { - // Process the call - result = await this.handleRequest(command, commandPayload); - } catch (error) { - // Send Error Response - await this.sendError(messageID, error); - throw error; - } - // Send Response - await this.sendResponse(messageID, command, result); - break; - // Response to an OCPP Request - case OCPPMessageType.CALL_RESULT_MESSAGE: - // Get the data - [,,commandPayload] = ocppMessage as OCPPIncomingResponse; - // Respond - if (Array.isArray(this.ocppRequests[messageID])) { - [responseCallback,,command] = this.ocppRequests[messageID]; - } - if (!responseCallback) { - throw new BackendError({ - chargingStationID: this.getChargingStationID(), - siteID: this.getSiteID(), - siteAreaID: this.getSiteAreaID(), - companyID: this.getCompanyID(), - module: MODULE_NAME, method: 'onMessage', - message: `Unknown OCPP Request: '${message.toString()}'`, - }); - } - responseCallback(commandPayload); - break; - // Error Response to an OCPP Request - case OCPPMessageType.CALL_ERROR_MESSAGE: - [,,commandPayload,errorDetails] = ocppMessage as OCPPIncomingResponse; - if (Array.isArray(this.ocppRequests[messageID])) { - [,rejectCallback,command] = this.ocppRequests[messageID]; - } - if (!rejectCallback) { - throw new BackendError({ - chargingStationID: this.getChargingStationID(), - siteID: this.getSiteID(), - siteAreaID: this.getSiteAreaID(), - companyID: this.getCompanyID(), - module: MODULE_NAME, method: 'onMessage', - message: `Unknown OCPP Request: '${message.toString()}'`, - detailedMessages: { messageType, messageID, commandPayload, errorDetails } - }); - } - rejectCallback(new OCPPError({ - chargingStationID: this.getChargingStationID(), - siteID: this.getSiteID(), - siteAreaID: this.getSiteAreaID(), - companyID: this.getCompanyID(), - module: MODULE_NAME, method: 'onMessage', - code: command, - message: message.toString(), - })); - break; - default: - throw new BackendError({ - chargingStationID: this.getChargingStationID(), - siteID: this.getSiteID(), - siteAreaID: this.getSiteAreaID(), - companyID: this.getCompanyID(), - action: OCPPUtils.buildServerActionFromOcppCommand(command), - module: MODULE_NAME, method: 'onMessage', - message: `Wrong OCPP Message Type '${messageType as string}' for '${message.toString()}'`, - }); - } + // Process the call + const result = await this.handleRequest(command, commandPayload); + // Send Response + this.sendResponse(messageID, command, commandPayload, result as Record); } catch (error) { - await Logging.logError({ + // Send Error Response + this.sendError(messageID, command, commandPayload, error); + Logging.beError()?.log({ tenantID: this.tenantID, siteID: this.siteID, siteAreaID: this.siteAreaID, @@ -247,22 +251,84 @@ export default abstract class WSConnection { chargingStationID: this.chargingStationID, action: OCPPUtils.buildServerActionFromOcppCommand(command), message: `${error.message as string}`, + module: MODULE_NAME, method: 'handleIncomingOcppRequest', + detailedMessages: { data: ocppMessage, error: error.stack } + }); + } + } + + private consumePendingOcppCommands(messageID: string) { + const pendingOcppCommand = this.pendingOcppCommands[messageID]; + if (pendingOcppCommand) { + // It can be consumed only once - so we remove it from the cache + delete this.pendingOcppCommands[messageID]; + } + return pendingOcppCommand; + } + + public handleIncomingOcppResponse(ocppMessage: OCPPIncomingResponse): void { + let done = false; + // Parse the data + const [messageType, messageID, commandPayload] = ocppMessage as OCPPIncomingResponse; + // Consume the pending OCPP command matching the current OCPP error? + const ocppPendingCommand = this.consumePendingOcppCommands(messageID); + if (ocppPendingCommand) { + // eslint-disable-next-line @typescript-eslint/no-unused-vars + ocppPendingCommand.resolve(commandPayload); + done = true; + } + if (!done) { + // No OCPP request found ??? + // Is there anything to cleanup? + throw new BackendError({ + ...LoggingHelper.getWSConnectionProperties(this), + module: MODULE_NAME, method: 'handleIncomingOcppResponse', + message: `OCPP Request not found for a response to messageID: '${messageID}'`, + detailedMessages: { messageType, messageID, commandPayload } + }); + } + } + + public handleIncomingOcppError(ocppMessage: OCPPIncomingResponse): void { + let done = false; + const [messageType, messageID, commandPayload, errorDetails] = ocppMessage; + // Consume the pending OCPP command matching the current OCPP error? + const ocppPendingCommand = this.consumePendingOcppCommands(messageID); + if (ocppPendingCommand) { + ocppPendingCommand.reject(new OCPPError({ + ...LoggingHelper.getWSConnectionProperties(this), module: MODULE_NAME, method: 'onMessage', - detailedMessages: { data: message, error: error.stack } + code: ocppPendingCommand.getCommand(), + message: JSON.stringify(ocppMessage), + })); + done = true; + } + if (!done) { + // No OCPP request found ??? + // Is there anything to cleanup? + throw new BackendError({ + ...LoggingHelper.getWSConnectionProperties(this), + module: MODULE_NAME, method: 'handleIncomingOcppError', + message: `OCPP Request not found for an error response to messageID: '${messageID}'`, + detailedMessages: { messageType, messageID, commandPayload, errorDetails } }); } } public getWS(): WSWrapper { - return this.ws; + return this.wsWrapper; } public getURL(): string { return this.url; } + public getOriginalURL(): string { + return this.originalURL; + } + public getClientIP(): string | string[] { - return this.clientIP; + return this.wsWrapper.getRemoteAddress(); } public setChargingStation(chargingStation: ChargingStation): void { @@ -313,8 +379,8 @@ export default abstract class WSConnection { return `${this.getTenantID()}~${this.getChargingStationID()}`; } - public getCurrentOcppRequests(): Record { - return this.ocppRequests; + public getPendingOccpCommands(): Record { + return this.pendingOcppCommands; } private checkMandatoryFieldsInRequest() { @@ -347,7 +413,7 @@ export default abstract class WSConnection { public abstract handleRequest(command: Command, commandPayload: Record | string): Promise; - public abstract onPing(message: string): Promise; + public abstract onPing(message: string): void; - public abstract onPong(message: string): Promise; + public abstract onPong(message: string): void; } diff --git a/src/server/ocpp/json/web-socket/WSWrapper.ts b/src/server/ocpp/json/web-socket/WSWrapper.ts index 9e8415f3d6..e2128a6329 100644 --- a/src/server/ocpp/json/web-socket/WSWrapper.ts +++ b/src/server/ocpp/json/web-socket/WSWrapper.ts @@ -1,66 +1,157 @@ import { RecognizedString, WebSocket } from 'uWebSockets.js'; +import { ServerAction, WSServerProtocol } from '../../../../types/Server'; +import { Command } from '../../../../types/ChargingStation'; +import Constants from '../../../../utils/Constants'; +import Logging from '../../../../utils/Logging'; +import LoggingHelper from '../../../../utils/LoggingHelper'; +import { OCPPPayload } from '../../../../types/ocpp/OCPPCommon'; import Utils from '../../../../utils/Utils'; import WSConnection from './WSConnection'; -import { WSServerProtocol } from '../../../../types/Server'; import { WebSocketAction } from '../../../../types/WebSocket'; +const MODULE_NAME = 'WSWrapper'; + export default class WSWrapper { - public key: string; public guid: string; - public siteID: string; - public siteAreaID: string; - public companyID: string; - public chargingStationID: string; - public tenantID: string; public tokenID: string; public url: string; public clientIP: string | string[]; public closed: boolean; public protocol: WSServerProtocol; - public wsConnection: WSConnection; public remoteAddress: string; + public wsConnection: WSConnection; public firstConnectionDate: Date; public nbrPingFailed: number; public lastPingDate: Date; public lastPongDate: Date; + public isValid: boolean; private ws: WebSocket; - public constructor(ws: WebSocket) { + public constructor(url: string) { + this.url = url; this.guid = Utils.generateShortNonUniqueID(); - this.ws = ws; - this.url = ws.url; - this.remoteAddress = Utils.convertBufferArrayToString(ws.getRemoteAddressAsText()).toString(); this.firstConnectionDate = new Date(); this.nbrPingFailed = 0; this.closed = false; + this.isValid = false; + if (this.url.startsWith('/OCPP16')) { + this.protocol = WSServerProtocol.OCPP16; + } else if (this.url.startsWith('/REST')) { + this.protocol = WSServerProtocol.REST; + } + } + + public setWebSocket(ws: WebSocket) { + this.ws = ws; + this.remoteAddress = Utils.convertBufferArrayToString(ws.getRemoteAddressAsText()).toString(); + this.isValid = true; + } + + public setConnection(wsConnection: WSConnection) { + this.wsConnection = wsConnection; + this.isValid = true; } - public send(message: RecognizedString, isBinary?: boolean, compress?: boolean): boolean { - this.checkWSClosed(WebSocketAction.MESSAGE); - return this.ws.send(message, isBinary, compress) === 1; + public send(messageToSend: string, initialCommand: Command, initialCommandPayload?: OCPPPayload, isBinary?: boolean, compress?: boolean): boolean { + this.canSendMessage(WebSocketAction.MESSAGE, messageToSend, initialCommand, initialCommandPayload); + const returnedCode = this.ws.send(messageToSend, isBinary, compress); + // Return a boolean in production + if (typeof returnedCode === 'boolean') { + return returnedCode; + } + // Handle back pressure + if (returnedCode !== 1) { + Logging.beWarning()?.log({ + ...LoggingHelper.getWSWrapperProperties(this), + tenantID: Constants.DEFAULT_TENANT_ID, + action: ServerAction.WS_SERVER_MESSAGE, + module: MODULE_NAME, method: 'send', + message: `WS Message returned a backpressure code '${returnedCode}'`, + detailedMessages: { + message: messageToSend, + returnedCode, + wsWrapper: this.toJson() + } + }); + } + return true; } public close(code: number, shortMessage: RecognizedString): void { if (!this.closed) { this.closed = true; - this.ws.end(code, shortMessage); + // Local ref to the Web Socket + const ws = this.ws; + if (ws) { + try { + // Clear the reference to the WebSocket! + this.ws = null; + // Close WS + ws.end(code, shortMessage); + } catch (error) { + // Do nothing + } + } } } - public ping(message?: RecognizedString) : boolean { - this.checkWSClosed(WebSocketAction.PING); - return this.ws.ping(message) === 1; + public ping(message: RecognizedString) : boolean { + this.canSendMessage(WebSocketAction.PING, message as string); + const returnedCode = this.ws.ping(message); + // Return a boolean in production + if (typeof returnedCode === 'boolean') { + return returnedCode; + } + // Handle back pressure + if (returnedCode !== 1) { + Logging.beWarning()?.log({ + ...LoggingHelper.getWSWrapperProperties(this), + tenantID: Constants.DEFAULT_TENANT_ID, + action: ServerAction.WS_SERVER_CONNECTION_PING, + module: MODULE_NAME, method: 'ping', + message: `WS Ping returned a backpressure code '${returnedCode}'`, + detailedMessages: { + message, + returnedCode, + wsWrapper: this.toJson() + } + }); + } + return true; } public getRemoteAddress(): string { return this.remoteAddress; } - private checkWSClosed(wsAction: WebSocketAction): void { + public toJson(): Record { + return { + key: this.wsConnection?.getID(), + guid: this.guid, + nbrPingFailed: this.nbrPingFailed, + ...LoggingHelper.getWSConnectionProperties(this.wsConnection), + tokenID: this.tokenID, + url: this.url, + clientIP: this.clientIP, + closed: this.closed, + protocol: this.protocol, + remoteAddress: this.remoteAddress, + firstConnectionDate: this.firstConnectionDate, + durationSecs: Utils.computeTimeDurationSecs(new Date(this.firstConnectionDate).getTime()), + lastPingDate: this.lastPingDate, + lastPongDate: this.lastPongDate, + }; + } + + private canSendMessage(wsAction: WebSocketAction, messageToSend: string, initialCommand?: Command, initialCommandPayload?: OCPPPayload): void { if (this.closed) { - throw new Error(`${wsAction} > WS Connection ID '${this.guid}' is already closed ('${this.url}'), cannot perform action`); + if (initialCommand && initialCommandPayload) { + throw new Error(`'${wsAction}' > Cannot send message '${messageToSend}', initial command '${initialCommand}', command payload '${JSON.stringify(initialCommandPayload)}', WS Connection ID '${this.guid}' is already closed ('${this.url}')`); + } else { + throw new Error(`'${wsAction}' > Cannot send message '${messageToSend}', WS Connection ID '${this.guid}' is already closed ('${this.url}')`); + } } } } diff --git a/src/server/ocpp/services/OCPPService.ts b/src/server/ocpp/services/OCPPService.ts index 747c77fbee..b86e7c94c9 100644 --- a/src/server/ocpp/services/OCPPService.ts +++ b/src/server/ocpp/services/OCPPService.ts @@ -1,6 +1,7 @@ import { ChargePointErrorCode, ChargePointStatus, OCPPAttribute, OCPPAuthorizationStatus, OCPPAuthorizeRequestExtended, OCPPAuthorizeResponse, OCPPBootNotificationRequestExtended, OCPPBootNotificationResponse, OCPPDataTransferRequestExtended, OCPPDataTransferResponse, OCPPDataTransferStatus, OCPPDiagnosticsStatusNotificationRequestExtended, OCPPDiagnosticsStatusNotificationResponse, OCPPFirmwareStatusNotificationRequestExtended, OCPPFirmwareStatusNotificationResponse, OCPPHeartbeatRequestExtended, OCPPHeartbeatResponse, OCPPLocation, OCPPMeasurand, OCPPMeterValue, OCPPMeterValuesRequest, OCPPMeterValuesRequestExtended, OCPPMeterValuesResponse, OCPPNormalizedMeterValue, OCPPNormalizedMeterValues, OCPPPhase, OCPPProtocol, OCPPReadingContext, OCPPSampledValue, OCPPStartTransactionRequestExtended, OCPPStartTransactionResponse, OCPPStatusNotificationRequestExtended, OCPPStatusNotificationResponse, OCPPStopTransactionRequestExtended, OCPPStopTransactionResponse, OCPPUnitOfMeasure, OCPPValueFormat, OCPPVersion, RegistrationStatus } from '../../../types/ocpp/OCPPServer'; import { ChargingProfilePurposeType, ChargingRateUnitType } from '../../../types/ChargingProfile'; import ChargingStation, { ChargerVendor, Connector, ConnectorCurrentLimitSource, ConnectorType, CurrentType, StaticLimitAmps } from '../../../types/ChargingStation'; +import FeatureToggles, { Feature } from '../../../utils/FeatureToggles'; import Tenant, { TenantComponents } from '../../../types/Tenant'; import Transaction, { InactivityStatus, TransactionAction } from '../../../types/Transaction'; @@ -39,7 +40,6 @@ import TransactionStorage from '../../../storage/mongodb/TransactionStorage'; import User from '../../../types/User'; import UserStorage from '../../../storage/mongodb/UserStorage'; import Utils from '../../../utils/Utils'; -import UtilsService from '../../rest/v1/service/UtilsService'; import moment from 'moment'; import momentDurationFormatSetup from 'moment-duration-format'; @@ -82,11 +82,12 @@ export default class OCPPService { // Notify this.notifyBootNotification(tenant, chargingStation); // Request OCPP configuration - // eslint-disable-next-line @typescript-eslint/no-misused-promises - setTimeout(async () => { - await OCPPCommon.requestAndSaveChargingStationOcppParameters(tenant, chargingStation); + setTimeout(() => { + OCPPCommon.requestAndSaveChargingStationOcppParameters(tenant, chargingStation).catch((error) => { + Logging.logPromiseError(error, tenant?.id); + }); }, Constants.DELAY_CHANGE_CONFIGURATION_EXECUTION_MILLIS); - await Logging.logInfo({ + Logging.beInfo()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, action: ServerAction.OCPP_BOOT_NOTIFICATION, @@ -102,7 +103,7 @@ export default class OCPPService { }; } catch (error) { this.addChargingStationToException(error, headers.chargeBoxIdentity); - await Logging.logActionExceptionMessage(headers.tenantID, ServerAction.OCPP_BOOT_NOTIFICATION, error, { bootNotification }); + Logging.logActionExceptionMessage(headers.tenantID, ServerAction.OCPP_BOOT_NOTIFICATION, error, { bootNotification }); // Reject return { status: RegistrationStatus.REJECTED, @@ -119,14 +120,16 @@ export default class OCPPService { if (!heartbeat) { heartbeat = {} as OCPPHeartbeatRequestExtended; } - OCPPValidator.getInstance().validateHeartbeat(heartbeat); - // Set Heart Beat Object - heartbeat.chargeBoxID = chargingStation.id; - heartbeat.timestamp = new Date(); - heartbeat.timezone = Utils.getTimezone(chargingStation.coordinates); - // Save Heart Beat - await OCPPStorage.saveHeartbeat(tenant, heartbeat); - await Logging.logInfo({ + if (FeatureToggles.isFeatureActive(Feature.OCPP_STORE_HEARTBEATS)) { + OCPPValidator.getInstance().validateHeartbeat(heartbeat); + // Set Heart Beat Object + heartbeat.chargeBoxID = chargingStation.id; + heartbeat.timestamp = new Date(); + heartbeat.timezone = Utils.getTimezone(chargingStation.coordinates); + // Save Heart Beat + await OCPPStorage.saveHeartbeat(tenant, heartbeat); + } + Logging.beInfo()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, module: MODULE_NAME, method: 'handleHeartbeat', @@ -134,16 +137,13 @@ export default class OCPPService { message: 'Heartbeat saved', detailedMessages: { heartbeat } }); - return { - currentTime: new Date().toISOString() - }; } catch (error) { this.addChargingStationToException(error, headers.chargeBoxIdentity); - await Logging.logActionExceptionMessage(headers.tenantID, ServerAction.OCPP_HEARTBEAT, error, { heartbeat }); - return { - currentTime: new Date().toISOString() - }; + Logging.logActionExceptionMessage(headers.tenantID, ServerAction.OCPP_HEARTBEAT, error, { heartbeat }); } + return { + currentTime: new Date().toISOString() + }; } public async handleStatusNotification(headers: OCPPHeader, statusNotification: OCPPStatusNotificationRequestExtended): Promise { @@ -156,7 +156,7 @@ export default class OCPPService { this.enrichOCPPRequest(chargingStation, statusNotification, false); // Skip connectorId = 0 case if (statusNotification.connectorId <= 0) { - await Logging.logInfo({ + Logging.beInfo()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, action: ServerAction.OCPP_STATUS_NOTIFICATION, @@ -168,25 +168,24 @@ export default class OCPPService { // Update only the given Connector ID await this.processConnectorFromStatusNotification(tenant, chargingStation, statusNotification); } - return {}; } catch (error) { this.addChargingStationToException(error, headers.chargeBoxIdentity); - await Logging.logActionExceptionMessage(headers.tenantID, ServerAction.OCPP_STATUS_NOTIFICATION, error, { statusNotification }); - return {}; + Logging.logActionExceptionMessage(headers.tenantID, ServerAction.OCPP_STATUS_NOTIFICATION, error, { statusNotification }); } + return {}; } public async handleMeterValues(headers: OCPPHeader, meterValues: OCPPMeterValuesRequestExtended): Promise { try { // Get the header infos const { chargingStation, tenant } = headers; - await OCPPValidator.getInstance().validateMeterValues(tenant.id, chargingStation, meterValues); + OCPPValidator.getInstance().validateMeterValues(tenant.id, chargingStation, meterValues); // Normalize Meter Values const normalizedMeterValues = this.normalizeMeterValues(chargingStation, meterValues); // Handle Charging Station's specificities this.filterMeterValuesOnSpecificChargingStations(tenant, chargingStation, normalizedMeterValues); if (Utils.isEmptyArray(normalizedMeterValues.values)) { - await Logging.logDebug({ + Logging.beDebug()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, module: MODULE_NAME, method: 'handleMeterValues', @@ -198,8 +197,10 @@ export default class OCPPService { } // Get Transaction const transaction = await this.getTransactionFromMeterValues(tenant, chargingStation, headers, meterValues); - // Save Meter Values - await OCPPStorage.saveMeterValues(tenant, normalizedMeterValues); + if (FeatureToggles.isFeatureActive(Feature.OCPP_STORE_METER_VALUES)) { + // Save Meter Values + await OCPPStorage.saveMeterValues(tenant, normalizedMeterValues); + } // Update Transaction this.updateTransactionWithMeterValues(chargingStation, transaction, normalizedMeterValues.values); // Create Consumptions @@ -242,7 +243,7 @@ export default class OCPPService { // Yes: Trigger Smart Charging await this.triggerSmartCharging(tenant, chargingStation.siteArea); } - await Logging.logInfo({ + Logging.beInfo()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, action: ServerAction.OCPP_METER_VALUES, @@ -253,7 +254,7 @@ export default class OCPPService { }); } catch (error) { this.addChargingStationToException(error, headers.chargeBoxIdentity); - await Logging.logActionExceptionMessage(headers.tenantID, ServerAction.OCPP_METER_VALUES, error, { meterValues }); + Logging.logActionExceptionMessage(headers.tenantID, ServerAction.OCPP_METER_VALUES, error, { meterValues }); } return {}; } @@ -272,7 +273,7 @@ export default class OCPPService { this.enrichAuthorize(user, chargingStation, headers, authorize); // Save await OCPPStorage.saveAuthorize(tenant, authorize); - await Logging.logInfo({ + Logging.beInfo()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, module: MODULE_NAME, method: 'handleAuthorize', @@ -288,7 +289,7 @@ export default class OCPPService { }; } catch (error) { this.addChargingStationToException(error, headers.chargeBoxIdentity); - await Logging.logActionExceptionMessage(headers.tenantID, ServerAction.OCPP_AUTHORIZE, error, { authorize }); + Logging.logActionExceptionMessage(headers.tenantID, ServerAction.OCPP_AUTHORIZE, error, { authorize }); // Rejected return { idTagInfo: { @@ -309,7 +310,7 @@ export default class OCPPService { this.enrichOCPPRequest(chargingStation, diagnosticsStatusNotification); // Save it await OCPPStorage.saveDiagnosticsStatusNotification(tenant, diagnosticsStatusNotification); - await Logging.logInfo({ + Logging.beInfo()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, action: ServerAction.OCPP_DIAGNOSTICS_STATUS_NOTIFICATION, @@ -320,7 +321,7 @@ export default class OCPPService { return {}; } catch (error) { this.addChargingStationToException(error, headers.chargeBoxIdentity); - await Logging.logActionExceptionMessage(headers.tenantID, ServerAction.OCPP_DIAGNOSTICS_STATUS_NOTIFICATION, error, { diagnosticsStatusNotification }); + Logging.logActionExceptionMessage(headers.tenantID, ServerAction.OCPP_DIAGNOSTICS_STATUS_NOTIFICATION, error, { diagnosticsStatusNotification }); return {}; } } @@ -338,7 +339,7 @@ export default class OCPPService { await ChargingStationStorage.saveChargingStationFirmwareStatus(tenant, chargingStation.id, firmwareStatusNotification.status); // Save it await OCPPStorage.saveFirmwareStatusNotification(tenant, firmwareStatusNotification); - await Logging.logInfo({ + Logging.beInfo()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, module: MODULE_NAME, method: 'handleFirmwareStatusNotification', @@ -349,7 +350,7 @@ export default class OCPPService { return {}; } catch (error) { this.addChargingStationToException(error, headers.chargeBoxIdentity); - await Logging.logActionExceptionMessage(headers.tenantID, ServerAction.OCPP_FIRMWARE_STATUS_NOTIFICATION, error, { firmwareStatusNotification }); + Logging.logActionExceptionMessage(headers.tenantID, ServerAction.OCPP_FIRMWARE_STATUS_NOTIFICATION, error, { firmwareStatusNotification }); return {}; } } @@ -395,7 +396,7 @@ export default class OCPPService { await ChargingStationStorage.saveChargingStation(tenant, chargingStation); // Notify NotificationHelper.notifyStartTransaction(tenant, newTransaction, chargingStation, user); - await Logging.logInfo({ + Logging.beInfo()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, module: MODULE_NAME, method: 'handleStartTransaction', @@ -412,7 +413,7 @@ export default class OCPPService { }; } catch (error) { this.addChargingStationToException(error, headers.chargeBoxIdentity); - await Logging.logActionExceptionMessage(headers.tenantID, ServerAction.OCPP_START_TRANSACTION, error, { startTransaction }); + Logging.logActionExceptionMessage(headers.tenantID, ServerAction.OCPP_START_TRANSACTION, error, { startTransaction }); // Invalid return { transactionId: 0, @@ -433,7 +434,7 @@ export default class OCPPService { this.enrichOCPPRequest(chargingStation, dataTransfer); // Save it await OCPPStorage.saveDataTransfer(tenant, dataTransfer); - await Logging.logInfo({ + Logging.beInfo()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, module: MODULE_NAME, method: 'handleDataTransfer', @@ -446,7 +447,7 @@ export default class OCPPService { }; } catch (error) { this.addChargingStationToException(error, headers.chargeBoxIdentity); - await Logging.logActionExceptionMessage(headers.tenantID, ServerAction.CHARGING_STATION_DATA_TRANSFER, error, { dataTransfer }); + Logging.logActionExceptionMessage(headers.tenantID, ServerAction.CHARGING_STATION_DATA_TRANSFER, error, { dataTransfer }); // Rejected return { status: OCPPDataTransferStatus.REJECTED @@ -464,7 +465,7 @@ export default class OCPPService { // Set header this.enrichOCPPRequest(chargingStation, stopTransaction, false); // Bypass Stop Transaction? - if (await this.bypassStopTransaction(tenant, chargingStation, stopTransaction)) { + if (this.bypassStopTransaction(tenant, chargingStation, stopTransaction)) { return { idTagInfo: { status: OCPPAuthorizationStatus.ACCEPTED @@ -502,7 +503,7 @@ export default class OCPPService { NotificationHelper.notifyStopTransaction(tenant, chargingStation, transaction, user, alternateUser); // Recompute the Smart Charging Plan await this.triggerSmartChargingStopTransaction(tenant, chargingStation, transaction); - await Logging.logInfo({ + Logging.beInfo()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, module: MODULE_NAME, method: 'handleStopTransaction', @@ -520,7 +521,7 @@ export default class OCPPService { }; } catch (error) { this.addChargingStationToException(error, headers.chargeBoxIdentity); - await Logging.logActionExceptionMessage(headers.tenantID, ServerAction.OCPP_STOP_TRANSACTION, error, { stopTransaction }); + Logging.logActionExceptionMessage(headers.tenantID, ServerAction.OCPP_STOP_TRANSACTION, error, { stopTransaction }); // Invalid return { idTagInfo: { @@ -662,13 +663,9 @@ export default class OCPPService { // Delete TxProfile if any await this.deleteAllTransactionTxProfile(tenant, transaction); // Call async because the Transaction ID on the connector should be cleared - // eslint-disable-next-line @typescript-eslint/no-misused-promises - setTimeout(async () => { - try { - // Trigger Smart Charging - await this.triggerSmartCharging(tenant, chargingStation.siteArea); - } catch (error) { - await Logging.logError({ + setTimeout(() => { + this.triggerSmartCharging(tenant, chargingStation.siteArea).catch((error) => { + Logging.beError()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, module: MODULE_NAME, method: 'triggerSmartChargingStopTransaction', @@ -676,7 +673,7 @@ export default class OCPPService { message: `${Utils.buildConnectorInfo(transaction.connectorId, transaction.id)} Smart Charging exception occurred`, detailedMessages: { error: error.stack, transaction, chargingStation } }); - } + }); }, Constants.DELAY_SMART_CHARGING_EXECUTION_MILLIS); } } @@ -692,7 +689,7 @@ export default class OCPPService { for (const chargingProfile of chargingProfiles.result) { try { await OCPPUtils.clearAndDeleteChargingProfile(tenant, chargingProfile); - await Logging.logDebug({ + Logging.beDebug()?.log({ ...LoggingHelper.getTransactionProperties(transaction), tenantID: tenant.id, action: ServerAction.CHARGING_PROFILE_DELETE, @@ -701,7 +698,7 @@ export default class OCPPService { detailedMessages: { chargingProfile } }); } catch (error) { - await Logging.logError({ + Logging.beError()?.log({ ...LoggingHelper.getTransactionProperties(transaction), tenantID: tenant.id, action: ServerAction.CHARGING_PROFILE_DELETE, @@ -744,7 +741,7 @@ export default class OCPPService { await ChargingStationStorage.saveChargingStation(tenant, chargingStation); // Process Smart Charging await this.processSmartChargingFromStatusNotification(tenant, chargingStation, connector, previousStatus); - await Logging.logInfo({ + Logging.beInfo()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, module: MODULE_NAME, method: 'processConnectorStatusNotification', @@ -753,7 +750,7 @@ export default class OCPPService { detailedMessages: { statusNotification, connector } }); // Notify Users - await this.notifyStatusNotification(tenant, chargingStation, connector, statusNotification); + this.notifyStatusNotification(tenant, chargingStation, connector, statusNotification); } } @@ -766,7 +763,7 @@ export default class OCPPService { // Trigger Smart Charging await this.triggerSmartCharging(tenant, chargingStation.siteArea); } catch (error) { - await Logging.logError({ + Logging.beError()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, module: MODULE_NAME, method: 'processSmartChargingStatusNotification', @@ -810,7 +807,7 @@ export default class OCPPService { // Same Status Notification? } else if (Utils.objectAllPropertiesAreEqual(statusNotification, connector, ['status', 'info', 'errorCode', 'vendorErrorCode'])) { ignoreStatusNotification = true; - await Logging.logWarning({ + Logging.beWarning()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, action: ServerAction.OCPP_STATUS_NOTIFICATION, @@ -850,7 +847,7 @@ export default class OCPPService { await TransactionStorage.saveTransaction(tenant, lastTransaction); } } else { - await Logging.logWarning({ + Logging.beWarning()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, module: MODULE_NAME, method: 'checkAndUpdateLastCompletedTransactionFromStatusNotification', @@ -862,7 +859,7 @@ export default class OCPPService { // Clear Connector Runtime Data OCPPUtils.clearChargingStationConnectorRuntimeData(chargingStation, lastTransaction.connectorId); } catch (error) { - await Logging.logWarning({ + Logging.beWarning()?.log({ ...LoggingHelper.getTransactionProperties(lastTransaction), tenantID: tenant.id, module: MODULE_NAME, method: 'checkAndUpdateLastCompletedTransactionFromStatusNotification', @@ -897,7 +894,7 @@ export default class OCPPService { Utils.createDecimal(currentStatusNotifTimestamp.getTime()).minus(transactionStopTimestamp.getTime()).div(1000).floor().toNumber(); // Negative inactivity if (transaction.stop.extraInactivitySecs < 0) { - await Logging.logWarning({ + Logging.beWarning()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, module: MODULE_NAME, method: 'checkAndComputeTransactionExtraInactivityFromStatusNotification', @@ -915,7 +912,7 @@ export default class OCPPService { ); // Build extra inactivity consumption await OCPPUtils.buildAndPriceExtraConsumptionInactivity(tenant, user, chargingStation, transaction); - await Logging.logInfo({ + Logging.beInfo()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, user: transaction.userID, @@ -927,7 +924,7 @@ export default class OCPPService { } } else { // No extra inactivity - connector status is not set to FINISHING - await Logging.logInfo({ + Logging.beInfo()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, user: transaction.userID, @@ -956,12 +953,12 @@ export default class OCPPService { return transactionUpdated; } - private async notifyStatusNotification(tenant: Tenant, chargingStation: ChargingStation, connector: Connector, statusNotification: OCPPStatusNotificationRequestExtended) { + private notifyStatusNotification(tenant: Tenant, chargingStation: ChargingStation, connector: Connector, statusNotification: OCPPStatusNotificationRequestExtended): void { // Faulted? if (connector.status !== ChargePointStatus.AVAILABLE && connector.status !== ChargePointStatus.FINISHING && // TODO: To remove after fix of ABB bug having Finishing status with an Error Code to avoid spamming Admins connector.errorCode !== ChargePointErrorCode.NO_ERROR) { - await Logging.logError({ + Logging.beError()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, action: ServerAction.OCPP_STATUS_NOTIFICATION, @@ -1194,7 +1191,7 @@ export default class OCPPService { meterValues.values = meterValues.values.filter(async (meterValue) => { // Remove Sample Clock if (meterValue.attribute && meterValue.attribute.context === OCPPReadingContext.SAMPLE_CLOCK) { - await Logging.logWarning({ + Logging.beWarning()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, module: MODULE_NAME, method: 'filterMeterValuesOnSpecificChargingStations', @@ -1285,8 +1282,13 @@ export default class OCPPService { }; } - private async processExistingTransaction(tenant: Tenant, chargingStation: ChargingStation, connectorId: number) { + private async processExistingTransaction(tenant: Tenant, chargingStation: ChargingStation, connectorId: number): Promise { + if (!FeatureToggles.isFeatureActive(Feature.OCPP_PROCESS_EXISTING_TRANSACTION)) { + // Skip the code below - for better performances + return Promise.resolve(); + } let activeTransaction: Transaction, lastCheckedTransactionID: number; + // TODO - to be clarified - why do we have a loop here! do { // Check if the charging station has already a transaction activeTransaction = await TransactionStorage.getActiveTransaction(tenant, chargingStation.id, connectorId); @@ -1299,7 +1301,7 @@ export default class OCPPService { // Has consumption? if (activeTransaction.currentTotalConsumptionWh <= 0) { // No consumption: delete - await Logging.logWarning({ + Logging.beWarning()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, module: MODULE_NAME, method: 'stopOrDeleteActiveTransactions', @@ -1313,6 +1315,7 @@ export default class OCPPService { OCPPUtils.clearChargingStationConnectorRuntimeData(chargingStation, activeTransaction.connectorId); } else { // Simulate a Stop Transaction + // TODO - To be clarified - the code below does not pass a valid OcppHeader const result = await this.handleStopTransaction({ tenantID: tenant.id, chargeBoxIdentity: activeTransaction.chargeBoxID, @@ -1327,7 +1330,7 @@ export default class OCPPService { }, false, true); if (result.idTagInfo.status === OCPPAuthorizationStatus.INVALID) { // Cannot stop it - await Logging.logError({ + Logging.beError()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, module: MODULE_NAME, method: 'stopOrDeleteActiveTransactions', @@ -1338,7 +1341,7 @@ export default class OCPPService { }); } else { // Stopped - await Logging.logWarning({ + Logging.beWarning()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, module: MODULE_NAME, method: 'stopOrDeleteActiveTransactions', @@ -1713,11 +1716,11 @@ export default class OCPPService { } } - private async bypassStopTransaction(tenant: Tenant, chargingStation: ChargingStation, - stopTransaction: OCPPStopTransactionRequestExtended): Promise { + private bypassStopTransaction(tenant: Tenant, chargingStation: ChargingStation, + stopTransaction: OCPPStopTransactionRequestExtended): boolean { // Ignore it (DELTA bug)? if (stopTransaction.transactionId === 0) { - await Logging.logWarning({ + Logging.beWarning()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, module: MODULE_NAME, method: 'bypassStopTransaction', @@ -1745,10 +1748,10 @@ export default class OCPPService { tenant, meterValues.transactionId, { withUser: true, withTag: true, withCar: true }); if (!transaction) { // Abort the ongoing Transaction - if (meterValues.transactionId) { + if (FeatureToggles.isFeatureActive(Feature.OCPP_METER_VALUE_ABORT_GHOST_TRANSACTION)) { await this.abortOngoingTransactionInMeterValues(tenant, chargingStation, meterValues); } - // Unkown Transaction + // Unknown Transaction throw new BackendError({ ...LoggingHelper.getChargingStationProperties(chargingStation), module: MODULE_NAME, method: 'getTransactionFromMeterValues', @@ -1758,20 +1761,22 @@ export default class OCPPService { }); } // Transaction finished - if (transaction?.stop) { + if (transaction.stop) { // Abort the ongoing Transaction - await this.abortOngoingTransactionInMeterValues(tenant, chargingStation, meterValues); + if (FeatureToggles.isFeatureActive(Feature.OCPP_METER_VALUE_ABORT_GHOST_TRANSACTION)) { + await this.abortOngoingTransactionInMeterValues(tenant, chargingStation, meterValues); + } throw new BackendError({ ...LoggingHelper.getChargingStationProperties(chargingStation), module: MODULE_NAME, method: 'getTransactionFromMeterValues', message: `${Utils.buildConnectorInfo(meterValues.connectorId, meterValues.transactionId)} Transaction has already been stopped`, action: ServerAction.OCPP_METER_VALUES, - detailedMessages: { transaction, meterValues } + detailedMessages: { meterValues } }); } // Received Meter Values after the Transaction End Meter Value if (transaction.transactionEndReceived) { - await Logging.logWarning({ + Logging.beWarning()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, module: MODULE_NAME, method: 'getTransactionFromMeterValues', @@ -1787,7 +1792,7 @@ export default class OCPPService { // Get the OCPP Client const chargingStationClient = await ChargingStationClientFactory.getChargingStationClient(tenant, chargingStation); if (!chargingStationClient) { - await Logging.logError({ + Logging.beError()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, module: MODULE_NAME, method: 'abortOngoingTransactionInMeterValues', @@ -1801,7 +1806,7 @@ export default class OCPPService { transactionId: meterValues.transactionId }); if (result.status === OCPPRemoteStartStopStatus.ACCEPTED) { - await Logging.logWarning({ + Logging.beWarning()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, module: MODULE_NAME, method: 'abortOngoingTransactionInMeterValues', @@ -1810,7 +1815,7 @@ export default class OCPPService { detailedMessages: { meterValues } }); } else { - await Logging.logError({ + Logging.beError()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, module: MODULE_NAME, method: 'abortOngoingTransactionInMeterValues', @@ -1871,7 +1876,7 @@ export default class OCPPService { } else if (transaction.lastConsumption) { // The consumption should be the same if (transaction.lastConsumption.value !== stopTransaction.meterStop) { - await Logging.logWarning({ + Logging.beWarning()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, action: ServerAction.OCPP_STOP_TRANSACTION, diff --git a/src/server/ocpp/soap/SoapOCPPServer.ts b/src/server/ocpp/soap/SoapOCPPServer.ts index 997ecbce44..76ce42f3b6 100644 --- a/src/server/ocpp/soap/SoapOCPPServer.ts +++ b/src/server/ocpp/soap/SoapOCPPServer.ts @@ -72,7 +72,7 @@ export default class SoapOCPPServer extends OCPPServer { } private async handleSoapServerMessage(ocppVersion: OCPPVersion, request: any, methodName: string) { - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: Constants.DEFAULT_TENANT_ID, module: MODULE_NAME, method: 'handleSoapServerMessage', action: ServerAction.EXPRESS_SERVER, @@ -84,7 +84,7 @@ export default class SoapOCPPServer extends OCPPServer { private async handleSoapServerLog(ocppVersion: OCPPVersion, type: string, data: any) { // Do not log 'Info' if (type === 'replied') { - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: Constants.DEFAULT_TENANT_ID, module: MODULE_NAME, method: 'handleSoapServerLog', action: ServerAction.EXPRESS_SERVER, diff --git a/src/server/ocpp/utils/OCPPCommon.ts b/src/server/ocpp/utils/OCPPCommon.ts index bad25b8252..cb6ad77719 100644 --- a/src/server/ocpp/utils/OCPPCommon.ts +++ b/src/server/ocpp/utils/OCPPCommon.ts @@ -35,7 +35,7 @@ export default class OCPPCommon { await OCPPCommon.requestAndSaveChargingStationOcppParameters(tenant, chargingStation); } if (triggerConditionalReset && result.status === OCPPConfigurationStatus.REBOOT_REQUIRED) { - await Logging.logInfo({ + Logging.beInfo()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, action: ServerAction.CHARGING_STATION_CHANGE_CONFIGURATION, @@ -52,7 +52,7 @@ export default class OCPPCommon { try { // Get the OCPP Configuration const ocppConfiguration = await OCPPCommon.requestChargingStationOcppParameters(tenant, chargingStation, {}); - await Logging.logDebug({ + Logging.beDebug()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, action: ServerAction.CHARGING_STATION_CHANGE_CONFIGURATION, @@ -90,7 +90,7 @@ export default class OCPPCommon { } // Save configuration await ChargingStationStorage.saveOcppParameters(tenant, chargingStationOcppParameters); - await Logging.logInfo({ + Logging.beInfo()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, action: ServerAction.CHARGING_STATION_CHANGE_CONFIGURATION, @@ -99,7 +99,7 @@ export default class OCPPCommon { }); return { status: OCPPConfigurationStatus.ACCEPTED }; } catch (error) { - await Logging.logActionExceptionMessage(tenant.id, ServerAction.CHARGING_STATION_CHANGE_CONFIGURATION, error); + Logging.logActionExceptionMessage(tenant.id, ServerAction.CHARGING_STATION_CHANGE_CONFIGURATION, error); return { status: OCPPConfigurationStatus.REJECTED }; } } @@ -118,7 +118,7 @@ export default class OCPPCommon { } let resetResult = await chargingStationClient.reset({ type: resetType }); if (resetResult.status === OCPPResetStatus.REJECTED) { - await Logging.logError({ + Logging.beError()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, action: ServerAction.CHARGING_STATION_RESET, @@ -126,7 +126,7 @@ export default class OCPPCommon { message: `Error at ${resetType} Rebooting charging station`, }); if (hardResetFallback && resetType !== OCPPResetType.HARD) { - await Logging.logInfo({ + Logging.beInfo()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, action: ServerAction.CHARGING_STATION_RESET, @@ -135,7 +135,7 @@ export default class OCPPCommon { }); resetResult = await chargingStationClient.reset({ type: OCPPResetType.HARD }); if (resetResult.status === OCPPResetStatus.REJECTED) { - await Logging.logError({ + Logging.beError()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, action: ServerAction.CHARGING_STATION_RESET, diff --git a/src/server/ocpp/utils/OCPPUtils.ts b/src/server/ocpp/utils/OCPPUtils.ts index 035373aa7d..de6bf0281b 100644 --- a/src/server/ocpp/utils/OCPPUtils.ts +++ b/src/server/ocpp/utils/OCPPUtils.ts @@ -482,7 +482,7 @@ export default class OCPPUtils { // Meter Value is in the past if (transaction.lastConsumption?.timestamp && meterValue.timestamp && moment(meterValue?.timestamp).isBefore(moment(transaction?.lastConsumption?.timestamp))) { - await Logging.logError({ + Logging.beError()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, module: MODULE_NAME, method: 'createConsumptionsFromMeterValues', @@ -795,7 +795,7 @@ export default class OCPPUtils { // Add unknown Connector ID chargingStation.chargePoints[0].connectorIDs.push(connector.connectorId); } - await Logging.logWarning({ + Logging.beWarning()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, action: ServerAction.UPDATE_CHARGING_STATION_WITH_TEMPLATE, @@ -821,7 +821,7 @@ export default class OCPPUtils { } // Not found but not master/salve if (!foundTemplateConnector) { - await Logging.logError({ + Logging.beError()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, action: ServerAction.UPDATE_CHARGING_STATION_WITH_TEMPLATE, @@ -874,7 +874,7 @@ export default class OCPPUtils { await OCPPUtils.setConnectorPhaseAssignment(tenant, chargingStation, connector, numberOfPhases); } // Success - await Logging.logInfo({ + Logging.beInfo()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, action: ServerAction.UPDATE_CHARGING_STATION_WITH_TEMPLATE, @@ -885,7 +885,7 @@ export default class OCPPUtils { return true; } // No Connector in Template - await Logging.logError({ + Logging.beError()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, action: ServerAction.UPDATE_CHARGING_STATION_WITH_TEMPLATE, @@ -896,7 +896,7 @@ export default class OCPPUtils { return false; } // No Template - await Logging.logInfo({ + Logging.beInfo()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, action: ServerAction.UPDATE_CHARGING_STATION_WITH_TEMPLATE, @@ -920,7 +920,7 @@ export default class OCPPUtils { } public static async applyTemplateOcppParametersToChargingStation(tenant: Tenant, chargingStation: ChargingStation): Promise { - await Logging.logInfo({ + Logging.beInfo()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, action: ServerAction.UPDATE_CHARGING_STATION_WITH_TEMPLATE, @@ -932,7 +932,7 @@ export default class OCPPUtils { Constants.DELAY_CHANGE_CONFIGURATION_EXECUTION_MILLIS, OCPPCommon.requestAndSaveChargingStationOcppParameters(tenant, chargingStation), `Time out error (${Constants.DELAY_CHANGE_CONFIGURATION_EXECUTION_MILLIS} ms): Cannot update Charging Station with Template's OCPP Parameters`); if (result.status !== OCPPConfigurationStatus.ACCEPTED) { - await Logging.logError({ + Logging.beError()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, action: ServerAction.UPDATE_CHARGING_STATION_WITH_TEMPLATE, @@ -945,7 +945,7 @@ export default class OCPPUtils { Constants.DELAY_CHANGE_CONFIGURATION_EXECUTION_MILLIS, OCPPUtils.updateChargingStationOcppParametersWithTemplate(tenant, chargingStation), `Time out error (${Constants.DELAY_CHANGE_CONFIGURATION_EXECUTION_MILLIS} ms): Cannot update Charging Station with Template's OCPP Parameters`); if (result.status === OCPPConfigurationStatus.ACCEPTED) { - await Logging.logInfo({ + Logging.beInfo()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, action: ServerAction.UPDATE_CHARGING_STATION_WITH_TEMPLATE, @@ -953,7 +953,7 @@ export default class OCPPUtils { message: 'Charging Station has been successfully updated with Template\'s OCPP Parameters', }); } else { - await Logging.logError({ + Logging.beError()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, action: ServerAction.UPDATE_CHARGING_STATION_WITH_TEMPLATE, @@ -984,7 +984,7 @@ export default class OCPPUtils { await this.clearAndDeleteChargingProfile(tenant, chargingProfile); actionsResponse.inSuccess++; } catch (error) { - await Logging.logError({ + Logging.beError()?.log({ tenantID: tenant.id, siteID: chargingProfile.chargingStation?.siteID, siteAreaID: chargingProfile.chargingStation?.siteAreaID, @@ -1039,7 +1039,7 @@ export default class OCPPUtils { try { await chargingStationVendor.clearChargingProfile(tenant, chargingStation, chargingProfile); } catch (error) { - await Logging.logError({ + Logging.beError()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, action: ServerAction.CHARGING_PROFILE_DELETE, @@ -1051,7 +1051,7 @@ export default class OCPPUtils { } // Delete from database await ChargingStationStorage.deleteChargingProfile(tenant, chargingProfile.id); - await Logging.logInfo({ + Logging.beInfo()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, action: ServerAction.CHARGING_PROFILE_DELETE, @@ -1136,7 +1136,7 @@ export default class OCPPUtils { } // Save const chargingProfileID = await ChargingStationStorage.saveChargingProfile(tenant, chargingProfile); - await Logging.logInfo({ + Logging.beInfo()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, action: ServerAction.CHARGING_PROFILE_UPDATE, @@ -1244,6 +1244,14 @@ export default class OCPPUtils { message: `Tenant ID '${tenantID}' does not exist!` }); } + // Check consistency + if (!tenant?.id || !tenant?.components) { + throw new BackendError({ + chargingStationID, + module: MODULE_NAME, method: 'checkAndGetChargingStationData', + message: `Tenant ID '${tenantID}' data is not consistent - sounds like the database is under pressure!` + }); + } // Get the Charging Station let token: RegistrationToken; const chargingStation = await ChargingStationStorage.getChargingStation( @@ -1268,7 +1276,7 @@ export default class OCPPUtils { // Must have a valid connection Token token = await OCPPUtils.ensureChargingStationHasValidConnectionToken(action, tenant, chargingStationID, tokenID); // Ok, set it - await Logging.logInfo({ + Logging.beInfo()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, action, module: MODULE_NAME, method: 'checkAndGetChargingStationData', @@ -1322,7 +1330,7 @@ export default class OCPPUtils { const currentOcppParameters = (await ChargingStationStorage.getOcppParameters(tenant, chargingStation.id)).result; if (Utils.isEmptyArray(chargingStation.ocppStandardParameters) && Utils.isEmptyArray(chargingStation.ocppVendorParameters)) { - await Logging.logInfo({ + Logging.beInfo()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, action: ServerAction.CHARGING_STATION_CHANGE_CONFIGURATION, @@ -1342,7 +1350,7 @@ export default class OCPPUtils { // Check Value if (currentOcppParam && currentOcppParam.value === ocppParameter.value) { // Ok: Already the good value - await Logging.logInfo({ + Logging.beInfo()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, action: ServerAction.CHARGING_STATION_CHANGE_CONFIGURATION, @@ -1358,7 +1366,7 @@ export default class OCPPUtils { }, false); if (result.status === OCPPConfigurationStatus.ACCEPTED) { updatedOcppParameters.inSuccess++; - await Logging.logInfo({ + Logging.beInfo()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, action: ServerAction.CHARGING_STATION_CHANGE_CONFIGURATION, @@ -1368,7 +1376,7 @@ export default class OCPPUtils { } else if (result.status === OCPPConfigurationStatus.REBOOT_REQUIRED) { updatedOcppParameters.inSuccess++; rebootRequired = true; - await Logging.logInfo({ + Logging.beInfo()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, action: ServerAction.CHARGING_STATION_CHANGE_CONFIGURATION, @@ -1377,7 +1385,7 @@ export default class OCPPUtils { }); } else { updatedOcppParameters.inError++; - await Logging.logError({ + Logging.beError()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, action: ServerAction.CHARGING_STATION_CHANGE_CONFIGURATION, @@ -1387,7 +1395,7 @@ export default class OCPPUtils { } } catch (error) { updatedOcppParameters.inError++; - await Logging.logError({ + Logging.beError()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, action: ServerAction.CHARGING_STATION_CHANGE_CONFIGURATION, @@ -1435,7 +1443,7 @@ export default class OCPPUtils { // Log const instantPower = Utils.truncTo(Utils.createDecimal(connector.currentInstantWatts).div(1000).toNumber(), 3); const totalConsumption = Utils.truncTo(Utils.createDecimal(connector.currentTotalConsumptionWh).div(1000).toNumber(), 3); - await Logging.logInfo({ + Logging.beInfo()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, module: MODULE_NAME, method: 'updateChargingStationConnectorRuntimeDataWithTransaction', @@ -1514,7 +1522,7 @@ export default class OCPPUtils { }; // Do not apply template if manual configured if (chargingStation.manualConfiguration) { - await Logging.logWarning({ + Logging.beWarning()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, action: ServerAction.UPDATE_CHARGING_STATION_WITH_TEMPLATE, @@ -1529,7 +1537,7 @@ export default class OCPPUtils { if (chargingStationTemplate) { // Already updated? if (chargingStation.templateHash !== chargingStationTemplate.hash) { - await Logging.logInfo({ + Logging.beInfo()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, action: ServerAction.UPDATE_CHARGING_STATION_WITH_TEMPLATE, @@ -1552,7 +1560,7 @@ export default class OCPPUtils { // Update chargingStation.templateHash = chargingStationTemplate.hash; templateUpdateResult.chargingStationUpdated = true; - await Logging.logInfo({ + Logging.beInfo()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, action: ServerAction.UPDATE_CHARGING_STATION_WITH_TEMPLATE, @@ -1561,7 +1569,7 @@ export default class OCPPUtils { detailedMessages: { templateUpdateResult, chargingStationTemplate, chargingStation } }); } else { - await Logging.logInfo({ + Logging.beInfo()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, action: ServerAction.UPDATE_CHARGING_STATION_WITH_TEMPLATE, @@ -1577,7 +1585,7 @@ export default class OCPPUtils { } } } else { - await Logging.logInfo({ + Logging.beInfo()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, action: ServerAction.UPDATE_CHARGING_STATION_WITH_TEMPLATE, @@ -1635,7 +1643,7 @@ export default class OCPPUtils { if (matchFirmware && matchOcpp) { for (const parameter in ocppParameters.parameters) { if (OCPPUtils.isOcppParamForPowerLimitationKey(parameter, chargingStation)) { - await Logging.logError({ + Logging.beError()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, action: ServerAction.UPDATE_CHARGING_STATION_WITH_TEMPLATE, @@ -1646,7 +1654,7 @@ export default class OCPPUtils { continue; } if (Constants.OCPP_HEARTBEAT_KEYS.includes(parameter)) { - await Logging.logWarning({ + Logging.beWarning()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, action: ServerAction.UPDATE_CHARGING_STATION_WITH_TEMPLATE, @@ -1665,7 +1673,7 @@ export default class OCPPUtils { } } // Not found - await Logging.logWarning({ + Logging.beWarning()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, action: ServerAction.UPDATE_CHARGING_STATION_WITH_TEMPLATE, @@ -1712,7 +1720,7 @@ export default class OCPPUtils { } } // Not found - await Logging.logWarning({ + Logging.beWarning()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, action: ServerAction.UPDATE_CHARGING_STATION_WITH_TEMPLATE, diff --git a/src/server/ocpp/validator/OCPPValidator.ts b/src/server/ocpp/validator/OCPPValidator.ts index d04285ee24..dc24219d15 100644 --- a/src/server/ocpp/validator/OCPPValidator.ts +++ b/src/server/ocpp/validator/OCPPValidator.ts @@ -106,13 +106,13 @@ export default class OCPPValidator extends SchemaValidator { } } - public async validateMeterValues(tenantID: string, chargingStation: ChargingStation, meterValues: OCPPMeterValuesRequestExtended): Promise { + public validateMeterValues(tenantID: string, chargingStation: ChargingStation, meterValues: OCPPMeterValuesRequestExtended): void { // Always integer this.validate(this.meterValueRequest, meterValues); // Check Connector ID if (meterValues.connectorId === 0) { // KEBA: Connector ID must be > 0 according to OCPP - await Logging.logWarning({ + Logging.beWarning()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenantID, module: MODULE_NAME, method: 'validateMeterValues', @@ -125,7 +125,7 @@ export default class OCPPValidator extends SchemaValidator { // Check if the transaction ID matches with the one on the Connector const foundConnector = Utils.getConnectorFromID(chargingStation, meterValues.connectorId); if (!foundConnector) { - await Logging.logWarning({ + Logging.beWarning()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenantID, module: MODULE_NAME, method: 'validateMeterValues', @@ -140,7 +140,7 @@ export default class OCPPValidator extends SchemaValidator { if (meterValues.transactionId === 0 && foundConnector.currentTransactionID > 0) { // Reuse Transaction ID from Connector meterValues.transactionId = foundConnector.currentTransactionID; - await Logging.logWarning({ + Logging.beWarning()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenantID, module: MODULE_NAME, method: 'validateMeterValues', diff --git a/src/server/odata/ODataRestAdapter.ts b/src/server/odata/ODataRestAdapter.ts index 648f0d7378..078bd3633c 100644 --- a/src/server/odata/ODataRestAdapter.ts +++ b/src/server/odata/ODataRestAdapter.ts @@ -97,7 +97,7 @@ export default class ODataRestAdapter { } } catch (error) { // Add logging - await Logging.logError({ + Logging.beError()?.log({ tenantID: req.user.tenantID, module: MODULE_NAME, method: 'query', action: ServerAction.ODATA_SERVER, diff --git a/src/server/odata/odata-schema/ODataSchema.ts b/src/server/odata/odata-schema/ODataSchema.ts index e41221636a..a00c038c71 100644 --- a/src/server/odata/odata-schema/ODataSchema.ts +++ b/src/server/odata/odata-schema/ODataSchema.ts @@ -42,7 +42,7 @@ export default class ODataSchema { } } catch (error) { // Add logging: login info - await Logging.logError({ + Logging.beError()?.log({ tenantID: Constants.DEFAULT_TENANT_ID, module: MODULE_NAME, method: 'getSchema', action: ServerAction.ODATA_SERVER, diff --git a/src/server/oicp/AbstractOICPService.ts b/src/server/oicp/AbstractOICPService.ts index 246baa4acf..d223870c95 100644 --- a/src/server/oicp/AbstractOICPService.ts +++ b/src/server/oicp/AbstractOICPService.ts @@ -103,7 +103,7 @@ export default abstract class AbstractOICPService { // Handle request action (endpoint) const endpoint = registeredEndpoints.get(endpointName); if (endpoint) { - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: tenant.id, module: MODULE_NAME, method: endpointName, message: `>> OICP Request ${req.method} ${req.originalUrl}`, @@ -112,7 +112,7 @@ export default abstract class AbstractOICPService { }); const response = await endpoint.process(req, res, next, tenant); if (response) { - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: tenant.id, module: MODULE_NAME, method: endpointName, message: `<< OICP Response ${req.method} ${req.originalUrl}`, @@ -121,7 +121,7 @@ export default abstract class AbstractOICPService { }); res.json(response); } else { - await Logging.logWarning({ + Logging.beWarning()?.log({ tenantID: tenant.id, module: MODULE_NAME, method: endpointName, message: `<< OICP Endpoint ${req.method} ${req.originalUrl} not implemented`, @@ -139,14 +139,14 @@ export default abstract class AbstractOICPService { }); } } catch (error) { - await Logging.logError({ + Logging.beError()?.log({ tenantID: req.user && req.user.tenantID ? req.user.tenantID : Constants.DEFAULT_TENANT_ID, module: MODULE_NAME, method: endpointName, message: `<< OICP Response Error ${req.method} ${req.originalUrl}`, action: ServerAction.OICP_ENDPOINT, detailedMessages: { error: error.stack } }); - await Logging.logActionExceptionMessage(req.user && req.user.tenantID ? req.user.tenantID : Constants.DEFAULT_TENANT_ID, ServerAction.OICP_ENDPOINT, error); + Logging.logActionExceptionMessage(req.user && req.user.tenantID ? req.user.tenantID : Constants.DEFAULT_TENANT_ID, ServerAction.OICP_ENDPOINT, error); let errorCode: any = {}; if (error instanceof AppError || error instanceof AppAuthError) { errorCode = error.params.errorCode; diff --git a/src/server/oicp/OICPFacade.ts b/src/server/oicp/OICPFacade.ts index 3204ac2d68..19f48244fc 100644 --- a/src/server/oicp/OICPFacade.ts +++ b/src/server/oicp/OICPFacade.ts @@ -58,7 +58,7 @@ export default class OICPFacade { // Update OICP Session await oicpClient.updateSession(transaction); } catch (error) { - await Logging.logWarning({ + Logging.beWarning()?.log({ ...LoggingHelper.getTransactionProperties(transaction), tenantID: tenant.id, action, module: MODULE_NAME, method: 'processUpdateTransaction', @@ -128,7 +128,7 @@ export default class OICPFacade { } } } catch (error) { - await Logging.logError({ + Logging.beError()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, module: MODULE_NAME, method: 'updateConnectorStatus', diff --git a/src/server/oicp/oicp-services-impl/oicp-2.3.0/CPORemoteAuthorizationsEndpoint.ts b/src/server/oicp/oicp-services-impl/oicp-2.3.0/CPORemoteAuthorizationsEndpoint.ts index 876a6dc5a5..1a63f5fa9a 100644 --- a/src/server/oicp/oicp-services-impl/oicp-2.3.0/CPORemoteAuthorizationsEndpoint.ts +++ b/src/server/oicp/oicp-services-impl/oicp-2.3.0/CPORemoteAuthorizationsEndpoint.ts @@ -61,7 +61,7 @@ export default class CPORemoteAuthorizationsEndpoint extends AbstractEndpoint { const connector = chargingStationConnector.connector; const chargingStation = chargingStationConnector.chargingStation; if (!chargingStation) { - await Logging.logError({ + Logging.beError()?.log({ tenantID: tenant.id, action: ServerAction.OICP_AUTHORIZE_REMOTE_START, message: `Charging Station ID '${authorizeRemoteStart.EvseID}' not found`, @@ -70,7 +70,7 @@ export default class CPORemoteAuthorizationsEndpoint extends AbstractEndpoint { return OICPUtils.noSuccess(session, `EVSE for EvseID '${authorizeRemoteStart.EvseID}' not found`); } if (!connector) { - await Logging.logError({ + Logging.beError()?.log({ tenantID: tenant.id, action: ServerAction.OICP_AUTHORIZE_REMOTE_START, message: `Connector for Charging Station ID '${authorizeRemoteStart.EvseID}' not found`, @@ -79,7 +79,7 @@ export default class CPORemoteAuthorizationsEndpoint extends AbstractEndpoint { return OICPUtils.noSuccess(session, `EVSE for EvseID '${authorizeRemoteStart.EvseID}' not found`); } if (!chargingStation.issuer || !chargingStation.public) { - await Logging.logError({ + Logging.beError()?.log({ tenantID: tenant.id, action: ServerAction.OICP_AUTHORIZE_REMOTE_START, message: `Charging Station ID '${authorizeRemoteStart.EvseID}' cannot be used with OICP`, @@ -88,7 +88,7 @@ export default class CPORemoteAuthorizationsEndpoint extends AbstractEndpoint { return OICPUtils.noSuccess(session, `EVSE '${authorizeRemoteStart.EvseID}' cannot be used with OICP`); } if (connector.status !== ChargePointStatus.AVAILABLE && connector.status !== ChargePointStatus.PREPARING) { - await Logging.logError({ + Logging.beError()?.log({ tenantID: tenant.id, action: ServerAction.OICP_AUTHORIZE_REMOTE_START, message: `Charging Station ID '${authorizeRemoteStart.EvseID}' is not available`, @@ -108,7 +108,7 @@ export default class CPORemoteAuthorizationsEndpoint extends AbstractEndpoint { // Check if authorization of different user is valid if (OICPUtils.isAuthorizationValid(existingAuthorization.timestamp)) { // Current remote authorization fails due to valid remote authorization of different user - await Logging.logDebug({ + Logging.beDebug()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, action: ServerAction.OICP_AUTHORIZE_REMOTE_START, @@ -155,7 +155,7 @@ export default class CPORemoteAuthorizationsEndpoint extends AbstractEndpoint { session.providerID = authorizeRemoteStop.ProviderID; const transaction = await TransactionStorage.getOICPTransactionBySessionID(tenant, authorizeRemoteStop.SessionID); if (!transaction) { - await Logging.logError({ + Logging.beError()?.log({ tenantID: tenant.id, action: ServerAction.OICP_AUTHORIZE_REMOTE_STOP, message: `OICP Transaction ID '${authorizeRemoteStop.SessionID}' does not exists`, @@ -164,7 +164,7 @@ export default class CPORemoteAuthorizationsEndpoint extends AbstractEndpoint { return OICPUtils.noSuccess(session, `Transaction with OICP Transaction ID '${authorizeRemoteStop.SessionID}' does not exists`); } if (!transaction.issuer) { - await Logging.logError({ + Logging.beError()?.log({ tenantID: tenant.id, action: ServerAction.OICP_AUTHORIZE_REMOTE_STOP, message: `OICP Transaction ID '${authorizeRemoteStop.SessionID}' has been issued locally`, @@ -173,7 +173,7 @@ export default class CPORemoteAuthorizationsEndpoint extends AbstractEndpoint { return OICPUtils.noSuccess(session, `Transaction with OICP Transaction ID '${authorizeRemoteStop.SessionID}' has been issued locally`); } if (transaction.stop) { - await Logging.logError({ + Logging.beError()?.log({ tenantID: tenant.id, action: ServerAction.OICP_AUTHORIZE_REMOTE_STOP, message: `OICP Transaction ID '${authorizeRemoteStop.SessionID}' is already stopped`, @@ -183,7 +183,7 @@ export default class CPORemoteAuthorizationsEndpoint extends AbstractEndpoint { } const chargingStation = await ChargingStationStorage.getChargingStation(tenant, transaction.chargeBoxID); if (!chargingStation) { - await Logging.logError({ + Logging.beError()?.log({ ...LoggingHelper.getTransactionProperties(transaction), tenantID: tenant.id, action: ServerAction.OICP_AUTHORIZE_REMOTE_STOP, @@ -204,7 +204,7 @@ export default class CPORemoteAuthorizationsEndpoint extends AbstractEndpoint { connector: Connector, authorizeRemoteStart: OICPAuthorizeRemoteStartCpoReceive): Promise { const chargingStationClient = await ChargingStationClientFactory.getChargingStationClient(tenant, chargingStation); if (!chargingStationClient) { - await Logging.logError({ + Logging.beError()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, action: ServerAction.OICP_AUTHORIZE_REMOTE_START, @@ -222,7 +222,7 @@ export default class CPORemoteAuthorizationsEndpoint extends AbstractEndpoint { private async remoteStopTransaction(tenant: Tenant, chargingStation: ChargingStation, transactionId: number): Promise { const chargingStationClient = await ChargingStationClientFactory.getChargingStationClient(tenant, chargingStation); if (!chargingStationClient) { - await Logging.logError({ + Logging.beError()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, action: ServerAction.OICP_AUTHORIZE_REMOTE_STOP, diff --git a/src/server/rest/RestServerService.ts b/src/server/rest/RestServerService.ts index 8c25795ee9..e79ea3846b 100644 --- a/src/server/rest/RestServerService.ts +++ b/src/server/rest/RestServerService.ts @@ -253,7 +253,7 @@ export default class RestServerService { try { // Parse the action const action = req.params.action as ServerAction; - await Logging.logWarning({ + Logging.beWarning()?.log({ tenantID: Constants.DEFAULT_TENANT_ID, message: `REST Endpoint 'restServiceUtil' should not be used for action '${action}'`, action: ServerAction.DEPRECATED_REST_ENDPOINT, @@ -311,7 +311,7 @@ export default class RestServerService { // Parse the action const action = req.params.action as ServerAction; // Old endpoint: should not be used - await Logging.logWarning({ + Logging.beWarning()?.log({ tenantID: req.tenant?.id, message: `REST Endpoint 'restServiceSecured' should not be used for action '${action}'`, action: ServerAction.DEPRECATED_REST_ENDPOINT, @@ -319,7 +319,7 @@ export default class RestServerService { }); // Check HTTP Verbs if (!['POST', 'GET', 'PUT', 'DELETE'].includes(req.method)) { - await Logging.logActionExceptionMessageAndSendResponse( + Logging.logActionExceptionMessageAndSendResponse( null, new Error(`Unsupported request method ${req.method}`), req, res, next); return; } diff --git a/src/server/rest/v1/service/AssetService.ts b/src/server/rest/v1/service/AssetService.ts index 574f7a6f04..b5875c8ab9 100644 --- a/src/server/rest/v1/service/AssetService.ts +++ b/src/server/rest/v1/service/AssetService.ts @@ -166,7 +166,7 @@ export default class AssetService { res.json(Object.assign({ connectionIsValid: true }, Constants.REST_RESPONSE_SUCCESS)); } catch (error) { // KO - await Logging.logError({ + Logging.beError()?.log({ tenantID: req.tenant.id, user: req.user, module: MODULE_NAME, method: 'handleCheckAssetConnection', @@ -292,7 +292,7 @@ export default class AssetService { // Delete await AssetStorage.deleteAsset(req.tenant, asset.id); // Log - await Logging.logInfo({ + Logging.beInfo()?.log({ ...LoggingHelper.getAssetProperties(asset), tenantID: req.tenant.id, user: req.user, @@ -422,7 +422,7 @@ export default class AssetService { // Save newAsset.id = await AssetStorage.saveAsset(req.tenant, newAsset); // Log - await Logging.logInfo({ + Logging.beInfo()?.log({ ...LoggingHelper.getAssetProperties(newAsset), tenantID: req.tenant.id, user: req.user, @@ -469,7 +469,7 @@ export default class AssetService { asset.lastChangedOn = new Date(); await AssetStorage.saveAsset(req.tenant, asset); // Log - await Logging.logInfo({ + Logging.beInfo()?.log({ ...LoggingHelper.getAssetProperties(asset), tenantID: req.tenant.id, user: req.user, diff --git a/src/server/rest/v1/service/AuthService.ts b/src/server/rest/v1/service/AuthService.ts index 51aa07dc8d..f15ae13045 100644 --- a/src/server/rest/v1/service/AuthService.ts +++ b/src/server/rest/v1/service/AuthService.ts @@ -77,7 +77,7 @@ export default class AuthService { // Yes: Check date to reset pass if (user.passwordBlockedUntil && moment(user.passwordBlockedUntil).isBefore(moment())) { // Time elapsed: activate the account again - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: req.user.tenantID, actionOnUser: user, module: MODULE_NAME, method: 'handleLogIn', action: action, @@ -199,7 +199,7 @@ export default class AuthService { }; await TagStorage.saveTag(req.tenant, tag); } - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: req.tenant.id, user: newUser, action: action, module: MODULE_NAME, @@ -251,7 +251,7 @@ export default class AuthService { const resetHash = Utils.generateUUID(); // Init Password info await UserStorage.saveUserPassword(tenant, user.id, { passwordResetHash: resetHash }); - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: tenant.id, user: user, action: action, module: MODULE_NAME, @@ -299,7 +299,7 @@ export default class AuthService { if (user.status === UserStatus.LOCKED) { await UserStorage.saveUserStatus(tenant, user.id, UserStatus.ACTIVE); } - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: tenant.id, user: user, action: action, module: MODULE_NAME, @@ -444,7 +444,7 @@ export default class AuthService { // Save User Verification Account await UserStorage.saveUserAccountVerification(req.tenant, user.id, { verificationToken: null, verifiedAt: new Date() }); - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: req.tenant.id, user: user, action: action, module: MODULE_NAME, method: 'handleVerifyEmail', @@ -523,7 +523,7 @@ export default class AuthService { // Get existing verificationToken verificationToken = user.verificationToken; } - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: req.tenant.id, user: user, action: action, @@ -598,7 +598,7 @@ export default class AuthService { public static async userLoginSucceeded(action: ServerAction, tenant: Tenant, user: User, req: Request, res: Response, next: NextFunction): Promise { // Password / Login OK - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: tenant.id, user: user, module: MODULE_NAME, method: 'checkUserLogin', diff --git a/src/server/rest/v1/service/BillingService.ts b/src/server/rest/v1/service/BillingService.ts index 0681971ef9..2a2c784060 100644 --- a/src/server/rest/v1/service/BillingService.ts +++ b/src/server/rest/v1/service/BillingService.ts @@ -59,7 +59,7 @@ export default class BillingService { res.json(operationResult); } catch (error) { // Ko - await Logging.logError({ + Logging.beError()?.log({ tenantID: req.tenant.id, user: req.user, module: MODULE_NAME, method: 'handleClearBillingTestData', @@ -96,7 +96,7 @@ export default class BillingService { res.json(Object.assign({ connectionIsValid: true }, Constants.REST_RESPONSE_SUCCESS)); } catch (error) { // Ko - await Logging.logError({ + Logging.beError()?.log({ tenantID: req.tenant.id, user: req.user, module: MODULE_NAME, method: 'handleCheckBillingConnection', @@ -296,7 +296,7 @@ export default class BillingService { const user: User = await UtilsService.checkAndGetUserAuthorization(req.tenant, req.user, filteredRequest.userID, Action.READ, action); // Invoke the billing implementation const paymentMethods: BillingPaymentMethod[] = await billingImpl.getPaymentMethods(user); - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: req.tenant.id, user, action: ServerAction.BILLING_PAYMENT_METHODS, @@ -339,7 +339,7 @@ export default class BillingService { // Invoke the billing implementation const operationResult: BillingOperationResult = await billingImpl.deletePaymentMethod(user, filteredRequest.paymentMethodId); // Log - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: req.tenant.id, user: req.user, module: MODULE_NAME, method: 'handleDeleteSite', message: `Payment Method '${filteredRequest.paymentMethodId}' has been deleted successfully`, diff --git a/src/server/rest/v1/service/CarService.ts b/src/server/rest/v1/service/CarService.ts index a589055a5d..b5d5d5d16b 100644 --- a/src/server/rest/v1/service/CarService.ts +++ b/src/server/rest/v1/service/CarService.ts @@ -242,7 +242,7 @@ export default class CarService { }; // Save newCar.id = await CarStorage.saveCar(req.tenant, newCar); - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: req.tenant.id, ...LoggingHelper.getCarProperties(newCar), user: req.user, module: MODULE_NAME, method: 'handleCreateCar', @@ -323,7 +323,7 @@ export default class CarService { if (setDefaultCarToOldUserID) { await CarService.setDefaultCarForUser(req.tenant, setDefaultCarToOldUserID); } - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: req.tenant.id, ...LoggingHelper.getCarProperties(car), user: req.user, module: MODULE_NAME, method: 'handleUpdateCar', @@ -405,7 +405,7 @@ export default class CarService { if (car.default) { await CarService.setDefaultCarForUser(req.tenant, car.userID); } - await Logging.logInfo({ + Logging.beInfo()?.log({ ...LoggingHelper.getCarProperties(car), tenantID: req.tenant.id, user: req.user, module: MODULE_NAME, method: 'handleDeleteCar', diff --git a/src/server/rest/v1/service/ChargingStationService.ts b/src/server/rest/v1/service/ChargingStationService.ts index 017d1c9869..d1b3c81494 100644 --- a/src/server/rest/v1/service/ChargingStationService.ts +++ b/src/server/rest/v1/service/ChargingStationService.ts @@ -87,7 +87,7 @@ export default class ChargingStationService { // Check and Apply Charging Station templates await ChargingStationService.checkAndApplyChargingStationTemplate( action, req.tenant, chargingStation, req.user, resetAndApplyTemplate); - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: req.tenant.id, action, user: req.user, module: MODULE_NAME, method: 'handleUpdateChargingStationParams', @@ -164,7 +164,7 @@ export default class ChargingStationService { detailedMessages: { result }, }); } - await Logging.logInfo({ + Logging.beInfo()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: req.tenant.id, action, user: req.user, @@ -397,7 +397,7 @@ export default class ChargingStationService { // Delete physically await ChargingStationStorage.deleteChargingStation(req.tenant, chargingStation.id); } - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: req.tenant.id, user: req.user, module: MODULE_NAME, method: 'handleDeleteChargingStation', message: `Charging Station '${chargingStation.id}' has been deleted successfully`, @@ -864,7 +864,7 @@ export default class ChargingStationService { } // OCPP Command with status if (Utils.objectHasProperty(result, 'status') && ![OCPPStatus.ACCEPTED, OCPPUnlockStatus.UNLOCKED].includes(result.status)) { - await Logging.logError({ + Logging.beError()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: req.tenant.id, user: req.user, @@ -874,7 +874,7 @@ export default class ChargingStationService { }); } else { // OCPP Command with no status - await Logging.logInfo({ + Logging.beInfo()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: req.tenant.id, user: req.user, @@ -1321,7 +1321,7 @@ export default class ChargingStationService { result.status === OCPPConfigurationStatus.REBOOT_REQUIRED) { // Reboot? if (result.status === OCPPConfigurationStatus.REBOOT_REQUIRED) { - await Logging.logWarning({ + Logging.beWarning()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: req.tenant.id, action, user: req.user, @@ -1389,7 +1389,7 @@ export default class ChargingStationService { await ocpiClient.patchChargingStationStatus(chargingStation, status); } } catch (error) { - await Logging.logError({ + Logging.beError()?.log({ tenantID: tenant.id, module: MODULE_NAME, method: 'updateChargingStationRoaming', action, @@ -1421,7 +1421,7 @@ export default class ChargingStationService { site, chargingStation.siteArea, chargingStation, options), actionType); } } catch (error) { - await Logging.logError({ + Logging.beError()?.log({ tenantID: tenant.id, module: MODULE_NAME, method: 'updateChargingStationRoaming', action, @@ -1453,7 +1453,7 @@ export default class ChargingStationService { site, siteArea, chargingStation, options), OICPActionType.DELETE); } } catch (error) { - await Logging.logError({ + Logging.beError()?.log({ tenantID: tenant.id, module: MODULE_NAME, method: 'deactivateChargingStationRoaming', action, @@ -1690,7 +1690,7 @@ export default class ChargingStationService { detailedMessages: { result: chargingProfiles[index] } }); } - await Logging.logWarning({ + Logging.beWarning()?.log({ ...LoggingHelper.getChargingStationProperties(chargingStation), tenantID: tenant.id, action, user, diff --git a/src/server/rest/v1/service/ChargingStationTemplateService.ts b/src/server/rest/v1/service/ChargingStationTemplateService.ts index e749391ed3..c464c7b424 100644 --- a/src/server/rest/v1/service/ChargingStationTemplateService.ts +++ b/src/server/rest/v1/service/ChargingStationTemplateService.ts @@ -34,7 +34,7 @@ export default class ChargingStationTemplateService { } }; newChargingStationTemplate.id = await ChargingStationTemplateStorage.saveChargingStationTemplate(newChargingStationTemplate); - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: req.tenant.id, user: req.user, module: MODULE_NAME, method: 'handleCreateChargingStationTemplate', message: `ChargingStationTemplate '${newChargingStationTemplate.id}' has been created successfully`, @@ -99,7 +99,7 @@ export default class ChargingStationTemplateService { const chargingStationTemplate = await UtilsService.checkAndGetChargingStationTemplateAuthorization(req.tenant, req.user, chargingStationTemplateID, Action.DELETE, action); // Delete await ChargingStationTemplateStorage.deleteChargingStationTemplate(req.tenant, chargingStationTemplate.id); - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: req.tenant.id, user: req.user, module: MODULE_NAME, method: 'handleDeleteChargingStationTemplate', message: `Charging Station Template'${chargingStationTemplate.id}' has been deleted successfully`, @@ -129,7 +129,7 @@ export default class ChargingStationTemplateService { chargingStationTemplate.lastChangedOn = new Date(); // Save await ChargingStationTemplateStorage.saveChargingStationTemplate(chargingStationTemplate); - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: req.tenant.id, user: req.user, module: MODULE_NAME, method: 'handleUpdateChargingStationTemplate', message: `'${chargingStationTemplate.id}' has been updated successfully`, diff --git a/src/server/rest/v1/service/CompanyService.ts b/src/server/rest/v1/service/CompanyService.ts index daceb2b644..136f92a69d 100644 --- a/src/server/rest/v1/service/CompanyService.ts +++ b/src/server/rest/v1/service/CompanyService.ts @@ -30,7 +30,7 @@ export default class CompanyService { req.tenant, req.user, companyID, Action.DELETE, action); // Delete await CompanyStorage.deleteCompany(req.tenant, company.id); - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: req.tenant.id, user: req.user, module: MODULE_NAME, method: 'handleDeleteCompany', message: `Company '${company.name}' has been deleted successfully`, @@ -163,7 +163,7 @@ export default class CompanyService { } // Save newCompany.id = await CompanyStorage.saveCompany(req.tenant, newCompany); - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: req.tenant.id, user: req.user, module: MODULE_NAME, method: 'handleCreateCompany', message: `Company '${newCompany.id}' has been created successfully`, @@ -203,7 +203,7 @@ export default class CompanyService { company.lastChangedOn = new Date(); // Update Company await CompanyStorage.saveCompany(req.tenant, company, Utils.objectHasProperty(filteredRequest, 'logo') ? true : false); - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: req.tenant.id, user: req.user, module: MODULE_NAME, method: 'handleUpdateCompany', message: `Company '${company.name}' has been updated successfully`, diff --git a/src/server/rest/v1/service/ConnectionService.ts b/src/server/rest/v1/service/ConnectionService.ts index 7f12d1f2fa..aff28cd8d6 100644 --- a/src/server/rest/v1/service/ConnectionService.ts +++ b/src/server/rest/v1/service/ConnectionService.ts @@ -104,7 +104,7 @@ export default class ConnectionService { if (!Utils.isNullOrUndefined(integrationConnector)) { // Create const connection: Connection = await integrationConnector.createConnection(filteredRequest.userId, filteredRequest.data); - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: req.tenant.id, user: req.user, module: MODULE_NAME, method: 'handleCreateConnection', message: `Connection to '${connection.connectorId}' has been created successfully`, @@ -141,7 +141,7 @@ export default class ConnectionService { // Delete await ConnectionStorage.deleteConnectionById(req.tenant, connection.id); // Log - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: req.tenant.id, user: req.user, actionOnUser: connection.userId, diff --git a/src/server/rest/v1/service/OCPIEndpointService.ts b/src/server/rest/v1/service/OCPIEndpointService.ts index e1b9f77b0d..4ac50d04c3 100644 --- a/src/server/rest/v1/service/OCPIEndpointService.ts +++ b/src/server/rest/v1/service/OCPIEndpointService.ts @@ -34,7 +34,7 @@ export default class OCPIEndpointService { const ocpiEndpoint = await UtilsService.checkAndGetOCPIEndpointAuthorization(req.tenant, req.user, filteredRequest.ID, Action.DELETE, action); // Delete await OCPIEndpointStorage.deleteOcpiEndpoint(req.tenant, ocpiEndpoint.id); - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: req.tenant.id, user: req.user, module: MODULE_NAME, method: 'handleDeleteOcpiEndpoint', message: `Ocpi Endpoint '${ocpiEndpoint.name}' has been deleted successfully`, @@ -108,7 +108,7 @@ export default class OCPIEndpointService { status: OCPIRegistrationStatus.NEW } as OCPIEndpoint; const endpointID = await OCPIEndpointStorage.saveOcpiEndpoint(req.tenant, ocpiEndpoint); - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: req.tenant.id, user: req.user, module: MODULE_NAME, method: 'handleCreateOcpiEndpoint', message: `Ocpi Endpoint '${filteredRequest.name}' has been created successfully`, @@ -132,7 +132,7 @@ export default class OCPIEndpointService { ocpiEndpoint.lastChangedOn = new Date(); // Update OcpiEndpoint await OCPIEndpointStorage.saveOcpiEndpoint(req.tenant, { ...ocpiEndpoint, ...filteredRequest }); - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: req.tenant.id, user: req.user, module: MODULE_NAME, method: 'handleUpdateOcpiEndpoint', message: `Ocpi Endpoint '${ocpiEndpoint.name}' has been updated successfully`, @@ -157,7 +157,7 @@ export default class OCPIEndpointService { const result = await ocpiClient.ping(); // Check ping result if (result.statusCode === StatusCodes.OK) { - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: req.tenant.id, user: req.user, module: MODULE_NAME, method: 'handlePingOcpiEndpoint', message: `Ocpi Endpoint '${filteredRequest.name}' can be reached successfully`, @@ -543,7 +543,7 @@ export default class OCPIEndpointService { const result = await ocpiClient.updateCredentials(); // Check ping result if (result.statusCode === StatusCodes.OK) { - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: req.tenant.id, user: req.user, module: MODULE_NAME, method: 'handleUpdateCredentialsOcpiEndpoint', message: `Ocpi Endpoint '${ocpiEndpoint.name}' can be reached successfully`, @@ -585,7 +585,7 @@ export default class OCPIEndpointService { const result = await ocpiClient.unregister(); // Check ping result if (result.statusCode === StatusCodes.OK) { - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: req.tenant.id, user: req.user, module: MODULE_NAME, method: 'handleUnregisterOcpiEndpoint', message: `Ocpi Endpoint '${ocpiEndpoint.name}' can be reached successfully`, @@ -627,7 +627,7 @@ export default class OCPIEndpointService { const result = await ocpiClient.register(); // Check ping result if (result.statusCode === StatusCodes.OK) { - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: req.tenant.id, user: req.user, module: MODULE_NAME, method: 'handleRegisterOcpiEndpoint', message: `Ocpi Endpoint '${ocpiEndpoint.name}' can be reached successfully`, @@ -663,7 +663,7 @@ export default class OCPIEndpointService { await AuthorizationService.checkAndGetOCPIEndpointsAuthorizations(req.tenant, req.user, Action.GENERATE_LOCAL_TOKEN); // Generate endpoint const localToken = OCPIUtils.generateLocalToken(req.tenant.subdomain); - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: req.tenant.id, user: req.user, module: MODULE_NAME, method: 'handleGenerateLocalTokenOcpiEndpoint', message: 'Local Token for Ocpi Endpoint has been generated successfully', diff --git a/src/server/rest/v1/service/OICPEndpointService.ts b/src/server/rest/v1/service/OICPEndpointService.ts index 7934c640a0..887b2c7d9b 100644 --- a/src/server/rest/v1/service/OICPEndpointService.ts +++ b/src/server/rest/v1/service/OICPEndpointService.ts @@ -44,7 +44,7 @@ export default class OICPEndpointService { // Delete await OICPEndpointStorage.deleteOicpEndpoint(req.tenant, oicpEndpoint.id); // Log - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: req.tenant.id, user: req.user, module: MODULE_NAME, method: 'handleDeleteOicpEndpoint', message: `Oicp Endpoint '${oicpEndpoint.name}' has been deleted successfully`, @@ -91,7 +91,7 @@ export default class OICPEndpointService { } as OICPEndpoint; const endpointID = await OICPEndpointStorage.saveOicpEndpoint(req.tenant, oicpEndpoint); // Log - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: req.tenant.id, user: req.user, module: MODULE_NAME, method: 'handleCreateOicpEndpoint', message: `Oicp Endpoint '${filteredRequest.name}' has been created successfully`, @@ -128,7 +128,7 @@ export default class OICPEndpointService { // Update OicpEndpoint await OICPEndpointStorage.saveOicpEndpoint(req.tenant, { ...oicpEndpoint, ...filteredRequest }); // Log - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: req.tenant.id, user: req.user, module: MODULE_NAME, method: 'handleUpdateOicpEndpoint', message: `Oicp Endpoint '${oicpEndpoint.name}' has been updated successfully`, @@ -293,7 +293,7 @@ export default class OICPEndpointService { // Check ping result if (pingResult.statusCode === OICPStatusCode.Code000) { // Log - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: req.tenant.id, user: req.user, module: MODULE_NAME, method: 'handlePingOicpEndpoint', message: `Oicp Endpoint '${oicpEndpoint.name}' can be reached successfully`, @@ -303,7 +303,7 @@ export default class OICPEndpointService { res.json(Object.assign(pingResult, Constants.REST_RESPONSE_SUCCESS)); } else { // Log - await Logging.logError({ + Logging.beError()?.log({ tenantID: req.tenant.id, user: req.user, module: MODULE_NAME, method: 'handlePingOicpEndpoint', message: `Oicp Endpoint '${oicpEndpoint.name}' cannot be reached`, @@ -341,7 +341,7 @@ export default class OICPEndpointService { // Check ping result if (result.statusCode === StatusCodes.OK) { // Log - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: req.tenant.id, user: req.user, module: MODULE_NAME, method: 'handleUnregisterOicpEndpoint', message: `Oicp Endpoint '${oicpEndpoint.name}' can be reached successfully`, @@ -351,7 +351,7 @@ export default class OICPEndpointService { res.json(Object.assign(result, Constants.REST_RESPONSE_SUCCESS)); } else { // Log - await Logging.logError({ + Logging.beError()?.log({ tenantID: req.tenant.id, user: req.user, module: MODULE_NAME, method: 'handleUnregisterOicpEndpoint', message: `Oicp Endpoint '${oicpEndpoint.name}' cannot be reached`, @@ -389,7 +389,7 @@ export default class OICPEndpointService { // Check ping result if (result.statusCode === StatusCodes.OK) { // Log - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: req.tenant.id, user: req.user, module: MODULE_NAME, method: 'handleRegisterOicpEndpoint', message: `Oicp Endpoint '${oicpEndpoint.name}' can be reached successfully`, @@ -399,7 +399,7 @@ export default class OICPEndpointService { res.json(Object.assign(result, Constants.REST_RESPONSE_SUCCESS)); } else { // Log - await Logging.logError({ + Logging.beError()?.log({ tenantID: req.tenant.id, user: req.user, module: MODULE_NAME, method: 'handleRegisterOicpEndpoint', message: `Oicp Endpoint '${oicpEndpoint.name}' cannot be reached`, diff --git a/src/server/rest/v1/service/PricingService.ts b/src/server/rest/v1/service/PricingService.ts index f4ca032361..e8567210e0 100644 --- a/src/server/rest/v1/service/PricingService.ts +++ b/src/server/rest/v1/service/PricingService.ts @@ -130,7 +130,7 @@ export default class PricingService { // Save newPricingDefinition.id = await PricingStorage.savePricingDefinition(req.tenant, newPricingDefinition); // Log - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: req.tenant.id, user: req.user, module: MODULE_NAME, method: 'handleCreatePricingDefinition', message: `Pricing model '${newPricingDefinition.id}' has been created successfully`, @@ -172,7 +172,7 @@ export default class PricingService { // Update Pricing await PricingStorage.savePricingDefinition(req.tenant, pricingDefinition); // Log - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: req.tenant.id, user: req.user, module: MODULE_NAME, method: 'handleUpdatePricingDefinition', message: `Pricing model '${pricingDefinition.id}' has been updated successfully`, @@ -201,7 +201,7 @@ export default class PricingService { // Delete await PricingStorage.deletePricingDefinition(req.tenant, pricingDefinition.id); // Log - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: req.tenant.id, user: req.user, module: MODULE_NAME, method: 'handleDeletePricingDefinition', message: `Pricing model '${pricingDefinitionID}' has been deleted successfully`, @@ -249,7 +249,7 @@ export default class PricingService { } catch (error) { canCreate = false; if (!(error instanceof AppAuthError)) { - await Logging.logError({ + Logging.beError()?.log({ tenantID: req.tenant.id, user: req.user, module: MODULE_NAME, method: 'alterCanCreate', message: 'Unexpected error while checking site access permissions', diff --git a/src/server/rest/v1/service/RegistrationTokenService.ts b/src/server/rest/v1/service/RegistrationTokenService.ts index 6a28ef380b..94c4de4ce8 100644 --- a/src/server/rest/v1/service/RegistrationTokenService.ts +++ b/src/server/rest/v1/service/RegistrationTokenService.ts @@ -41,7 +41,7 @@ export default class RegistrationTokenService { }; // Save registrationToken.id = await RegistrationTokenStorage.saveRegistrationToken(req.tenant, registrationToken); - await Logging.logInfo({ + Logging.beInfo()?.log({ ...LoggingHelper.getRegistrationTokenProperties(registrationToken), tenantID: req.tenant.id, user: req.user, module: MODULE_NAME, method: 'handleCreateRegistrationToken', @@ -72,7 +72,7 @@ export default class RegistrationTokenService { registrationToken.revocationDate = null; // Save await RegistrationTokenStorage.saveRegistrationToken(req.tenant, registrationToken); - await Logging.logInfo({ + Logging.beInfo()?.log({ ...LoggingHelper.getRegistrationTokenProperties(registrationToken), tenantID: req.tenant.id, user: req.user, module: MODULE_NAME, method: 'handleUpdateRegistrationToken', @@ -91,7 +91,7 @@ export default class RegistrationTokenService { req.tenant, req.user, registrationTokenID, Action.DELETE, action); // Delete await RegistrationTokenStorage.deleteRegistrationToken(req.tenant, registrationToken.id); - await Logging.logInfo({ + Logging.beInfo()?.log({ ...LoggingHelper.getRegistrationTokenProperties(registrationToken), tenantID: req.tenant.id, user: req.user, @@ -126,7 +126,7 @@ export default class RegistrationTokenService { registrationToken.lastChangedOn = now; // Save await RegistrationTokenStorage.saveRegistrationToken(req.tenant, registrationToken); - await Logging.logInfo({ + Logging.beInfo()?.log({ ...LoggingHelper.getRegistrationTokenProperties(registrationToken), tenantID: req.tenant.id, user: req.user, diff --git a/src/server/rest/v1/service/SettingService.ts b/src/server/rest/v1/service/SettingService.ts index d585d7fb8a..25f86d9f3c 100644 --- a/src/server/rest/v1/service/SettingService.ts +++ b/src/server/rest/v1/service/SettingService.ts @@ -28,7 +28,7 @@ export default class SettingService { // Delete await SettingStorage.deleteSetting(req.tenant, settingID); // Log - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: req.tenant.id, user: req.user, module: MODULE_NAME, method: 'handleDeleteSetting', message: `Setting '${setting.identifier}' has been deleted successfully`, @@ -110,7 +110,7 @@ export default class SettingService { // Save Setting filteredRequest.id = await SettingStorage.saveSettings(req.tenant, filteredRequest); // Log - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: req.tenant.id, user: req.user, module: MODULE_NAME, method: 'handleCreateSetting', message: `Setting '${filteredRequest.identifier}' has been created successfully`, @@ -223,7 +223,7 @@ export default class SettingService { } } // Log - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: req.tenant.id, user: req.user, module: MODULE_NAME, method: 'handleUpdateSetting', message: `Setting '${filteredRequest.id}' has been updated successfully`, diff --git a/src/server/rest/v1/service/SiteAreaService.ts b/src/server/rest/v1/service/SiteAreaService.ts index 170ded47c4..363736f3ee 100644 --- a/src/server/rest/v1/service/SiteAreaService.ts +++ b/src/server/rest/v1/service/SiteAreaService.ts @@ -50,7 +50,7 @@ export default class SiteAreaService { await SiteAreaStorage.removeAssetsFromSiteArea( req.tenant, filteredRequest.siteAreaID, assets.map((asset) => asset.id)); } - await Logging.logInfo({ + Logging.beInfo()?.log({ ...LoggingHelper.getSiteAreaProperties(siteArea), tenantID: req.tenant.id, user: req.user, @@ -104,7 +104,7 @@ export default class SiteAreaService { req.tenant, filteredRequest.siteAreaID, chargingStations.map((chargingStation) => chargingStation.id)); } // Log - await Logging.logInfo({ + Logging.beInfo()?.log({ ...LoggingHelper.getSiteAreaProperties(siteArea), tenantID: req.tenant.id, user: req.user, @@ -130,7 +130,7 @@ export default class SiteAreaService { // Update children await SiteAreaStorage.attachSiteAreaChildrenToNewParent(req.tenant, siteArea.id, siteArea.parentSiteAreaID); // Log - await Logging.logInfo({ + Logging.beInfo()?.log({ ...LoggingHelper.getSiteAreaProperties(siteArea), tenantID: req.tenant.id, user: req.user, module: MODULE_NAME, method: 'handleDeleteSiteArea', @@ -329,7 +329,7 @@ export default class SiteAreaService { req.tenant, rootSiteArea, siteArea, parentSiteArea, subSiteAreasActions); // Save siteArea.id = await SiteAreaStorage.saveSiteArea(req.tenant, siteArea, Utils.objectHasProperty(filteredRequest, 'image')); - await Logging.logInfo({ + Logging.beInfo()?.log({ ...LoggingHelper.getSiteAreaProperties(siteArea), tenantID: req.tenant.id, user: req.user, module: MODULE_NAME, method: 'handleCreateSiteArea', @@ -410,7 +410,7 @@ export default class SiteAreaService { } // Retrigger Smart Charging void SiteAreaService.triggerSmartCharging(req.tenant, action, siteArea); - await Logging.logInfo({ + Logging.beInfo()?.log({ ...LoggingHelper.getSiteAreaProperties(siteArea), tenantID: req.tenant.id, user: req.user, module: MODULE_NAME, method: 'handleUpdateSiteArea', @@ -488,7 +488,7 @@ export default class SiteAreaService { await smartCharging.computeAndApplyChargingProfiles(siteArea); } } catch (error) { - await Logging.logError({ + Logging.beError()?.log({ ...LoggingHelper.getSiteAreaProperties(siteArea), tenantID: tenant.id, action, module: MODULE_NAME, method: 'triggerSmartCharging', diff --git a/src/server/rest/v1/service/SiteService.ts b/src/server/rest/v1/service/SiteService.ts index 8268b91e57..3c75f35dd0 100644 --- a/src/server/rest/v1/service/SiteService.ts +++ b/src/server/rest/v1/service/SiteService.ts @@ -44,7 +44,7 @@ export default class SiteService { const user = await UtilsService.checkAndGetUserAuthorization(req.tenant, req.user, filteredRequest.userID, Action.READ, action); // Update await SiteStorage.updateSiteUserAdmin(req.tenant, filteredRequest.siteID, filteredRequest.userID, filteredRequest.siteAdmin); - await Logging.logInfo({ + Logging.beInfo()?.log({ ...LoggingHelper.getSiteProperties(site), tenantID: req.tenant.id, user: req.user, actionOnUser: user, @@ -70,7 +70,7 @@ export default class SiteService { req.tenant, req.user, filteredRequest.userID, Action.READ, action); // Update await SiteStorage.updateSiteOwner(req.tenant, filteredRequest.siteID, filteredRequest.userID, filteredRequest.siteOwner); - await Logging.logInfo({ + Logging.beInfo()?.log({ ...LoggingHelper.getSiteProperties(site), tenantID: req.tenant.id, user: req.user, actionOnUser: user, @@ -111,7 +111,7 @@ export default class SiteService { } else { await SiteStorage.removeUsersFromSite(req.tenant, site.id, users.map((user) => user.id)); } - await Logging.logInfo({ + Logging.beInfo()?.log({ ...LoggingHelper.getSiteProperties(site), tenantID: req.tenant.id, user: req.user, @@ -169,7 +169,7 @@ export default class SiteService { req.tenant, req.user, siteID, Action.DELETE, action); // Delete await SiteStorage.deleteSite(req.tenant, site.id); - await Logging.logInfo({ + Logging.beInfo()?.log({ ...LoggingHelper.getSiteProperties(site), tenantID: req.tenant.id, user: req.user, module: MODULE_NAME, method: 'handleDeleteSite', @@ -314,7 +314,7 @@ export default class SiteService { } // Save site.id = await SiteStorage.saveSite(req.tenant, site, Utils.objectHasProperty(filteredRequest, 'image')); - await Logging.logInfo({ + Logging.beInfo()?.log({ ...LoggingHelper.getSiteProperties(site), tenantID: req.tenant.id, user: req.user, module: MODULE_NAME, method: 'handleCreateSite', @@ -393,7 +393,7 @@ export default class SiteService { await SiteStorage.saveSite(req.tenant, site, Utils.objectHasProperty(filteredRequest, 'image')); // Update all refs void SiteStorage.updateEntitiesWithOrganizationIDs(req.tenant, site.companyID, filteredRequest.id); - await Logging.logInfo({ + Logging.beInfo()?.log({ ...LoggingHelper.getSiteProperties(site), tenantID: req.tenant.id, user: req.user, module: MODULE_NAME, method: 'handleUpdateSite', diff --git a/src/server/rest/v1/service/TagService.ts b/src/server/rest/v1/service/TagService.ts index 88cbca338d..1b81da2de9 100644 --- a/src/server/rest/v1/service/TagService.ts +++ b/src/server/rest/v1/service/TagService.ts @@ -188,7 +188,7 @@ export default class TagService { await TagStorage.saveTag(req.tenant, newTag); // OCPI void TagService.updateTagRoaming(action, req.tenant, req.user, newTag); - await Logging.logInfo({ + Logging.beInfo()?.log({ ...LoggingHelper.getTagProperties(newTag), tenantID: req.tenant.id, action: action, @@ -264,7 +264,7 @@ export default class TagService { await TagStorage.saveTag(req.tenant, tag); // OCPI void TagService.updateTagRoaming(action, req.tenant, req.user, tag); - await Logging.logInfo({ + Logging.beInfo()?.log({ ...LoggingHelper.getTagProperties(tag), tenantID: req.tenant.id, action: action, @@ -306,7 +306,7 @@ export default class TagService { // Save await TagStorage.saveTag(req.tenant, tag); void TagService.updateTagRoaming(action, req.tenant, req.user, tag); - await Logging.logInfo({ + Logging.beInfo()?.log({ ...LoggingHelper.getTagProperties(tag), tenantID: req.tenant.id, action: action, @@ -382,7 +382,7 @@ export default class TagService { } // OCPI void TagService.updateTagRoaming(action, req.tenant, req.user, tag); - await Logging.logInfo({ + Logging.beInfo()?.log({ ...LoggingHelper.getTagProperties(tag), tenantID: req.tenant.id, action: action, @@ -490,7 +490,7 @@ export default class TagService { }, async (error: CSVError) => { // Release the lock await LockingManager.release(importTagsLock); - await Logging.logError({ + Logging.beError()?.log({ tenantID: req.tenant.id, module: MODULE_NAME, method: 'handleImportTags', action: action, @@ -562,7 +562,7 @@ export default class TagService { parser.on('error', async (error) => { // Release the lock await LockingManager.release(importTagsLock); - await Logging.logError({ + Logging.beError()?.log({ tenantID: req.tenant.id, module: MODULE_NAME, method: 'handleImportTags', action: action, @@ -580,7 +580,7 @@ export default class TagService { } else { // Release the lock await LockingManager.release(importTagsLock); - await Logging.logError({ + Logging.beError()?.log({ tenantID: req.tenant.id, module: MODULE_NAME, method: 'handleImportTags', action: action, @@ -629,7 +629,7 @@ export default class TagService { // Handle dup keys result.inSuccess += error.result.nInserted; result.inError += error.writeErrors.length; - await Logging.logError({ + Logging.beError()?.log({ tenantID: tenant.id, module: MODULE_NAME, method: 'insertTags', action: action, @@ -663,7 +663,7 @@ export default class TagService { } } catch (error) { result.inError++; - await Logging.logError({ + Logging.beError()?.log({ tenantID: tenant.id, module: MODULE_NAME, method: 'deleteTags', action: ServerAction.TAG_DELETE, @@ -708,7 +708,7 @@ export default class TagService { } } catch (error) { result.inError++; - await Logging.logError({ + Logging.beError()?.log({ tenantID: tenant.id, module: MODULE_NAME, method: 'unassignTags', action: ServerAction.TAG_DELETE, @@ -833,7 +833,7 @@ export default class TagService { UserValidatorRest.getInstance().validateUserImportCreateReq(newImportedUser); tagToImport = { ...tagToImport, ...newImportedUser as ImportedTag }; } catch (error) { - await Logging.logWarning({ + Logging.beWarning()?.log({ tenantID: req.tenant.id, module: MODULE_NAME, method: 'processTag', action: action, @@ -846,7 +846,7 @@ export default class TagService { tagsToBeImported.push(tagToImport); return true; } catch (error) { - await Logging.logError({ + Logging.beError()?.log({ tenantID: req.tenant.id, module: MODULE_NAME, method: 'importTag', action: action, @@ -875,7 +875,7 @@ export default class TagService { }); } } catch (error) { - await Logging.logError({ + Logging.beError()?.log({ tenantID: tenant.id, module: MODULE_NAME, method: 'checkAndDeleteTagOCPI', action: ServerAction.TAG_DELETE, @@ -898,7 +898,7 @@ export default class TagService { ); } } catch (error) { - await Logging.logError({ + Logging.beError()?.log({ tenantID: tenant.id, action: action, module: MODULE_NAME, method: 'updateTagOCPI', diff --git a/src/server/rest/v1/service/TenantService.ts b/src/server/rest/v1/service/TenantService.ts index 4c58e5ad07..586640a9ce 100644 --- a/src/server/rest/v1/service/TenantService.ts +++ b/src/server/rest/v1/service/TenantService.ts @@ -65,7 +65,7 @@ export default class TenantService { // Remove collection await TenantStorage.deleteTenantDB(tenant.id); // Log - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: req.tenant.id, user: req.user, module: MODULE_NAME, method: 'handleDeleteTenant', message: `Tenant '${tenant.name}' has been deleted successfully`, @@ -344,7 +344,7 @@ export default class TenantService { Logging.logPromiseError(error, req?.tenant?.id); }); // Log - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: req.tenant.id, user: req.user, module: MODULE_NAME, method: 'handleCreateTenant', message: `Tenant '${filteredRequest.name}' has been created successfully`, @@ -418,7 +418,7 @@ export default class TenantService { // Update with components await TenantService.updateSettingsWithComponents(filteredRequest, req); // Log - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: req.tenant.id, user: req.user, module: MODULE_NAME, method: 'handleUpdateTenant', message: `Tenant '${filteredRequest.name}' has been updated successfully`, @@ -457,7 +457,7 @@ export default class TenantService { // Update Tenant await TenantStorage.saveTenant(tenant, Utils.objectHasProperty(filteredRequest, 'logo') ? true : false); // Log - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: req.tenant.id, user: req.user, module: MODULE_NAME, method: 'handleUpdateTenantData', message: `Tenant '${filteredRequest.name}' data has been updated successfully`, diff --git a/src/server/rest/v1/service/TransactionService.ts b/src/server/rest/v1/service/TransactionService.ts index 7c975da756..c7f9e402f0 100644 --- a/src/server/rest/v1/service/TransactionService.ts +++ b/src/server/rest/v1/service/TransactionService.ts @@ -70,7 +70,7 @@ export default class TransactionService { res.json(response); next(); } catch (error) { - await Logging.logActionExceptionMessageAndSendResponse(action, error, req, res, next); + Logging.logActionExceptionMessageAndSendResponse(action, error, req, res, next); } } @@ -196,7 +196,7 @@ export default class TransactionService { } // Save await TransactionStorage.saveTransactionOcpiData(req.tenant, transaction.id, transaction.ocpiData); - await Logging.logInfo({ + Logging.beInfo()?.log({ ...LoggingHelper.getTransactionProperties(transaction), tenantID: req.tenant.id, action, module: MODULE_NAME, method: 'handlePushTransactionCdr', @@ -231,7 +231,7 @@ export default class TransactionService { } // Save await TransactionStorage.saveTransactionOicpData(req.tenant, transaction.id, transaction.oicpData); - await Logging.logInfo({ + Logging.beInfo()?.log({ ...LoggingHelper.getTransactionProperties(transaction), tenantID: req.tenant.id, user: req.user, actionOnUser: (transaction.user ?? null), @@ -421,7 +421,7 @@ export default class TransactionService { }; res.json(advenirPayload); } catch (error) { - await Logging.logActionExceptionMessageAndSendResponse(action, error, req, res, next); + Logging.logActionExceptionMessageAndSendResponse(action, error, req, res, next); } } @@ -685,7 +685,7 @@ export default class TransactionService { // Transaction refunded if (refundConnector && !refundConnector.canBeDeleted(transaction)) { result.inError++; - await Logging.logError({ + Logging.beError()?.log({ ...LoggingHelper.getTransactionProperties(transaction), tenantID: loggedUser.tenantID, user: loggedUser, @@ -698,7 +698,7 @@ export default class TransactionService { // Transaction billed if (billingImpl && transaction.billingData?.stop?.status === BillingStatus.BILLED) { result.inError++; - await Logging.logError({ + Logging.beError()?.log({ ...LoggingHelper.getTransactionProperties(transaction), tenantID: loggedUser.tenantID, user: loggedUser, @@ -811,7 +811,7 @@ export default class TransactionService { OCPPUtils.clearChargingStationConnectorRuntimeData(chargingStation, transaction.connectorId); await ChargingStationStorage.saveChargingStationConnectors(req.tenant, chargingStation.id, chargingStation.connectors); } - await Logging.logInfo({ + Logging.beInfo()?.log({ ...LoggingHelper.getTransactionProperties(transaction), tenantID: req.tenant.id, user: req.user, actionOnUser: transaction.userID, @@ -833,7 +833,7 @@ export default class TransactionService { try { await new OCPPService(Configuration.getChargingStationConfig()).softStopTransaction( req.tenant, transaction, chargingStation, chargingStation.siteArea); - await Logging.logInfo({ + Logging.beInfo()?.log({ ...LoggingHelper.getTransactionProperties(transaction), tenantID: req.tenant.id, user: req.user, actionOnUser: transaction.userID, diff --git a/src/server/rest/v1/service/UserService.ts b/src/server/rest/v1/service/UserService.ts index af3d29d1c6..cb94a1b0e8 100644 --- a/src/server/rest/v1/service/UserService.ts +++ b/src/server/rest/v1/service/UserService.ts @@ -210,7 +210,7 @@ export default class UserService { } else { await UserStorage.removeSitesFromUser(req.tenant, filteredRequest.userID, sites.map((site) => site.id)); } - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: req.tenant.id, user: req.user, module: MODULE_NAME, @@ -230,7 +230,7 @@ export default class UserService { if (!user.issuer) { // Delete User await UserStorage.deleteUser(req.tenant, user.id); - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: req.tenant.id, user: req.user, actionOnUser: user, module: MODULE_NAME, method: 'handleDeleteUser', @@ -250,7 +250,7 @@ export default class UserService { // Delete User await UserStorage.deleteUser(req.tenant, user.id); // Log - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: req.tenant.id, user: req.user, actionOnUser: user, module: MODULE_NAME, method: 'handleDeleteUser', @@ -315,7 +315,7 @@ export default class UserService { // Update Billing await UserService.syncUserAndUpdateBillingData(ServerAction.USER_UPDATE, req.tenant, req.user, user); // Log - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: req.tenant.id, user: req.user, actionOnUser: user, module: MODULE_NAME, method: 'handleUpdateUser', @@ -355,7 +355,7 @@ export default class UserService { mobileVersion: filteredRequest.mobileVersion, mobileLastChangedOn: new Date() }); - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: req.tenant.id, user: user, module: MODULE_NAME, method: 'handleUpdateUserMobileData', @@ -575,7 +575,7 @@ export default class UserService { // Release the lock await LockingManager.release(importUsersLock); // Log - await Logging.logError({ + Logging.beError()?.log({ tenantID: req.tenant.id, module: MODULE_NAME, method: 'handleImportUsers', action: action, @@ -650,7 +650,7 @@ export default class UserService { // Release the lock await LockingManager.release(importUsersLock); // Log - await Logging.logError({ + Logging.beError()?.log({ tenantID: req.tenant.id, module: MODULE_NAME, method: 'handleImportUsers', action: action, @@ -669,7 +669,7 @@ export default class UserService { // Release the lock await LockingManager.release(importUsersLock); // Log - await Logging.logError({ + Logging.beError()?.log({ tenantID: req.tenant.id, module: MODULE_NAME, method: 'handleImportUsers', action: action, @@ -737,7 +737,7 @@ export default class UserService { // Update Billing await UserService.syncUserAndUpdateBillingData(ServerAction.USER_CREATE, req.tenant, req.user, newUser); // Log - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: req.tenant.id, user: req.user, actionOnUser: req.user, module: MODULE_NAME, method: 'handleCreateUser', @@ -756,7 +756,7 @@ export default class UserService { // Handle dup keys result.inSuccess += error.result.nInserted; result.inError += error.writeErrors.length; - await Logging.logError({ + Logging.beError()?.log({ tenantID: tenant.id, module: MODULE_NAME, method: 'insertUsers', action: action, @@ -873,7 +873,7 @@ export default class UserService { usersToBeImported.push(newImportedUser); return true; } catch (error) { - await Logging.logError({ + Logging.beError()?.log({ tenantID: req.tenant.id, module: MODULE_NAME, method: 'importUser', action: action, @@ -894,7 +894,7 @@ export default class UserService { ...await billingImpl.precheckStartTransactionPrerequisites(user)); } } catch (error) { - await Logging.logError({ + Logging.beError()?.log({ tenantID: tenant.id, module: MODULE_NAME, method: 'checkBillingErrorCodes', @@ -961,7 +961,7 @@ export default class UserService { } } } catch (error) { - await Logging.logError({ + Logging.beError()?.log({ tenantID: tenant.id, module: MODULE_NAME, method: 'checkAndDeleteUserOCPI', @@ -1002,7 +1002,7 @@ export default class UserService { // For performance reasons, the creation of a customer in the billing system should be done in a LAZY mode await billingImpl.synchronizeUser(user); } catch (error) { - await Logging.logError({ + Logging.beError()?.log({ tenantID: tenant.id, action, module: MODULE_NAME, method: 'syncUserAndUpdateBillingData', user: loggedUser, actionOnUser: user, diff --git a/src/server/rest/v1/service/UtilsService.ts b/src/server/rest/v1/service/UtilsService.ts index de6fcbbf88..e99cc3ef75 100644 --- a/src/server/rest/v1/service/UtilsService.ts +++ b/src/server/rest/v1/service/UtilsService.ts @@ -104,7 +104,7 @@ export default class UtilsService { message: `The Captcha score is too low, got ${response.data.score as string} but expected ${centralSystemRestConfig.captchaScore}`, }); } - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: tenant?.id, module: MODULE_NAME, action, method, message: `The Captcha score is ${response.data.score as string} (score limit is ${centralSystemRestConfig.captchaScore})`, @@ -1067,10 +1067,10 @@ export default class UtilsService { public static async handleUnknownAction(action: ServerAction, req: Request, res: Response, next: NextFunction): Promise { // Action provided if (!action) { - await Logging.logActionExceptionMessageAndSendResponse( + Logging.logActionExceptionMessageAndSendResponse( null, new Error('No Action has been provided'), req, res, next); } else { - await Logging.logActionExceptionMessageAndSendResponse( + Logging.logActionExceptionMessageAndSendResponse( action, new Error(`The Action '${action}' does not exist`), req, res, next); } } diff --git a/src/start.ts b/src/start.ts index a1c386e56c..69251ac8f9 100644 --- a/src/start.ts +++ b/src/start.ts @@ -105,7 +105,7 @@ export default class Bootstrap { } else { const message = `Monitoring Server implementation does not exist '${this.monitoringConfig.implementation}'`; Logging.logConsoleError(message); - await Logging.logError({ + Logging.beError()?.log({ tenantID: Constants.DEFAULT_TENANT_ID, action: ServerAction.STARTUP, module: MODULE_NAME, method: 'startServers', message @@ -142,7 +142,6 @@ export default class Bootstrap { } - // ------------------------------------------------------------------------- // Start all the Servers // ------------------------------------------------------------------------- @@ -188,7 +187,7 @@ export default class Bootstrap { await this.logDuration(startTimeGlobalMillis, `${serverStarted.join(', ')} server has been started successfully`, ServerAction.BOOTSTRAP_STARTUP); } catch (error) { Logging.logConsoleError(error); - global.database && await Logging.logError({ + global.database && Logging.beError()?.log({ tenantID: Constants.DEFAULT_TENANT_ID, action: ServerAction.BOOTSTRAP_STARTUP, module: MODULE_NAME, method: 'start', @@ -202,7 +201,7 @@ export default class Bootstrap { const timeStartMillis = Date.now(); Logging.logConsoleDebug(logMessage); if (global.database) { - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: Constants.DEFAULT_TENANT_ID, action: ServerAction.STARTUP, module: MODULE_NAME, method: 'start', @@ -217,7 +216,7 @@ export default class Bootstrap { logMessage = `${logMessage} in ${timeDurationSecs} secs`; Logging.logConsoleDebug(logMessage); if (global.database) { - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: Constants.DEFAULT_TENANT_ID, action, module: MODULE_NAME, method: 'start', @@ -303,7 +302,7 @@ export default class Bootstrap { } } catch (error) { Logging.logConsoleError(error.stack); - await Logging.logError({ + Logging.beError()?.log({ tenantID: Constants.DEFAULT_TENANT_ID, action: ServerAction.STARTUP, module: MODULE_NAME, method: 'startServers', diff --git a/src/storage/mongodb/MongoDBStorage.ts b/src/storage/mongodb/MongoDBStorage.ts index 3d48f3c559..6b6c46011e 100644 --- a/src/storage/mongodb/MongoDBStorage.ts +++ b/src/storage/mongodb/MongoDBStorage.ts @@ -71,7 +71,7 @@ export default class MongoDBStorage { const changeStream = dbCollection.watch([], { fullDocument: 'updateLookup' }); const message = `Database collection '${tenant.id}.${collectionName}' is being watched`; Utils.isDevelopmentEnv() && Logging.logConsoleDebug(message); - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: tenant.id, action: ServerAction.MONGO_DB, message, module: MODULE_NAME, method: 'watchDatabaseCollection' @@ -96,7 +96,7 @@ export default class MongoDBStorage { action: ServerAction.MONGO_DB }); } - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: tenantID, action: ServerAction.MONGO_DB, message: 'Check of MongoDB database...', @@ -195,7 +195,7 @@ export default class MongoDBStorage { { fields: { deleted: 1, issuer: 1 } }, { fields: { 'connectors.status': 1 } }, ]); - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: tenantID, action: ServerAction.MONGO_DB, message: 'Check of MongoDB database done', @@ -319,7 +319,7 @@ export default class MongoDBStorage { this.dbPingFailed++; const message = `${this.dbPingFailed} database ping(s) failed: ${error.message as string}`; Logging.logConsoleError(message); - await Logging.logError({ + Logging.beError()?.log({ tenantID: Constants.DEFAULT_TENANT_ID, action: ServerAction.MONGO_DB, module: MODULE_NAME, method: 'ping', @@ -393,7 +393,7 @@ export default class MongoDBStorage { } catch (error) { const message = 'Error while checking Database in tenant \'default\''; Logging.logConsoleError(message); - await Logging.logError({ + Logging.beError()?.log({ tenantID: Constants.DEFAULT_TENANT_ID, action: ServerAction.MONGO_DB, module: MODULE_NAME, method: 'handleIndexesInCollection', @@ -423,7 +423,7 @@ export default class MongoDBStorage { } catch (error) { const message = `Error while checking Database in tenant '${tenantId}'`; Logging.logConsoleError(message); - await Logging.logError({ + Logging.beError()?.log({ tenantID: Constants.DEFAULT_TENANT_ID, action: ServerAction.MONGO_DB, module: MODULE_NAME, method: 'handleIndexesInCollection', @@ -458,7 +458,7 @@ export default class MongoDBStorage { } catch (error) { const message = `Error in creating collection '${tenantID}.${tenantCollectionName}': ${error.message as string}`; Logging.logConsoleError(message); - await Logging.logError({ + Logging.beError()?.log({ tenantID: Constants.DEFAULT_TENANT_ID, action: ServerAction.MONGO_DB, module: MODULE_NAME, method: 'handleIndexesInCollection', @@ -491,7 +491,7 @@ export default class MongoDBStorage { if (Utils.isDevelopmentEnv()) { const message = `Drop index '${databaseIndex.name as string}' in collection ${tenantCollectionName}`; Utils.isDevelopmentEnv() && Logging.logConsoleDebug(message); - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: Constants.DEFAULT_TENANT_ID, action: ServerAction.MONGO_DB, module: MODULE_NAME, method: 'handleIndexesInCollection', @@ -503,7 +503,7 @@ export default class MongoDBStorage { } catch (error) { const message = `Error in dropping index '${databaseIndex.name as string}' in '${tenantCollectionName}': ${error.message as string}`; Logging.logConsoleError(message); - await Logging.logError({ + Logging.beError()?.log({ tenantID: Constants.DEFAULT_TENANT_ID, action: ServerAction.MONGO_DB, module: MODULE_NAME, method: 'handleIndexesInCollection', @@ -522,7 +522,7 @@ export default class MongoDBStorage { if (Utils.isDevelopmentEnv()) { const message = `Create index ${JSON.stringify(index)} in collection ${tenantCollectionName}`; Utils.isDevelopmentEnv() && Logging.logConsoleDebug(message); - await Logging.logInfo({ + Logging.beInfo()?.log({ tenantID: Constants.DEFAULT_TENANT_ID, action: ServerAction.MONGO_DB, module: MODULE_NAME, method: 'handleIndexesInCollection', @@ -534,7 +534,7 @@ export default class MongoDBStorage { } catch (error) { const message = `Error in creating index '${JSON.stringify(index.fields)}' with options '${JSON.stringify(index.options)}' in '${tenantCollectionName}': ${error.message as string}`; Logging.logConsoleError(message); - await Logging.logError({ + Logging.beError()?.log({ tenantID: Constants.DEFAULT_TENANT_ID, action: ServerAction.MONGO_DB, module: MODULE_NAME, method: 'handleIndexesInCollection', @@ -547,7 +547,7 @@ export default class MongoDBStorage { } catch (error) { const message = `Unexpected error in handling Collection '${tenantID}.${name}': ${error.message as string}`; Logging.logConsoleError(message); - await Logging.logError({ + Logging.beError()?.log({ tenantID: Constants.DEFAULT_TENANT_ID, action: ServerAction.MONGO_DB, module: MODULE_NAME, method: 'handleIndexesInCollection', diff --git a/src/storage/mongodb/PerformanceStorage.ts b/src/storage/mongodb/PerformanceStorage.ts index 99441074e8..78d7be8dba 100644 --- a/src/storage/mongodb/PerformanceStorage.ts +++ b/src/storage/mongodb/PerformanceStorage.ts @@ -8,7 +8,7 @@ import PerformanceRecord from '../../types/Performance'; import PerformanceValidatorStorage from '../validator/PerformanceValidatorStorage'; import Utils from '../../utils/Utils'; -const PERFS_ENABLED = true; +const PERFS_ENABLED = false; // TODO: To remove when switched to k8s with Prometheus export default class PerformanceStorage { diff --git a/src/storage/mongodb/SiteAreaStorage.ts b/src/storage/mongodb/SiteAreaStorage.ts index 930e156ec6..809b339f46 100644 --- a/src/storage/mongodb/SiteAreaStorage.ts +++ b/src/storage/mongodb/SiteAreaStorage.ts @@ -131,7 +131,7 @@ export default class SiteAreaStorage { }, Constants.DB_PARAMS_SINGLE_RECORD, projectFields); // No unique key on OCPI Location (avoid create several Site Area with the same location ID) if (siteAreaMDB.count > 1) { - await Logging.logWarning({ + Logging.beWarning()?.log({ tenantID: tenant.id, action: ServerAction.UNKNOWN_ACTION, module: MODULE_NAME, method: 'getSiteAreaByOcpiLocationUid', diff --git a/src/storage/mongodb/TagStorage.ts b/src/storage/mongodb/TagStorage.ts index 9c456c41f6..33cae324a0 100644 --- a/src/storage/mongodb/TagStorage.ts +++ b/src/storage/mongodb/TagStorage.ts @@ -24,7 +24,7 @@ export default class TagStorage { const id = Utils.generateTagID(); existingTag = await TagStorage.getTag(tenant, id); if (existingTag) { - await Logging.logWarning({ + Logging.beWarning()?.log({ tenantID: tenant.id, module: MODULE_NAME, method: 'findAvailableID', action: ServerAction.TAG_CREATE, diff --git a/src/storage/mongodb/TransactionStorage.ts b/src/storage/mongodb/TransactionStorage.ts index 22d222f2e0..5b9ffdb10f 100644 --- a/src/storage/mongodb/TransactionStorage.ts +++ b/src/storage/mongodb/TransactionStorage.ts @@ -1223,7 +1223,7 @@ export default class TransactionStorage { const id = Utils.getRandomIntSafe(); existingTransaction = await TransactionStorage.getTransaction(tenant, id); if (existingTransaction) { - await Logging.logWarning({ + Logging.beWarning()?.log({ tenantID: tenant.id, module: MODULE_NAME, method: 'findAvailableID', action: ServerAction.TRANSACTION_STARTED, diff --git a/src/types/Server.ts b/src/types/Server.ts index b70b6cf04d..90b00eb113 100644 --- a/src/types/Server.ts +++ b/src/types/Server.ts @@ -280,6 +280,8 @@ export enum ServerAction { WS_CLIENT_CONNECTION_CLOSE = 'WsClientConnectionClose', WS_CLIENT_CONNECTION_OPEN = 'WsClientConnectionOpen', WS_CLIENT_CONNECTION_ERROR = 'WsClientConnectionError', + WS_CLIENT_CONNECTION_PING = 'WsClientConnectionPing', + WS_CLIENT_CONNECTION_PONG = 'WsClientConnectionPong', NOTIFICATION = 'Notification', CHARGING_STATION_STATUS_ERROR = 'ChargingStationStatusError', diff --git a/src/types/ocpp/OCPPCommon.ts b/src/types/ocpp/OCPPCommon.ts index feb3c3d3cf..747ce04e5c 100644 --- a/src/types/ocpp/OCPPCommon.ts +++ b/src/types/ocpp/OCPPCommon.ts @@ -4,12 +4,10 @@ import OCPPError from '../../exception/OcppError'; export type FctOCPPResponse = (payload?: Record | string) => void; export type FctOCPPReject = (reason?: OCPPError) => void; -export type OCPPRequest = [FctOCPPResponse, FctOCPPReject, Command]; - -export type OCPPIncomingRequest = [OCPPMessageType, string, Command, Record, Record]; -export type OCPPIncomingResponse = [OCPPMessageType, string, Record, Record]; - -export type OCPPOutgoingRequest = [OCPPMessageType, string, Command, Record]; +export type OCPPPayload = Record; +export type OCPPIncomingRequest = [OCPPMessageType, string, Command, OCPPPayload, OCPPPayload]; +export type OCPPIncomingResponse = [OCPPMessageType, string, OCPPPayload, OCPPPayload]; +export type OCPPOutgoingRequest = [OCPPMessageType, string, Command, OCPPPayload]; export enum OCPPMessageType { CALL_MESSAGE = 2, // Caller to Callee diff --git a/src/utils/Constants.ts b/src/utils/Constants.ts index d80d3ff933..6c731fadb5 100644 --- a/src/utils/Constants.ts +++ b/src/utils/Constants.ts @@ -475,7 +475,7 @@ export default class Constants { public static readonly STRIPE_API_VERSION = '2020-08-27'; public static readonly WEB_SOCKET_OCPP_CONNECTIONS_COUNT = 'web_socket_ocpp_connections_count'; - public static readonly WEB_SOCKET_CURRRENT_REQUEST = 'web_socket_current_request'; + public static readonly WEB_SOCKET_CURRENT_REQUEST = 'web_socket_current_request'; public static readonly WEB_SOCKET_REST_CONNECTIONS_COUNT = 'web_socket_rest_connections_count'; public static readonly WEB_SOCKET_RUNNING_REQUEST = 'web_socket_running_request'; public static readonly WEB_SOCKET_RUNNING_REQUEST_RESPONSE = 'web_socket_running_request_response'; diff --git a/src/utils/FeatureToggles.ts b/src/utils/FeatureToggles.ts index 58ee7044e6..66e6ce0d17 100644 --- a/src/utils/FeatureToggles.ts +++ b/src/utils/FeatureToggles.ts @@ -5,6 +5,14 @@ export enum Feature { BILLING_PREVENT_CUSTOMER_DELETION, BILLING_SHOW_PRICING_DETAIL, BILLING_PLATFORM_USE_EXPRESS_ACCOUNT, + WS_SEND_PING_AUTOMATICALLY, + OCPP_STORE_HEARTBEATS, + OCPP_STORE_METER_VALUES, + OCPP_OPTIMIZE_LAST_SEEN_UPDATE, + OCPP_MONITOR_MEMORY_USAGE, + OCPP_PROCESS_EXISTING_TRANSACTION, + OCPP_METER_VALUE_ABORT_GHOST_TRANSACTION, + HEALTH_CHECK_PING_DATABASE, } export default class FeatureToggles { @@ -13,6 +21,14 @@ export default class FeatureToggles { Feature.BILLING_INVOICES_EXCLUDE_PENDING_ITEMS, Feature.BILLING_PREVENT_CUSTOMER_DELETION, Feature.BILLING_PLATFORM_USE_EXPRESS_ACCOUNT, + Feature.WS_SEND_PING_AUTOMATICALLY, + // Feature.OCPP_STORE_HEARTBEATS, + // Feature.OCPP_STORE_METER_VALUES, + Feature.OCPP_OPTIMIZE_LAST_SEEN_UPDATE, + Feature.OCPP_MONITOR_MEMORY_USAGE, + // Feature.OCPP_METER_VALUE_ABORT_GHOST_TRANSACTION + Feature.OCPP_PROCESS_EXISTING_TRANSACTION, + // Feature.HEALTH_CHECK_PING_DATABASE, ]; // Check whether the feature is active or not! diff --git a/src/utils/Logging.ts b/src/utils/Logging.ts index cf57de2a48..7655ef5ec5 100644 --- a/src/utils/Logging.ts +++ b/src/utils/Logging.ts @@ -28,10 +28,94 @@ import sizeof from 'object-sizeof'; const MODULE_NAME = 'Logging'; +export abstract class AbstractLightLogger { + public abstract log(log: Log): void ; +} + +export class LightLogger extends AbstractLightLogger { + + private logLevel: LogLevel; + + public constructor(logLevel: LogLevel) { + super(); + this.logLevel = logLevel; + } + + public log(log: Log): void { + log.level = this.logLevel; + log.timestamp = new Date(); + Logging.lightLog(log); + } +} + export default class Logging { private static logConfig: LogConfiguration; private static traceConfig: TraceConfiguration; + public static isLevelEnabled(expectedLogLevel: LogLevel): boolean { + // Check the configuration for the actual log level being enabled + const logConfig = Logging.getConfiguration(); + const logLevelLetter = logConfig.logLevel ? logConfig.logLevel : 'D'; + const logLevel = logLevelLetter as LogLevel; + switch (logLevel) { + case LogLevel.NONE: + return false; + case LogLevel.INFO: + if (expectedLogLevel === LogLevel.DEBUG) { + return false; + } + break; + case LogLevel.WARNING: + if (expectedLogLevel === LogLevel.INFO || expectedLogLevel === LogLevel.DEBUG) { + return false; + } + break; + case LogLevel.ERROR: + if (expectedLogLevel === LogLevel.INFO || expectedLogLevel === LogLevel.WARNING || expectedLogLevel === LogLevel.DEBUG) { + return false; + } + break; + case LogLevel.DEBUG: + default: + break; + } + return true; + } + + public static lightLog(log: Log): void { + Logging.log(log).catch(() => { /* Intentional */ }); + } + + public static beError(): AbstractLightLogger { + return Logging.beThatLevel(LogLevel.ERROR); + } + + public static beWarning(): AbstractLightLogger { + return Logging.beThatLevel(LogLevel.WARNING); + } + + public static beInfo(): AbstractLightLogger { + return Logging.beThatLevel(LogLevel.INFO); + } + + public static beDebug(): AbstractLightLogger { + return Logging.beThatLevel(LogLevel.DEBUG); + } + + public static beThatLevel(expectedLogLevel: LogLevel): AbstractLightLogger { + if (Logging.isLevelEnabled(expectedLogLevel)) { + return new LightLogger(expectedLogLevel); + } + // ------------------------------------------------------------------------------ + // ACHTUNG - returns null when the level is disabled + // ------------------------------------------------------------------------------ + // The purpose here is to avoid evaluating the log parameters and thus + // avoid triggering unnecessary garbage collection of log messages + // Make sure to use optional chaining operator (?.) when calling the log method + // ------------------------------------------------------------------------------ + return null; + } + public static getConfiguration(): LogConfiguration { if (!this.logConfig) { this.logConfig = Configuration.getLogConfig(); @@ -171,25 +255,21 @@ export default class Logging { public static async logDebug(log: Log): Promise { log.level = LogLevel.DEBUG; - // eslint-disable-next-line @typescript-eslint/no-floating-promises return Logging.log(log); } public static async logInfo(log: Log): Promise { log.level = LogLevel.INFO; - // eslint-disable-next-line @typescript-eslint/no-floating-promises return Logging.log(log); } public static async logWarning(log: Log): Promise { log.level = LogLevel.WARNING; - // eslint-disable-next-line @typescript-eslint/no-floating-promises return Logging.log(log); } public static async logError(log: Log): Promise { log.level = LogLevel.ERROR; - // eslint-disable-next-line @typescript-eslint/no-floating-promises return Logging.log(log); } @@ -386,8 +466,7 @@ export default class Logging { public static traceExpressResponse(req: Request, res: Response, next: NextFunction, action?: ServerAction): void { if (Logging.getTraceConfiguration().traceIngressHttp) { - // eslint-disable-next-line @typescript-eslint/no-misused-promises - res.on('finish', async () => { + res.on('finish',() => { // Get Tenant info const tenantID = req['tenantID'] as string; // Compute duration @@ -404,7 +483,7 @@ export default class Logging { Utils.isDevelopmentEnv() && Logging.logConsoleInfo(message); if (sizeOfResponseDataKB > Constants.PERF_MAX_DATA_VOLUME_KB) { const error = new Error(`Data must be < ${Constants.PERF_MAX_DATA_VOLUME_KB} KB, got ${(sizeOfResponseDataKB > 0) ? sizeOfResponseDataKB : '?'} KB`); - await Logging.logWarning({ + Logging.beWarning()?.log({ tenantID, action: ServerAction.PERFORMANCES, module: MODULE_NAME, method: 'logExpressResponse', @@ -421,7 +500,7 @@ export default class Logging { } if (executionDurationMillis > Constants.PERF_MAX_RESPONSE_TIME_MILLIS) { const error = new Error(`Execution must be < ${Constants.PERF_MAX_RESPONSE_TIME_MILLIS} ms, got ${(executionDurationMillis > 0) ? executionDurationMillis : '?'} ms`); - await Logging.logWarning({ + Logging.beWarning()?.log({ tenantID, action: ServerAction.PERFORMANCES, module: MODULE_NAME, method: 'logExpressResponse', @@ -436,7 +515,7 @@ export default class Logging { Logging.logConsoleWarning('===================================='); } } - await Logging.logDebug({ + Logging.beDebug()?.log({ tenantID: tenantID, user: req.user, action: action ?? ServerAction.HTTP_RESPONSE, @@ -456,7 +535,9 @@ export default class Logging { durationMs: executionDurationMillis, resSizeKb: sizeOfResponseDataKB, } as PerformanceRecord; - await PerformanceStorage.updatePerformanceRecord(performanceRecord); + PerformanceStorage.updatePerformanceRecord(performanceRecord).catch((error) => { + Logging.logPromiseError(error, tenantID); + }); } }); } @@ -466,8 +547,8 @@ export default class Logging { } } - public static async traceExpressError(error: Error, req: Request, res: Response, next: NextFunction): Promise { - await Logging.logActionExceptionMessageAndSendResponse( + public static traceExpressError(error: Error, req: Request, res: Response, next: NextFunction): void { + Logging.logActionExceptionMessageAndSendResponse( error['params'] && error['params']['action'] ? error['params']['action'] : ServerAction.HTTP_ERROR, error, req, res, next); if (Logging.getTraceConfiguration().traceIngressHttp) { // Nothing done yet @@ -634,40 +715,40 @@ export default class Logging { } } - public static async logException(exception: Error, action: ServerAction, - module: string, method: string, tenantID: string, user?: UserToken | User | string): Promise { + public static logException(exception: Error, action: ServerAction, + module: string, method: string, tenantID: string, user?: UserToken | User | string): void { if (exception instanceof AppAuthError) { - await Logging.logActionAppAuthException(tenantID, action, exception); + Logging.logActionAppAuthException(tenantID, action, exception); } else if (exception instanceof AppError) { - await Logging.logActionAppException(tenantID, action, exception); + Logging.logActionAppException(tenantID, action, exception); } else if (exception instanceof OCPPError) { - await Logging.logActionOcppException(tenantID, action, exception); + Logging.logActionOcppException(tenantID, action, exception); } else if (exception instanceof BackendError) { - await Logging.logActionBackendException(tenantID, action, exception); + Logging.logActionBackendException(tenantID, action, exception); } else { - await Logging.logError( + Logging.beError()?.log( Logging.buildLogError(action, module, method, tenantID, user, exception)); } } // Used to log exception in catch(...) only - public static async logActionExceptionMessage(tenantID: string, action: ServerAction, exception: Error, detailedMessages = {}): Promise { + public static logActionExceptionMessage(tenantID: string, action: ServerAction, exception: Error, detailedMessages = {}): void { if (exception instanceof AppError) { - await Logging.logActionAppException(tenantID, action, exception, detailedMessages); + Logging.logActionAppException(tenantID, action, exception, detailedMessages); } else if (exception instanceof BackendError) { - await Logging.logActionBackendException(tenantID, action, exception, detailedMessages); + Logging.logActionBackendException(tenantID, action, exception, detailedMessages); } else if (exception instanceof AppAuthError) { - await Logging.logActionAppAuthException(tenantID, action, exception, detailedMessages); + Logging.logActionAppAuthException(tenantID, action, exception, detailedMessages); } else if (exception instanceof OCPPError) { - await Logging.logActionOcppException(tenantID, action, exception); + Logging.logActionOcppException(tenantID, action, exception); } else { - await Logging.logActionException(tenantID, action, exception, detailedMessages); + Logging.logActionException(tenantID, action, exception, detailedMessages); } } // Used to log exception in catch(...) only - public static async logActionExceptionMessageAndSendResponse(action: ServerAction, exception: Error, - req: Request, res: Response, next: NextFunction, tenantID = Constants.DEFAULT_TENANT_ID): Promise { + public static logActionExceptionMessageAndSendResponse(action: ServerAction, exception: Error, + req: Request, res: Response, next: NextFunction, tenantID = Constants.DEFAULT_TENANT_ID): void { // Clear password if (action === ServerAction.LOGIN && req.body.password) { req.body.password = '####'; @@ -679,15 +760,15 @@ export default class Logging { tenantID = req.tenant.id; } if (exception instanceof AppError) { - await Logging.logActionAppException(tenantID, action, exception); + Logging.logActionAppException(tenantID, action, exception); } else if (exception instanceof BackendError) { - await Logging.logActionBackendException(tenantID, action, exception); + Logging.logActionBackendException(tenantID, action, exception); } else if (exception instanceof AppAuthError) { - await Logging.logActionAppAuthException(tenantID, action, exception); + Logging.logActionAppAuthException(tenantID, action, exception); } else if (exception instanceof OCPPError) { - await Logging.logActionOcppException(tenantID, action, exception); + Logging.logActionOcppException(tenantID, action, exception); } else { - await Logging.logActionException(tenantID, action, exception); + Logging.logActionException(tenantID, action, exception); } // Send error if (!res.headersSent) { @@ -812,17 +893,17 @@ export default class Logging { } public static logPromiseError(error, tenantID?: string): void { - Logging.logError({ + Logging.beError()?.log({ tenantID, action: ServerAction.UNKNOWN_ACTION, module: MODULE_NAME, method: 'logPromiseError', message: 'Unexpected error in floating promise', detailedMessages: { error: error.stack } - }).catch(() => { /* Intentional */ }); + }); } - private static async logActionException(tenantID: string, action: ServerAction, exception: any, detailedMessages = {}): Promise { - await Logging.logError({ + private static logActionException(tenantID: string, action: ServerAction, exception: any, detailedMessages = {}): void { + Logging.beError()?.log({ tenantID: tenantID, user: exception.user, module: exception.module, @@ -833,9 +914,9 @@ export default class Logging { }); } - private static async logActionAppException(tenantID: string, action: ServerAction, exception: AppError, detailedMessages = {}): Promise { + private static logActionAppException(tenantID: string, action: ServerAction, exception: AppError, detailedMessages = {}): void { Utils.handleExceptionDetailedMessages(exception); - await Logging.logError({ + Logging.beError()?.log({ tenantID: tenantID, chargingStationID: exception.params.chargingStationID, siteID: exception.params.siteID, @@ -854,9 +935,9 @@ export default class Logging { }); } - private static async logActionBackendException(tenantID: string, action: ServerAction, exception: BackendError, detailedMessages = {}): Promise { + private static logActionBackendException(tenantID: string, action: ServerAction, exception: BackendError, detailedMessages = {}): void { Utils.handleExceptionDetailedMessages(exception); - await Logging.logError({ + Logging.beError()?.log({ tenantID: tenantID, chargingStationID: exception.params.chargingStationID, siteID: exception.params.siteID, @@ -876,9 +957,9 @@ export default class Logging { } // Used to check URL params (not in catch) - private static async logActionAppAuthException(tenantID: string, action: ServerAction, exception: AppAuthError, detailedMessages = {}): Promise { + private static logActionAppAuthException(tenantID: string, action: ServerAction, exception: AppAuthError, detailedMessages = {}): void { Utils.handleExceptionDetailedMessages(exception); - await Logging.logError({ + Logging.beError()?.log({ tenantID: tenantID, user: exception.params.user, chargingStationID: exception.params.chargingStationID, @@ -897,9 +978,9 @@ export default class Logging { }); } - private static async logActionOcppException(tenantID: string, action: ServerAction, exception: OCPPError, detailedMessages = {}): Promise { + private static logActionOcppException(tenantID: string, action: ServerAction, exception: OCPPError, detailedMessages = {}): void { Utils.handleExceptionDetailedMessages(exception); - await Logging.logError({ + Logging.beError()?.log({ tenantID: tenantID, chargingStationID: exception.params.chargingStationID, siteID: exception.params.siteID, @@ -964,7 +1045,7 @@ export default class Logging { break; } // Timestamp - log.timestamp = new Date(); + log.timestamp = log.timestamp || new Date(); // Host log.host = Utils.getHostName(); if (log.detailedMessages) { @@ -1097,3 +1178,4 @@ export default class Logging { }; } } + diff --git a/src/utils/LoggingHelper.ts b/src/utils/LoggingHelper.ts index ac98735279..1d7ebd9fac 100644 --- a/src/utils/LoggingHelper.ts +++ b/src/utils/LoggingHelper.ts @@ -8,6 +8,7 @@ import SiteArea from '../types/SiteArea'; import Tag from '../types/Tag'; import Transaction from '../types/Transaction'; import User from '../types/User'; +import WSConnection from '../server/ocpp/json/web-socket/WSConnection'; import WSWrapper from '../server/ocpp/json/web-socket/WSWrapper'; export default class LoggingHelper { @@ -41,13 +42,21 @@ export default class LoggingHelper { }; } - public static getWSWrapperProperties(wsWrapper: WSWrapper): { tenantID: string; siteID: string; siteAreaID: string; companyID: string; chargingStationID: string; } { + public static getWSWrapperProperties(wsWrapper: WSWrapper): { siteID: string; siteAreaID: string; companyID: string; chargingStationID } { return { - tenantID: wsWrapper?.tenantID, - siteID: wsWrapper?.siteID, - siteAreaID: wsWrapper?.siteAreaID, - companyID: wsWrapper?.companyID, - chargingStationID: wsWrapper?.chargingStationID, + siteID: wsWrapper?.wsConnection?.getSiteID(), + siteAreaID: wsWrapper?.wsConnection?.getSiteAreaID(), + companyID: wsWrapper?.wsConnection?.getCompanyID(), + chargingStationID: wsWrapper?.wsConnection?.getChargingStationID(), + }; + } + + public static getWSConnectionProperties(wsConnection: WSConnection): { siteID: string; siteAreaID: string; companyID: string; chargingStationID } { + return { + siteID: wsConnection?.getSiteID(), + siteAreaID: wsConnection?.getSiteAreaID(), + companyID: wsConnection?.getCompanyID(), + chargingStationID: wsConnection?.getChargingStationID(), }; } @@ -91,7 +100,7 @@ export default class LoggingHelper { }; } - public static getSourceDataProperties(sourceData: any): { siteID: string, siteAreaID?: string, companyID: string, chargingStationID: string } { + public static getSourceDataProperties(sourceData: any): { siteID: string, siteAreaID?: string, companyID: string, chargingStationID: string } { return { siteID: sourceData?.siteID, siteAreaID: sourceData?.siteAreaID, diff --git a/src/utils/RouterUtils.ts b/src/utils/RouterUtils.ts index b8587161a2..c9ce27bec8 100644 --- a/src/utils/RouterUtils.ts +++ b/src/utils/RouterUtils.ts @@ -37,7 +37,7 @@ export default class RouterUtils { // Trace } catch (error) { Utils.isDevelopmentEnv() && Logging.logConsoleError(error.stack); - void Logging.logActionExceptionMessage(req.tenant?.id ?? Constants.DEFAULT_TENANT_ID, error.params?.action ?? ServerAction.OCPI_ENDPOINT, error); + Logging.logActionExceptionMessage(req.tenant?.id ?? Constants.DEFAULT_TENANT_ID, error.params?.action ?? ServerAction.OCPI_ENDPOINT, error); res.status(error.params?.errorCode ?? HTTPError.GENERAL_ERROR).json(OCPIUtils.toErrorResponse(error)); next(); }