|
@ -62,6 +62,7 @@ export class PongGateway implements OnGatewayConnection, OnGatewayDisconnect { |
|
|
} |
|
|
} |
|
|
if (name !== undefined) { |
|
|
if (name !== undefined) { |
|
|
console.log('Disconnected ', this.socketToPlayerName.get(client)) |
|
|
console.log('Disconnected ', this.socketToPlayerName.get(client)) |
|
|
|
|
|
this.matchmakingQueue.removePlayer(name) |
|
|
this.socketToPlayerName.delete(client) |
|
|
this.socketToPlayerName.delete(client) |
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
@ -202,20 +203,19 @@ export class PongGateway implements OnGatewayConnection, OnGatewayDisconnect { |
|
|
client: WebSocketWithId, |
|
|
client: WebSocketWithId, |
|
|
@MessageBody() matchmakingUpdateData: MatchmakingDtoValidated |
|
|
@MessageBody() matchmakingUpdateData: MatchmakingDtoValidated |
|
|
): { event: string, data: MatchmakingDtoValidated } { |
|
|
): { event: string, data: MatchmakingDtoValidated } { |
|
|
let isMatchmaking: boolean = false |
|
|
let matchmaking: boolean = false |
|
|
const name: string | undefined = this.socketToPlayerName.get(client) |
|
|
const name: string | undefined = this.socketToPlayerName.get(client) |
|
|
if (name !== undefined) { |
|
|
if (name !== undefined) { |
|
|
if (matchmakingUpdateData.matchmaking) { |
|
|
if (matchmakingUpdateData.matchmaking && !this.games.isInAGame(name)) { |
|
|
if (this.matchmakingQueue.addPlayer(name, client, client.id)) { |
|
|
this.matchmakingQueue.addPlayer(name, client, client.id) |
|
|
isMatchmaking = true |
|
|
|
|
|
} |
|
|
|
|
|
} else { |
|
|
} else { |
|
|
this.matchmakingQueue.removePlayer(name) |
|
|
this.matchmakingQueue.removePlayer(name) |
|
|
} |
|
|
} |
|
|
|
|
|
matchmaking = this.matchmakingQueue.isInQueue(name) |
|
|
} |
|
|
} |
|
|
return { |
|
|
return { |
|
|
event: GAME_EVENTS.MATCHMAKING, |
|
|
event: GAME_EVENTS.MATCHMAKING, |
|
|
data: { matchmaking: isMatchmaking } |
|
|
data: { matchmaking } |
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|