build: reenable eslint type checking
[poolifier.git] / examples / typescript / http-server-pool / express-hybrid / src / express-worker.ts
index 7ba9f374f5fa248012fab50afb72e508f8391de4..f9364b43fe354fc91d6a661516035e72bc90fc4f 100644 (file)
@@ -5,15 +5,15 @@ import express, { type Express, type Request, type Response } from 'express'
 import {
   availableParallelism,
   ClusterWorker,
-  DynamicThreadPool
+  DynamicThreadPool,
 } from 'poolifier'
 
-import {
-  type ClusterWorkerData,
-  type ClusterWorkerResponse,
-  type DataPayload,
-  type ThreadWorkerData,
-  type ThreadWorkerResponse
+import type {
+  ClusterWorkerData,
+  ClusterWorkerResponse,
+  DataPayload,
+  ThreadWorkerData,
+  ThreadWorkerResponse,
 } from './types.js'
 
 const emptyFunction = (): void => {
@@ -21,24 +21,25 @@ const emptyFunction = (): void => {
 }
 
 class ExpressWorker extends ClusterWorker<
-ClusterWorkerData,
-ClusterWorkerResponse
+  ClusterWorkerData,
+  ClusterWorkerResponse
 > {
   private static server: Server
   private static requestHandlerPool: DynamicThreadPool<
-  ThreadWorkerData<DataPayload>,
-  ThreadWorkerResponse<DataPayload>
+    ThreadWorkerData<DataPayload>,
+    ThreadWorkerResponse<DataPayload>
   >
 
   private static readonly startExpress = (
     workerData?: ClusterWorkerData
   ): ClusterWorkerResponse => {
     const { port, workerFile, minWorkers, maxWorkers, ...poolOptions } =
+      // eslint-disable-next-line @typescript-eslint/no-non-null-assertion
       workerData!
 
     ExpressWorker.requestHandlerPool = new DynamicThreadPool<
-    ThreadWorkerData<DataPayload>,
-    ThreadWorkerResponse<DataPayload>
+      ThreadWorkerData<DataPayload>,
+      ThreadWorkerResponse<DataPayload>
     >(
       minWorkers ?? 1,
       maxWorkers ?? availableParallelism(),
@@ -53,6 +54,7 @@ ClusterWorkerResponse
 
     application.all('/api/echo', (req: Request, res: Response) => {
       ExpressWorker.requestHandlerPool
+        // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment
         .execute({ data: req.body }, 'echo')
         .then(response => {
           return res.send(response.data).end()
@@ -63,7 +65,7 @@ ClusterWorkerResponse
     application.get('/api/factorial/:number', (req: Request, res: Response) => {
       const { number } = req.params
       ExpressWorker.requestHandlerPool
-        .execute({ data: { number: parseInt(number) } }, 'factorial')
+        .execute({ data: { number: Number.parseInt(number) } }, 'factorial')
         .then(response => {
           return res.send(response.data).end()
         })
@@ -74,12 +76,12 @@ ClusterWorkerResponse
     ExpressWorker.server = application.listen(port, () => {
       listenerPort = (ExpressWorker.server.address() as AddressInfo).port
       console.info(
-        `⚡️[express server]: Express server is started in cluster worker at http://localhost:${listenerPort}/`
+        `⚡️[express server]: Express server is started in cluster worker at http://localhost:${listenerPort.toString()}/`
       )
     })
     return {
       status: true,
-      port: listenerPort ?? port
+      port: listenerPort ?? port,
     }
   }
 
@@ -88,7 +90,7 @@ ClusterWorkerResponse
       killHandler: async () => {
         await ExpressWorker.requestHandlerPool.destroy()
         ExpressWorker.server.close()
-      }
+      },
     })
   }
 }