Skip to content

Latest commit

 

History

History
244 lines (167 loc) · 28.5 KB

integrating-swagger-with-docs.md

File metadata and controls

244 lines (167 loc) · 28.5 KB

Интеграция Swagger с документацией

Всякий раз, когда обсуждаются Swagger и другие спецификации REST API, технические писатели неизменно спрашивают, как они могут интегрировать выходные данные Swagger с остальной частью своей документации. Когда речь идет о Swagger, этот вопрос обсуждается среди технических писателей гораздо чаще других.

Содержание раздела

Единственный источник истины

Вариант 1. Встраиваем Swagger UI в свои документы

Вариант 2: Размещаем всю информацию в спецификацию в сворачиваемых разделах

Вариант 3: Парсим (анализируем) документ в спецификации OpenAPI

Вариант 4. Храним содержимое в YAML формате

Вариант 5: Используем инструмент, импортирующий Swagger и позволяющий работать с другой документацией

Вариант 6: Меняем перспективы - наличие двух сайтов не так уж плохо

Следующие шаги

Единственный источник истины

Когда мы помещаем документацию в другой исходный файл - в данном случае в файл YAML или JSON, включенный в набор файлов Swagger UI, в конечном итоге разбиваем свой единственный источник истины на несколько источников. Конечные точки и параметры уже определены в обычной документации, и теперь их нужно перенести в спецификацию OpenAPI . Вы копируете и вставляете одинаковые параметры и другую информацию на обоих сайтах? Вы как-то генерируете описания из одного и того же источника?

Эта головоломка обычно кристально ясна для технических авторов. Документация API состоит не только из адресного материала об API. Также имеется информация о получении ключей API, установке и настройке сервисов, или другие сведения, которые не соответствуют спецификации. Все это будем рассматривать в разделе Концептуальные разделы. Концептуальными разделами считают следующие:

Бывает, имеется больше данных, которые нужно сообщить пользователю, но которые не вписываются в спецификацию. Например, в конечной точке weather в примере API OpenWeatherMap, который мы использовали в этом курсе, есть некоторые подробности об идентификаторах городов, которые требуют некоторого объяснения.

...
},
"id": 420006397,
"name": "Santa Clara",
"cod": 200
}

Что означает "cod": 200? Если перейти в раздел «Идентификатор города» в документации OpenWeatherMap, увидим ссылку для загрузки списка кодов городов файлов.

Может быть сложной задачей добавить описания всех параметров, выделенных в спецификации OpenAPI, если таких данных очень много в адресных разделах документации. К сожалению, простого решения для создания единого источника истины не существует . Вот несколько вариантов:

Вариант 1. Встраиваем Swagger UI в свои документы

Одним из решений является внедрение Swagger UI непосредственно в документацию. Пример этого здесь: Swagger UI Demo. Вставить Swagger в HTML-страницу довольно легко. Последняя версия Swagger имеет более отзывчивый, гибкий дизайн. Так и просится быть встроенным в другой сайт.

Единственная проблема с вариантом встраивания состоит в том, что некоторые из моделей не ограничены в своем контейнере, поэтому они расширяются за пределы контейнера. Попробуйте расширить раздел «Модель» в демоверсии - будет понятно, о чем речь.

Может быть джедай стилей и смог бы изменить такое поведение. Возможно, но падаван, который не силен в стилях, не может решить такую проблему. В Swagger UI Demo добавлены несколько пользовательских стилей, для внесения изменений в интерфейс Swagger в разных местах. Если просмотреть исходный код этой страницы и изучить второй блок <style>, можно увидеть добавленные стили.

Благодаря встроенному параметру все равно можно использовать официальный инструментарий Swagger UI для чтения спецификации, и включать вывод Swagger UI в основную документацию. Swagger UI читает последнюю версию спецификации OpenAPI, которую многие инструменты еще не поддерживают. Кроме того, интерфейс Swagger имеет знакомый интерфейс, с которым разработчики API, уже знакомы. Но, если стилистика уродливым образом пересекается в разделах модели, можно не использовать подхода встраивания документации .

Вариант 2: Размещаем всю информацию в спецификацию в сворачиваемых разделах

Этот вариант предполагает попытку поместить всю информацию в сам документ спецификации. Удивительно, сколько информации можно включить в спецификацию. Любой элемент description (не только свойство description в объекте info) позволяет использовать Markdown и HTML. Например, вот объект info в спецификации OpenAPI, где появляется описание. (При желании можно набрать >, для перевода на следующую строку, а затем сделать отступ в два пробела. Можно добавить много содержимого в элементах description.)

info:
  title: OpenWeatherMap API
  description: 'Get the current weather, daily forecast for 16 days, and a three-hour-interval forecast for 5 days for your city. Helpful stats, graphics, and this day in history charts are available for your reference. Interactive maps show precipitation, clouds, pressure, wind around your location. Data is available in JSON, XML, or HTML format. **Note**: This sample Swagger file covers the `weather` endpoint only from the OpenWeatherMap API. <br/><br/> **Tip**: We recommend that you call the API by city ID (using the `id` parameter) to get unambiguous results for your city.'
  version: '2.5'

