OpenAPI (Swagger)
OpenAPI (Swagger)
This chapter applies only to TypeScript
OpenAPI (Swagger) μ¬μμ RESTful APIλ₯Ό μ€λͺ νλ κ°λ ₯ν μ μ νμμ λλ€. Nestλ μ μ© λͺ¨λμ μ 곡ν©λλ€.
Installation
λ¨Όμ νμν ν¨ν€μ§λ₯Ό μ€μΉν΄μΌν©λλ€.
fastifyλ₯Ό μ¬μ©νλ κ²½μ° swagger-ui-express
λμ fastify-swagger
λ₯Ό μ€μΉν΄μΌν©λλ€.
Bootstrap
μ€μΉ νλ‘μΈμ€κ° μλ£λλ©΄ λΆνΈ μ€νΈλ© νμΌ (λλΆλΆ main.ts
)μ μ΄κ³ SwaggerModule
ν΄λμ€λ₯Ό μ¬μ©νμ¬ Swaggerλ₯Ό μ΄κΈ°ν νμμμ€.
DocumentBuilder
λ SwaggerModule
μ κΈ°λ³Έ λ¬Έμλ₯Ό ꡬμ±νλ λ° λμμ μ£Όλ ν¬νΌ ν΄λμ€μ
λλ€. μ λͺ©, μ€λͺ
, λ²μ λ±κ³Ό κ°μ μμ±μ μ€μ ν μμλ λͺκ°μ§ λ°©λ²μ΄ ν¬ν¨λμ΄ μμ΅λλ€.
μ μλ HTTP κ²½λ‘λ‘ μ 체 λ¬Έμλ₯Ό λ§λ€λ €λ©΄ SwaggerModule
ν΄λμ€μ createDocument()
λ©μλλ₯Ό μ¬μ©νμμμ€. μ΄ λ©μλλ κ°κ° μμ© νλ‘κ·Έλ¨ μΈμ€ν΄μ€μ κΈ°λ³Έ Swagger μ΅μ
μ λκ°μ§ μΈμλ₯Ό μ¬μ©ν©λλ€.
λ§μ§λ§ λ¨κ³λ setup()
μ νΈμΆνλ κ²μ
λλ€. (1) Swaggerλ₯Ό μ₯μ°©νλ κ²½λ‘, (2) μμ© νλ‘κ·Έλ¨ μΈμ€ν΄μ€, (3) Nest μ ν리μΌμ΄μ
μ μ€λͺ
νλ λ¬Έμλ₯Ό μμ°¨μ μΌλ‘ νμ©ν©λλ€.
μ΄μ λ€μ λͺ λ Ήμ μ€ννμ¬ HTTP μλ²λ₯Ό μμν μ μμ΅λλ€.
μμ© νλ‘κ·Έλ¨μ΄ μ€νλλ λμ λΈλΌμ°μ λ₯Ό μ΄κ³ http://localhost:3000/api
λ‘ μ΄λνμμμ€. λΉμ·ν νμ΄μ§κ° λνλ©λλ€.
SwaggerModule
μ λͺ¨λ μλ ν¬μΈνΈλ₯Ό μλμΌλ‘ λ°μν©λλ€. λ°±κ·ΈλΌμ΄λμμλ swagger-ui-express
λ₯Ό μ¬μ©νκ³ λΌμ΄λΈ λ¬Έμλ₯Ό λ§λλλ€.
info ννΈ ν΄λΉ Swagger JSON νμΌμ λ€μ΄λ‘λνλ €λ©΄ λΈλΌμ°μ μμ
http://localhost:3000/api-json
μ νΈμΆνλ©΄λ©λλ€ (Swagger μ€λͺ μκ°http://localhost:3000/api
μ κ²μλ κ²½μ°). ).
Body, query, path parameters
μ μλ 컨νΈλ‘€λ¬λ₯Ό κ²μ¬νλ λμ SwaggerModule
μ κ²½λ‘ νΈλ€λ¬μμ μ¬μ©λ @Body()
, @Query()
λ° @Param()
λ°μ½λ μ΄ν°λ₯Ό λͺ¨λ μ°Ύμ΅λλ€. λ°λΌμ μ ν¨ν λ¬Έμλ₯Ό λ§λ€ μ μμ΅λλ€.
λν μ΄ λͺ¨λμ 리νλ μ μ νμ©νμ¬ λͺ¨λΈ μ μλ₯Ό λ§λλλ€. λ€μ μ½λλ₯Ό μ΄ν΄λ³΄μμμ€.
warning μλ¦Ό λ³Έλ¬Έ μ μλ₯Ό μμμ μΌλ‘ μ€μ νλ €λ©΄
@ApiImplicitBody()
λ°μ½λ μ΄ν° (@nestjs/swagger
ν¨ν€μ§)λ₯Ό μ¬μ©ν μ μμ΅λλ€.
CreateCatDto
λ₯Ό κΈ°λ°μΌλ‘ λͺ¨λ μ μκ° μμ±λ©λλ€ :
보μλ€μνΌ ν΄λμ€μ μ μΈλ μμ±μ΄ λͺ κ° μμ§λ§ μ μκ° λΉμ΄ μμ΅λλ€. ν΄λμ€ μμ±μ΄ SwaggerModule
μ μ‘μΈμ€ν μ μλλ‘ νλ €λ©΄, @ApiModelProperty()
λ°μ½λ μ΄ν°λ‘ λͺ¨λ μμ±μ νμν΄μΌ ν©λλ€.
λΈλΌμ°μ λ₯Ό μ΄κ³ μμ± λ CreateCatDto
λͺ¨λΈμ νμΈνμμμ€ :
@ApiModelProperty()
λ°μ½λ μ΄ν°λ μ΅μ
κ°μ²΄λ₯Ό λ°μ΅λλ€ :
warning ννΈ
{{"@ApiModelProperty({ required: false })"}}
λ₯Ό κ³μ μ λ ₯νμ§ μλλ‘ νλ@ApiModelPropertyOptional()
λ¨μΆ λ°μ½λ μ΄ν°κ° μμ΅λλ€.
λλΆμ default κ°μ κ°λ¨ν μ€μ νκ³ μμ±μ΄ νμνμ§ μ¬λΆλ₯Ό κ²°μ νκ±°λ μ νμ λͺ μμ μΌλ‘ μ€μ ν μ μμ΅λλ€.
Multiple specifications
Swagger λͺ¨λμ λν μ¬λ¬ μ¬μμ μ§μνλ λ°©λ²μ μ 곡ν©λλ€. μ¦, μλ ν¬μΈνΈλ§λ€ λ€λ₯Έ SwaggerUI
λ₯Ό μ¬μ©νμ¬ λ€λ₯Έ λ¬Έμλ₯Ό μ 곡ν μ μμ΅λλ€.
SwaggerModule
μ΄ λ€μ€ μ¬μμ μ§μν μ μλλ‘ νλ €λ©΄ μμ© νλ‘κ·Έλ¨μ λͺ¨λ λ°©μμΌλ‘ μμ±ν΄μΌ ν©λλ€. createDocument()
λ©μλλ μΈ λ²μ§Έ μΈμμΈ extraOptions
λ₯Ό μ¬μ©ν©λλ€. extraOptions
λ include
μμ±μ΄ λͺ¨λ λ°°μ΄μ νμλ‘ νλ κ°μ²΄μ
λλ€.
μλμ κ°μ΄ λ€μ€ μ¬μ μ§μμ μ€μ ν μ μμ΅λλ€.
μ΄μ λ€μ λͺ λ ΉμΌλ‘ μλ²λ₯Ό μμν μ μμ΅λλ€.
Catμ SwaggerUIλ₯Ό λ³΄λ €λ©΄ http://localhost:3000/api/cats
λ‘ μ΄λνμμμ€.
http://localhost:3000/api/dogs
λ κ°μμ§λ₯Όμν SwaggerUIλ₯Ό λ
ΈμΆμν΅λλ€:
warning μλ¦Ό
DocumentBuilder
λ‘ SwaggerOptionsλ₯Ό μμ±νκ³ μλ‘ μμ± λoptions
μ λν΄createDocument()
λ₯Ό μ€νν λ€μ λ λ²μ§Έ SwaggerOptionsμ λν μμ μ μμνκΈ° μ μsetup()
μ μ¬μ©νμ¬ μ¦μ "μ 곡"ν΄μΌ ν©λλ€. λ λ²μ§Έ Swagger μ¬μμ κ²½μ°. μ΄ νΉμ μμλ Swagger ꡬμ±μ΄ λ€λ₯Έ μ΅μ μΌλ‘ λ체λμ§ μλλ‘νκΈ°μν κ²μ λλ€.
Working with enums
SwaggerModule
μ΄ Enum
μ μλ³ν μ μμΌλ €λ©΄, @ApiModelProperty
μ enum
μμ±μ κ° λ°°μ΄λ‘ μλμΌλ‘ μ€μ ν΄μΌ ν©λλ€.
UserRole
μ΄κ±°νμ λ€μκ³Ό κ°μ΄ μ μν μ μμ΅λλ€.
warning Note The above usage can only be applied to a property as part of a model definition.
Enums can be used by itself with the @Query()
parameter decorator in combination with the @ApiImplicitQuery()
decorator.
warning ννΈ
enum
κ³ΌisArray
λ@ApiImplicitQuery()
μ ν¨κ» μ¬μ©ν μ μμ΅λλ€
isArray
λ₯Ό trueλ‘ μ€μ νλ©΄ enum
μ multi-selectλ‘ μ νν μ μμ΅λλ€.
Working with arrays
μμ±μ΄ μ€μ λ‘ λ°°μ΄μΌ λ μ νμ μλμΌλ‘ νμν΄μΌ ν©λλ€.
μμ κ·Έλ¦Όμ²λΌ λ°°μ΄μ 첫 λ²μ§Έ μμλ‘ νμ
μ μ
λ ₯νκ±°λ isArray
μμ±μ true
λ‘ μ€μ νμμμ€.
Tags
μ²μμλ DocumentBuilder
λ₯Ό μ¬μ©νμ¬ cats
νκ·Έλ₯Ό λ§λ€μμ΅λλ€. μ§μ λ νκ·Έμ 컨νΈλ‘€λ¬λ₯Ό μ°κ²°νλ €λ©΄@ApiUseTags(...tags)
λ°μ½λ μ΄ν°λ₯Ό μ¬μ©ν΄μΌν©λλ€.
Responses
컀μ€ν
HTTP μλ΅μ μ μνκΈ° μν΄ @ApiResponse()
λ°μ½λ μ΄ν°λ₯Ό μ¬μ©ν©λλ€.
μμΈ νν° μΉμ
μ μ μλ μΌλ°μ μΈ HTTP μμΈμ λ§μ°¬κ°μ§λ‘ Nestλ ν΅μ¬ @ApiResponse
λ°μ½λ μ΄ν°μμ μμλλ μ¬μ© κ°λ₯ν API μλ΅ μΈνΈλ₯Ό μ 곡ν©λλ€.
@ApiOkResponse()
@ApiCreatedResponse()
@ApiBadRequestResponse()
@ApiUnauthorizedResponse()
@ApiNotFoundResponse()
@ApiForbiddenResponse()
@ApiMethodNotAllowedResponse()
@ApiNotAcceptableResponse()
@ApiRequestTimeoutResponse()
@ApiConflictResponse()
@ApiGoneResponse()
@ApiPayloadTooLargeResponse()
@ApiUnsupportedMediaTypeResponse()
@ApiUnprocessableEntityResponse()
@ApiInternalServerErrorResponse()
@ApiNotImplementedResponse()
@ApiBadGatewayResponse()
@ApiServiceUnavailableResponse()
@ApiGatewayTimeoutResponse()
μ¬μ© κ°λ₯ν HTTP μμΈ μΈμλ Nestλ HttpStatus.OK
, HttpStatus.CREATED
λ° HttpStatus.METHOD_NOT_ALLOWED
μ λν λ¨μΆ λ°μ½λ μ΄ν°λ₯Ό μ 곡ν©λλ€.
Authentication
DocumentBuilder
ν΄λμ€μ addBearerAuth()
λ©μλλ₯Ό μ¬μ©νμ¬ λ² μ΄λ¬ μΈμ¦μ νμ±νν μ μμ΅λλ€. κ·Έλ° λ€μ μ νν κ²½λ‘ λλ μ 체 컨νΈλ‘€λ¬λ₯Ό μ ννλ €λ©΄ @ApiBearerAuth()
λ°μ½λ μ΄ν°λ₯Ό μ¬μ©νμμμ€.
OpenAPI μ€λͺ μλ λ€μκ³Ό κ°μ΅λλ€.
File upload
@ApiImplicitFile
λ°μ½λ μ΄ν°μ @ApiConsumes()
λ₯Ό μ¬μ©νμ¬ νΉμ λ©μλμ λν νμΌ μ
λ‘λλ₯Ό νμ±ν ν μ μμ΅λλ€. λ€μμ File Upload κΈ°μ μ μ¬μ©ν μ 체 μμ
λλ€.
Decorators
μ¬μ© κ°λ₯ν λͺ¨λ OpenAPI λ°μ½λ μ΄ν°μλ ν΅μ¬ λ°μ½λ μ΄ν°μ λͺ
ννκ² κ΅¬λΆν μμλ Api
μ λμ¬κ° μμ΅λλ€. μλλ μ μλ μ¬μ© μμ€ (μ μ© κ°λ₯ν κ²½μ°)μ κ°μ§ μμ€ν¬νΈλ λ°μ½λ μ΄ν°μ μ 체 λͺ©λ‘μ
λλ€.
@ApiOperation()
Method
@ApiResponse()
Method / Controller
@ApiProduces()
Method / Controller
@ApiConsumes()
Method / Controller
@ApiBearerAuth()
Method / Controller
@ApiOAuth2Auth()
Method / Controller
@ApiImplicitBody()
Method
@ApiImplicitParam()
Method
@ApiImplicitQuery()
Method
@ApiImplicitHeader()
Method
@ApiImplicitFile()
Method
@ApiExcludeEndpoint()
Method
@ApiUseTags()
Method / Controller
@ApiModelProperty()
Model
@ApiModelPropertyOptional()
Model
μ€μ μ¬λ‘λ μ¬κΈ°μμ νμΈν μ μμ΅λλ€.
Last updated
Was this helpful?