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:
parent
6a729cc7ad
commit
c9157e83ef
12
client.ts
12
client.ts
@ -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;
|
||||||
|
@ -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;
|
||||||
|
|
||||||
|
25
server.ts
25
server.ts
@ -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));
|
||||||
|
}
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user