From 470c0667c7a9636eade5c4f19e45add3be841190 Mon Sep 17 00:00:00 2001 From: solufa Date: Wed, 17 Jul 2024 03:46:02 +0900 Subject: [PATCH] feat: implement broadcastToAuthedClients --- server/service/websocket.ts | 19 +++++++++++++------ 1 file changed, 13 insertions(+), 6 deletions(-) diff --git a/server/service/websocket.ts b/server/service/websocket.ts index 1219fcb..e7fec0b 100644 --- a/server/service/websocket.ts +++ b/server/service/websocket.ts @@ -8,6 +8,12 @@ let fastify: FastifyInstance; const users: Record = {}; +const sendJson = (socket: WebSocket, data: WebSocketData): void => { + if (socket.readyState !== WebSocket.OPEN) return; + + socket.send(JSON.stringify(data)); +}; + export const websocket = { init: (app: FastifyInstance): void => { fastify = app; @@ -26,13 +32,14 @@ export const websocket = { }); }, send: (userId: DtoId['user'], data: WebSocketData): void => { - users[userId]?.send(JSON.stringify(data)); + users[userId] && sendJson(users[userId], data); + }, + broadcastToAuthedClients: (data: WebSocketData): void => { + Object.values(users) + .filter((user) => user !== undefined) + .forEach((socket) => sendJson(socket, data)); }, broadcast: (data: WebSocketData): void => { - fastify.websocketServer.clients.forEach((socket) => { - if (socket.readyState !== WebSocket.OPEN) return; - - socket.send(JSON.stringify(data)); - }); + fastify.websocketServer.clients.forEach((socket) => sendJson(socket, data)); }, };