X-Git-Url: https://git.piment-noir.org/?a=blobdiff_plain;f=src%2Ftypes%2FConfigurationData.ts;h=ba9fb14ce993430379facda2f77d376e00e48a15;hb=36999e7745b090d38c68015929b5d223b4162613;hp=32470f7b6906e336a0e930d209e9574b58473545;hpb=1f7fa4de53a1b28324f362402f61b81b28d75c2c;p=e-mobility-charging-stations-simulator.git diff --git a/src/types/ConfigurationData.ts b/src/types/ConfigurationData.ts index 32470f7b..ba9fb14c 100644 --- a/src/types/ConfigurationData.ts +++ b/src/types/ConfigurationData.ts @@ -1,13 +1,12 @@ -import { ListenOptions } from 'net'; +import type { ListenOptions } from 'net'; import type { WorkerChoiceStrategy } from 'poolifier'; -import { ServerOptions as WSServerOptions } from 'ws'; -import { StorageType } from './Storage'; -import { ApplicationProtocol } from './UIProtocol'; -import { WorkerProcessType } from './Worker'; +import type { StorageType } from './Storage'; +import type { ApplicationProtocol, AuthenticationType } from './UIProtocol'; +import type { WorkerProcessType } from './Worker'; -export type ServerOptions = WSServerOptions & ListenOptions; +export type ServerOptions = ListenOptions; export enum SupervisionUrlDistribution { ROUND_ROBIN = 'round-robin', @@ -15,24 +14,30 @@ export enum SupervisionUrlDistribution { SEQUENTIAL = 'sequential', } -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; @@ -40,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[]; @@ -72,4 +77,4 @@ export default interface ConfigurationData { logFile?: string; logErrorFile?: string; logConsole?: boolean; -} +};