Можно делать ссылки на Bootstrap CSS и JS в заголовке index.html проекта Swagger UI, и затем включать предупреждения Bootstrap и кнопки раскрытия / свертывания в элементе description. Вот пример:

info:
  description: >
    ACME offers a lot of configuration options...
    <div class="alert alert-success" role="alert"><i class="fa fa-info-circle"></i> <b>Tip: </b>See the resources available in the portal for more detail.</div>
    <div class="alert alert-warning" role="alert"><i class="fa fa-info-circle"></i> <b>Note: </b>The  network includes a firewall that protects your access to the resources...</div>

    <div class="container">
    <div class="apiConfigDetails">
    <button type="button" class="btn btn-warning" data-toggle="collapse" data-target="#demo">
    <span class="glyphicon glyphicon-collapse-down"></span> See API Configuration Details
    </button>
    <div id="demo" class="collapse">

    <h2>Identifiers Allowed</h2>

    <p>Based on this configuration, ACME will accept any of the following identifiers in requests.</p>

    <table class="table">
    <thead>
    <tr>
    <th>Request Codes</th>
    <th>Data Type</th>
    <th>Comparison Method</th>
    </tr>
    </thead>
    <tbody>
    <tr>
    ...

Результатом будет сжатие большей части информации в одну кнопку, которая при нажатии разворачивалась, выдавая более подробную информацию. Включая разделы «развернуть/ свернуть» из Bootstrap, можно добавить массу информации в объект description. (Для необходимого JavaScript надо добавить теги <script> в заголовок или футер того же файла index.html, где мы ссылались на файл openapi.yaml)

Кроме того, можно включить модальные окна, которые появляются при нажатии. Модальные окна - это диалоговые окна, которые затемняют фон за пределами диалогового окна. Опять же, весь необходимый JavaScript-код можно включать в файл index.html проекта Swagger UI.

Если включить Bootstrap, вероятно, потребуется ограничить пространство имен, чтобы оно не влияло на другие элементы в отображении Swagger UI. (Подробнее о том, как это сделать, см. В разделе «How to Isolate Bootstrap CSS to Avoid Conflicts».)

В целом, если документация API относительно невелика, можно сначала попытаться поместить всю свою информацию в спецификации. Если есть сложный API или просто API, который содержит много дополнительной информации, не относящейся к спецификации, надо искать альтернативные подходы. Но попробуйте сначала вписать его в спецификацию. Это сохранит информацию в одном месте.

В использовании спецификации много преимуществ, которые легко упустить, если выбрать другой подход. Многие инструменты могут анализировать спецификацию и генерировать интерактивные дисплеи если сохранять информацию в спецификации.

Например, Spectacle - это проект, который создает вывод из файла Swagger - он практически не требует программирования или технических знаний. Появляется все больше и больше инструментов, которые позволяют импортировать вашу спецификацию OpenAPI: Lucybot, Restlet Studio, адаптивная тема Swagger UI, пользовательский интерфейс Material Swagger, DynamicAPIs, Run in Postman, SwaggerHub и многое другое. Все они читают спецификацию OpenAPI.

Перевод контента в формат спецификации OpenAPI позволяет отделять контент от уровня представления, мгновенно используя преимущества любого нового инструментария API или платформы, которые могут анализировать спецификацию.

Вариант 3: Парсим (анализируем) документ в спецификации OpenAPI

Если используется инструмент, такой как Jekyll, включающий язык под названием Liquid, можно использовать инстанс Liquid для Jekyll, для чтения документации спецификации OpenAPI (который, в конце концов, просто синтаксис YAML). Например, можно использовать цикл for для итерации значений спецификации OpenAPI. В примере ниже файл swagger.yml хранится в каталоге _data Jekyll.

<table>
    <thead>
    <tr><th>Name</th><th>Type</th><th>Description</th><th>Required?</th></tr>
    </thead>
    {% for parameter in site.data.swagger.paths.get.parameters %}
        {% if parameter.in == "query" %}
        <tr>
            <td><code>{{ parameter.name }}</code></td>
            <td><code>{{ parameter.type }}</code></td>
            <td>
            {% assign found = false %}
            {% for param in site.data.swagger.paths.get.parameters %}
                {% if parameter.name == param.name %}
                    {{ param.description }}
                    {% assign found = true %}
                {% endif %}
            {% endfor %}
            {% if found == false %}
                ** New parameter **
            {% endif %}
            </td>
            <td><code>{{ parameter.required }}</code></td>
        </tr>
        {% endif %}
    {% endfor %}
</table>

Особая благодарность Питеру Хендерсону за то, что он поделился этой техникой и кодом. При таком подходе, возможно, придется выяснить правильный синтаксис Liquid для итерации вашей спецификации OpenAPI, и это может занять некоторое время. Но это может сработать в поиске тесной интеграции с авторским инструментом. (Стоит обратить внимание, что многие генераторы статических сайтов могут анализировать YAML, а не только Jekyll.)

Дополнительная информация об этом подходе в статью Питера Хендерсону в разделе «Интеграция автоматически сгенерированного контента в ваш сайт документации с использованием Swagger и Jekyll» и этот пример кода GitHub.

