All files / user user.controller.ts

100% Statements 24/24
100% Branches 0/0
100% Functions 4/4
100% Lines 22/22

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 774x 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);
  }
}