X-Git-Url: https://git.piment-noir.org/?a=blobdiff_plain;f=src%2Ftypes%2FConfigurationData.ts;h=fe8b84819452354572011d23388ffc679637d701;hb=48c7e1d6db4b3cbf82d17e191b2255066c462a71;hp=a244aa45d7cfafa99c6e6ca32568c5ac8b5738fd;hpb=3d48c1c13adbe046643a952b1ddfce30c6cc0a97;p=e-mobility-charging-stations-simulator.git diff --git a/src/types/ConfigurationData.ts b/src/types/ConfigurationData.ts index a244aa45..fe8b8481 100644 --- a/src/types/ConfigurationData.ts +++ b/src/types/ConfigurationData.ts @@ -1,106 +1,123 @@ -import type { ListenOptions } from 'node:net'; +import type { ListenOptions } from 'node:net' +import type { ResourceLimits } from 'node:worker_threads' -import type { WorkerChoiceStrategy } from 'poolifier'; +import type { WorkerChoiceStrategy } from 'poolifier' -import type { StorageType } from './Storage'; -import type { ApplicationProtocol, AuthenticationType } from './UIProtocol'; -import type { WorkerProcessType } from '../worker'; +import type { StorageType } from './Storage.js' +import type { ApplicationProtocol, AuthenticationType } from './UIProtocol.js' +import type { WorkerProcessType } from '../worker/index.js' -type ServerOptions = ListenOptions; +type ServerOptions = ListenOptions + +export enum ConfigurationSection { + log = 'log', + performanceStorage = 'performanceStorage', + worker = 'worker', + uiServer = 'uiServer' +} export enum SupervisionUrlDistribution { ROUND_ROBIN = 'round-robin', RANDOM = 'random', - CHARGING_STATION_AFFINITY = 'charging-station-affinity', + CHARGING_STATION_AFFINITY = 'charging-station-affinity' +} + +export interface StationTemplateUrl { + file: string + numberOfStations: number } -export type StationTemplateUrl = { - file: string; - numberOfStations: number; -}; +export interface LogConfiguration { + enabled?: boolean + file?: string + errorFile?: string + statisticsInterval?: number + level?: string + console?: boolean + format?: string + rotate?: boolean + maxFiles?: string | number + maxSize?: string | number +} -export type LogConfiguration = { - enabled?: boolean; - file?: string; - errorFile?: string; - statisticsInterval?: number; - level?: string; - console?: boolean; - format?: string; - rotate?: boolean; - maxFiles?: string | number; - maxSize?: string | number; -}; +export enum ApplicationProtocolVersion { + VERSION_11 = 1.1, + VERSION_20 = 2.0 +} -export type UIServerConfiguration = { - enabled?: boolean; - type?: ApplicationProtocol; - options?: ServerOptions; +export interface UIServerConfiguration { + enabled?: boolean + type?: ApplicationProtocol + version?: ApplicationProtocolVersion + options?: ServerOptions authentication?: { - enabled: boolean; - type: AuthenticationType; - username?: string; - password?: string; - }; -}; + enabled: boolean + type: AuthenticationType + username?: string + password?: string + } +} -export type StorageConfiguration = { - enabled?: boolean; - type?: StorageType; - uri?: string; -}; +export interface StorageConfiguration { + enabled?: boolean + type?: StorageType + uri?: string +} -export type WorkerConfiguration = { - processType?: WorkerProcessType; - startDelay?: number; - elementsPerWorker?: number; - elementStartDelay?: number; - poolMinSize?: number; - poolMaxSize?: number; - poolStrategy?: WorkerChoiceStrategy; -}; +export type ElementsPerWorkerType = number | 'auto' | 'all' -export type ConfigurationData = { - supervisionUrls?: string | string[]; - supervisionUrlDistribution?: SupervisionUrlDistribution; - stationTemplateUrls: StationTemplateUrl[]; - log?: LogConfiguration; - worker?: WorkerConfiguration; - uiServer?: UIServerConfiguration; - performanceStorage?: StorageConfiguration; - autoReconnectMaxRetries?: number; +export interface WorkerConfiguration { + processType?: WorkerProcessType + startDelay?: number + elementsPerWorker?: ElementsPerWorkerType + elementStartDelay?: number + poolMinSize?: number + poolMaxSize?: number + resourceLimits?: ResourceLimits +} + +export interface ConfigurationData { + supervisionUrls?: string | string[] + supervisionUrlDistribution?: SupervisionUrlDistribution + stationTemplateUrls: StationTemplateUrl[] + log?: LogConfiguration + worker?: WorkerConfiguration + uiServer?: UIServerConfiguration + performanceStorage?: StorageConfiguration + /** @deprecated Moved to charging station template */ + autoReconnectMaxRetries?: number /** @deprecated Moved to worker configuration section. */ - workerProcess?: WorkerProcessType; + workerProcess?: WorkerProcessType /** @deprecated Moved to worker configuration section. */ - workerStartDelay?: number; + workerStartDelay?: number /** @deprecated Moved to worker configuration section. */ - elementStartDelay?: number; + elementStartDelay?: number /** @deprecated Moved to worker configuration section. */ - workerPoolMinSize?: number; + workerPoolMinSize?: number /** @deprecated Moved to worker configuration section. */ - workerPoolMaxSize?: number; + workerPoolMaxSize?: number /** @deprecated Moved to worker configuration section. */ - workerPoolStrategy?: WorkerChoiceStrategy; + workerPoolStrategy?: WorkerChoiceStrategy /** @deprecated Moved to worker configuration section. */ - chargingStationsPerWorker?: number; + chargingStationsPerWorker?: number /** @deprecated Moved to log configuration section. */ - logStatisticsInterval?: number; + logStatisticsInterval?: number /** @deprecated Moved to log configuration section. */ - logEnabled?: boolean; + logEnabled?: boolean /** @deprecated Moved to log configuration section. */ - logConsole?: boolean; + logConsole?: boolean /** @deprecated Moved to log configuration section. */ - logFormat?: string; + logFormat?: string /** @deprecated Moved to log configuration section. */ - logLevel?: string; + logLevel?: string /** @deprecated Moved to log configuration section. */ - logRotate?: boolean; + logRotate?: boolean /** @deprecated Moved to log configuration section. */ - logMaxFiles?: number | string; + logMaxFiles?: number | string /** @deprecated Moved to log configuration section. */ - logMaxSize?: number | string; + logMaxSize?: number | string /** @deprecated Moved to log configuration section. */ - logFile?: string; + logFile?: string /** @deprecated Moved to log configuration section. */ - logErrorFile?: string; -}; + logErrorFile?: string +}