Как генерировать документацию API с помощью Swagger в NestJS?
Документация API — это важная часть разработки, особенно когда речь идет о RESTful сервисах. Она помогает разработчикам легко ориентироваться в вашем API, становится основным инструментом для коммуникации между фронтенд и бэкенд командами и упрощает интеграцию. Swagger — это один из самых популярных инструментов для документирования API, который позволяет автоматизировать этот процесс и создавать интерактивную документацию.
Шаги для интеграции Swagger в NestJS
@nestjs/swagger
и swagger-ui-express
. Вы можете установить их с помощью npm:npm install @nestjs/swagger swagger-ui-express
main.ts
):import { NestFactory } from '@nestjs/core';
import { AppModule } from './app.module';
import { SwaggerModule, DocumentBuilder } from '@nestjs/swagger';
async function bootstrap() {
const app = await NestFactory.create(AppModule);
const config = new DocumentBuilder()
.setTitle('API документация')
.setDescription('Описание вашего API')
.setVersion('1.0')
.addTag('api') // добавьте теги, если хотите
.build();
const document = SwaggerModule.createDocument(app, config);
SwaggerModule.setup('api-docs', app, document);
await app.listen(3000);
}
bootstrap();
@nestjs/swagger
, чтобы описать поля вашего класса.import { ApiProperty } from '@nestjs/swagger';
export class CreateUserDto {
@ApiProperty({
description: 'Имя пользователя',
example: 'John Doe',
})
name: string;
@ApiProperty({
description: 'Электронная почта пользователя',
example: 'john@example.com',
})
email: string;
}
@ApiResponse
, @ApiTags
, и другие, чтобы описать ваши контроллеры:import { Controller, Post, Body } from '@nestjs/common';
import { ApiOperation, ApiResponse, ApiTags } from '@nestjs/swagger';
import { CreateUserDto } from './create-user.dto';
@ApiTags('users')
@Controller('users')
export class UsersController {
@Post()
@ApiOperation({ summary: 'Создать пользователя' })
@ApiResponse({ status: 201, description: 'Пользователь успешно создан.' })
@ApiResponse({ status: 400, description: 'Некорректные данные.' })
async create(@Body() createUserDto: CreateUserDto) {
// Логика создания пользователя
}
}
Преимущества документирования API
Использование Swagger в NestJS позволяет легко поддерживать и обновлять документацию, увеличивая продуктивность команды и снижая количество ошибок на этапе разработки.