X-Git-Url: https://git.piment-noir.org/?a=blobdiff_plain;f=src%2Ftypes%2FConfigurationData.ts;h=58372a3882a5cb064ae7df9c20748c0693ce18e9;hb=ebbfbf1c01e010d051956867484b74a94237f546;hp=708f411c04f4d5bf34c79987617c83ddda083f96;hpb=49a493fc49be51d1dc2a90201c92a6625252a019;p=e-mobility-charging-stations-simulator.git diff --git a/src/types/ConfigurationData.ts b/src/types/ConfigurationData.ts index 708f411c..58372a38 100644 --- a/src/types/ConfigurationData.ts +++ b/src/types/ConfigurationData.ts @@ -1,34 +1,43 @@ -import { ListenOptions } from 'net'; -import { StorageType } from './Storage'; -import { ServerOptions as WSServerOptions } from 'ws'; +import type { ListenOptions } from 'net'; + import type { WorkerChoiceStrategy } from 'poolifier'; -import { WorkerProcessType } from './Worker'; -export type ServerOptions = WSServerOptions & ListenOptions; +import type { StorageType } from './Storage'; +import type { ApplicationProtocol, AuthenticationType } from './UIProtocol'; +import type { WorkerProcessType } from './Worker'; + +export type ServerOptions = ListenOptions; export enum SupervisionUrlDistribution { ROUND_ROBIN = 'round-robin', RANDOM = 'random', - SEQUENTIAL = 'sequential', + CHARGING_STATION_AFFINITY = 'charging-station-affinity', } -export interface StationTemplateUrl { +export type StationTemplateUrl = { file: string; numberOfStations: number; -} +}; -export interface UIServerConfiguration { +export type UIServerConfiguration = { enabled?: boolean; + type?: ApplicationProtocol; options?: ServerOptions; -} + authentication?: { + enabled: boolean; + type: AuthenticationType; + username?: string; + password?: string; + }; +}; -export interface StorageConfiguration { +export type StorageConfiguration = { enabled?: boolean; type?: StorageType; uri?: string; -} +}; -export interface WorkerConfiguration { +export type WorkerConfiguration = { processType?: WorkerProcessType; startDelay?: number; elementsPerWorker?: number; @@ -36,9 +45,9 @@ export interface WorkerConfiguration { poolMinSize?: number; poolMaxSize?: number; poolStrategy?: WorkerChoiceStrategy; -} +}; -export default interface ConfigurationData { +export type ConfigurationData = { supervisionUrls?: string | string[]; supervisionUrlDistribution?: SupervisionUrlDistribution; stationTemplateUrls: StationTemplateUrl[]; @@ -68,4 +77,4 @@ export default interface ConfigurationData { logFile?: string; logErrorFile?: string; logConsole?: boolean; -} +};