repositories
/
e-mobility-charging-stations-simulator.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
build(deps): apply updates
[e-mobility-charging-stations-simulator.git]
/
src
/
types
/
ConfigurationData.ts
diff --git
a/src/types/ConfigurationData.ts
b/src/types/ConfigurationData.ts
index 32470f7b6906e336a0e930d209e9574b58473545..d1948921660b0da42774c813686405c2baf4d74c 100644
(file)
--- a/
src/types/ConfigurationData.ts
+++ b/
src/types/ConfigurationData.ts
@@
-1,18
+1,25
@@
-import { ListenOptions } from '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 { ServerOptions as WSServerOptions } from 'ws';
-import { StorageType } from './Storage';
-import
{ ApplicationProtocol
} from './UIProtocol';
-import
{ WorkerProcessType } from './W
orker';
+import
type
{ StorageType } from './Storage';
+import
type { ApplicationProtocol, AuthenticationType
} from './UIProtocol';
+import
type { WorkerProcessType } from '../w
orker';
-export type ServerOptions = WSServerOptions & ListenOptions;
+type ServerOptions = ListenOptions;
+
+export enum ConfigurationSection {
+ log = 'log',
+ performanceStorage = 'performanceStorage',
+ worker = 'worker',
+ uiServer = 'uiServer',
+}
export enum SupervisionUrlDistribution {
ROUND_ROBIN = 'round-robin',
RANDOM = 'random',
export enum SupervisionUrlDistribution {
ROUND_ROBIN = 'round-robin',
RANDOM = 'random',
-
SEQUENTIAL = 'sequential
',
+
CHARGING_STATION_AFFINITY = 'charging-station-affinity
',
}
export interface StationTemplateUrl {
}
export interface StationTemplateUrl {
@@
-20,10
+27,35
@@
export interface StationTemplateUrl {
numberOfStations: number;
}
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 enum ApplicationProtocolVersion {
+ VERSION_11 = 1.1,
+ VERSION_20 = 2.0,
+}
+
export interface UIServerConfiguration {
enabled?: boolean;
type?: ApplicationProtocol;
export interface UIServerConfiguration {
enabled?: boolean;
type?: ApplicationProtocol;
+ version?: ApplicationProtocolVersion;
options?: ServerOptions;
options?: ServerOptions;
+ authentication?: {
+ enabled: boolean;
+ type: AuthenticationType;
+ username?: string;
+ password?: string;
+ };
}
export interface StorageConfiguration {
}
export interface StorageConfiguration {
@@
-32,44
+64,60
@@
export interface StorageConfiguration {
uri?: string;
}
uri?: string;
}
+export type ElementsPerWorkerType = number | 'auto' | 'all';
+
export interface WorkerConfiguration {
processType?: WorkerProcessType;
startDelay?: number;
export interface WorkerConfiguration {
processType?: WorkerProcessType;
startDelay?: number;
- elementsPerWorker?:
number
;
+ elementsPerWorker?:
ElementsPerWorkerType
;
elementStartDelay?: number;
poolMinSize?: number;
poolMaxSize?: number;
elementStartDelay?: number;
poolMinSize?: number;
poolMaxSize?: number;
-
poolStrategy?: WorkerChoiceStrategy
;
+
resourceLimits?: ResourceLimits
;
}
}
-export
default
interface ConfigurationData {
+export interface ConfigurationData {
supervisionUrls?: string | string[];
supervisionUrlDistribution?: SupervisionUrlDistribution;
stationTemplateUrls: StationTemplateUrl[];
supervisionUrls?: string | string[];
supervisionUrlDistribution?: SupervisionUrlDistribution;
stationTemplateUrls: StationTemplateUrl[];
+ log?: LogConfiguration;
+ worker?: WorkerConfiguration;
uiServer?: UIServerConfiguration;
performanceStorage?: StorageConfiguration;
uiServer?: UIServerConfiguration;
performanceStorage?: StorageConfiguration;
- worker?: WorkerConfiguration;
+ /** @deprecated Moved to charging station template */
autoReconnectMaxRetries?: number;
autoReconnectMaxRetries?: number;
- /
/ deprecated
+ /
** @deprecated Moved to worker configuration section. */
workerProcess?: WorkerProcessType;
workerProcess?: WorkerProcessType;
- /
/ deprecated
+ /
** @deprecated Moved to worker configuration section. */
workerStartDelay?: number;
workerStartDelay?: number;
- /
/ deprecated
+ /
** @deprecated Moved to worker configuration section. */
elementStartDelay?: number;
elementStartDelay?: number;
- /
/ deprecated
+ /
** @deprecated Moved to worker configuration section. */
workerPoolMinSize?: number;
workerPoolMinSize?: number;
- /
/ deprecated
+ /
** @deprecated Moved to worker configuration section. */
workerPoolMaxSize?: number;
workerPoolMaxSize?: number;
- /
/ deprecated
+ /
** @deprecated Moved to worker configuration section. */
workerPoolStrategy?: WorkerChoiceStrategy;
workerPoolStrategy?: WorkerChoiceStrategy;
- /
/ deprecated
+ /
** @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;
+ /** @deprecated Moved to log configuration section. */
+ 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;
- logMaxFiles?: number;
+ /** @deprecated Moved to log configuration section. */
+ logMaxFiles?: number | string;
+ /** @deprecated Moved to log configuration section. */
+ logMaxSize?: number | string;
+ /** @deprecated Moved to log configuration section. */
logFile?: string;
logFile?: string;
+ /** @deprecated Moved to log configuration section. */
logErrorFile?: string;
logErrorFile?: string;
- logConsole?: boolean;
}
}