Press n or j to go to the next uncovered block, b, p or k for the previous block.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 | 4x 4x 4x 4x 4x 4x 4x 4x 4x 4x 4x 4x 4x 4x 4x 15x 4x 1x 4x 1x 4x 3x | import { Body, Controller, Get, HttpStatus, Param, Put, UseGuards } from '@nestjs/common'; import { ApiBearerAuth, ApiOperation, ApiParam, ApiTags } from '@nestjs/swagger'; import { JwtAuthGuard } from 'src/auth/guards/jwt-auth.guard'; import { ERROR } from 'src/commons/constants/error'; import { ApiExceptionResponse } from 'src/commons/decorators/api-exception-response.decorator'; import { ApiSuccessResponse } from 'src/commons/decorators/api-success-response.decorator'; import { CurrentUser } from 'src/commons/decorators/user.decorator'; import { UuidResponseDto } from 'src/commons/dtos/uuid-response.dto'; import { BadWordsPipe } from 'src/commons/pipe/badwords.pipe'; import { ApiUserGetProfileResponseDto } from 'src/user/dto/api-user-get-profile-response.dto'; import { ApiUserGetTokenResponseDto } from 'src/user/dto/api-user-get-token-response.dto'; import { ApiUserPutUpdateRequestBodyDto } from 'src/user/dto/api-user-put-update-request-body.dto'; import { UserDto } from 'src/user/dto/user.dto'; import { UserService } from 'src/user/user.service'; @ApiTags('사용자') @Controller('/api/user') export class UserController { constructor(private readonly userService: UserService) {} @Put('/profile/:uuid') @UseGuards(JwtAuthGuard) @ApiBearerAuth('access-token') @ApiOperation({ summary: '프로필 수정', description: '프로필 수정', }) @ApiSuccessResponse(UuidResponseDto, { description: '프로필 수정 성공', status: HttpStatus.NO_CONTENT, }) async profileUpdate( @Body(BadWordsPipe) dto: ApiUserPutUpdateRequestBodyDto, @CurrentUser() user: UserDto, ): Promise<UuidResponseDto> { return this.userService.profileUpdate(dto, user); } @Get('/token/:uuid') @ApiOperation({ summary: 'Test - access_token 발급', description: 'Test - access_token 발급', }) @ApiSuccessResponse(ApiUserGetTokenResponseDto, { status: HttpStatus.OK, description: 'Test - access_token 발급', }) @ApiParam({ name: 'uuid', type: 'string', required: false, description: '승모 - 2871948cc25b589ea0a672a6f060fae3', }) async getAccessToken(@Param('uuid') uuid: string): Promise<ApiUserGetTokenResponseDto> { return this.userService.getAccessToken(uuid); } @Get('/profile') @UseGuards(JwtAuthGuard) @ApiBearerAuth('access-token') @ApiOperation({ summary: '유저 프로필 조회', description: '유저 프로필 조회', }) @ApiSuccessResponse(ApiUserGetProfileResponseDto, { description: '유저 프로필 조회 성공', status: HttpStatus.OK, }) @ApiExceptionResponse([ERROR.NOT_EXIST_DATA], { description: '유저 uuid가 없을 경우', status: HttpStatus.NOT_FOUND, }) async getProfile(@CurrentUser() user: UserDto): Promise<ApiUserGetProfileResponseDto> { return this.userService.getProfile(user); } } |