<div dir='auto'><br><div class="gmail_extra" dir="auto">This sounds like a fantastic path forward as the version in the service type is a source of frustration in some ways. I personally love the versionless discoverability of Keystone as an API model.</div><div class="gmail_extra" dir="auto"><br></div><div class="gmail_extra" dir="auto">I'm also assuming this is related to this repo here:</div><div class="gmail_extra" dir="auto">https://github.com/openstack/service-types-authority<br></div><div class="gmail_extra" dir="auto"><br></div><div class="gmail_extra" dir="auto">Are there plans to actually fill that repo out and start building the full 'official' catalog of service types? Because right now that repo is missing many services but appears to actually be a good place to list what all the various service types are already in use.</div><div class="gmail_extra" dir="auto"><br></div><div class="gmail_extra" dir="auto">I know that trying to choose a good new service type for a project is hard because finding a list for the ones already in use isn't that easy. I was sad to find that repo, although ideal, was lacking.</div><div class="gmail_extra" dir="auto"><br></div><div class="gmail_extra" dir="auto"><br><div class="gmail_quote" dir="auto">On 29 Apr. 2017 10:26 am, Monty Taylor <mordred@inaugust.com> wrote:<br type="attribution"><blockquote class="quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><p dir="ltr">Hey everybody!</p>
<p dir="ltr">Yay! (I'm sure you're all saying this, given the topic. I'll let you <br>
collect yourself from your exuberant celebration)</p>
<p dir="ltr">== Background ==</p>
<p dir="ltr">As I'm sure you all know, we've been trying to make some hearway for a <br>
while on getting service-types that are registered in the keystone <br>
service catalog to be consistent. The reason for this is so that API <br>
Consumers can know how to request a service from the catalog. That might <br>
sound like a really easy task - but uh-hoh, you'd be so so wrong. :)</p>
<p dir="ltr">The problem is that we have some services that went down the path of <br>
suggesting people register a new service in the catalog with a version <br>
appended. This pattern was actually started by nova for the v3 api but <br>
which we walked back from - with "computev3". The pattern was picked up <br>
by at least cinder (volumev2, volumev3) and mistral (workflowv2) that I <br>
am aware of. We're also suggesting in the service-types-authority that <br>
manila go by "shared-file-system" instead of "share".</p>
<p dir="ltr">(Incidentally, this is related to a much larger topic of version <br>
discovery, which I will not bore you with in this email, but about which <br>
I have a giant pile of words just waiting for you in a little bit. Get <br>
excited about that!)</p>
<p dir="ltr">== Proposed Solution ==</p>
<p dir="ltr">As a follow up to the consuming version discovery spec, which you should <br>
absolutely run away from and never read, I wrote these:</p>
<p dir="ltr">https://review.openstack.org/#/c/460654/ (Consuming historical aliases)<br>
and<br>
https://review.openstack.org/#/c/460539/ (Listing historical aliases)</p>
<p dir="ltr">It's not a particularly clever proposal - but it breaks down like this:</p>
<p dir="ltr">* Make a list of the known historical aliases we're aware of - in a <br>
place that isn't just in one of our python libraries (460539)<br>
* Write down a process for using them as part of finding a service from <br>
the catalog so that there is a clear method that can be implemented by <br>
anyone doing libraries or REST interactions. (460654)<br>
* Get agreement on that process as the "recommended" way to look up <br>
services by service-type in the catalog.<br>
* Implement it in the base libraries OpenStack ships.<br>
* Contact the authors of as many OpenStack API libraries that we can find.<br>
* Add tempest tests to verify the mappings in both directions.<br>
* Change things in devstack/deployer guides.</p>
<p dir="ltr">The process as described is backwards compatible. That is, once <br>
implemented it means that a user can request "volumev2" or <br>
"block-storage" with version=2 - and both will return the endpoint the <br>
user expects. It also means that we're NOT asking existing clouds to run <br>
out and break their users. New cloud deployments can do the new thing - <br>
but the old values are handled in both directions.</p>
<p dir="ltr">There is a hole, which is that people who are not using the base libs <br>
OpenStack ships may find themselves with a new cloud that has a <br>
different service-type in the catalog than they have used before. It's <br>
not idea, to be sure. BUT - hopefully active outreach to the community <br>
libraries coupled with documentation will keep the issues to a minimum.</p>
<p dir="ltr">If we can agree on the matching and fallback model, I am volunteering to <br>
do the work to implement in every client library in which it needs to be <br>
implemented across OpenStack and to add the tempest tests. (it's <br>
actually mostly a patch to keystoneauth, so that's actually not _that_ <br>
impressive of a volunteer) I will also reach out to as many of the <br>
OpenStack API client library authors as I can find, point them at the <br>
docs and suggest they add the support.</p>
<p dir="ltr">Thoughts? Anyone violently opposed?</p>
<p dir="ltr">Thanks for reading...</p>
<p dir="ltr">Monty</p>
<p dir="ltr">__________________________________________________________________________<br>
OpenStack Development Mailing List (not for usage questions)<br>
Unsubscribe: OpenStack-dev-request@lists.openstack.org?subject:unsubscribe<br>
http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack-dev<br>
</p>
</blockquote></div><br></div></div>