From da03eed2b16e993401a35b4ffae13189f0af1b5f Mon Sep 17 00:00:00 2001 From: zaehuun Date: Thu, 18 Nov 2021 16:46:54 +0900 Subject: [PATCH 1/4] =?UTF-8?q?Feat:=20DevField=20=EB=A6=AC=ED=8F=AC=20?= =?UTF-8?q?=EC=B6=94=EA=B0=80?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- server/api/src/domain/auth/auth.module.ts | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/server/api/src/domain/auth/auth.module.ts b/server/api/src/domain/auth/auth.module.ts index 8c94a148..39ee1c3f 100644 --- a/server/api/src/domain/auth/auth.module.ts +++ b/server/api/src/domain/auth/auth.module.ts @@ -6,11 +6,12 @@ import { JwtStrategy } from './strategy/jwt.strategy'; import { AuthController } from './controller/auth.controller'; import { AuthService } from './service/auth.service'; import { UserRepository } from '../user/repository/user.repository'; +import { DevFieldRepository } from '../field/repository/dev-field.repository'; import { HistoryModule } from '../history/history.module'; @Module({ imports: [ - TypeOrmModule.forFeature([UserRepository]), + TypeOrmModule.forFeature([UserRepository, DevFieldRepository]), PassportModule, JwtModule.register({ secret: 'secretkey', From e47f48dfcd450bb0fbdde0f5be8357660654b6a1 Mon Sep 17 00:00:00 2001 From: zaehuun Date: Thu, 18 Nov 2021 16:47:20 +0900 Subject: [PATCH 2/4] =?UTF-8?q?Feat:=20=ED=9A=8C=EC=9B=90=EA=B0=80?= =?UTF-8?q?=EC=9E=85=20=EC=8B=9C=20=EA=B0=9C=EB=B0=9C=20=EB=B6=84=EC=95=BC?= =?UTF-8?q?=20=EC=A0=80=EC=9E=A5?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- server/api/src/domain/auth/service/auth.service.ts | 10 +++++++++- 1 file changed, 9 insertions(+), 1 deletion(-) diff --git a/server/api/src/domain/auth/service/auth.service.ts b/server/api/src/domain/auth/service/auth.service.ts index af08910c..33fa10af 100644 --- a/server/api/src/domain/auth/service/auth.service.ts +++ b/server/api/src/domain/auth/service/auth.service.ts @@ -4,13 +4,15 @@ import { JwtService } from '@nestjs/jwt'; import { LocalDate } from 'js-joda'; import { Bcrypt } from 'src/utils/bcrypt'; import { UserBuilder } from '../../../builder'; -import { UserException } from '../../../exception'; +import { DevFieldException, UserException } from '../../../exception'; import { User } from '../../user/user.entity'; import { HistoryService } from 'src/domain/history/service/history.service'; import { UserRepository } from '../../user/repository/user.repository'; +import { DevFieldRepository } from 'src/domain/field/repository/dev-field.repository'; import { LoginRequestDto } from '../dto/login-request.dto'; import { UserResponseDto } from '../dto/user-response.dto'; import { JoinRequestDto } from '../dto/join-request.dto'; +import { DevField } from 'src/domain/field/dev-field.entity'; @Injectable() export class AuthService { @@ -18,6 +20,9 @@ export class AuthService { @InjectRepository(UserRepository) private readonly userRepository: UserRepository, + @InjectRepository(DevFieldRepository) + private readonly devFieldRepository: DevFieldRepository, + private readonly historyService: HistoryService, private jwtService: JwtService, ) {} @@ -42,11 +47,14 @@ export class AuthService { const { nickname, email, password } = joinRequestDto; const isExistUser = await this.userRepository.exists(joinRequestDto); if (isExistUser) throw UserException.userIsExist(); + const devField: DevField = await this.devFieldRepository.findDevById(joinRequestDto.devFieldId); + if (!devField) throw DevFieldException.devFieldNotFound(); const user: User = new UserBuilder() .setNickName(nickname) .setEmail(email) .setPassword(Bcrypt.hash(password)) .setImageURL(process.env.DEFAULT_IMG) + .setDevField(devField) .build(); await this.userRepository.save(user); return true; From 35f31d706427e3692a39040db24270261bc06f6e Mon Sep 17 00:00:00 2001 From: zaehuun Date: Thu, 18 Nov 2021 16:48:28 +0900 Subject: [PATCH 3/4] =?UTF-8?q?Refactor:=20IRoomRequest=EC=97=90=20maxHead?= =?UTF-8?q?=20=EC=B6=94=EA=B0=80?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- server/socket/src/gateway/room.interface.ts | 1 + 1 file changed, 1 insertion(+) diff --git a/server/socket/src/gateway/room.interface.ts b/server/socket/src/gateway/room.interface.ts index 4c5ee3fc..6cd938f8 100644 --- a/server/socket/src/gateway/room.interface.ts +++ b/server/socket/src/gateway/room.interface.ts @@ -6,6 +6,7 @@ export interface IRoomRequest { kickNickname?: string; field?: string; img?: string; + maxHead: number; } export enum MessageType { From 7abd6827fb47e49d33311c831a1b1c77ea0f9832 Mon Sep 17 00:00:00 2001 From: zaehuun Date: Thu, 18 Nov 2021 16:48:58 +0900 Subject: [PATCH 4/4] =?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) {