X-Git-Url: https://git.piment-noir.org/?a=blobdiff_plain;f=examples%2Ftypescript%2Fhttp-server-pool%2Fexpress-cluster%2Fsrc%2Fworker.ts;h=d575647375edca90297ee647d0c4c26395e288f1;hb=dae90956d7de793209a952cb754b317a0ef221c8;hp=c5fe74acc122c0c391d419c559d613026ea56354;hpb=624e51e36eb773aa325fa03df96bce20761ab65b;p=poolifier.git diff --git a/examples/typescript/http-server-pool/express-cluster/src/worker.ts b/examples/typescript/http-server-pool/express-cluster/src/worker.ts index c5fe74ac..d5756473 100644 --- a/examples/typescript/http-server-pool/express-cluster/src/worker.ts +++ b/examples/typescript/http-server-pool/express-cluster/src/worker.ts @@ -2,22 +2,22 @@ import type { Server } from 'node:http' import type { AddressInfo } from 'node:net' import { ClusterWorker } from 'poolifier' import express, { type Express, type Request, type Response } from 'express' -import { type WorkerData, type WorkerResponse } from './types.js' - -const factorial: (n: number) => number = n => { - if (n === 0) { - return 1 - } - return factorial(n - 1) * n -} +import type { WorkerData, WorkerResponse } from './types.js' class ExpressWorker extends ClusterWorker { private static server: Server + private static readonly factorial = (n: number): number => { + if (n === 0) { + return 1 + } + return ExpressWorker.factorial(n - 1) * n + } + private static readonly startExpress = ( workerData?: WorkerData ): WorkerResponse => { - const { port } = workerData as WorkerData + const { port } = workerData! const application: Express = express() @@ -30,18 +30,17 @@ class ExpressWorker extends ClusterWorker { application.get('/api/factorial/:number', (req: Request, res: Response) => { const { number } = req.params - res.send({ number: factorial(parseInt(number)) }).end() + res.send({ number: ExpressWorker.factorial(parseInt(number)) }).end() }) ExpressWorker.server = application.listen(port, () => { console.info( - // eslint-disable-next-line @typescript-eslint/restrict-template-expressions `⚡️[express server]: Express server is started in cluster worker at http://localhost:${port}/` ) }) return { status: true, - port: (ExpressWorker.server.address() as AddressInfo)?.port ?? port + port: (ExpressWorker.server.address() as AddressInfo).port } }