From 7abd6827fb47e49d33311c831a1b1c77ea0f9832 Mon Sep 17 00:00:00 2001 From: zaehuun Date: Thu, 18 Nov 2021 16:48:58 +0900 Subject: [PATCH] =?UTF-8?q?Feat:=20=EB=B0=A9=20=EC=9D=B8=EC=9B=90=20?= =?UTF-8?q?=EB=8B=A4=20=EC=B0=BE=EB=8A=94=EC=A7=80=20=EA=B2=80=EC=82=AC=20?= =?UTF-8?q?/=20verify-room=20=EC=9D=B4=EB=B2=A4=ED=8A=B8?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- server/socket/src/gateway/room.gateway.ts | 32 +++++++++++++++++------ 1 file changed, 24 insertions(+), 8 deletions(-) diff --git a/server/socket/src/gateway/room.gateway.ts b/server/socket/src/gateway/room.gateway.ts index 731386d4..eb1f336f 100644 --- a/server/socket/src/gateway/room.gateway.ts +++ b/server/socket/src/gateway/room.gateway.ts @@ -31,28 +31,44 @@ export class RoomGateway implements OnGatewayInit, OnGatewayConnection, OnGatewa } @SubscribeMessage('join-room') - handleJoinRoom(client: Socket, { field, img, nickname, roomId }: IRoomRequest): void { + handleJoinRoom(client: Socket, { field, img, nickname, roomId, maxHead }: IRoomRequest): void { + client.leave(client.id); //verify-room에서 생성한 룸을 삭제합니다. 이제 사용될 일이 없어서.. client.join(roomId); - if (!this.userList[roomId]) this.userList[roomId] = {}; - this.userList[roomId][nickname] = { + if (!this.userList[roomId]) this.userList[roomId] = { list: {}, maxHead: maxHead }; + this.userList[roomId]['list'][nickname] = { field: field, img: img, }; - this.server.to(roomId).emit('user-list', this.userList[roomId]); + this.server.to(roomId).emit('user-list', this.userList[roomId]['list']); } @SubscribeMessage('leave-room') handleLeaveRoom(client: Socket, { nickname, roomId }: IRoomRequest): void { client.leave(roomId); - delete this.userList[roomId][nickname]; - this.server.to(roomId).emit('user-list', this.userList[roomId]); + delete this.userList[roomId]['list'][nickname]; + this.server.to(roomId).emit('user-list', this.userList[roomId]['list']); } @SubscribeMessage('kick-room') handleKickRoom(client: Socket, { roomId, kickNickname }: IRoomRequest): void { if (!kickNickname) return; - delete this.userList[roomId][kickNickname]; - this.server.to(roomId).emit('user-list', this.userList[roomId]); + delete this.userList[roomId]['list'][kickNickname]; + this.server.to(roomId).emit('user-list', this.userList[roomId]['list']); + } + + @SubscribeMessage('verify-room') + handleVerifyRoom(client: Socket, { roomId }: IRoomRequest): void { + client.join(client.id); //해당 사용자한테만 전송될 수 있게 + if (!this.userList[roomId]) { + this.server.to(client.id).emit('is-verify', true); + return; + } + if (Object.keys(this.userList[roomId]['list']).length < this.userList[roomId]['maxHead']) { + this.server.to(client.id).emit('is-verify', true); + return; + } + + this.server.to(client.id).emit('is-verify', false); } afterInit(server: Server) {