Hi Benoit,

Thanks for accommodating my suggestions.  All resolutions look good to me.

I have a preference to hold shipping this document to IETF LC until the 
instance-data doc is also ready.  I think that it will help the IESG review if 
they have both documents available to review at the same time.  I assume that 
the updates to the instance-data doc are also in progress?

Thanks,
Rob


From: Benoit Claise <benoit.cla...@huawei.com>
Sent: 05 July 2021 11:53
To: Rob Wilton (rwilton) <rwil...@cisco.com>; netmod@ietf.org; 
draft-ietf-netconf-notification-capabilit...@ietf.org
Cc: NetMod WG Chairs <netmod-cha...@ietf.org>
Subject: Re: AD review of draft-ietf-netconf-notification-capabilities

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><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