1 import ConfigurationData
, { StationTemplateURL
} from
'../types/ConfigurationData';
3 import Utils from
'./Utils';
6 export default class Configuration
{
7 private static configuration
: ConfigurationData
;
9 static getStatisticsDisplayInterval(): number {
11 return Utils
.objectHasOwnProperty(Configuration
.getConfig(), 'statisticsDisplayInterval') ? Configuration
.getConfig().statisticsDisplayInterval
: 60;
14 static getAutoReconnectTimeout(): number {
16 return Utils
.objectHasOwnProperty(Configuration
.getConfig(), 'autoReconnectTimeout') ? Configuration
.getConfig().autoReconnectTimeout
: 10;
19 static getAutoReconnectMaxRetries(): number {
21 return Utils
.objectHasOwnProperty(Configuration
.getConfig(), 'autoReconnectMaxRetries') ? Configuration
.getConfig().autoReconnectMaxRetries
: -1;
24 static getStationTemplateURLs(): StationTemplateURL
[] {
25 Configuration
.getConfig().stationTemplateURLs
.forEach((stationURL
: StationTemplateURL
) => {
26 if (!Utils
.isUndefined(stationURL
['numberOfStation'])) {
27 console
.error(`Deprecated configuration key 'numberOfStation' usage for template file '${stationURL.file}' in 'stationTemplateURLs'. Use 'numberOfStations' instead`);
31 return Configuration
.getConfig().stationTemplateURLs
;
34 static useWorkerPool(): boolean {
35 return Configuration
.getConfig().useWorkerPool
;
38 static getWorkerPoolSize(): number {
39 return Configuration
.getConfig().workerPoolSize
;
42 static getLogConsole(): boolean {
43 Configuration
.deprecateConfigurationKey('consoleLog', 'Use \'logConsole\' instead');
44 return Utils
.objectHasOwnProperty(Configuration
.getConfig(), 'logConsole') ? Configuration
.getConfig().logConsole
: false;
47 static getLogFormat(): string {
48 return Utils
.objectHasOwnProperty(Configuration
.getConfig(), 'logFormat') ? Configuration
.getConfig().logFormat
: 'simple';
51 static getLogRotate(): boolean {
52 return Utils
.objectHasOwnProperty(Configuration
.getConfig(), 'logRotate') ? Configuration
.getConfig().logRotate
: true;
55 static getLogMaxFiles(): number {
56 return Utils
.objectHasOwnProperty(Configuration
.getConfig(), 'logMaxFiles') ? Configuration
.getConfig().logMaxFiles
: 7;
59 static getLogLevel(): string {
60 return Utils
.objectHasOwnProperty(Configuration
.getConfig(), 'logLevel') ? Configuration
.getConfig().logLevel
: 'info';
63 static getLogFile(): string {
64 return Utils
.objectHasOwnProperty(Configuration
.getConfig(), 'logFile') ? Configuration
.getConfig().logFile
: 'combined.log';
67 static getLogErrorFile(): string {
68 Configuration
.deprecateConfigurationKey('errorFile', 'Use \'logErrorFile\' instead');
69 return Utils
.objectHasOwnProperty(Configuration
.getConfig(), 'logErrorFile') ? Configuration
.getConfig().logErrorFile
: 'error.log';
72 static getSupervisionURLs(): string[] {
74 return Configuration
.getConfig().supervisionURLs
;
77 static getDistributeStationsToTenantsEqually(): boolean {
78 Configuration
.deprecateConfigurationKey('distributeStationToTenantEqually', 'Use \'distributeStationsToTenantsEqually\' instead');
79 return Utils
.objectHasOwnProperty(Configuration
.getConfig(), 'distributeStationsToTenantsEqually') ? Configuration
.getConfig().distributeStationsToTenantsEqually
: true;
82 private static deprecateConfigurationKey(key
: string, logMsgToAppend
= '') {
83 if (!Utils
.isUndefined(Configuration
.getConfig()[key
])) {
84 console
.error(`Deprecated configuration key '${key}' usage${logMsgToAppend && '. ' + logMsgToAppend}`);
88 // Read the config file
89 private static getConfig(): ConfigurationData
{
90 if (!Configuration
.configuration
) {
91 Configuration
.configuration
= JSON
.parse(fs
.readFileSync('./src/assets/config.json', 'utf8')) as ConfigurationData
;
93 return Configuration
.configuration
;