The static site on the picture was built with Slate backend together with SwaggerDoc preprocessor
This preprocessor generates Markdown documentation from Swagger spec files. It uses Jinja2 templating engine or Widdershins for generating Markdown from swagger spec files.
$ pip install foliantcontrib.swaggerdoc
This preprocessor requires Widdershins to be installed on your system (unless you are using Foliant with Full Docker Image):
npm install -g widdershins
To enable the preprocessor, add swaggerdoc
to preprocessors
section in the project config:
preprocessors:
- swaggerdoc
The preprocessor has a number of options:
preprocessors:
- swaggerdoc:
spec_url: http://localhost/swagger.json
spec_path: swagger.json
additional_json_path: tags.json
mode: widdershins
template: swagger.j2
environment: env.yaml
spec_url
: URL to Swagger spec file. If it is a list — preprocessor takes the first url which works.
spec_path
: Local path to Swagger spec file (relative to project dir).
If both url and path are specified — preprocessor first tries to fetch spec from url, and then (if that fails) looks for the file on local path.
additional_json_path
: Only for jinja
mode. Local path to swagger spec file with additional info (relative to project dir). It will be merged into original spec file, not overriding existing fields.
mode
: Determines how the Swagger spec file would be converted to markdown. Should be one of: jinja
, widdershins
. Default: widdershins
jinja
mode is deprecated. It may be removed in future
template
: Only for jinja
mode. Path to jinja-template for rendering the generated documentation. Path is relative to the project directory. If no template is specified preprocessor will use default template (and put it into project dir if it was missing). Default: swagger.j2
environment
: Only for widdershins
mode. Parameters for widdershins converter. You can either pass a string containing relative path to YAML or JSON file with all parameters (like in example above) or specify all parameters in YAML format under this key. More info on widdershins parameters.
Add a <swaggerdoc></swaggerdoc>
tag at the position in the document where the generated documentation should be inserted:
# Introduction
This document contains the automatically generated documentation of our API.
<swaggerdoc></swaggerdoc>
Each time the preprocessor encounters the tag <swaggerdoc></swaggerdoc>
it inserts the whole generated documentation text instead of it. The path or url to Swagger spec file are taken from foliant.yml.
You can also specify some parameters (or all of them) in the tag options:
# Introduction
Introduction text for API documentation.
<swaggerdoc spec_url="http://localhost/swagger.json"
mode="jinja"
template="swagger.j2">
</swaggerdoc>
<swaggerdoc spec_url="http://localhost/swagger.json"
mode="widdershins"
environment="env.yml">
</swaggerdoc>
Tag parameters have the highest priority.
This way you can have documentation from several different Swagger spec files in one foliant project (even in one md-file if you like it so).
In widdershins
mode the output markdown is generated by widdershins Node.js application. It supports customizing the output with doT.js templates.
- Clone the original widdershins repository and modify the templates located in one of the subfolders in the templates folder.
- Save the modified templates somewhere near your foliant project.
- Specify the path to modified templates in the
user_templates
field of theenvironment
configuration. For example, like this:
preprocessors:
- swaggerdoc:
spec_path: swagger.yml
environment:
user_templates: !path ./widdershins_templates/
jinja
mode is deprecated. It may be removed in future
In jinja
mode the output markdown is generated by the Jinja2 template. In this template all fields from Swagger spec file are available under the dictionary named swagger_data
.
To customize the output create a template which suits your needs. Then supply the path to it in the template
parameter.
If you wish to use the default template as a starting point, build the foliant project with swaggerdoc
preprocessor turned on. After the first build the default template will appear in your foliant project dir under name swagger.j2
.