On 1/20/2017 7:13 AM, Carl Moberg (camoberg) wrote:
  Inline below:

On Jan 19, 2017, at 12:23 PM, Benoit Claise (bclaise) <[email protected]> wrote:

Benoit Claise has entered the following ballot position for
draft-ietf-i2rs-yang-l3-topology-08: Discuss

When responding, please keep the subject line intact and reply to all
email addresses included in the To and CC lines. (Feel free to cut this
introductory paragraph, however.)


Please refer to https://www.ietf.org/iesg/statement/discuss-criteria.html
for more information about IESG DISCUSS and COMMENT positions.


The document, along with other ballot positions, can be found here:
https://datatracker.ietf.org/doc/draft-ietf-i2rs-yang-l3-topology/



----------------------------------------------------------------------
DISCUSS:
----------------------------------------------------------------------

1. The examples.
In the AUTH48 for the RESTCONF RFC, the example YANG module discussion
came up (again).  And the examples in draft-ietf-i2rs-yang-l3-topology
were also discussed. Here is the feedback from one YANG doctor, from a
couple of days ago.

Look at this:

   module example-ietf-ospf-topology {
     ...
     namespace
       "urn:ietf:params:xml:ns:yang:example-ietf-ospf-topology";
     ...
     description
       "This module defines a model for OSPF network topologies.
        Copyright (c) 2017 IETF Trust and the persons identified as
        authors of the code.


They are using the IANA-controlled namespace w/o registering it.

This module *really* looks like a proper normative module, rather than
an
example.  They went to far in trying to mimic a real module.

It is clear that we need more guidelines in 6087 for how to write
example modules.

I was going to ask if this module passed YANG doctor review - then I
checked and saw that version -02 was reviewed, which didn't include
this example.  How should we (the YANG doctors) handle such a case?

In this case they should:

  1.  change the name to example-ospf-topology
  2.  change the namespace to urn:example:ospf-topology
  3.  remove the top-level statements:
          organization, contact, revision

  4.  change the top-level description to what the text in the draft
      says:

      description
        "This module is intended as an example for how the
         Layer 3 Unicast topology model can be extended to cover
         OSFP topologies.";

(same for the other example module)


As I mentioned to the authors, respective chairs and AD already, we
should follow the decision in this NETMOD email thread
https://www.ietf.org/mail-archive/web/netmod/current/msg17428.html
This will hopefully resolve fast. Once settled, the examples should be
updated.

2. The security considerations should be better aligned with
https://trac.ietf.org/trac/ops/wiki/yang-security-guidelines, as
mentioned by others.

3. Carl Moberg, as YANG doctor, reviewed v1 of the draft.
https://www.ietf.org/mail-archive/web/yang-doctors/current/msg00031.html
I'm waiting for final blessing on v8 any time soon. Hence this late
DISCUSS.
  I have re-reviewed the current (-08) draft to follow up on my remarks from 
-01. The only remark that has not been addressed in the draft is the following:

“”"
1. All data definitions are optional configuration (e.g. no config false, 
default values or mandatory statements). This seems to open up for many odd 
combinations of e.g. existing and non-existing leafs in node, link, and 
termination-points. This is also true for the notifications. Is this by design 
or something that needs additional work?
“””

  The response from the authors (through Alex Clemm) during the first review 
was that:

“”"
This is actually by design, as there is always the issue for leaving 
flexibility for implementations (I know, this flexibility can be at odds with 
ease-of-use) but we shall review this.
“””

  I agree that this is a reasonable tradeoff, and am fine with leaving it as is.
Thanks Carl.
Authors, some text clarifying that all data definitions are optional configuration (e.g. no config false, default values or mandatory statements) and stressing that this is per design would be an excellent addition to the draft.

Regards, Benoit

4.

       leaf-list router-id {
           type inet:ip-address;
           description
             "Router-id for the node";
         }

We don't want to wait for
https://tools.ietf.org/html/draft-ietf-rtgwg-routing-types-00 (btw, we
should expedite this publication), but any good reason why
this is aligned with its definition?
    typedef router-id {
       type yang:dotted-quad;
       description
         "A 32-bit number in the dotted quad format assigned to each
          router. This number uniquely identifies the router within an
          Autonomous System.";
     }


----------------------------------------------------------------------
COMMENT:
----------------------------------------------------------------------

- YANG definition "YANG: A data definition language for NETCONF"
I would use:
   YANG is a data modeling language used to model configuration data,
   state data, Remote Procedure Calls, and notifications for network
   management protocols [RFC7950]

- There are multiple slightly different definitions of the datastore in
the different RFCs.
Let's not add to the confusion.
Pick one (RFC6241 should be the latest one) and mention the reference.

- Instead of:

   Brackets
   enclose list keys, "rw" means configuration, "ro" operational state
   data, "?" designates optional nodes, "*" designates nodes that can
   have multiple instances.  Parantheses enclose choice and case nodes.

Use the cut/paste from RFC8022 and
https://tools.ietf.org/html/draft-ietf-netmod-rfc6087bis-09]

   o  Brackets "[" and "]" enclose list keys.

   o  Curly braces "{" and "}" contain names of optional features that
      make the corresponding node conditional.

   o  Abbreviations before data node names: "rw" means configuration
      (read-write), "ro" state data (read-only), "-x" RPC operations or
      actions, and "-n" notifications.

   o  Symbols after data node names: "?" means an optional node, "!" a
      container with presence, and "*" denotes a "list" or "leaf-list".

   o  Parentheses enclose choice and case nodes, and case nodes are
also
      marked with a colon (":").

   o  Ellipsis ("...") stands for contents of subtrees that are not
      shown.

Btw, no need to repeat this convention in section 6.1.1 and 6.2.1

- I agree with Suresh: "OSPF and IS-IS are used later in the document as
examples but this section (especially Figure 1) seems to treat them as
more than examples"
Either modify figure 1, or even better, stress in section 3 that
ospf-topology and isis-topology are examples, and defined as such in this
document

- section 7
OLD:
The moodel defines
NEW:
The model defines



_______________________________________________
i2rs mailing list
[email protected]
https://www.ietf.org/mailman/listinfo/i2rs

Reply via email to