1
0
mirror of https://github.com/thib8956/tic-tac-toe-ws.git synced 2025-01-12 04:41:06 +00:00

handle remote websocketserver and handle game reset by client

This commit is contained in:
Thibaud Gasser 2024-09-25 22:15:10 +02:00
parent 6a729cc7ad
commit c9157e83ef
3 changed files with 35 additions and 10 deletions

View File

@ -5,7 +5,11 @@ const GRID_SIZE = CELL_SIZE * 3;
const SHAPE_SIZE = 100; const SHAPE_SIZE = 100;
const ANIMATE_DURATION = 500; // ms const ANIMATE_DURATION = 500; // ms
const ws = new WebSocket("ws://localhost:1234"); let address = "ws://localhost:1234";
if (window.location.hostname !== "localhost") {
address = "wss://tic-tac-toe-ws-production.up.railway.app";
}
const ws = new WebSocket(address);
interface Point { interface Point {
x: number; x: number;
@ -221,6 +225,12 @@ function init() {
} }
break; break;
} }
case "reset": {
canvasMsg = `Game reset... Id #${myId}, playing as ${mySymbol}`;
grid = new Array(9);
pendingEvts = [];
break;
}
default: { default: {
console.warn("unhandled message kind:", msg.kind); console.warn("unhandled message kind:", msg.kind);
break; break;

View File

@ -1,8 +1,8 @@
export type MessageKind = "hello" | "update" | "endgame"; export type MessageKind = "hello" | "update" | "endgame" | "reset";
export interface Message { export interface Message {
kind: MessageKind, kind: MessageKind,
data: Response | Hello | EndGame, data: Response | Hello | EndGame | Reset,
} }
export interface Request { export interface Request {
@ -11,7 +11,6 @@ export interface Request {
} }
export interface Response { export interface Response {
grid: number[],
last: { x: number, y: number, symbol: "x" | "o" } last: { x: number, y: number, symbol: "x" | "o" }
} }
@ -23,3 +22,6 @@ export interface Hello {
export interface EndGame { export interface EndGame {
issue: "win" | "lose" | "draw" issue: "win" | "lose" | "draw"
} }
type Reset = undefined;

View File

@ -19,6 +19,12 @@ let id = 1;
let clients: Client[] = []; let clients: Client[] = [];
let currentPlayer: Client | undefined = undefined; let currentPlayer: Client | undefined = undefined;
function getPlayerSymbol(): "o" | "x" {
console.assert(clients.length < 2, "there should never be more than 2 clients");
if (clients.length === 0) return "o";
return clients[0].symbol === "o" ? "x" : "o";
}
wss.on("connection", (ws) => { wss.on("connection", (ws) => {
id += 1; id += 1;
if (clients.length == 2) { if (clients.length == 2) {
@ -27,7 +33,7 @@ wss.on("connection", (ws) => {
return; return;
} }
const symbol = clients.length == 0 ? "o" : "x"; const symbol = getPlayerSymbol();
const helloMsg: Message = { const helloMsg: Message = {
kind: "hello", kind: "hello",
data: { id, symbol } as Hello data: { id, symbol } as Hello
@ -57,7 +63,6 @@ wss.on("connection", (ws) => {
const msg: Message = { const msg: Message = {
kind: "update", kind: "update",
data: { data: {
grid,
last: { x, y, symbol: player.symbol } last: { x, y, symbol: player.symbol }
} as Response, } as Response,
} }
@ -92,14 +97,22 @@ wss.on("connection", (ws) => {
kind: "endgame", kind: "endgame",
data: { issue: "lose" } as EndGame data: { issue: "lose" } as EndGame
} as Message)); } as Message));
endGame = true; endGame = true;
} }
} }
}); });
ws.on("close", () => { ws.on("close", (code: number) => {
console.log(`player #${id} disconnected`); console.log(`player disconnected. Resetting game. code: ${code}`);
clients = clients.filter(x => x.id !== id); clients = clients.filter(x => x.ws.readyState !== 3); // 3 == CLOSED
// reset game state
grid = [0, 0, 0, 0, 0, 0, 0, 0, 0]
currentPlayer = undefined;
for (const c of clients) {
c.ws.send(JSON.stringify({
kind: "reset"
} as Message));
}
}); });
}); });