summaryrefslogtreecommitdiff
path: root/api-guide/source/microversions.rst
blob: b1590123cbc4c668a598cb1f28daf7f229e091e5 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
..
      Licensed under the Apache License, Version 2.0 (the "License"); you may
      not use this file except in compliance with the License. You may obtain
      a copy of the License at

          http://www.apache.org/licenses/LICENSE-2.0

      Unless required by applicable law or agreed to in writing, software
      distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
      WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
      License for the specific language governing permissions and limitations
      under the License.

=============
Microversions
=============

API v2.1 supports microversions: small, documented changes to the API. A user
can use microversions to discover the latest API microversion supported in
their cloud. A cloud that is upgraded to support newer microversions will still
support all older microversions to maintain the backward compatibility for
those users who depend on older microversions. Users can also discover new
features easily with microversions, so that they can benefit from all the
advantages and improvements of the current cloud.

There are multiple cases which you can resolve with microversions:

- **Older clients with new cloud**

  Before using an old client to talk to a newer cloud, the old client can check
  the minimum version of microversions to verify whether the cloud is
  compatible with the old API. This prevents the old client from breaking with
  backwards incompatible API changes.

  Currently the minimum version of microversions is `2.1`, which is a
  microversion compatible with the legacy v2 API. That means the legacy v2 API
  user doesn't need to worry that their older client software will be broken
  when their cloud is upgraded with new versions. And the cloud operator
  doesn't need to worry that upgrading their cloud to newer versions will
  break any user with older clients that don't expect these changes.

- **User discovery of available features between clouds**

  The new features can be discovered by microversions. The user client should
  check the microversions firstly, and new features are only enabled when
  clouds support. In this way, the user client can work with clouds that have
  deployed different microversions simultaneously.

Version Discovery
=================

The Version API will return the minimum and maximum microversions. These values
are used by the client to discover the API's supported microversion(s).

Requests to `/` will get version info for all endpoints. A response would look
as follows::

  {
    "versions": [
        {
            "id": "v2.0",
            "links": [
                {
                    "href": "http://openstack.example.com/v2/",
                    "rel": "self"
                }
            ],
            "status": "SUPPORTED",
            "version": "",
            "min_version": "",
            "updated": "2011-01-21T11:33:21Z"
        },
        {
            "id": "v2.1",
            "links": [
                {
                    "href": "http://openstack.example.com/v2.1/",
                    "rel": "self"
                }
            ],
            "status": "CURRENT",
            "version": "2.14",
            "min_version": "2.1",
            "updated": "2013-07-23T11:33:21Z"
        }
    ]
  }

``version`` is the maximum microversion, ``min_version`` is the minimum
microversion. If the value is the empty string, it means this endpoint doesn't
support microversions; it is a legacy v2 API endpoint -- for example, the
endpoint `http://openstack.example.com/v2/` in the above sample. The endpoint
`http://openstack.example.com/v2.1/` supports microversions; the maximum
microversion is `2.14`, and the minimum microversion is `2.1`. The client
should specify a microversion between (and including) the minimum and maximum
microversion to access the endpoint.

You can also obtain specific endpoint version information by performing a GET
on the base version URL (e.g., `http://openstack.example.com/v2.1/`). You can
get more information about the version API at :doc:`versions`.

Client Interaction
==================

A client specifies the microversion of the API they want by using the following
HTTP header::

  X-OpenStack-Nova-API-Version: 2.4

Starting with microversion `2.27` it is also correct to use the
following header to specify the microversion::

  OpenStack-API-Version: compute 2.27

.. note:: For more detail on this newer form see the `Microversion Specification
   <http://specs.openstack.org/openstack/api-wg/guidelines/microversion_specification.html>`_.

This acts conceptually like the "Accept" header. Semantically this means:

* If neither ``X-OpenStack-Nova-API-Version`` nor ``OpenStack-API-Version``
  (specifying `compute`) is provided, act as if the minimum supported
  microversion was specified.

* If both headers are provided, ``OpenStack-API-Version`` will be preferred.

* If ``X-OpenStack-Nova-API-Version`` or ``OpenStack-API-Version`` is provided,
  respond with the API at that microversion. If that's outside of the range
  of microversions supported, return 406 Not Acceptable.

* If ``X-OpenStack-Nova-API-Version`` or ``OpenStack-API-Version`` has a value
  of `latest` (special keyword), act as if maximum was specified.

.. warning:: The `latest` value is mostly meant for integration testing and
  would be dangerous to rely on in client code since microversions are not
  following semver and therefore backward compatibility is not guaranteed.
  Clients should always require a specific microversion but limit what is
  acceptable to the microversion range that it understands at the time.

This means that out of the box, an old client without any knowledge of
microversions can work with an OpenStack installation with microversions
support.

In microversions prior to `2.27` two extra headers are always returned in
the response::

    X-OpenStack-Nova-API-Version: microversion_number
    Vary: X-OpenStack-Nova-API-Version

The first header specifies the microversion number of the API which was
executed.

The ``Vary`` header is used as a hint to caching proxies that the response
is also dependent on the microversion and not just the body and query
parameters. See :rfc:`2616` section 14.44 for details.

From microversion `2.27` two additional headers are added to the
response::

    OpenStack-API-Version: compute microversion_number
    Vary: OpenStack-API-Version