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