<div dir="ltr"><br><div class="gmail_extra"><br><div class="gmail_quote">On Thu, Feb 5, 2015 at 11:37 AM, Andrey Kurilin <span dir="ltr"><<a href="mailto:akurilin@mirantis.com" target="_blank">akurilin@mirantis.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex"><div dir="ltr"><div><div><div>First results is <a href="https://review.openstack.org/#/c/152569/" target="_blank">https://review.openstack.org/#/c/152569/</a><span class=""><br><br>> - if os-compute-api-version is not supplied don't send any header at all<br></span></div><span class="">> - it is probably worth doing a bit version parsing to see if it makes sense eg of format:<br>>      r"^([1-9]\d*)\.([1-9]\d*|0)$" or latest<br><br></span>implemented<br><br></div><span class=""><br><div>>- handle  HTTPNotAcceptable if the user asked for a version which is not supported <br></div>>  (can also get a badrequest if its badly formatted and got through the novaclient filter)<br></span></div>Based on <a href="https://review.openstack.org/#/c/150641/" target="_blank">https://review.openstack.org/#/c/150641/</a> , HTTPNotFound (404) will be returned by API, so the current implementation of novaclient is not required any changes.<span class=""><br><div><br></div></span></div></blockquote><div><br></div><div>So a microversion (say v2.12) is a concept which covers the API as a whole, not just an extension. And as a result there is a concept of a minimum version supported (currently 2.1) and a maximum). If a client requests a version which it outside of min<->max they will have a HTTPNotAcceptable returned.</div><div><br></div><div>If a client a requests a version which is valid, but the actual resource point they attempt to access does not support an implementation (say the version requested did not support anything yet), they will get a 404 (eg it pretends not to be there).</div><div><br></div><div> </div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex"><div dir="ltr"><span class=""><div>> - show the version header information returned<br></div></span><div>Imo, API should return exception with proper message which already include this information.<br></div></div></blockquote><div><br></div><div>Yep, if you request a version which doesn't fit within the global supported (min<->max) you will get  a 406 which specifies min/max api versions for that server.</div><div><br></div><div>For any other request you get returned an X-OpenStack-Compute-API-Version header which</div><div>specifies the version used - which you may nto have exactly known on the request if you didn't specify a version (eg not specified or 'latest')</div><div><br></div><div>Regards,</div><div><br></div><div>Chris</div><div> </div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex"><div dir="ltr"><div></div></div><div class=""><div class="h5"><div class="gmail_extra"><br><div class="gmail_quote">On Mon, Feb 2, 2015 at 2:02 PM, Andrey Kurilin <span dir="ltr"><<a href="mailto:akurilin@mirantis.com" target="_blank">akurilin@mirantis.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex"><div dir="ltr">Thanks for the summary, I'll try to send first patch(maybe WIP) in few days.<br></div><div class="gmail_extra"><br><div class="gmail_quote"><div><div>On Mon, Feb 2, 2015 at 1:43 PM, Christopher Yeoh <span dir="ltr"><<a href="mailto:cbkyeoh@gmail.com" target="_blank">cbkyeoh@gmail.com</a>></span> wrote:<br></div></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex"><div><div><div dir="ltr"><br><div class="gmail_extra"><br><div class="gmail_quote"><span>On Sat, Jan 31, 2015 at 4:09 AM, Andrey Kurilin <span dir="ltr"><<a href="mailto:akurilin@mirantis.com" target="_blank">akurilin@mirantis.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-style:solid;border-left-color:rgb(204,204,204);padding-left:1ex"><span><div dir="ltr">Thanks for the answer. Can I help with implementation of novaclient part?</div></span></blockquote><div><br></div></span><div>Sure! Do you think its something you can get proposed into Gerrit by the end of the week or very soon after? <br></div><div>Its the sort of timeframe we're looking for to get microversions enabled asap.... I guess just let me know if it <br></div><div>turns out you don't have the time.<br></div><div><br></div><div>So I think a short summary of what is needed is:<br></div><div>- if os-compute-api-version is not supplied don't send any header at all<br></div><div>- it is probably worth doing a bit version parsing to see if it makes sense eg of format:<br>     r"^([1-9]\d*)\.([1-9]\d*|0)$" or latest<br></div><div>- handle  HTTPNotAcceptable if the user asked for a version which is not supported <br></div><div>  (can also get a badrequest if its badly formatted and got through the novaclient filter)<br></div><div>- show the version header information returned<br></div><div><br></div><div>Regards,<br><br>Chris<br></div><div><div><div><br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-style:solid;border-left-color:rgb(204,204,204);padding-left:1ex"><div class="gmail_extra"><br><div class="gmail_quote"><span>On Wed, Jan 28, 2015 at 11:50 AM, Christopher Yeoh <span dir="ltr"><<a href="mailto:cbkyeoh@gmail.com" target="_blank">cbkyeoh@gmail.com</a>></span> wrote:<br></span><div><div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-style:solid;border-left-color:rgb(204,204,204);padding-left:1ex"><span>On Fri, 23 Jan 2015 15:51:54 +0200<br>
Andrey Kurilin <<a href="mailto:akurilin@mirantis.com" target="_blank">akurilin@mirantis.com</a>> wrote:<br>
<br>
> Hi everyone!<br>
> After removing nova V3 API from novaclient[1], implementation of v1.1<br>
> client is used for v1.1, v2 and v3 [2].<br>
> Since we moving to micro versions, I wonder, do we need such<br>
> mechanism of choosing api version(os-compute-api-version) or we can<br>
> simply remove it, like in proposed change - [3]?<br>
> If we remove it, how micro version should be selected?<br>
><br>
<br>
</span>So since v3 was never officially released I think we can re-use<br>
os-compute-api-version for microversions which will map to the<br>
X-OpenStack-Compute-API-Version header. See here for details on what<br>
the header will look like. We need to also modify novaclient to handle<br>
errors when a version requested is not supported by the server.<br>
<br>
If the user does not specify a version number then we should not send<br>
anything at all. The server will run the default behaviour which for<br>
quite a while will just be v2.1 (functionally equivalent to v.2)<br>
<br>
<a href="http://specs.openstack.org/openstack/nova-specs/specs/kilo/approved/api-microversions.html" target="_blank">http://specs.openstack.org/openstack/nova-specs/specs/kilo/approved/api-microversions.html</a><br>
<div><div><br>
<br>
><br>
> [1] - <a href="https://review.openstack.org/#/c/138694" target="_blank">https://review.openstack.org/#/c/138694</a><br>
> [2] -<br>
> <a href="https://github.com/openstack/python-novaclient/blob/master/novaclient/client.py#L763-L769" target="_blank">https://github.com/openstack/python-novaclient/blob/master/novaclient/client.py#L763-L769</a><br>
> [3] - <a href="https://review.openstack.org/#/c/149006" target="_blank">https://review.openstack.org/#/c/149006</a><br>
><br>
<br>
</div></div></blockquote></div></div></div><br><br clear="all"><span><br>-- <br><div><div dir="ltr">Best regards,<br>Andrey Kurilin.<br></div></div>
</span></div>
</blockquote></div></div></div><br></div></div>
<br></div></div>__________________________________________________________________________<br>
OpenStack Development Mailing List (not for usage questions)<br>
Unsubscribe: <a href="http://OpenStack-dev-request@lists.openstack.org?subject:unsubscribe" target="_blank">OpenStack-dev-request@lists.openstack.org?subject:unsubscribe</a><br>
<a href="http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack-dev" target="_blank">http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack-dev</a><br>
<br></blockquote></div><span><br><br clear="all"><br>-- <br><div><div dir="ltr">Best regards,<br>Andrey Kurilin.<br></div></div>
</span></div>
</blockquote></div><br><br clear="all"><br>-- <br><div><div dir="ltr">Best regards,<br>Andrey Kurilin.<br></div></div>
</div>
</div></div><br>__________________________________________________________________________<br>
OpenStack Development Mailing List (not for usage questions)<br>
Unsubscribe: <a href="http://OpenStack-dev-request@lists.openstack.org?subject:unsubscribe" target="_blank">OpenStack-dev-request@lists.openstack.org?subject:unsubscribe</a><br>
<a href="http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack-dev" target="_blank">http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack-dev</a><br>
<br></blockquote></div><br></div></div>