<div dir="ltr"><br><div class="gmail_extra"><br><br><div class="gmail_quote">On Thu, Jan 16, 2014 at 9:45 AM, Jesse Noller <span dir="ltr"><<a href="mailto:jesse.noller@rackspace.com" target="_blank">jesse.noller@rackspace.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 style="word-wrap:break-word">
<br>
<div><div><div class="h5">
<div>On Jan 16, 2014, at 5:53 AM, Chmouel Boudjnah <<a href="mailto:chmouel@enovance.com" target="_blank">chmouel@enovance.com</a>> wrote:</div>
<br>
<blockquote type="cite">
<div dir="ltr">
<div class="gmail_extra"><br>
<div class="gmail_quote">On Thu, Jan 16, 2014 at 12:38 PM, Chris Jones <span dir="ltr">
<<a href="mailto:cmsj@tenshu.net" target="_blank">cmsj@tenshu.net</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">
Once a common library is in place, is there any intention to (or resistance against) collapsing the clients into a single project or even a single command (a la busybox)?</blockquote>
</div>
<br>
<br>
</div>
<div class="gmail_extra">that's what openstackclient is here for <a href="https://github.com/openstack/python-openstackclient" target="_blank">
https://github.com/openstack/python-openstackclient</a><br>
</div>
</div>
</blockquote>
<div><br>
</div>
</div></div><div>After speaking with people working on OSC and looking at the code base in depth; I don’t think this addresses what Chris is implying: OSC wraps the individual CLIs built by each project today, instead of the inverse: a common backend that the individual
CLIs can wrap - the latter is an important distinction as currently, building a single binary install of OSC for say, Windows is difficult given the dependency tree incurred by each of the wrapped CLIs, difference in dependencies, structure, etc.</div>
<div><br>
</div>
<div>Also, wrapping a series of inconsistent back end Client classes / functions / methods means that the layer that presents a consistent user interface (OSC) to the user is made more complex juggling names/renames/commands/etc. </div>
<div><br>
</div>
<div>In the inverted case of what we have today (single backend); as a developer of user interfaces (CLIs, Applications, Web apps (horizon)) you would be able to:</div>
<div><br>
</div>
<div>
<div>from openstack.common.api import Auth</div>
</div>
<div>from openstack.common.api import Compute</div>
<div>from openstack.common.util import cli_tools</div>
<div><br>
</div>
<div>my_cli = cli_tools.build(…)</div>
<div><br>
</div>
<div>def my_command(cli):</div>
<div><span style="white-space:pre-wrap"></span>compute = Compute(Auth(cli.tentant…, connect=True))</div>
<div><span style="white-space:pre-wrap"></span>compute.list_flavors()</div>
<div><br>
</div>
<div>This would mean that *even if the individual clients needed or wanted to keep their specific CLIs, they would be able to use a not “least common denominator” back end (each service can have a rich <a href="http://common.api.compute.py" target="_blank">common.api.compute.py</a> or api.compute/client.py and extend
where needed. However tools like horizon / openstackclient can choose not to leverage the “power user/operator/admin” components and present a simplified user interface.</div>
<div><br>
</div>
<div>I’m working on a wiki page + blueprint to brainstorm how we could accomplish this based off of what work is in flight today (see doug’s linked blueprint) and sussing out a layout / API strawman for discussion. </div>
<div><br>
</div>
<div>Some of the additions that came out of this email threads and others:</div>
<div><br>
</div>
<div>1. Common backend should provide / offer caching utilities </div>
<div>2. Auth retries need to be handled by the auth object, and each sub-project delegates to the auth object to manage that.</div>
<div>3. Verified Mocks / Stubs / Fakes must be provided for proper unit testing </div></div></div></blockquote><div><br></div><div>I am happy to see this work being done, there is definitely a lot of work to be done on the clients.</div>
<div><br></div><div>This blueprint sounds like its still being fleshed out, so I am wondering what the value is of the current patches <a href="https://review.openstack.org/#/q/topic:bp/common-client-library-2,n,z">https://review.openstack.org/#/q/topic:bp/common-client-library-2,n,z</a></div>
<div><br></div><div>Those patches mainly sync cliutils and apiutils from oslo into the assorted clients. But if this blueprint is about the python API and not the CLI (as that would be the openstack-pythonclient), why sync in apiutils?</div>
<div><br></div><div>Also does this need to go through oslo-incubator or can this start out as a library? Making this a library earlier on will reduce the number of patches needed to get 20+ repositories to use this.</div>
<div><br></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 style="word-wrap:break-word">
<div><div class="im">
<div><span style="white-space:pre-wrap"></span></div>
<div><span style="white-space:pre-wrap"></span></div>
<br>
<blockquote type="cite">_______________________________________________<br>
OpenStack-dev mailing list<br>
<a href="mailto:OpenStack-dev@lists.openstack.org" target="_blank">OpenStack-dev@lists.openstack.org</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>
</blockquote>
</div></div>
<br>
</div>
<br>_______________________________________________<br>
OpenStack-dev mailing list<br>
<a href="mailto:OpenStack-dev@lists.openstack.org">OpenStack-dev@lists.openstack.org</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>