UI Server: add WS Insomnia requests collection
[e-mobility-charging-stations-simulator.git] / src / types / ConfigurationData.ts
index 708f411c04f4d5bf34c79987617c83ddda083f96..58372a3882a5cb064ae7df9c20748c0693ce18e9 100644 (file)
@@ -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;
-}
+};