From 86ab1e0326c9be5f4f5fc693ab54aed9b24b59e0 Mon Sep 17 00:00:00 2001 From: Danny Piper Date: Sun, 5 May 2024 21:20:03 +0100 Subject: [PATCH] fix: race condition --- game-source-redux/src/App.svelte | 8 ++++---- game-source-redux/src/lib/websockets.ts | 26 +++++++++++++------------ 2 files changed, 18 insertions(+), 16 deletions(-) diff --git a/game-source-redux/src/App.svelte b/game-source-redux/src/App.svelte index 355c383..76231b0 100644 --- a/game-source-redux/src/App.svelte +++ b/game-source-redux/src/App.svelte @@ -10,15 +10,15 @@ const cube_size = 100; onMount(() => { - KubeWebSocket.onError = (err) => { + const ws = new KubeWebSocket("Danny"); + + ws.onError = (err) => { console.error(err); }; - KubeWebSocket.onClose = () => { + ws.onClose = () => { console.error("Connection closed"); }; - - KubeWebSocket.connectAs("DannyBoy"); }); diff --git a/game-source-redux/src/lib/websockets.ts b/game-source-redux/src/lib/websockets.ts index a32dcce..728a61d 100644 --- a/game-source-redux/src/lib/websockets.ts +++ b/game-source-redux/src/lib/websockets.ts @@ -1,6 +1,6 @@ import { v4 } from "uuid"; -const baseUrl = "https://hack.djpiper28.co.uk/ws/"; +const baseUrl = "wss://hack.djpiper28.co.uk/ws/"; export const ERR_VAL = -9999999; @@ -12,7 +12,7 @@ export type PlayerCoordinateDelta = { newCoord: Coordinate; }; -class KubeWebSocket { +export default class KubeWebSocket { // Socket Shite public onError: (ev: Event) => void = console.error; public onClose: () => void = console.error; @@ -26,12 +26,16 @@ class KubeWebSocket { public onEmptyAction?: (coords: PlayerCoordinateDelta) => void; private ws: WebSocket; + private name: string; + + constructor(name: string) { + this.name = name; - constructor() { this.ws = new WebSocket(baseUrl); this.ws.onmessage = this.onMessage.bind(this); this.ws.onclose = this.onClose.bind(this); this.ws.onerror = this.onError.bind(this); + this.ws.onopen = this.onopen.bind(this) } private onMessage(event: MessageEvent) { @@ -61,23 +65,21 @@ class KubeWebSocket { } } - public connectAs(name: string) { + private send(data: string) { + console.log(`Sending: ${data}`); + this.ws.send(data); + } + + private onopen() { const data: PlayerInfo = { initialised: false, player: { uuid: v4(), - username: name, + username: this.name, }, coordinates: [0, 0], }; this.send(JSON.stringify(data)); } - - private send(data: string) { - console.log(`Sending: ${data}`); - this.ws.send(data); - } } - -export default new KubeWebSocket();