refactor: cleanup charging profiles handling code
[e-mobility-charging-stations-simulator.git] / src / start.ts
index 90eb5161fc4c85b3c3a6330e6398b7d82102a2ef..7c42c4d205682073c4d23c04d7d2a3eff15add97 100644 (file)
@@ -1,45 +1,11 @@
-import Configuration from './utils/Configuration';
-import WorkerData from './types/WorkerData';
-import WorkerFactory from './worker/WorkerFactory';
-import Wrk from './worker/Wrk';
+// Partial Copyright Jerome Benoit. 2021-2024. All Rights Reserved.
 
-class Bootstrap {
-  static start() {
-    try {
-      let numStationsTotal = 0;
-      const workerImplementation: Wrk = WorkerFactory.getWorkerImpl('./dist/charging-station/StationWorker.js');
-      void workerImplementation.start();
-      // Start ChargingStation object in worker thread
-      if (Configuration.getStationTemplateURLs()) {
-        for (const stationURL of Configuration.getStationTemplateURLs()) {
-          try {
-            const nbStations = stationURL.numberOfStations ? stationURL.numberOfStations : 0;
-            for (let index = 1; index <= nbStations; index++) {
-              const workerData: WorkerData = {
-                index,
-                templateFile: stationURL.file
-              };
-              void workerImplementation.addElement(workerData);
-              numStationsTotal++;
-            }
-          } catch (error) {
-            // eslint-disable-next-line no-console
-            console.error('Charging station start with template file ' + stationURL.file + ' error ', error);
-          }
-        }
-      } else {
-        console.log('No stationTemplateURLs defined in configuration, exiting');
-      }
-      if (numStationsTotal === 0) {
-        console.log('No charging station template enabled in configuration, exiting');
-      } else {
-        console.log(`Charging station simulator started with ${numStationsTotal.toString()} charging station(s) and ${workerImplementation.size}${Configuration.useWorkerPool() ? `/${Configuration.getWorkerPoolMaxSize().toString()}` : ''} worker(s) concurrently running (${workerImplementation.maxElementsPerWorker} charging station(s) per worker)`);
-      }
-    } catch (error) {
-      // eslint-disable-next-line no-console
-      console.error('Bootstrap start error ', error);
-    }
-  }
-}
+import chalk from 'chalk'
+
+import { Bootstrap } from './charging-station/index.js'
 
-Bootstrap.start();
+try {
+  await Bootstrap.getInstance().start()
+} catch (error) {
+  console.error(chalk.red('Startup error: '), error)
+}