From fd3f2c1a5fac360ac214048e08db7173fcd32209 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E1=84=8B=E1=85=B5=E1=84=8E=E1=85=A1=E1=86=AB=E1=84=8C?= =?UTF-8?q?=E1=85=B5=E1=86=AB?= Date: Sat, 6 Aug 2022 17:15:41 +0900 Subject: [PATCH 1/3] =?UTF-8?q?:hammer:=20fix(user)=20:=20user=20entity=20?= =?UTF-8?q?eagar=20=EA=B4=80=EB=A0=A8=20=EC=98=B5=EC=85=98=20=EB=81=84?= =?UTF-8?q?=EA=B8=B0?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/auth/guards/AccessToken.guard.ts | 3 ++- src/database/entities/user.entity.ts | 6 +++--- 2 files changed, 5 insertions(+), 4 deletions(-) diff --git a/src/auth/guards/AccessToken.guard.ts b/src/auth/guards/AccessToken.guard.ts index 7d30e78..159d57a 100644 --- a/src/auth/guards/AccessToken.guard.ts +++ b/src/auth/guards/AccessToken.guard.ts @@ -21,7 +21,7 @@ export class AccessTokenGuard implements CanActivate { context: ExecutionContext ): boolean | Promise | Observable { //@NoAuth 사용시 해당 부분에서 AccessTokenGuard 사용 해제시킴 - const noAuth = this.reflector.get('no-auth', context.getHandler()) + const noAuth = this.reflector.get('no-auth', context.getHandler()); if (noAuth) { return true; } @@ -56,6 +56,7 @@ export class AccessTokenGuard implements CanActivate { const payload = this.authService.verifyAccessJWT(jwtString); + // const user = payload const user = await this.authService.findUserById(payload.id); if (!user) { throw new UnauthorizedException( diff --git a/src/database/entities/user.entity.ts b/src/database/entities/user.entity.ts index 0c681e0..1dcc874 100644 --- a/src/database/entities/user.entity.ts +++ b/src/database/entities/user.entity.ts @@ -52,7 +52,7 @@ export class User { }) public role: Role; - @OneToMany(type => Comment, comment => comment.user, { eager: true }) + @OneToMany(type => Comment, comment => comment.user, { eager: false }) public comments: Comment[]; @ApiProperty({ @@ -60,7 +60,7 @@ export class User { type: () => [Order] }) @Expose() - @OneToMany(type => Order, order => order.user, { eager: true }) + @OneToMany(type => Order, order => order.user, { eager: false }) public order: Order[]; @ApiProperty({ @@ -68,7 +68,7 @@ export class User { type: () => [Ticket] }) @Expose() - @OneToMany(type => Ticket, ticket => ticket.user, { eager: true }) + @OneToMany(type => Ticket, ticket => ticket.user, { eager: false }) public ticket: Ticket[]; @ApiProperty({ From 8ca05723533823cb3ca8296a8673db4fa27cfa70 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E1=84=8B=E1=85=B5=E1=84=8E=E1=85=A1=E1=86=AB=E1=84=8C?= =?UTF-8?q?=E1=85=B5=E1=86=AB?= Date: Sat, 6 Aug 2022 17:26:20 +0900 Subject: [PATCH 2/3] =?UTF-8?q?:hammer:=20fix(user)=20:=20user=20entity=20?= =?UTF-8?q?eager=20false=20null=20=ED=83=80=EC=9E=85=20=EC=B6=94=EA=B0=80?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/database/entities/user.entity.ts | 6 +-- src/database/repositories/user.repository.ts | 17 ++++--- src/users/users.service.ts | 48 ++++++++++++-------- 3 files changed, 41 insertions(+), 30 deletions(-) diff --git a/src/database/entities/user.entity.ts b/src/database/entities/user.entity.ts index 1dcc874..f696bbf 100644 --- a/src/database/entities/user.entity.ts +++ b/src/database/entities/user.entity.ts @@ -53,7 +53,7 @@ export class User { public role: Role; @OneToMany(type => Comment, comment => comment.user, { eager: false }) - public comments: Comment[]; + public comments: Comment[] | null; @ApiProperty({ description: '유저의 주문목록', @@ -61,7 +61,7 @@ export class User { }) @Expose() @OneToMany(type => Order, order => order.user, { eager: false }) - public order: Order[]; + public order: Order[] | null; @ApiProperty({ description: '유저의 티켓목록', @@ -69,7 +69,7 @@ export class User { }) @Expose() @OneToMany(type => Ticket, ticket => ticket.user, { eager: false }) - public ticket: Ticket[]; + public ticket: Ticket[] | null; @ApiProperty({ description: '유저 생성 일자', diff --git a/src/database/repositories/user.repository.ts b/src/database/repositories/user.repository.ts index 04d369e..e106e43 100644 --- a/src/database/repositories/user.repository.ts +++ b/src/database/repositories/user.repository.ts @@ -18,7 +18,7 @@ export class UserRepository { ) {} async getMyInfo(user: User) { - return await this.userRepository.findOne({ where : {id: user.id}}); + return await this.userRepository.findOne({ where: { id: user.id } }); } async findByPhoneNumber(phoneNumber: string): Promise { @@ -57,7 +57,7 @@ export class UserRepository { // 유저 정보 조회(관리자용) 전체 정보 조회 async getAllUserInfo( - userFindDto: UserFindDto, + userFindDto: UserFindDto, pageOptionsDto: PageOptionsDto ) { const { searchName, phoneNumber } = userFindDto; @@ -82,18 +82,18 @@ export class UserRepository { .addSelect('ticket') .skip(pageOptionsDto.skip) .take(pageOptionsDto.take); - + const itemCount = await queryBuilder.getCount(); const { entities } = await queryBuilder.getRawAndEntities(); - const pageMetaDto = new PageMetaDto({ itemCount, pageOptionsDto }) - - return new PageDto(entities, pageMetaDto); + const pageMetaDto = new PageMetaDto({ itemCount, pageOptionsDto }); + + return new PageDto(entities, pageMetaDto); } // 입금자명 수정 async changeName(id: number, requestUserNameDto: RequestUserNameDto) { - const found = await this.userRepository.findOne({ where: {id: id}}); + const found = await this.userRepository.findOne({ where: { id: id } }); if (!found) { throw new NotFoundException('해당 유저가 존재하지 않습니다.'); @@ -105,5 +105,4 @@ export class UserRepository { await this.userRepository.save(found); return plainToInstance(UserProfileDto, found); } - -} \ No newline at end of file +} diff --git a/src/users/users.service.ts b/src/users/users.service.ts index 8e07627..3c3a9a1 100644 --- a/src/users/users.service.ts +++ b/src/users/users.service.ts @@ -35,25 +35,31 @@ export class UsersService { async findUserById(id: number): Promise { return await this.userRepository.findUserById(id); } - + // 유저 정보 조회(관리자용) 전체 정보 조회 - async getAllUserInfo(userFindDto: UserFindDto, pageOptionsDto: PageOptionsDto) { - const pageDto = await this.userRepository.getAllUserInfo(userFindDto, pageOptionsDto); + async getAllUserInfo( + userFindDto: UserFindDto, + pageOptionsDto: PageOptionsDto + ) { + const pageDto = await this.userRepository.getAllUserInfo( + userFindDto, + pageOptionsDto + ); const pageMetaData = pageDto.meta; const users = pageDto.data; - const ret_users = users.map(function(user) { + const ret_users = users.map(function (user) { const userProfile = { id: user.id, name: user.name, phoneNumber: user.phoneNumber, role: user.role, createAt: user.createdAt, - ticketNum: user.ticket.length - } + ticketNum: user.ticket?.length + }; return userProfile; - }) - const entities = plainToInstance(ResponseUserTicketNumDto, ret_users) - + }); + const entities = plainToInstance(ResponseUserTicketNumDto, ret_users); + return new PageDto(entities, pageMetaData); } @@ -69,28 +75,34 @@ export class UsersService { // 모든 댓글 조회 async getAllComment(userId: number, scrollOptionsDto: ScrollOptionsDto) { - const responseScrollCommentDto = await this.commentRepository.getAllComment(userId, scrollOptionsDto); + const responseScrollCommentDto = await this.commentRepository.getAllComment( + userId, + scrollOptionsDto + ); const comments = responseScrollCommentDto.list; - const ret_comments = comments.map(function(comment) { + const ret_comments = comments.map(function (comment) { const responseCommentDto = { ...comment, iUserId: userId - } - return responseCommentDto; - } - ) + }; + return responseCommentDto; + }); const final_comments = plainToInstance(ResponseCommentDto, ret_comments); - return new ResponseScrollCommentsDto(final_comments, responseScrollCommentDto.meta); + return new ResponseScrollCommentsDto( + final_comments, + responseScrollCommentDto.meta + ); } // 댓글 랜덤 조회 async getRandomComment(requestRandomCommentDto: RequestRandomCommentDto) { - return await this.commentRepository.getRandomComment(requestRandomCommentDto); + return await this.commentRepository.getRandomComment( + requestRandomCommentDto + ); } // 댓글 삭제 async deleteComment(id: number) { return await this.commentRepository.deleteComment(id); } - } From f5f8434913502b5544cb01b3aef60b09d0bbbe72 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E1=84=8B=E1=85=B5=E1=84=8E=E1=85=A1=E1=86=AB=E1=84=8C?= =?UTF-8?q?=E1=85=B5=E1=86=AB?= Date: Sat, 6 Aug 2022 17:32:56 +0900 Subject: [PATCH 3/3] :rocket: fix(accessGuard) : reqUser type to accessJWTpalyod --- src/auth/auth.interface.ts | 3 +++ src/auth/auth.service.ts | 14 +++++++++----- src/auth/guards/AccessToken.guard.ts | 2 +- src/common/decorators/user.decorator.ts | 3 ++- src/tickets/tickets.controller.ts | 8 ++++---- src/tickets/tickets.service.ts | 9 ++++++--- 6 files changed, 25 insertions(+), 14 deletions(-) diff --git a/src/auth/auth.interface.ts b/src/auth/auth.interface.ts index e9c2796..6b5fe9b 100644 --- a/src/auth/auth.interface.ts +++ b/src/auth/auth.interface.ts @@ -1,3 +1,5 @@ +import { Role } from 'src/common/consts/enum'; + export interface RegisterJwtPayload { phoneNumber: string; } @@ -6,4 +8,5 @@ export interface AccessJwtPayload { phoneNumber: string; name: string; id: number; + role: Role; } diff --git a/src/auth/auth.service.ts b/src/auth/auth.service.ts index bf61674..54ad029 100644 --- a/src/auth/auth.service.ts +++ b/src/auth/auth.service.ts @@ -129,7 +129,8 @@ export class AuthService { const accessToken = this.accessJwtSign({ id: user.id, phoneNumber: user.phoneNumber, - name: user.name + name: user.name, + role: user.role }); //console.log(accessToken); @@ -180,7 +181,8 @@ export class AuthService { const accessToken = this.accessJwtSign({ id: signUser.id, phoneNumber: signUser.phoneNumber, - name: signUser.name + name: signUser.name, + role: signUser.role }); await queryRunner.commitTransaction(); @@ -289,7 +291,8 @@ export class AuthService { const accessToken = this.accessJwtSign({ id: searchUser.id, phoneNumber: searchUser.phoneNumber, - name: searchUser.name + name: searchUser.name, + role: searchUser.role }); return { user: searchUser, @@ -371,12 +374,13 @@ export class AuthService { | string ) & AccessJwtPayload; - const { phoneNumber, id, name } = payload; + const { phoneNumber, id, name, role } = payload; return { id, phoneNumber, - name + name, + role }; } catch (e) { if (e.name === 'TokenExpiredError') diff --git a/src/auth/guards/AccessToken.guard.ts b/src/auth/guards/AccessToken.guard.ts index 159d57a..d717595 100644 --- a/src/auth/guards/AccessToken.guard.ts +++ b/src/auth/guards/AccessToken.guard.ts @@ -57,7 +57,7 @@ export class AccessTokenGuard implements CanActivate { const payload = this.authService.verifyAccessJWT(jwtString); // const user = payload - const user = await this.authService.findUserById(payload.id); + const user = payload; if (!user) { throw new UnauthorizedException( AuthErrorDefine['Auth-1003'], diff --git a/src/common/decorators/user.decorator.ts b/src/common/decorators/user.decorator.ts index 22432be..3780a20 100644 --- a/src/common/decorators/user.decorator.ts +++ b/src/common/decorators/user.decorator.ts @@ -1,11 +1,12 @@ import { createParamDecorator, ExecutionContext } from '@nestjs/common'; +import { AccessJwtPayload } from 'src/auth/auth.interface'; export const ReqUser = createParamDecorator( (data: unknown, ctx: ExecutionContext) => { const request = ctx.switchToHttp().getRequest(); // //console.log('asdfasdfasd'); - const userObj = request.user; + const userObj = request.user as AccessJwtPayload; return userObj; } diff --git a/src/tickets/tickets.controller.ts b/src/tickets/tickets.controller.ts index 3255d8c..c7aab79 100644 --- a/src/tickets/tickets.controller.ts +++ b/src/tickets/tickets.controller.ts @@ -38,6 +38,7 @@ import { NoAuth } from 'src/auth/guards/NoAuth.guard'; import { TicketCountDto } from './dtos/ticket-count.dto'; import { ErrorResponse } from 'src/common/decorators/ErrorResponse.decorator'; import { TicketEntryResponseDto } from './dtos/ticket-entry-response.dto'; +import { AccessJwtPayload } from 'src/auth/auth.interface'; @ApiTags('tickets') @ApiBearerAuth('accessToken') @@ -155,7 +156,7 @@ export class TicketsController { @Patch('/status') updateTicketStatus( @Body('') updateTicketStatusDto: UpdateTicketStatusDto, - @ReqUser() user: User + @ReqUser() user: AccessJwtPayload ) { return this.ticketService.updateTicketStatus(updateTicketStatusDto, user); } @@ -176,7 +177,7 @@ export class TicketsController { getTicketByUuid( @Param('uuid') uuid: string, - @ReqUser() user: User + @ReqUser() user: AccessJwtPayload ) { //console.log(user); return this.ticketService.findByUuid(uuid, user); @@ -279,7 +280,6 @@ export class TicketsController { return this.ticketService.deleteTicketByUuid(ticketUuid); } - // /* 테스트용 라우팅 */ // @ApiOperation({ // summary: '[테스트용, 삭제예정]조건없이 모든 티켓을 불러온다' @@ -298,7 +298,7 @@ export class TicketsController { // getAllTickets() { // return this.ticketService.findAll(); // } - + // @ApiOperation({ summary: '[테스트용] 임시 티켓 생성' }) // @ApiResponse({ // status: 200, diff --git a/src/tickets/tickets.service.ts b/src/tickets/tickets.service.ts index 9dfd1c9..5607868 100644 --- a/src/tickets/tickets.service.ts +++ b/src/tickets/tickets.service.ts @@ -20,6 +20,7 @@ import { CreateTicketDto } from './dtos/create-ticket.dto'; import { TicketEntryResponseDto } from './dtos/ticket-entry-response.dto'; import { TicketFindDto } from './dtos/ticket-find.dto'; import { UpdateTicketStatusDto } from './dtos/update-ticket-status.dto'; +import { AccessJwtPayload } from 'src/auth/auth.interface'; @Injectable() export class TicketsService { @@ -42,7 +43,10 @@ export class TicketsService { * @param user Request User * @returns Ticket Promise */ - async findByUuid(ticketUuid: string, user: User): Promise { + async findByUuid( + ticketUuid: string, + user: AccessJwtPayload + ): Promise { const ticket = await this.ticketRepository.findByUuid(ticketUuid); //어드민이거나 Ticket.user.id === user.id 일때만 리턴 @@ -124,7 +128,7 @@ export class TicketsService { return '입금 기한이 만료된 티켓입니다'; } else if (status == TicketStatus.ORDERWAIT) { return '입금 대기중인 티켓입니다'; - } + } return '검증 오류'; }; @@ -137,7 +141,6 @@ export class TicketsService { // 티켓 상태 오류('입장대기'가 아님) if (ticket.status !== TicketStatus.ENTERWAIT) { - response.message = '[입장실패]' + getFailureMessage(ticket.status); this.socketService.emitToAll(response); throw new BadRequestException(getFailureMessage(ticket.status));