import { ThreadWorker } from 'poolifier'
import { BaseError } from '../exception/index.js'
-import type {
- ChargingStationData,
- ChargingStationWorkerData,
- ChargingStationWorkerEventError,
- ChargingStationWorkerMessage
-} from '../types/index.js'
-import { buildChargingStationDataPayload, Configuration } from '../utils/index.js'
-import { type WorkerMessage, WorkerMessageEvents } from '../worker/index.js'
+import type { ChargingStationInfo, ChargingStationWorkerData } from '../types/index.js'
+import { Configuration } from '../utils/index.js'
+import { type WorkerDataError, type WorkerMessage, WorkerMessageEvents } from '../worker/index.js'
import { ChargingStation } from './ChargingStation.js'
export let chargingStationWorker: object
if (Configuration.workerPoolInUse()) {
- chargingStationWorker = new ThreadWorker<ChargingStationWorkerData>(
- (data?: ChargingStationWorkerData): void => {
- // eslint-disable-next-line @typescript-eslint/no-non-null-assertion, no-new
- new ChargingStation(data!.index, data!.templateFile, data!.options)
- }
- )
+ chargingStationWorker = new ThreadWorker<
+ ChargingStationWorkerData,
+ ChargingStationInfo | undefined
+ >((data?: ChargingStationWorkerData): ChargingStationInfo | undefined => {
+ // eslint-disable-next-line @typescript-eslint/no-non-null-assertion
+ const { index, templateFile, options } = data!
+ return new ChargingStation(index, templateFile, options).stationInfo
+ })
} else {
// eslint-disable-next-line @typescript-eslint/no-extraneous-class
class ChargingStationWorker<Data extends ChargingStationWorkerData> {
constructor () {
parentPort?.on('message', (message: WorkerMessage<Data>) => {
- switch (message.event) {
- case WorkerMessageEvents.addWorkerElement:
- try {
- const chargingStation = new ChargingStation(
- message.data.index,
- message.data.templateFile,
- message.data.options
+ const { uuid, event, data } = message
+ // eslint-disable-next-line @typescript-eslint/no-unnecessary-condition
+ if (uuid != null) {
+ switch (event) {
+ case WorkerMessageEvents.addWorkerElement:
+ try {
+ const chargingStation = new ChargingStation(
+ data.index,
+ data.templateFile,
+ data.options
+ )
+ parentPort?.postMessage({
+ uuid,
+ event: WorkerMessageEvents.addedWorkerElement,
+ // eslint-disable-next-line @typescript-eslint/no-non-null-assertion
+ data: chargingStation.stationInfo!
+ } satisfies WorkerMessage<ChargingStationInfo>)
+ } catch (error) {
+ parentPort?.postMessage({
+ uuid,
+ event: WorkerMessageEvents.workerElementError,
+ data: {
+ event,
+ name: (error as Error).name,
+ message: (error as Error).message,
+ stack: (error as Error).stack
+ }
+ } satisfies WorkerMessage<WorkerDataError>)
+ }
+ break
+ default:
+ throw new BaseError(
+ `Unknown worker message event: '${event}' received with data: '${JSON.stringify(
+ data,
+ undefined,
+ 2
+ )}'`
)
- parentPort?.postMessage({
- event: WorkerMessageEvents.addedWorkerElement,
- data: buildChargingStationDataPayload(chargingStation)
- } satisfies ChargingStationWorkerMessage<ChargingStationData>)
- } catch (error) {
- parentPort?.postMessage({
- event: WorkerMessageEvents.workerElementError,
- data: {
- event: WorkerMessageEvents.addWorkerElement,
- name: (error as Error).name,
- message: (error as Error).message,
- stack: (error as Error).stack
- }
- } satisfies ChargingStationWorkerMessage<ChargingStationWorkerEventError>)
- }
- break
- default:
- throw new BaseError(
- `Unknown worker event: '${message.event}' received with data: '${JSON.stringify(
- message.data,
- undefined,
- 2
- )}'`
- )
+ }
}
})
}