Swagger?
Swagger는 API 문서 자동화 도구이다. 이전에는 API 문서를 따로 작성하여 프런트엔드에게 전달했지만 Swagger를 사용하면 문서 작업 없이 코드를 수정하면서 API 문서를 같이 수정할 수 있다. 코드가 수정되었을 때 API 문서 최신화를 굳이 하지 않아도 되는 수고로움을 덜 할 수 있다. 제일 큰 장점은 API를 테스트할 수 있는 화면을 제공하여 실제 데이터 베이스와 통신이 가능하다.
Swagger Install
npm install @nestjs/swagger swagger-ui-express
npm install express-basic-auth
https://www.npmjs.com/package/express-basic-auth 참조
Nest JS에서는 Swagger를 사용할 수 있도록 모듈을 제공한다. 따라서 간단히 모듈 하나만 설치하면 된다. 종종 swagger에 보안 설정을 해놓지 않아 보안이 취약한 웹 사이트를 볼 수 있다. 따라서 두 번째 모듈도 설치해 아이디와 비밀번호를 설정해야 한다.
Swagger setting
data:image/s3,"s3://crabby-images/106a3/106a3658a4946cae7e91bdb78ad6fdd626f97bb5" alt=""
- Swagger를 사용하기 위해서 상위와 같이 main.ts에 장착한다.
- Nest는 express 기반 위해서 동작하게 설계를 했다. app.use를 통해 미들웨어를 main.ts에 장착하고 Swagger user와 password를 성정한다. 이 설정 파일은 꼭. env를 활용하여 환경 변수로 활용해야 한다.
- setUp은 genuioApi로 Swagger의 url을 정의한다.
- setTitile, setDescription으로 프로젝트 Swagger에 대한 간단한 설명을 설정한다.
- 필자는 인증/인가를 위해 JWT TOKEN을 사용하였습니다. 따라서 JwtAuthGuard가 적용되어 Token이 필요한 API를 Swagger에서 설정하기 위해 main.ts에서 addBearerAuth를 설정한다.
API Documentation
기본적으로 Swagger는 endpoint 별 혹은 메서드 별로 분류를 해 놓는다. 필자는 이렇게 분류되어 있는 곳에 좀 더 설명을 추가하였다. Swagger 사용법은 간단하다, @nestjs/swagger에서 제공하는 데코레이터들을 사용하면 된다.
data:image/s3,"s3://crabby-images/c2e83/c2e8365ad0b59a93e5b5b525199a9fff6825ac31" alt=""
data:image/s3,"s3://crabby-images/d92a9/d92a96913a183f7a6582a936e9d3d84571e6648e" alt=""
주로 기능별로 묶을 때 사용하지만 필자는 앱 별로 묶어서 사용하였다.### @ApiOperatons & @ApiCreateResponse @ApiBody
data:image/s3,"s3://crabby-images/3fbb4/3fbb40fc004e3c2919785deb94cd79d38fdfad5e" alt=""
data:image/s3,"s3://crabby-images/fdfb7/fdfb7e82d9df347c64ba9964d1b4f718937a3205" alt=""
- @ApiOperation은 API에 대한 간단한 요약과 설명을 제공한다.
- @ApiCreateResponse는 Status 201에 대한 설정으로, Response의 Description과 Type을 제공한다.
- @ApiBody는 Request Body의 타입을 설명한다.
@ApiBearerAuth
data:image/s3,"s3://crabby-images/e7bf1/e7bf15ecb8d2b47b6702f0bd493a1eae75365f62" alt=""
main.ts에 JWT로 지정한 Token을 @ApiBearerAuth()로 불러와서 사용한다. 이때 Parameter는 main.ts에 설정한 값이 일치해야 한다. 예를 들어 main.ts에 'token'이라고 설정했다면 데코레이터로 사용할 때도 동일하게 'token'이라고 설정해야 한다. @ApiBearerAuth를 사용하게 되면, API 별로 자물쇠 모양이 생겨날 것이다.
@ApiOkResponse & @ApiQuery
data:image/s3,"s3://crabby-images/6069e/6069ef8ecc4887d0a8bacd55224a4b5b27f80999" alt=""
data:image/s3,"s3://crabby-images/ed4f8/ed4f88814e27d8c951768e0bfae94a5061507e3e" alt=""
- @ApiOkResponse는 Status 200에 대한 설정으로, Response의 Description과 Type을 제공한다.
- @ApiQuery는 Query String에 대한 설명을 설정할 수 있다.
@Apiparams
data:image/s3,"s3://crabby-images/bd644/bd644856edaaede4e023443d2e188ad83fc464ac" alt=""
data:image/s3,"s3://crabby-images/f059c/f059c9d0b186cef18e981dd2f51b4501e8b23a33" alt=""
- @ApiParams는 Query Parameter에 대한 설명을 설정할 수 있다.
@ApiProperty
data:image/s3,"s3://crabby-images/579ab/579abab10d006d1310576edd4e2af56f0bbd7ea6" alt=""
data:image/s3,"s3://crabby-images/f5012/f50124543a71300eb65d53ff99b4c0e14f2dea24" alt=""
data:image/s3,"s3://crabby-images/a7ad0/a7ad012e8fd77591f92721a7e6d930134bd42de7" alt=""
- Dto 클래스의 속성에 @ApiProperty() 데코레이터를 사용해서 Swagger 문서화한다.
- @ApiProperty에서 기본적으로 제공하는 옵션을 통해서 설정할 수 있다.
- 다른 Dto에서 Picktype을 통해서 설정해 놓은 @ApiProperty를 가져다가 쓸 수 있다. updateDto는 기본적으로 ParticalType을 사용한다.