Merge branch 'master' into fix-template
[e-mobility-charging-stations-simulator.git] / src / types / Worker.ts
CommitLineData
9efbac5b 1import { PoolOptions } from 'poolifier';
c045d9a9
JB
2import { Worker } from 'worker_threads';
3
a4624c96
JB
4export enum WorkerProcessType {
5 WORKER_SET = 'workerSet',
6 DYNAMIC_POOL = 'dynamicPool',
7 STATIC_POOL = 'staticPool'
8}
9
b8da29bc 10export interface WorkerOptions {
322c9192 11 startDelay?: number;
b8da29bc
JB
12 poolMaxSize?: number;
13 poolMinSize?: number;
14 elementsPerWorker?: number;
9efbac5b 15 poolOptions?: PoolOptions<Worker>;
821c6c82 16 messageHandler?: (message: unknown) => void | Promise<void>;
b8da29bc
JB
17}
18
322c9192
JB
19// eslint-disable-next-line @typescript-eslint/no-empty-interface
20export interface WorkerData {}
46eb543c 21
c045d9a9 22export interface WorkerSetElement {
81797102
JB
23 worker: Worker;
24 numberOfWorkerElements: number;
25}
26
27export interface WorkerMessage {
2a370053 28 id: WorkerMessageEvents;
81797102 29 data: any;
c045d9a9
JB
30}
31
2a370053 32export enum WorkerMessageEvents {
c045d9a9 33 START_WORKER_ELEMENT = 'startWorkerElement',
98dc07fa 34 STOP_WORKER_ELEMENT = 'stopWorkerElement'
c045d9a9
JB
35}
36