X-Git-Url: https://git.piment-noir.org/?a=blobdiff_plain;f=examples%2Ftypescript%2Fwebsocket-server-pool%2Fws-cluster%2Fsrc%2Fworker.ts;h=a3ab5e28f04b458c68493faadd9125243c2b5b1d;hb=260bb73734384fc982006e15359ca1c43463cc55;hp=9ec81eb5db8b8c8fc5b7b5d4ad94d522629df89c;hpb=ded253e27e59ae936fe91d789d8454b7eb11dd6a;p=poolifier.git diff --git a/examples/typescript/websocket-server-pool/ws-cluster/src/worker.ts b/examples/typescript/websocket-server-pool/ws-cluster/src/worker.ts index 9ec81eb5..a3ab5e28 100644 --- a/examples/typescript/websocket-server-pool/ws-cluster/src/worker.ts +++ b/examples/typescript/websocket-server-pool/ws-cluster/src/worker.ts @@ -6,22 +6,29 @@ import { type MessagePayload, MessageType, type WorkerData, - type WorkerResponse + type WorkerResponse, } from './types.js' class WebSocketServerWorker extends ClusterWorker { private static wss: WebSocketServer - private static readonly factorial = (n: number): number => { - if (n === 0) { - return 1 + 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 } - return WebSocketServerWorker.factorial(n - 1) * n } private static readonly startWebSocketServer = ( workerData?: WorkerData ): WorkerResponse => { + // eslint-disable-next-line @typescript-eslint/no-non-null-assertion const { port } = workerData! WebSocketServerWorker.wss = new WebSocketServer({ port }, () => { @@ -34,7 +41,6 @@ class WebSocketServerWorker extends ClusterWorker { ws.on('error', console.error) ws.on('message', (message: RawData) => { const { type, data } = JSON.parse( - // eslint-disable-next-line @typescript-eslint/no-base-to-string message.toString() ) as MessagePayload switch (type) { @@ -42,18 +48,22 @@ class WebSocketServerWorker extends ClusterWorker { ws.send( JSON.stringify({ type: MessageType.echo, - data + data, }) ) break case MessageType.factorial: ws.send( - JSON.stringify({ - type: MessageType.factorial, - data: { - number: WebSocketServerWorker.factorial(data.number!) - } - }) + JSON.stringify( + { + type: MessageType.factorial, + data: { + // eslint-disable-next-line @typescript-eslint/no-non-null-assertion + number: WebSocketServerWorker.factorial(data.number!), + }, + }, + (_, v) => (typeof v === 'bigint' ? v.toString() : v) + ) ) break } @@ -61,7 +71,7 @@ class WebSocketServerWorker extends ClusterWorker { }) return { status: true, - port: WebSocketServerWorker.wss.options.port + port: WebSocketServerWorker.wss.options.port, } } @@ -69,7 +79,7 @@ class WebSocketServerWorker extends ClusterWorker { super(WebSocketServerWorker.startWebSocketServer, { killHandler: () => { WebSocketServerWorker.wss.close() - } + }, }) } }