X-Git-Url: https://git.piment-noir.org/?a=blobdiff_plain;ds=sidebyside;f=examples%2Ftypescript%2Fwebsocket-server-pool%2Fws-cluster%2Fsrc%2Fworker.ts;h=18ece026c891efb3106499667027a1a2aba0b73a;hb=312eb4a0ae67660e3c74d836bee8f9c84e41a431;hp=efe0facdc900b96ae4b4d49d36da3729a598147a;hpb=8ad621cc1d32ed396fca3ef2ec48337e42d2dcc2;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 efe0facd..18ece026 100644 --- a/examples/typescript/websocket-server-pool/ws-cluster/src/worker.ts +++ b/examples/typescript/websocket-server-pool/ws-cluster/src/worker.ts @@ -8,27 +8,28 @@ import { type WorkerResponse } from './types.js' -const factorial: (n: number) => number = (n) => { - if (n === 0) { - return 1 - } - return factorial(n - 1) * n -} - class WebSocketServerWorker extends ClusterWorker { private static wss: WebSocketServer + private static readonly factorial = (n: number): number => { + if (n === 0) { + return 1 + } + return WebSocketServerWorker.factorial(n - 1) * n + } + private static readonly startWebSocketServer = ( workerData?: WorkerData ): WorkerResponse => { - const { port } = workerData as WorkerData + const { port } = workerData! + WebSocketServerWorker.wss = new WebSocketServer({ port }, () => { console.info( `⚡️[ws server]: WebSocket server is started in cluster worker at ws://localhost:${port}/` ) }) - WebSocketServerWorker.wss.on('connection', (ws) => { + WebSocketServerWorker.wss.on('connection', ws => { ws.on('error', console.error) ws.on('message', (message: RawData) => { const { type, data } = JSON.parse( @@ -48,7 +49,9 @@ class WebSocketServerWorker extends ClusterWorker { ws.send( JSON.stringify({ type: MessageType.factorial, - data: { number: factorial(data.number as number) } + data: { + number: WebSocketServerWorker.factorial(data.number!) + } }) ) break @@ -62,7 +65,11 @@ class WebSocketServerWorker extends ClusterWorker { } public constructor () { - super(WebSocketServerWorker.startWebSocketServer) + super(WebSocketServerWorker.startWebSocketServer, { + killHandler: () => { + WebSocketServerWorker.wss.close() + } + }) } }