Merge dependabot/npm_and_yarn/examples/typescript/http-server-pool/fastify-worker_thr...
[poolifier.git] / examples / typescript / http-server-pool / fastify-hybrid / src / request-handler-worker.ts
index d3b6c876048afed0392a707f4bae618e7f4e6048..b7ff8b166e40bc19d55dfadcf6038f15554cbb8d 100644 (file)
@@ -1,21 +1,28 @@
 import { ThreadWorker } from 'poolifier'
+
 import {
-  type BodyPayload,
+  type DataPayload,
   type ThreadWorkerData,
   type ThreadWorkerResponse
 } from './types.js'
 
-const factorial: (n: number) => number = (n) => {
-  if (n === 0) {
-    return 1
-  }
-  return factorial(n - 1) * n
-}
-
 class RequestHandlerWorker<
-  Data extends ThreadWorkerData<BodyPayload>,
-  Response extends ThreadWorkerResponse<BodyPayload>
+  Data extends ThreadWorkerData<DataPayload>,
+  Response extends ThreadWorkerResponse<DataPayload>
 > extends ThreadWorker<Data, Response> {
+  private static readonly factorial = (n: number | bigint): bigint => {
+    if (n === 0 || n === 1) {
+      return 1n
+    } else {
+      n = BigInt(n)
+      let factorial = 1n
+      for (let i = 1n; i <= n; i++) {
+        factorial *= i
+      }
+      return factorial
+    }
+  }
+
   public constructor () {
     super({
       echo: (workerData?: Data) => {
@@ -23,7 +30,11 @@ class RequestHandlerWorker<
       },
       factorial: (workerData?: Data) => {
         return {
-          body: { number: factorial(workerData?.body?.number as number) }
+          data: {
+            number: RequestHandlerWorker.factorial(
+              workerData!.data.number!
+            ).toString()
+          }
         } as unknown as Response
       }
     })
@@ -31,6 +42,6 @@ class RequestHandlerWorker<
 }
 
 export const requestHandlerWorker = new RequestHandlerWorker<
-ThreadWorkerData<BodyPayload>,
-ThreadWorkerResponse<BodyPayload>
+ThreadWorkerData<DataPayload>,
+ThreadWorkerResponse<DataPayload>
 >()