1.0.4 • Published 2 years ago

swagger-autogen-doc v1.0.4

Weekly downloads
-
License
ISC
Repository
github
Last release
2 years ago

swagger-autogen-doc

Установка

Для установки данного модуля используйте

npm install swagger-autogen-doc

Подключение

Подключение к проекту происходит путём импорта модуля и передачи в него объекта созданного через функцию express() и путь к директории проекта. Пример подключения:

const express = require('express')
const app = express()

/*
Подключение API к app
*/

const options = {};
require("swagger-autogen-doc").configure(app, options, __dirname);

ВАЖНО! Вызов функции .confugure() использовать после подключения API к объекту app. Т.к. не все данные могут быть получены.

Использование

Модуль расчитан на шаблон разработки, где каждый API лежит в отдельном файле и структуру файла подобной этой:

const { swaggerApi } = require("swagger-autogen-doc");
const Joi = require('joi')

module.exports = () => {
  return swaggerApi({
    method: 'get',
    path: '/api/v1/public/test',
    validationSchema: Joi.object({
      email: Joi.string().email()
    }),
    handler: async function (req, _res) {
      return res.status(200).json({message: "Hello world"});
    }
  });
}

Функция swaggerApi(object) используется получение информации о данном объекте. Поэтому и рекомендуется использовать configure() после подключения API для отработки данных функций. Описание Joi схемы следующее, если при её описании были использованы example(), то это будет использоваться для вывода примера запроса в документации. ВАЖНО!. Примеры для query параметров не будут отображаться в документации, но будут использованы для тестовых запросов

Использование комментариев

Синтаксис комментариев для описания имеет струкутуру похожую на HTML и XML. Для обозначения, что это именно комментарий для swagger генератора, используются тег \<swagger>\</swagger> Список доступных тегов:

  • summary - тег для описания заголовка API. Например:
<summary>
Авторизация пользователя
</summary>
  • remarks - тег для описания API
<remarks>
Принимает в теле запроса логин и пароль
</remarks>
  • param - тег для описания параметров query API. Имеет атрибуты:
    1. required - обязательный ли параметр
    2. name - имя параметра
<param name='Name' require=true>
Имя пользователя
</param>
  • body - тег для описания тела запроса API. Имеет атрибуты:
    1. required - обязательный ли параметр
    2. name - имя параметра
<body name='Data' require=true>
Данные о пользователе
</param>
  • response - тег для описания возможных ответов API. Имеет атрибуты:
    1. code - код ответа
<response code='200'>
Запрос успешен
</response>

Пример описания кода:

/*
<swagger>
<summary>
Тестовый API
</summary>

<remarks>
Тестовый API, ничего не принимает и всегда возвращает ответ с кодом 200 и текстом "Hello World"
</remarks>

<response code = '200'>Запрос успешен</response>
</swagger>
*/
const { swaggerApi } = require("swagger-autogen-doc");
const Joi = require('joi')

module.exports = () => {
  return swaggerApi({
    method: 'get',
    path: '/api/v1/public/test',
    validationSchema: Joi.object({
      email: Joi.string().email()
    }),
    handler: async function (req, _res) {
      return res.status(200).json({message: "Hello world"});
    }
  });
}

Также в комментариях имеется возможность использовать стандартные теги HTML, например, \<b>, \</br>.

Настройки

Объект настроек принимает в себя следующие поля:

  • folderApi - путь к папке где лежат API. Для оптимизации парсинга проекта
  • pathDoc - путь куда будет сохраняться .json файл документа относительно директории проекта. По-умолчанию равен "./swagger.json"
  • endpointSwagger - endpoint для доступа к документации. По-умолчанию равен "/api-docs"
  • url - объект настройки путей API который будет использоваться в разработке. Имеет свойства:
    • templateRout - шаблон endpoint. По-умолчанию равен "/api/:version/:controller/:resources+". То есть каждый endpoint будет иметь такую схему, например: '/api/v1/public/login'. Здесь v1 - version, public - controller, login - resources.
    • groupBy - по какому из частей endpoint будет группировка. По-умолчанию "controller".
  • Title - название документации
  • Version - версию документации
  • Schemes - массив схем для запросов, по-умолчанию хранит в себе все схемы. Может включать в себя:
    • http
    • https

Авторизация

Пример подключения авторизации:

const { AuthTypes } = require("swagger-autogen-doc");

const apiKey = new AuthTypes.ApiKeyAuth();
apiKey.Name = "Authorization";

const options = {
  auth: {
    Auth: apiKey
  }
}
require("swagger-autogen-doc").configure(app, options, __dirname);

В объекте AuthTypes лежат прототипы методов авторизации, такие как:

  • ApiKey - имеет свойство Name, которое будет передаваться в заголовок запроса
  • Bearer
  • Basic

После настройки выбранного объекта, необходимо подключить объект к объекту Swagger. Для этого при создании объекта OptionsSwagger передаем объект с полем auth. При добавлении объекта в это поле, имя поле будет названием схемы к которой можно будет подключать API. Например:

const { swaggerApi } = require("swagger-autogen-doc");
const Joi = require('joi')

module.exports = () => {
  return swaggerApi({
    method: 'get',
    path: '/api/v1/public/test',
    validationSchema: Joi.object({
      email: Joi.string().email()
    }),
    handler: async function (req, _res) {
      return res.status(200).json({message: "Hello world"});
    }
  }, "Auth");

Здесь функция swaggerApi принимает вторым аргументов имя схемы, которая будет использоваться для данного API.

Тестовые запросы

При первом запуске модуль попытается произвести запросы по всем АПИ для получения схемы ответов. Для этого требуется вызвать событие 'run' в app и передать в него порт. Например:

port = process.env.PORT || 3000;
app.emit('run', port);

ВАЖНО!. Событие надо вызвать после запуска сервера, иначе схемы не будут получены. После тестовых запросов в документацию будут добавлены схемы ответов соответствующих запросов. Тестовые данные для запросов генерируются автоматически, если не были указаны примеры в схемах черезе example(). Например:

Joi.object({
      email: Joi.string().email().example("test@mail.com");
    })

=======

Схемы

В данном генератора используются joi схемы для примеров параметров запроса.