|
@ -8,11 +8,11 @@ import { |
|
|
WebSocketGateway |
|
|
WebSocketGateway |
|
|
} from '@nestjs/websockets' |
|
|
} from '@nestjs/websockets' |
|
|
import { randomUUID } from 'crypto' |
|
|
import { randomUUID } from 'crypto' |
|
|
import { Pong } from './pong' |
|
|
import { Games } from './pong' |
|
|
import { formatWebsocketData, Point } from './game/utils' |
|
|
import { formatWebsocketData, Point } from './game/utils' |
|
|
import { GAME_EVENTS } from './game/constants' |
|
|
import { GAME_EVENTS } from './game/constants' |
|
|
import { PlayerNamesDto } from './dtos/PlayerNamesDto'; |
|
|
import { PlayerNamesDto } from './dtos/PlayerNamesDto' |
|
|
import { UsePipes, ValidationPipe } from '@nestjs/common'; |
|
|
import { UsePipes, ValidationPipe } from '@nestjs/common' |
|
|
|
|
|
|
|
|
interface WebSocketWithId extends WebSocket { |
|
|
interface WebSocketWithId extends WebSocket { |
|
|
id: string |
|
|
id: string |
|
@ -20,7 +20,7 @@ interface WebSocketWithId extends WebSocket { |
|
|
|
|
|
|
|
|
@WebSocketGateway() |
|
|
@WebSocketGateway() |
|
|
export class PongGateway implements OnGatewayConnection, OnGatewayDisconnect { |
|
|
export class PongGateway implements OnGatewayConnection, OnGatewayDisconnect { |
|
|
private readonly pong: Pong = new Pong() |
|
|
private readonly games: Games = new Games() |
|
|
private readonly socketToPlayerName = new Map<WebSocketWithId, string>() |
|
|
private readonly socketToPlayerName = new Map<WebSocketWithId, string>() |
|
|
|
|
|
|
|
|
handleConnection (client: WebSocketWithId) { |
|
|
handleConnection (client: WebSocketWithId) { |
|
@ -32,10 +32,11 @@ export class PongGateway implements OnGatewayConnection, OnGatewayDisconnect { |
|
|
@ConnectedSocket() |
|
|
@ConnectedSocket() |
|
|
client: WebSocketWithId |
|
|
client: WebSocketWithId |
|
|
) { |
|
|
) { |
|
|
if (this.pong.isInAGame(client.id)) { |
|
|
const name: string = this.socketToPlayerName.get(client) |
|
|
|
|
|
if (this.games.isInAGame(name)) { |
|
|
console.log(`Disconnected ${this.socketToPlayerName.get(client)}`) |
|
|
console.log(`Disconnected ${this.socketToPlayerName.get(client)}`) |
|
|
if (this.pong.playerGame(client.id).isPlaying()) { |
|
|
if (this.games.playerGame(name).isPlaying()) { |
|
|
this.pong.playerGame(client.id).stop() |
|
|
this.games.playerGame(name).stop() |
|
|
} |
|
|
} |
|
|
this.socketToPlayerName.delete(client) |
|
|
this.socketToPlayerName.delete(client) |
|
|
} |
|
|
} |
|
@ -53,13 +54,16 @@ export class PongGateway implements OnGatewayConnection, OnGatewayDisconnect { |
|
|
|
|
|
|
|
|
@SubscribeMessage(GAME_EVENTS.GET_GAME_INFO) |
|
|
@SubscribeMessage(GAME_EVENTS.GET_GAME_INFO) |
|
|
getPlayerCount (@ConnectedSocket() client: WebSocketWithId) { |
|
|
getPlayerCount (@ConnectedSocket() client: WebSocketWithId) { |
|
|
|
|
|
const name: string = this.socketToPlayerName.get(client) |
|
|
|
|
|
if (name) { |
|
|
client.send( |
|
|
client.send( |
|
|
formatWebsocketData( |
|
|
formatWebsocketData( |
|
|
GAME_EVENTS.GET_GAME_INFO, |
|
|
GAME_EVENTS.GET_GAME_INFO, |
|
|
this.pong.getGameInfo(client.id) |
|
|
this.games.getGameInfo(name) |
|
|
) |
|
|
) |
|
|
) |
|
|
) |
|
|
} |
|
|
} |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
@SubscribeMessage(GAME_EVENTS.PLAYER_MOVE) |
|
|
@SubscribeMessage(GAME_EVENTS.PLAYER_MOVE) |
|
|
movePlayer ( |
|
|
movePlayer ( |
|
@ -67,7 +71,8 @@ export class PongGateway implements OnGatewayConnection, OnGatewayDisconnect { |
|
|
client: WebSocketWithId, |
|
|
client: WebSocketWithId, |
|
|
@MessageBody('position') position: Point |
|
|
@MessageBody('position') position: Point |
|
|
) { |
|
|
) { |
|
|
this.pong.movePlayer(client.id, position) |
|
|
const name: string = this.socketToPlayerName.get(client) |
|
|
|
|
|
this.games.movePlayer(name, position) |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
@UsePipes(new ValidationPipe({ whitelist: true })) |
|
|
@UsePipes(new ValidationPipe({ whitelist: true })) |
|
@ -75,17 +80,21 @@ export class PongGateway implements OnGatewayConnection, OnGatewayDisconnect { |
|
|
createGame ( |
|
|
createGame ( |
|
|
@ConnectedSocket() |
|
|
@ConnectedSocket() |
|
|
client: WebSocketWithId, |
|
|
client: WebSocketWithId, |
|
|
@MessageBody() playerNames: PlayerNamesDto |
|
|
@MessageBody() playerNamesDto: PlayerNamesDto |
|
|
) { |
|
|
) { |
|
|
console.log(playerNames); |
|
|
if (this.socketToPlayerName.size >= 2) { |
|
|
const allPlayerNames: Array<string> = Array.from(this.socketToPlayerName.values()); |
|
|
const player1Socket: WebSocketWithId = Array.from( |
|
|
if (allPlayerNames && allPlayerNames.length >= 2) { |
|
|
this.socketToPlayerName.keys() |
|
|
const player1Socket: WebSocketWithId = Array.from(this.socketToPlayerName.keys()).find( |
|
|
).find( |
|
|
(key) => this.socketToPlayerName.get(key) === playerNames[0] |
|
|
(key) => |
|
|
); |
|
|
this.socketToPlayerName.get(key) === playerNamesDto.playerNames[0] |
|
|
const player2Socket: WebSocketWithId = Array.from(this.socketToPlayerName.keys()).find( |
|
|
) |
|
|
(key) => this.socketToPlayerName.get(key) === playerNames[1] |
|
|
const player2Socket: WebSocketWithId = Array.from( |
|
|
); |
|
|
this.socketToPlayerName.keys() |
|
|
|
|
|
).find( |
|
|
|
|
|
(key) => |
|
|
|
|
|
this.socketToPlayerName.get(key) === playerNamesDto.playerNames[1] |
|
|
|
|
|
) |
|
|
|
|
|
|
|
|
if ( |
|
|
if ( |
|
|
player1Socket && |
|
|
player1Socket && |
|
@ -93,14 +102,13 @@ export class PongGateway implements OnGatewayConnection, OnGatewayDisconnect { |
|
|
(client.id === player1Socket.id || client.id === player2Socket.id) && |
|
|
(client.id === player1Socket.id || client.id === player2Socket.id) && |
|
|
player1Socket.id !== player2Socket.id |
|
|
player1Socket.id !== player2Socket.id |
|
|
) { |
|
|
) { |
|
|
this.pong.newGame( |
|
|
this.games.newGame( |
|
|
[player1Socket, player2Socket], |
|
|
[player1Socket, player2Socket], |
|
|
[player1Socket.id, player2Socket.id], |
|
|
[player1Socket.id, player2Socket.id], |
|
|
playerNames.playerNames |
|
|
playerNamesDto.playerNames |
|
|
); |
|
|
) |
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
|
return { event: GAME_EVENTS.CREATE_GAME }; |
|
|
|
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
@SubscribeMessage(GAME_EVENTS.READY) |
|
|
@SubscribeMessage(GAME_EVENTS.READY) |
|
@ -108,6 +116,21 @@ export class PongGateway implements OnGatewayConnection, OnGatewayDisconnect { |
|
|
@ConnectedSocket() |
|
|
@ConnectedSocket() |
|
|
client: WebSocketWithId |
|
|
client: WebSocketWithId |
|
|
) { |
|
|
) { |
|
|
this.pong.ready(client.id) |
|
|
const name: string = this.socketToPlayerName.get(client) |
|
|
|
|
|
if (name) { |
|
|
|
|
|
this.games.ready(name) |
|
|
|
|
|
} |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
@SubscribeMessage(GAME_EVENTS.SPECTATE) |
|
|
|
|
|
spectate ( |
|
|
|
|
|
@ConnectedSocket() |
|
|
|
|
|
client: WebSocketWithId, |
|
|
|
|
|
@MessageBody('playerToSpectate') playerToSpectate: string |
|
|
|
|
|
) { |
|
|
|
|
|
const name: string = this.socketToPlayerName.get(client) |
|
|
|
|
|
if (name) { |
|
|
|
|
|
this.games.spectateGame(playerToSpectate, client, client.id, name) |
|
|
|
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
|