2016-03-10 09:52:35 -06:00
|
|
|
.. _api-docs:
|
|
|
|
|
|
|
|
===========================
|
|
|
|
OpenStack API documentation
|
|
|
|
===========================
|
|
|
|
|
|
|
|
Source files for developer.openstack.org
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
The `developer.openstack.org`_ web site is intended for application developers
|
|
|
|
using the OpenStack APIs to build upon. It contains links to multiple SDKs for
|
2016-04-14 15:47:43 -05:00
|
|
|
specific programming languages, API references, and API Guides.
|
2016-03-10 09:52:35 -06:00
|
|
|
|
|
|
|
For existing APIs, the reference information comes from RST and YAML source
|
2016-10-11 10:55:23 -05:00
|
|
|
files. The RST and YAML files get stored in your project repository in an
|
|
|
|
``api-ref`` directory. The nova project has an example you can follow,
|
|
|
|
including tox jobs for running ``tox -e api-ref`` within the ``api-ref``
|
|
|
|
directory to generate the documents.
|
2016-03-10 09:52:35 -06:00
|
|
|
|
|
|
|
The RST conceptual and how-to files are stored in each project's
|
|
|
|
``doc/source/api-guide`` directory. These are built to locations based on the
|
|
|
|
service name, such as the `Compute API Guide`_.
|
|
|
|
|
|
|
|
You may embed annotations in your source code if you want to generate the
|
|
|
|
reference information. Here is an `example patch`_ from the nova project.
|
|
|
|
Because no project has complete annotations, there are no build jobs for this
|
|
|
|
scenario.
|
|
|
|
|
|
|
|
Standards for API reference in OpenStack
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
The API working group has `API documentation guidelines`_ that all teams
|
2016-10-11 10:55:23 -05:00
|
|
|
providing a REST API service in OpenStack strive to follow. This
|
|
|
|
document tells you what and how much to write. If you follow the suggested
|
|
|
|
outline, your API guide will be accurate and complete.
|
|
|
|
|
|
|
|
If your project does not have any documentation, you can find a suggested
|
|
|
|
outline in the `API documentation guidelines`_. The Compute project has
|
|
|
|
examples to follow:
|
|
|
|
|
2017-01-31 13:38:10 +09:00
|
|
|
* https://git.openstack.org/cgit/openstack/nova/tree/api-guide
|
|
|
|
* https://git.openstack.org/cgit/openstack/nova/tree/api-ref
|
2016-03-10 09:52:35 -06:00
|
|
|
|
2016-08-11 10:41:06 -05:00
|
|
|
For service names, you must adhere to the official name for the service as
|
|
|
|
indicated in the governance repository in the ``reference/projects.yaml``
|
|
|
|
file. These names are used in the URL for the documentation by stating the
|
|
|
|
target directory for the content in the ``api-ref-jobs:`` indicator. If
|
|
|
|
your service does not have a name indicated in the governance repo,
|
|
|
|
please ask your PTL or a Technical Committee member how to proceed.
|
|
|
|
|
2017-02-14 16:33:48 -06:00
|
|
|
Versions and releases for API reference information
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
All API reference jobs publish from master as soon as a change lands in the
|
|
|
|
respective project repository. This publishing practice means that you must
|
|
|
|
write inline information when an API has a change release-to-release. Inline
|
|
|
|
text descriptions are the only way to convey the corresponding release
|
|
|
|
information to the documentation consumer.
|
|
|
|
|
|
|
|
There are different types of versions related to OpenStack services that
|
|
|
|
provide an API. For example, a version of a service is separate from the
|
|
|
|
version of an API provided by that service. Also, `microversions`_
|
|
|
|
are small, documented changes to an individual API method, and are only
|
|
|
|
applicable to some OpenStack APIs, as indicated with (microversions) on
|
|
|
|
the `API Quick Start page`_.
|
|
|
|
|
|
|
|
Example representations of versions for the OpenStack Compute service:
|
|
|
|
|
|
|
|
* Header version: `OpenStack-API-Version: compute 2.1`
|
|
|
|
* Service version (Release name): 15.0 (Newton)
|
|
|
|
* URI version: `https://servers.api.openstack.org/v2.1/`
|
|
|
|
* MIME type version: `application/vnd.openstack.compute.v2.1+json`
|
|
|
|
* Microversion: `2.6`
|
|
|
|
|
|
|
|
Each project that follows the `cycle-with-milestones release model`_ has stable
|
|
|
|
branches that contain a point-in-time set of API reference content. If needed,
|
|
|
|
refer to that source repository's content for release comparisons for API
|
|
|
|
reference information.
|
|
|
|
|
2016-05-01 12:01:10 -05:00
|
|
|
.. _how-to-document-api:
|
2016-03-10 09:52:35 -06:00
|
|
|
|
2016-05-01 12:01:10 -05:00
|
|
|
How to document your OpenStack API service
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
2016-03-10 09:52:35 -06:00
|
|
|
|
2016-10-11 10:55:23 -05:00
|
|
|
Use these instructions if you have no documentation currently, or want to
|
|
|
|
update it to match OpenStack standards.
|
2016-03-10 09:52:35 -06:00
|
|
|
|
2016-05-01 12:01:10 -05:00
|
|
|
The basic steps are:
|
2016-03-10 09:52:35 -06:00
|
|
|
|
2016-05-01 12:01:10 -05:00
|
|
|
#. Create an ``api-ref/source`` directory in your project repository.
|
2016-04-27 10:21:11 -05:00
|
|
|
|
2016-10-11 10:55:23 -05:00
|
|
|
#. Create a ``conf.py`` for the project, similar to the `nova example`_. In it,
|
|
|
|
include the html theme, openstackdocstheme, use the os-api-ref Sphinx
|
|
|
|
extension, and also point the bug reporting link to your project's repo::
|
|
|
|
|
|
|
|
extensions = [
|
|
|
|
'os_api_ref',
|
2017-06-26 21:25:58 +02:00
|
|
|
'openstackdocstheme'
|
2016-10-11 10:55:23 -05:00
|
|
|
]
|
|
|
|
|
2017-06-26 21:25:58 +02:00
|
|
|
# The prefix and repo name like
|
|
|
|
repository_name = 'openstack/glance'
|
|
|
|
# Set Launchpad bug tag, default is empty
|
|
|
|
bug_tag = ''
|
|
|
|
# The launchpad project name like
|
|
|
|
bug_project = 'glance'
|
2016-10-11 10:55:23 -05:00
|
|
|
|
|
|
|
html_theme = 'openstackdocs'
|
|
|
|
html_theme_options = {
|
|
|
|
"sidebar_mode": "toc",
|
|
|
|
}
|
2017-06-26 21:25:58 +02:00
|
|
|
|
|
|
|
# Must set this variable to include year, month, day, hours, and minutes.
|
|
|
|
html_last_updated_fmt = '%Y-%m-%d %H:%M'
|
2016-04-27 10:21:11 -05:00
|
|
|
|
2016-05-20 17:25:37 -05:00
|
|
|
#. Update the ``test-requirements.txt`` file for the project with a line for
|
|
|
|
the ``os-api-ref`` Sphinx extension::
|
|
|
|
|
2016-09-29 20:12:57 +08:00
|
|
|
os-api-ref>=1.0.0 # Apache-2.0
|
2016-04-27 10:21:11 -05:00
|
|
|
|
2016-05-01 12:01:10 -05:00
|
|
|
#. Create RST files for each operation.
|
2016-03-10 09:52:35 -06:00
|
|
|
|
2016-05-01 12:01:10 -05:00
|
|
|
#. In the RST file, use ``.. rest_method::`` for each operation.
|
2016-03-10 09:52:35 -06:00
|
|
|
|
2016-05-01 12:01:10 -05:00
|
|
|
Example: ``.. rest_method:: GET /v2.1/{tenant_id}/flavors``
|
2016-03-10 09:52:35 -06:00
|
|
|
|
2016-05-01 12:01:10 -05:00
|
|
|
#. In the RST file, add requests and responses that point to a
|
|
|
|
``parameters.yaml`` file::
|
2016-03-10 09:52:35 -06:00
|
|
|
|
2016-05-01 12:01:10 -05:00
|
|
|
.. rest_parameters:: parameters.yaml
|
2016-04-26 11:32:06 -05:00
|
|
|
|
2016-05-01 12:01:10 -05:00
|
|
|
- tenant_id: tenant_id
|
2016-04-26 11:32:06 -05:00
|
|
|
|
2016-05-01 12:01:10 -05:00
|
|
|
Here is an example entry in ``parameters.yaml``::
|
2016-04-26 11:32:06 -05:00
|
|
|
|
2016-05-01 12:01:10 -05:00
|
|
|
admin_tenant_id:
|
|
|
|
description: |
|
2016-08-18 00:52:42 +00:00
|
|
|
The UUID of the administrative project.
|
2016-05-01 12:01:10 -05:00
|
|
|
in: path
|
|
|
|
required: true
|
|
|
|
type: string
|
2016-04-26 11:32:06 -05:00
|
|
|
|
2016-05-01 12:01:10 -05:00
|
|
|
#. Create sample JSON requests and responses and store in a directory, and
|
|
|
|
point to those in your RST files. As an example::
|
2016-03-10 09:52:35 -06:00
|
|
|
|
2016-05-01 12:01:10 -05:00
|
|
|
.. literalinclude:: samples/os-evacuate/server-evacuate-resp.json
|
|
|
|
:language: javascript
|
2016-03-10 09:52:35 -06:00
|
|
|
|
2016-05-06 14:57:32 -05:00
|
|
|
#. Update the project's ``tox.ini`` file to include a configuration for
|
|
|
|
building the API reference locally with these lines:
|
|
|
|
|
|
|
|
.. code-block:: console
|
|
|
|
|
|
|
|
[testenv:api-ref]
|
|
|
|
# This environment is called from CI scripts to test and publish
|
|
|
|
# the API Ref to developer.openstack.org.
|
|
|
|
commands =
|
2016-10-11 10:55:23 -05:00
|
|
|
rm -rf api-ref/build
|
|
|
|
sphinx-build -W -b html -d api-ref/build/doctrees api-ref/source api-ref/build/html
|
2016-05-06 14:57:32 -05:00
|
|
|
|
|
|
|
#. Test the ``tox.ini`` changes by running this tox command:
|
|
|
|
|
|
|
|
.. code-block:: console
|
|
|
|
|
|
|
|
$ tox -e api-ref
|
|
|
|
|
2016-05-01 12:01:10 -05:00
|
|
|
#. Create a build job similar to the nova job for your project. Examples:
|
|
|
|
https://review.openstack.org/#/c/305464/ and
|
|
|
|
https://review.openstack.org/#/c/305485/.
|
2016-04-14 15:47:43 -05:00
|
|
|
|
2016-10-11 10:55:23 -05:00
|
|
|
After the source files and build jobs exist, the docs are built to
|
|
|
|
`developer.openstack.org`_.
|
2016-03-10 09:52:35 -06:00
|
|
|
|
2016-10-11 10:55:23 -05:00
|
|
|
If your document is completely new, you need to add links to it from the API
|
|
|
|
landing page and the OpenStack Governance reference document, projects.yaml.
|
2016-03-10 09:52:35 -06:00
|
|
|
|
2016-10-11 10:55:23 -05:00
|
|
|
To add a link to the project's API docs to the API landing page, patch the
|
|
|
|
``index.rst`` file stored in the `openstack/api-site repository`_.
|
2016-03-10 09:52:35 -06:00
|
|
|
|
2016-10-11 10:55:23 -05:00
|
|
|
To ensure the openstack/governance repository has the correct link to your API
|
|
|
|
documentation, patch the ``reference/projects.yaml`` file in the
|
|
|
|
`openstack/governance repository`.
|
2016-03-10 09:52:35 -06:00
|
|
|
|
|
|
|
|
|
|
|
|
2017-01-28 11:50:17 +09:00
|
|
|
.. _`developer.openstack.org`: https://developer.openstack.org
|
2016-03-10 09:52:35 -06:00
|
|
|
.. _`wadl2rst`: http://github.com/annegentle/wadl2rst
|
2017-01-28 11:50:17 +09:00
|
|
|
.. _`Compute API Guide`: https://developer.openstack.org/api-guide/compute
|
2016-03-10 09:52:35 -06:00
|
|
|
.. _`example patch`: https://review.openstack.org/#/c/233446/
|
2017-01-31 07:36:05 +09:00
|
|
|
.. _`API documentation guidelines`: https://specs.openstack.org/openstack/api-wg/guidelines/api-docs.html
|
2017-02-14 16:33:48 -06:00
|
|
|
.. _`microversions`: https://developer.openstack.org/api-guide/compute/microversions.html
|
|
|
|
.. _`API Quick Start page`: https://developer.openstack.org/api-guide/quick-start/
|
|
|
|
.. _`cycle-with-milestones release model`: https://releases.openstack.org/reference/release_models.html#cycle-with-milestones
|
2016-04-27 10:21:11 -05:00
|
|
|
.. _`nova example`: https://github.com/openstack/nova/blob/master/api-ref/source/conf.py
|
2017-01-31 13:38:10 +09:00
|
|
|
.. _`openstack/api-site repository`: https://git.openstack.org/cgit/openstack/api-site/tree/api-quick-start/source/index.rst
|
|
|
|
.. _`openstack/governance repository`: https://git.openstack.org/cgit/openstack/governance/tree/reference/projects.yaml
|
2017-02-14 16:33:48 -06:00
|
|
|
|