<div dir="ltr"><br><div class="gmail_extra"><br><div class="gmail_quote">On Tue, Mar 24, 2015 at 5:45 AM, Jay Pipes <span dir="ltr"><<a href="mailto:jaypipes@gmail.com" target="_blank">jaypipes@gmail.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div class="HOEnZb"><div class="h5">On Tue, Mar 10, 2015 at 09:52:14PM +1030, Christopher Yeoh wrote:<br>
> On Mon, 09 Mar 2015 16:14:21 -0400<br>
> Sean Dague <<a href="mailto:sean@dague.net">sean@dague.net</a>> wrote:<br>
><br>
> > On 03/09/2015 03:37 PM, Jay Pipes wrote:<br>
> > > On 03/08/2015 08:10 AM, Alex Xu wrote:<br>
> > >> Thanks for Jay point this out! If we have agreement on this and<br>
> > >> document it, that will be great for guiding developer how to add<br>
> > >> new API.<br>
> > >><br>
> > >> I know we didn't want extension for API. But I think we still<br>
> > >> need modularity. I don't think we should put everything in a single<br>
> > >> file, that file will become huge in the future and hard to<br>
> > >> maintenance.<br>
> > ><br>
> > > I don't think everything should be in a single file either. In fact,<br>
> > > I've never advocated for that.<br>
> > ><br>
> > >> We can make the 'extension' not configurable. Replace 'extension'<br>
> > >> with another name, deprecate the extension info api int he<br>
> > >> future.... But that is not mean we should put everything in a file.<br>
> > ><br>
> > > I didn't say that in my email. I'm not sure where you got the<br>
> > > impression I want to put everything in one file?<br>
> > ><br>
> > >> For modularity, we need define what should be in a separated<br>
> > >> module(it is extension now.) There are three cases:<br>
> > >><br>
> > >> 1. Add new resource<br>
> > >> This is totally worth to put in a separated module.<br>
> > ><br>
> > > Agreed.<br>
> > ><br>
> > >> 2. Add new sub-resource<br>
> > >> like server-tags, I prefer to put in a separated module, I<br>
> > >> don't think put another 100 lines code in the servers.py is good<br>
> > >> choice.<br>
> > ><br>
> > > Agreed, which is exactly what I said in my email:<br>
> > ><br>
> > > "Similarly, new microversion API functionality should live in a<br>
> > > module, as a top-level (or subcollection) Controller in<br>
> > > /nova/api/openstack/compute/, and should not be in the<br>
> > > /nova/api/openstack/compute/plugins/ directory. Why? Because it's<br>
> > > not a plugin."<br>
> > ><br>
><br>
> Ok so I'm getting confused about what we're disagreeing about then.<br>
<br>
</div></div>I wasn't disagreeing with you. I was disagreeing with Alex Xu :) Perhaps<br>
your mail client was confusing you?<br>
<span class=""><br>
> However, the first microversion change<br>
> <a href="https://review.openstack.org/#/c/140313/32" target="_blank">https://review.openstack.org/#/c/140313/32</a> is one case where we didn't<br>
> need to create a new extension, relying only on microversions to add a<br>
> new parameter to the response, whereas server tags does add a new<br>
> conroller (os-server-tags) which is non trivia so I think it does. Do<br>
> we disagree about that?<br>
<br>
</span>The server tags patch does add more functionality to the API, for sure.<br>
But, as I've written about in this thread, there's no reason at all that<br>
it needed to use the extension framework. It could better have been<br>
written as a simple Controller object in a new file in<br>
/nova/api/openstack/compute/server_tags.py, with no use of the<br>
extension mechanism whatsoever.<br>
<span class=""><br>
> btw in a situation now where (I think) we are saying we are not going<br>
> to do any work for 3rd parties to add their own API plugins and have a<br>
> well planned API we don't need the prefixes as we don't need the prefix<br>
> on parameter names as there won't be name clashes without us realising<br>
> during testing. And we certainly don't need the os- prefix is the<br>
> plugin alias, but we do neeed them unique across the API I believe<br>
> because of the way we store information about them.<br>
<br>
</span>Right. There won't be any more name clashes if we don't allow API<br>
extensions any more. Which is what I'm asking for.<br>
<span class=""><br>
> > >> 3. extend attributes and methods for a existed resource<br>
> > >> like add new attributes for servers, we can choice one of<br>
> > >> existed module to put it in. Just like this patch<br>
> > >> <a href="https://review.openstack.org/#/c/155853/" target="_blank">https://review.openstack.org/#/c/155853/</a><br>
> > >> But for servers-tags, it's sub-resource, we can put it in<br>
> > >> its-own module.<br>
> > ><br>
> > > Agreed, and that's what I put in my email.<br>
> > ><br>
> > >> If we didn't want to support extension right now, we can begin<br>
> > >> from not show servers-tags in extension info API first. That means<br>
> > >> extension info is freeze now. We deprecated the extension info api<br>
> > >> in later version.<br>
><br>
> It can be surpressed from /extensions by adding it to the suppress list<br>
> in the extensions code. Probably a good idea to stop v2.1+microversion<br>
> code REST API users not accidentally relying on it.<br>
<br>
</span>I don't want it suppressed. I want the use of API extensions and the<br>
extension framework(s) to be completely dropped for all future<br>
API-affecting work.<br>
<span class=""><br>
> > > I don't understand what you're saying here. Could you elaborate?<br>
> > > What I am asking for is for new functionality (like the server-tags<br>
> > > subcollection resource), just add a new module called<br>
> > > /nova/api/openstack/compute/server_tags.py, create a Controller<br>
> > > object in that file with the new server tags resource, and don't<br>
> > > use any of the API extensions framework whatsoever.<br>
> > ><br>
> > > In addition to that, for the changes to the main GET<br>
> > > /servers/{server_id} resource, use microversions to decorate the<br>
> > > /nova/api/openstack/compute/servers.py.Controller.show() method for<br>
> > > 2.4 and add a "tags" key to the dict (note: NOT a<br>
> > > "os-server-tags:tags" key) returned by GET /servers/{server_id}. No<br>
> > > use of API extensions needed.<br>
><br>
> So I that's doabe but I think if we compared to the two wsgi.extends<br>
> is cleaner and less code and we have to have the separate module file<br>
> anyway for the controller. Can discuss this more later...<br>
<br>
</span>As mentioned above, I'm quite happy with a separate module for the<br>
server tags Controller. What I'm not happy about is forcing the server<br>
tags stuff to be implemented as an API "plugin" using the extensions<br>
framework, because the extensions framework no longer has any point.<br>
<span class=""><br>
> Incidentally as has been mentioned before we need new names for the<br>
> API and where the files need to live needs cleaning up. For example v3<br>
> and v2.1 needs to be worked out of the directory paths.This clenaup not<br>
> on involves but directly affects the all the related unit and<br>
> functional tests. Nor should we have contrib or should v2 live directly<br>
> in in nova/api/openstack/compute. But we also need a name for v2.1<br>
> microversions and should spend some time on that (does api modules work<br>
> for anyone?)<br>
<br>
</span>Why do we need new names for stuff? Just put everything in<br>
/nova/api/openstack/compute/ and be done with it. It doesn't have to be<br>
all in one single file, of course. But there's just no reason to<br>
continue using the extensions framework for anything nor putting new<br>
functionality into any of the files in<br>
/nova/api/openstack/compute/plugins/.<br>
<span class=""><br>
> I think this dicussion indicates we should start with a bit of planning<br>
> first rather than just jump in and start shuffling this around now.<br>
> Work out what we want the final thing to look like so we can see what<br>
> the dependencies look like and minimise the number of times that files<br>
> get shuffled around. It is also likely to be one of those patches that<br>
> is a real pain to merge without some well timed +2 coordination.<br>
<br>
</span>I haven't asked to shuffle anything around. I'm simply asking that *new*<br>
functionality that touches the API:<br>
<br>
* be placed in /nova/api/openstack/compute/ files<br>
* not use the extensions framework (i.e. the plugin stuff)<br>
<br>
That's it. No shuffling required right now. Happy to have discussions in<br>
Vancouver about cleaning directories up in Liberty.<br>
<span class=""><br>
> Perhaps its something we can talk about at the Nova API meeting this<br>
> week?<br>
<br>
</span>I'm game for this week :) Sorry, missed last week.<br>
<span class=""><br></span></blockquote><div><br></div><div>Ok, lets put it down on the agenda for the Nova API meeting this week. I suspect there's still some concerns of yours I'm missing and hopefully an irc meeting will help clear that up. I'm still of the mind though that priority has to during the rest of this cycle given to tech debt reduction - primarily test consolidation and directory cleanups. This sort of work always gets puts last which causes us issues at other points of the development cycle. Even just moving new code to nova/api/openstack/compute is not straightforwards because the old v2 code is scattered throughout where we want new files. And even if there isn't a direct nameclash its really confusing for anyone wanting to read the new code.</div><div><br></div><div>So I'm really pushing for cleanup first. directory reorg then everything can go where it belongs long term. Anyway can discuss more at the meeting this week.</div><div><br></div><div> </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><span class="">
> Also, apologies in advance but over at least the next couple of weeks I<br>
> may be slow in replying on irc/email.<br>
<br>
</span>No worries at all, Chris!<br>
<span class="HOEnZb"><font color="#888888"><br>
-jay<br>
</font></span><span class="im HOEnZb"><br>
><br>
> Regards,<br>
><br>
> Chris<br>
><br>
> > So possibly another way to think about this is our prior signaling of<br>
> > what was supported by Nova was signaled by the extension list. Our<br>
> > code was refactored into a way that supported optional loading by<br>
> > that unit.<br>
> ><br>
> > As we're making things less optional it probably makes sense to evolve<br>
> > the API code tree to look more like our REST resource tree. Yes, that<br>
> > means servers.py ends up being big, but it is less confusing that all<br>
> > servers related code is in that file vs all over a bunch of other<br>
> > files.<br>
> ><br>
> > So I'd agree that in this case server tags probably should just be in<br>
> > servers.py. I also think long term we should do some "plugin collapse"<br>
> > for stuff that's all really just features on one resource tree so that<br>
> > the local filesystem code structure looks a bit more like the REST<br>
> > url tree.<br>
> ><br>
> > -Sean<br>
> ><br>
><br>
><br>
</span><div class="HOEnZb"><div class="h5">> __________________________________________________________________________<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>
__________________________________________________________________________<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>
</div></div></blockquote></div><br></div></div>