Вариант 4. Храним содержимое в YAML формате

Другой подход к интеграции выходных данных Swagger с другими документами может состоять в том, чтобы хранить описания и другую информацию в файлах данных YAML в проекте, а затем включать ссылки на данные в документ спецификации. Рассмотрим пример с использованием Jekyll (но аналогичные методы существуют для других генераторов статических сайтов).

Jekyll позволяет хранить содержимое в файлах YAML в папке _data. Допустим, внутри _data есть файл parameters.yml со следующим содержимым:

acme_parameter: >
  This is a description of my parameter ...

Затем можно обернуть эту ссылку в такие теги:

{{site.data.parameters.acme_parameter}}

В проекте Jekyll ссылка на спецификацию выглядела бы следующим образом:

info:
  description: >
    {{site.data.parameters.acme_parameter}}

После берем вывод из Jekyll, который содержит контент, вставленный в каждое свойство спецификации. В этой модели происходит генерация спецификацию OpenAPI из проекта Jekyll.

Не плохой вариант, но трудно гарантировать, что спецификация OpenAPI останется действительной, пока пишется контент. При наличии подобных ссылок в содержании спецификации ({{site.data.parameters.acme_parameter}}), не получится воспользоваться проверкой спецификации в реальном времени в Swagger.

Скорее всего, придется подключить весь проект Swagger UI к сайту Jekyll. Вверху файла Swagger.yml нужно добавить frontmatter с layout: null, чтобы Jekyll обработал файл:

---
layout: null
---

В команде jekyll serve конфигурируем место назначения (destination), чтобы преобразовать выходные данные в папку htdocs, в которой работает простой локальный HTTP-сервер. С каждой сборкой, нужно проверять наличие ошибок.

Сохраняя значения в файлах данных, можно затем включить их в другое место в документе. Например, в документе может быть раздел параметров, в котором также включено описание {{site.data.parameters.acme_parameter}}.

Недостаток этого подхода в отсутствии возможности проверки спецификации. Сложно отслеживать виновников ошибок валидации.

Вариант 5: Используем инструмент, импортирующий Swagger и позволяющий работать с другой документацией

еще один подход заключается в использовании таких инструментов, как Readme.io или Stoplight, которые позволяют как импортировать спецификации OpenAPI, так и добавлять собственные страницы документации. Readme.io предоставляет один из наиболее привлекательных результатов и полностью включает в себя практически все функции документации, которые могут понадобиться. Более подробно изучим Readme в разделе Headless CMS option (и Readme.io). Readme.io требует сторонний хостинг, но некоторые другие инструментальные документы позволяют также включить Swagger. Подробно изучали Stoplight в теме: Stoplight - инструменты визуального моделирования для создания вашей спецификации OpenAPI.

Такие сайты, как Apiary и Mulesoft, позволяют импортировать спецификации OpenAPI, и добавлять пользовательские страницы документации. Эти сайты предлагают полное управление API-интерфейсами, поэтому, если разработчики уже используют одну из этих платформ, имеет смысл также хранить документацию в этих инструментах.

У Cherryleaf есть интересная статья под названием «Пример портала документации API с использованием MadCap Flare». В этом посте Эллис Пратт демонстрирует концепцию проекта Flare, который читает спецификацию OpenAPI и генерирует из нее статический контент HTML. Если интересен Flare, возможно, стоит изучить статью.

Вариант 6: Меняем перспективы - наличие двух сайтов не так уж плохо

Наконец, спросим себя, что плохого в наличии двух разных сайтов? Один сайт с описанием адресных разделов, а другой для концептуальной документации. Программисты могут посчитать справочную информацию на основе Swagger удобной, потому что она перерабатывает и упрощает объем информации. Вместо огромного сайта для навигации, вывод Swagger предоставляет базовую справочную информацию, которая им нужна. Когда им нужна не справочная информация, они могут обратиться к сопроводительному руководству. Можно рассматривать вывод Swagger UI как краткий справочник API.

Правда в том, что программисты годами работают с Javadocs, Doxygen и другими инструментами генерации документов, которые генерируют документацию из Java, C++, C#, Python, Ruby и других языков программирования. Автоматическое создание справочной информации из исходного кода в автономном режиме является чрезвычайно распространенным явлением и не должно восприниматься программистами как фрагментарная информация.

В конце концов, вместо того, чтобы чувствовать, что наличие двух выводов фрагментировано или разъединено, можно переосмыслить свою точку зрения. Вывод Swagger предоставляет четкий источник перехода к справочной информации о конечных точках, параметрах, запросах и ответах. Остальные документы предоставляют справочную информацию. Два этих результата просто стали организационной стратегией для документации.

Следующие шаги

Итак, мы разобрались со адресной документацией API, пришло время погрузиться в тестирование. Поскольку мы работаем с конечными точками API и кодом, нам нужно будет самостоятельно тестировать конечные точки, чтобы собрать и проверить информацию, содержащуюся в документации. Тестирование - не всегда просто. Поэтому ему посвящен целый раздел. Переходим к модулю тестирования документации.

🔙

Go next ➡