From d3ac83e63b10aae1ced66e40f28b4c7774c8ec9c Mon Sep 17 00:00:00 2001 From: TheSparta Date: Sat, 4 May 2024 18:02:20 +0000 Subject: [PATCH] expose websockets (!321) - Added 2 methods that expose the websocket server and each session's websocket Reviewed-on: https://dev.sp-tarkov.com/SPT-AKI/Server/pulls/321 Co-authored-by: TheSparta Co-committed-by: TheSparta --- project/src/servers/WebSocketServer.ts | 19 +++++++++++++++---- 1 file changed, 15 insertions(+), 4 deletions(-) diff --git a/project/src/servers/WebSocketServer.ts b/project/src/servers/WebSocketServer.ts index 4dce9dee..03b05769 100644 --- a/project/src/servers/WebSocketServer.ts +++ b/project/src/servers/WebSocketServer.ts @@ -32,14 +32,25 @@ export class WebSocketServer protected httpConfig: IHttpConfig; protected defaultNotification: INotification = { type: NotificationType.PING, eventId: "ping" }; + protected webSocketServer: WebSocket.Server; protected webSockets: Record = {}; protected websocketPingHandler = null; + public getWebSocketServer(): WebSocket.Server + { + return this.webSocketServer; + } + + public getSessionWebSocket(sessionID: string): WebSocket.WebSocket + { + return this.webSockets[sessionID]; + } + public setupWebSocket(httpServer: http.Server): void { - const webSocketServer = new WebSocket.Server({ server: httpServer }); + this.webSocketServer = new WebSocket.Server({ server: httpServer }); - webSocketServer.addListener("listening", () => + this.webSocketServer.addListener("listening", () => { this.logger.success( this.localisationService.getText("websocket-started", this.httpServerHelper.getWebsocketUrl()), @@ -49,7 +60,7 @@ export class WebSocketServer ); }); - webSocketServer.addListener("connection", this.wsOnConnection.bind(this)); + this.webSocketServer.addListener("connection", this.wsOnConnection.bind(this)); } public sendMessage(sessionID: string, output: INotification): void @@ -101,7 +112,7 @@ export class WebSocketServer const logger = this.logger; const msgToLog = this.localisationService.getText("websocket-received_message", playerInfoText); - ws.on("message", function message(msg) + ws.on("message", (msg) => { logger.info(`${msgToLog} ${msg}`); });