<div dir="ltr">Ton,<div><br></div><div>It seems the approach you proposed requires the yaml file that describes all the labels to be copied between repos (openstack/magnum, openstack/python-magnumclient, openstack/magnum-ui). Unless we setup a CI job to copy the file, I don't think it can solve the maintenance problem.</div><div><br></div><div>Best regards,</div><div>Hongbin</div></div><div class="gmail_extra"><br><div class="gmail_quote">On Thu, May 12, 2016 at 4:33 PM, Ton Ngo <span dir="ltr"><<a href="mailto:ton@us.ibm.com" target="_blank">ton@us.ibm.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div><p>I would like to add some context for a bigger picture so we might arrive at a more general solution.<br>Typically CLI options are fairly static so the help messages are usually coded directly in the client.<br>This provides a good user experience by making the info readily available to the users.<br>The case for label is a little different, because label provides a general mechanism to pass arbitrary key/value pairs.  <br>The meaning for these key/value is interpreted based on a particular option in a particular COE type, so they are not generally applicable.<br>For instance,  Kubernetes baymodel that uses flannel as network-driver supports the label "flannel_backend", with the allowed values of "udp, vxlan, host-gw".  <br>This particular label would be meaningless in another COE like Mesos.<br><br>So to provide this kind of info to the users, we have to address 2 issues:
</p><ol type="1"><li>How the user can discover the available labels specific to the COE, along with the valid values to specify.
</li><li>How to maintain the help messages specific to each label since they are likely to change frequently.  </li></ol><br>I think just displaying the info for all labels together would not be too helpful.<br>Putting the info in the API would make it available to tools built on Magnum, but Madhuri has a good point that the info would not be available when the server is not running.<br>We need to accommodate new bay drivers that may add new labels.<br>Validation for the label value is another requirement.<br><br>Here is a thought on how to meet these requirements:  we can install a yaml file in /etc/magnum/labels.yaml that would describe all the supported labels, something like:<br><br>flannel_backend:<br>   valid_values: <br>      -udp<br>      -vxlan<br>      -host-gw<br>   default_value:  udp<br>   COE:  <br>      -kubernetes<br>      -swarm<br>   help_message: "This label is used with the flannel network driver to specify the type of back end to use. The option host-gw gives the best bandwidth performance."<br>   doc_url: "<a href="http://xxx" target="_blank">http://xxx</a>"<br>   <br>Then the client can read this yaml file and list the labels for a COE, say Kubernetes.  For help on a specific label, the client would print the help message along with the url for further info (if available)<br>The validation code can also load this file for a more general way to validate the baymodel, avoiding hardcoding in api/attr_validator.py<br>New bay drivers can just append new labels to this file to have them handled in the same way as Magnum supported labels.<br>Optionally, the API server can provide access to this info.<br>In the source, we can keep this file in etc/magnum/labels.yaml.<br>Maintaining the help messages would be simpler since we just need to edit the file.<br><br>Thought?<br><br>Ton,<br> <br><br><img width="16" height="16" src="cid:1__=8FBBF522DFC6DCDE8f9e8a93df938690918c8FB@" border="0" alt="Inactive hide details for Jamie Hannaford ---05/12/2016 07:08:47 AM---+1 for 1 and 3. I'm not sure maintainability should disco"><font color="#424282">Jamie Hannaford ---05/12/2016 07:08:47 AM---+1 for 1 and 3. I'm not sure maintainability should discourage us from exposing information to the u</font><br><br><font size="2" color="#5F5F5F">From:        </font><font size="2">Jamie Hannaford <<a href="mailto:jamie.hannaford@rackspace.com" target="_blank">jamie.hannaford@rackspace.com</a>></font><span class=""><br><font size="2" color="#5F5F5F">To:        </font><font size="2">"OpenStack Development Mailing List (not for usage questions)" <<a href="mailto:openstack-dev@lists.openstack.org" target="_blank">openstack-dev@lists.openstack.org</a>></font><br><font size="2" color="#5F5F5F">Cc:        </font><font size="2">Qun XK Wang <<a href="mailto:bjwqun@cn.ibm.com" target="_blank">bjwqun@cn.ibm.com</a>></font><br></span><font size="2" color="#5F5F5F">Date:        </font><font size="2">05/12/2016 07:08 AM</font><br><font size="2" color="#5F5F5F">Subject:        </font><font size="2">Re: [openstack-dev] [magnum] How to document 'labels'</font><br><hr width="100%" size="2" align="left" noshade style="color:#8091a5"><div><div class="h5"><br><br><br><font size="4" face="Calibri">+1 for 1 and 3. </font><br><br><font size="4" face="Calibri">I'm not sure maintainability should discourage us from exposing information to the user through the client - we'll face the same maintenance burden as we currently do, and IMO it's our job as a team to ensure our docs are up-to-date. Any kind of input which touches the API should also live in the API docs, because that's in line with every other OpenStack service.</font><br><br><font size="4" face="Calibri">I don't think I've seen documentation exposed via the API before (#2). I think it's a lot of work too, and I don't see what benefit it provides.</font><br><br><font size="4" face="Calibri">Jamie</font><br>
</div></div><p></p><div><div class="h5"><hr width="100%" size="2" align="left"><br><b><font face="Calibri">From:</font></b><font face="Calibri"> Hongbin Lu <<a href="mailto:hongbin.lu@huawei.com" target="_blank">hongbin.lu@huawei.com</a>></font><b><font face="Calibri"><br>Sent:</font></b><font face="Calibri"> 11 May 2016 21:52</font><b><font face="Calibri"><br>To:</font></b><font face="Calibri"> OpenStack Development Mailing List (not for usage questions)</font><b><font face="Calibri"><br>Cc:</font></b><font face="Calibri"> Qun XK Wang</font><b><font face="Calibri"><br>Subject:</font></b><font face="Calibri"> [openstack-dev] [magnum] How to document 'labels'</font><font size="4" color="#212121" face="Calibri"> </font><br><font size="4" color="#212121" face="Calibri"> </font><br><font color="#1F497D" face="Calibri">Hi all,</font><br><font color="#1F497D" face="Calibri"> </font><br><font color="#1F497D" face="Calibri">This is a continued discussion from the last team meeting. For recap, ‘labels’ is a property in baymodel and is used by users to input additional key-pair pairs to configure the bay. In the last team meeting, we discussed what is the best way to document ‘labels’. In general, I heard three options:</font><ul><ul><font color="#1F497D" face="Calibri">1.       Place the documentation in Magnum CLI as help text (as Wangqun proposed [1][2]).</font><br><font color="#1F497D" face="Calibri">2.       Place the documentation in Magnum server and expose them via the REST API. Then, have the CLI to load help text of individual properties from Magnum server.</font><br><font color="#1F497D" face="Calibri">3.       Place the documentation in a documentation server (like <a href="http://developer.openstack.org/" target="_blank">developer.openstack.org/</a>…), and add the doc link to the CLI help text.</font></ul></ul><font color="#1F497D" face="Calibri">For option #1, I think an advantage is that it is close to end-users, thus providing a better user experience. In contrast, Tom Cammann pointed out a disadvantage that the CLI help text might be easier to become out of date. For option #2, it should work but incurs a lot of extra work. For option #3, the disadvantage is the user experience (since user need to click the link to see the documents) but it makes us easier to maintain. I am thinking if it is possible to have a combination of #1 and #3. Thoughts?</font><br><font color="#1F497D" face="Calibri"> </font><br><font color="#1F497D" face="Calibri">[1] </font><a href="https://review.openstack.org/#/c/307631/" target="_blank"><u><font color="#0000FF" face="Calibri">https://review.openstack.org/#/c/307631/</font></u></a><br><font color="#1F497D" face="Calibri">[2] </font><a href="https://review.openstack.org/#/c/307642/" target="_blank"><u><font color="#0000FF" face="Calibri">https://review.openstack.org/#/c/307642/</font></u></a><br><font color="#1F497D" face="Calibri"> </font><br><font color="#1F497D" face="Calibri">Best regards,</font><br><font color="#1F497D" face="Calibri">Hongbin</font></div></div><p><font size="4" face="Calibri">    </font></p><hr width="100%" size="2" align="left"><font size="4" face="Calibri">Rackspace International GmbH a company registered in the Canton of Zurich, Switzerland (company identification number CH-020.4.047.077-1) whose registered office is at Pfingstweidstrasse 60, 8005 Zurich, Switzerland. Rackspace International GmbH privacy policy can be viewed at </font><font size="4" face="Calibri"><a href="http://www.rackspace.co.uk/legal/swiss-privacy-policy" target="_blank">www.rackspace.co.uk/legal/swiss-privacy-policy</a></font><font size="4" face="Calibri"> - This e-mail message may contain confidential or privileged information intended for the recipient. Any dissemination, distribution or copying of the enclosed material is prohibited. If you receive this transmission in error, please notify us immediately by e-mail at <a href="mailto:abuse@rackspace.com" target="_blank">abuse@rackspace.com</a> and delete the original message. Your cooperation is appreciated. </font><tt>__________________________________________________________________________<span class=""><br>OpenStack Development Mailing List (not for usage questions)<br></span>Unsubscribe: <a href="http://OpenStack-dev-request@lists.openstack.org?subject:unsubscribe" target="_blank">OpenStack-dev-request@lists.openstack.org?subject:unsubscribe</a><br></tt><tt><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></tt><tt><br></tt><p></p><p><br>
</p><p></p><p></p><p></p><p></p></div>
<br>__________________________________________________________________________<br>
OpenStack Development Mailing List (not for usage questions)<br>
Unsubscribe: <a href="http://OpenStack-dev-request@lists.openstack.org?subject:unsubscribe" rel="noreferrer" target="_blank">OpenStack-dev-request@lists.openstack.org?subject:unsubscribe</a><br>
<a href="http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack-dev" rel="noreferrer" target="_blank">http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack-dev</a><br>
<br></blockquote></div><br></div>