npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

swagger-autogen-doc

v1.0.4

Published

## Установка

Downloads

7

Readme

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("[email protected]");
    })

=======

Схемы

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