Hi Rob,

Thanks for your detailed review.
A new draft version has been posted.

URL:https://www.ietf.org/archive/id/draft-ietf-netconf-notification-capabilities-17.txt
Status:https://datatracker.ietf.org/doc/draft-ietf-netconf-notification-capabilities/
Htmlized:https://datatracker.ietf.org/doc/html/draft-ietf-netconf-notification-capabilities
Diff:https://www.ietf.org/rfcdiff?url2=draft-ietf-netconf-notification-capabilities-17


See the justifications below.

On 6/21/2021 10:45 AM, Rob Wilton (rwilton) wrote:
Hi,

Here is my AD review of draft-ietf-netconf-notification-capabiltiies-16

Thanks for this draft, sorry for the delay in reviewing.  It looks like it is 
in good shape.

I think that most of my comments are minor or cosmetic suggestions to 
potentially improve the phrasing of the text.


1.
Abstract:

    The module "ietf-system-capabilities" provides a placeholder
    structure that can be used to discover YANG related system
    capabilities for servers.  The module can be used to report
    capability information from the server at run-time or implementation-
    time, per the YANG Instance Data File Format.

Suggest "by making use of" rather than "per".
DONE.


2.
    1.  Introduction

    There is a need to publish this capability information as it is part
    of the contract between the server and client.

Suggest "contract" -> "API contract".
DONE


3.
    There is a need to publish this capability information as it is part
    of the contract between the server and client.  Examples include
    maximum size of data that can be stored or transferred, information
    about counters (whether a node supports "on-change" telemetry), etc.
    Such capabilities are often dependent on a vendor's implementation or
    the available resources at deployment.  Many such capabilities are
    specific to either the complete system, individual YANG datastores
    [RFC8342] or specific parts of the YANG schema, or even individual
    data nodes.  It is a goal of this document to provide a common way of
    representing such capabilities in a format that is:

Suggest: maximum -> the maximum
          "or specific" -> ", specific"
DONE


4.
    o  available in identical format both at implementation-time and run-
       time
        
Suggest: "in an identical", and a period at the end.
DONE


5.
    If the information is
    not documented in a way available to the NMS designer, but only as
    instance data from the network node once it is deployed, the NMS
    implementation will be delayed

Suggest: "way available" => "way that is readily available"
DONE


6.
    The network operator needs to plan his
    management practices and NMS implementation before he even decides to
    buy the specific network node type.

Suggest: "him" -> "their", "he even decides" -> "they decide"
DONE


7.
    Run-time information is needed:
Suggest: Run-time capability information is needed:
DONE.


8.
    o  to check that capability information provided earlier, at
       implementation-time is what the publisher has implemented.

Suggest: "at implementation-time, is"
DONE


9.
      To find a capability value for a specific data node in a
      specific datastore the user SHALL:
        
Please clarify that the capability value is selected by the relative path
to the datanode defining the capability.  i.e., the same name/path must be
used both under the system level and per datastore level capabilties.
NEW SENTENCE.

"When stating a specific capability, the relative path for any specific
capability must be the same under the system-capabilities container and
under the per-node-capabilities list: the same grouping for defining the
capabilities MUST be used. "

10.
2) If the datastore entry is found within that entry, process all
      per-node-capabilities entries in the order they appear in the list.
      The first entry that specifies the specific capability and has a
      node-selector selecting the specific data node defines the
      capability value.

