Remove string literal from log messages
[e-mobility-charging-stations-simulator.git] / src / performance / storage / Storage.ts
CommitLineData
c27c3eee
JB
1// Copyright Jerome Benoit. 2021. All Rights Reserved.
2
a6b3c6c3 3import { DBName, StorageType } from '../../types/Storage';
c27c3eee 4
717c1e56 5import { EmptyObject } from '../../types/EmptyObject';
e0a50bcd 6import { HandleErrorParams } from '../../types/Error';
72f041bd
JB
7import Statistics from '../../types/Statistics';
8import { URL } from 'url';
a6b3c6c3 9import Utils from '../../utils/Utils';
9f2e3130 10import logger from '../../utils/Logger';
72f041bd
JB
11
12export abstract class Storage {
1f5df42a 13 protected readonly storageUri: URL;
2a370053
JB
14 protected readonly logPrefix: string;
15 protected dbName: string;
72f041bd 16
1f5df42a
JB
17 constructor(storageUri: string, logPrefix: string) {
18 this.storageUri = new URL(storageUri);
72f041bd
JB
19 this.logPrefix = logPrefix;
20 }
21
717c1e56 22 protected handleDBError(type: StorageType, error: Error, table?: string, params: HandleErrorParams<EmptyObject> = { throwError: false }): void {
9f2e3130 23 logger.error(`${this.logPrefix} ${this.getDBNameFromStorageType(type)} error '${error.message}'${(!Utils.isNullOrUndefined(table) || !table) && ` in table or collection '${table}'`}: %j`, error);
e0a50bcd
JB
24 if (params?.throwError) {
25 throw error;
26 }
c27c3eee
JB
27 }
28
a6b3c6c3 29 protected getDBNameFromStorageType(type: StorageType): DBName {
c27c3eee
JB
30 switch (type) {
31 case StorageType.MARIA_DB:
a6b3c6c3 32 return DBName.MARIA_DB;
c27c3eee 33 case StorageType.MONGO_DB:
a6b3c6c3 34 return DBName.MONGO_DB;
c27c3eee 35 case StorageType.MYSQL:
a6b3c6c3 36 return DBName.MYSQL;
c27c3eee 37 case StorageType.SQLITE:
a6b3c6c3 38 return DBName.SQLITE;
c27c3eee 39 }
2a370053
JB
40 }
41
42 public abstract open(): void | Promise<void>;
43 public abstract close(): void | Promise<void>;
44 public abstract storePerformanceStatistics(performanceStatistics: Statistics): void | Promise<void>;
72f041bd 45}