API documentation tools¶
Specialized descriptive languages help when writing API documentation. Some of our favorite descriptive languages include:
- API Blueprint
- Swagger
When specifying a descriptive language for your API, you’ll also need tools to create engaging documents. Several tools work best with our favorite descriptive languages:
Apiary¶
Apiary is a service that allows you to edit and host documentation online.
Hosting Apiary docs¶
Apiary provides a service for creating and hosting API documentation described in the API Blueprint or Swagger format. Once the API description is complete, Apiary generates interactive documentation in a three column layout. Example requests and responses are shown for every endpoint in multiple programming languages. It also enables the user to make requests to your live API.
Building Apiary docs¶
To build Apiary docs locally, follow these steps:
- Navigate to the directory containing your - .apibfile.
- Run the following to validate your - .apibfile and create the HTML file:- apiary preview --path="myfile.apib" --output="myfile.html" 
- View the document in your browser. 
API Blueprint¶
API Blueprint is a high-level language for describing web APIs. The goal of the API Blueprint format is to support the design-first philosophy for REST APIs; however, the format also works for documenting existing APIs. The files are saved with a .apib extension.
The syntax combines Markdown syntax and Markdown Syntax for Object Notation (MSON). Markdown is a lightweight text formatting syntax and MSON is an extension of Markdown for describing data objects.
Getting started with API Blueprint¶
The quickest way to get started with API Blueprint is to use Apiary to edit and view your documentation by following these steps:
- Sign up for an account on Apiary.
- Follow the API Blueprint Tutorial. to describe an API.
Writing API Blueprint docs¶
The structure for an .apib file is:
Metadata
API Name
Resource Group
  Resource
    Action
    Action
  Resource
Resource Group
Data Structures
- Metadata:
- describes the API Blueprint version
- API Name:
- your API name
- Resource Groups:
- describes a collection of related API endpoints
- Resources:
- describes a specific API endpoint
- Actions:
- describes specific HTTP verb actions to an endpoint
- Data Structures:
- describes data used in your API requests/responses. By defining them in a separate section, they can easily be reused.
Testing API docs¶
When specifying an API in a descriptive language, you don’t have to manually validate your documents. Tools like Dredd can test your documentation against the live API.
 
    
  
 
      