I'm not sure this is required, but perhaps consider adding text to make it clear
that longest path matching can be achieved by ordering more specific
matches before less specific matches.
ADDED "Note that longest path matching can be achieved by ordering more specific matches before less specific ones"
under

    list per-node-capabilities {
        description
          "Each list entry specifies capabilities for the selected
           data nodes. The same capabilities apply for the data nodes
           in the subtree below the selected nodes.

           The system SHALL order the entries according to their
           precedence. The order of the entries MUST NOT change unless
           the underlying capabilities also change.";

We did NOT add next to "2) If the datastore entry is found within that entry ..." because that section focuses on the user (as opposed to the implementer on the server), as mentioned in "To find a capability value for a specific data node in a

     specific datastore the user SHALL:"



11.
     // augmentation point for system level capabilities
Suggest: "Augmentation ... capabilities."  I would also suggest using a block 
style
comment so this doesn't get lost.       
DONE.


12.
            Only one specific datastore can be specified
            e.g., ds:conventional is not allowed.";
                
Suggest changing to:

            Only specific datastores can be specified.
                   E.g., ds:conventional, which represents a
                   set of configuration datastores, must not be
                   used";
DONE


13.
           description
             "A method to select all or some nodes within a datastore.";

"some or all" would flow better.
DONE


14.
         // augmentation point for datastore or data node level
         // capabilities

Suggest: "Augmentation ... capabilities."  I would also suggest using a block 
style
comment so this doesn't get lost.
DONE.


15.
5.2.  YANG Module (ietf-notification-capabilities)

       - capabilities related to the throughput of notification data
       the publisher can support. (Note that for a specific
       subscription the publisher MAY still allow only longer periods
       or smaller updates depending on e.g., actual load conditions.)
        
Suggest: "data that the publisher"
          "specific subscription, the"
                 "still allow" -> "allow"
          "e.g., -> ", e.g., "                
DONE.

16.
            bit config-changes {
              description
                "The publisher is capable of sending
                 notifications for 'config false' nodes for the
                 relevant scope and subscription type.";
                                
I presume that this should this be 'config true' nodes?
GOOD CATCH+



17.
          description
            "Type for defining whether 'on-change' or
             'periodic' notifications are supported 'config false'
             data nodes, 'config true' date nodes, no data nodes,
             or all data nodes.
                        
Suggest: "supported for 'config false'",
          "date" -> "data
As an optional minor nit, it might be worth putting 'all' at the beginning
of the list rather than the end.
DONE.


18.
              "Indicates the minimal update period that is
               supported for a 'periodic' subscription.

               A subscription request to the selected data
               nodes with a smaller period than what this leaf
               specifies will result in a 'period-unsupported' error.";

Is "will result" right here, or should it be "MAY result" or "is likely to 
result"?
I.e., is the server guaranteeing that it won't handle a smaller update for the
given capability under any circumstance?  The same question also applies
to the "supported-update-period".
DONE. "is likely to result"


19.
            "The change types that can be excluded in
             YANG-Push subscriptions.";
                        
Suggest adding something like "for the selected data nodes."
DONE


20.
7.2.  The YANG Module Names Registry

    This document registers two YANG modules in the YANG Module Names
    registry.  Following the format in [RFC7950], the the following
    registrations are requested:
This should be (along with a normative reference to RFC 6020):

    This document registers two YANG modules in the YANG Module Names
    registry [RFC6020].  Following the format in [RFC6020], the the following
    registrations are requested:
DONE.


21.
9.2.  Informative References

    [RFC3688]  Mealling, M., "The IETF XML Registry", BCP 81, RFC 3688,
               DOI 10.17487/RFC3688, January 2004,
               <https://www.rfc-editor.org/info/rfc3688>.
                        
This needs to be a normative reference (for the IANA registry) definition.
DONE


22.
Appendix A.  Instance data example #1

Suggest changing:
"the running, and operational datastores" => "the running and operational 
datastores".
'"on-change" only' -> '"on-change", only'
'reported "on-change" as they' -> 'reported "on-change", as they'
DONE


23.
========== NOTE: '\' line wrapping per BCP YYY (RFC YYYY) ===========

This can be updated to "NOTE: '\' line wrapping per RFC 8792".
DONE


24.
"only has running, and operational" -> "only has running and operational"
DONE.


25.
     false" data from the operational datastore. Statistics are
     not reported on-change only two important counters, for these
     a smaller dampening period is possible.
        
Suggest:
        false" data from the operational datastore. Statistics are
     not reported on-change except for two important counters, where
     a small dampening period is mandated.
DONE.
        

Spelling/grammar warnings (generated by tool):

Potentially incorrect spellings: sheperds, getconfig

Grammar Warnings:
Section: 1, draft text:
  Servers and/or a publishers often have capabilities, values describing 
operational behavior, that need to be conveyed to clients, which is enabled by 
the YANG modules described in this document.
Warning:  The plural noun "publishers" cannot be used with the article "a". Did 
you mean a publisher or publishers?
Suggested change:  "a publisher"
DONE

Section: 1, draft text:
It is a goal of this document to provide a common way of representing such 
capabilities in a format that is:
- vendor independent
- machine readable
- available in identical format both at implementation-time and run-time

Warning:  This word is normally spelled with hyphen.
Suggested change:  "machine-readable"
DONE


Section: 1, draft text:
It is a goal of this document to provide a common way of representing such 
capabilities in a format that is:
- vendor independent
- machine readable
- available in identical format both at implementation-time and run-time

Warning:  Please add a punctuation mark at the end of paragraph.
Suggested change:  "run-time."
DONE


Section: 1, draft text:
Moreover the decision to buy the node type sometimes depends on these 
management possibilities.
Warning:  Did you forget a comma after a conjunctive/linking adverb?
Suggested change:  "Moreover,"
DONE.


Section: 1.1, draft text:
  "Implementation-time information": Information about the server's behavior 
that is made available during the implementation of the server, available from a source 
other then a running server.
Warning:  Did you mean other than?
Suggested change:  "other than"
DONE.


Section: 3, draft text:
These include:
- Supported (reporting) periods for "periodic" subscriptions
- Maximum number of objects that can be sent in an update
- The set of datastores or data nodes for which "periodic" notification is 
supported

Warning:  Please add a punctuation mark at the end of paragraph.
Suggested change:  "supported."
DONE


Section: 7.2, draft text:
Following the format in [RFC7950], the the following registrations are 
requested:
Warning:  Maybe you need to remove one determiner so that only the or the is 
left.
Suggested change:  "the"
DONE


Section: Appendix C, draft text:
In this latter case it is really the server functionality that is discussed

Warning:  Please add a punctuation mark at the end of paragraph.
Suggested change:  "discussed."
DONE

Thanks,
Rob
.

_______________________________________________
netmod mailing list
netmod@ietf.org
https://www.ietf.org/mailman/listinfo/netmod

Reply via email to