Re: [Last-Call] Yangdoctors last call review of draft-ietf-dots-telemetry-14 (First Part)

mohamed.boucadair@orange.com Fri, 27 November 2020 08:24 UTC

Return-Path: <mohamed.boucadair@orange.com>
X-Original-To: last-call@ietfa.amsl.com
Delivered-To: last-call@ietfa.amsl.com
Received: from localhost (localhost [127.0.0.1]) by ietfa.amsl.com (Postfix) with ESMTP id 4ECDE3A14C9; Fri, 27 Nov 2020 00:24:12 -0800 (PST)
X-Virus-Scanned: amavisd-new at amsl.com
X-Spam-Flag: NO
X-Spam-Score: -2.118
X-Spam-Level:
X-Spam-Status: No, score=-2.118 tagged_above=-999 required=5 tests=[BAYES_00=-1.9, DKIM_SIGNED=0.1, DKIM_VALID=-0.1, DKIM_VALID_AU=-0.1, DKIM_VALID_EF=-0.1, RCVD_IN_MSPIKE_H4=-0.01, RCVD_IN_MSPIKE_WL=-0.01, SPF_HELO_NONE=0.001, SPF_PASS=-0.001, UNPARSEABLE_RELAY=0.001, URIBL_BLOCKED=0.001] autolearn=ham autolearn_force=no
Authentication-Results: ietfa.amsl.com (amavisd-new); dkim=pass (2048-bit key) header.d=orange.com
Received: from mail.ietf.org ([4.31.198.44]) by localhost (ietfa.amsl.com [127.0.0.1]) (amavisd-new, port 10024) with ESMTP id rkA2H7aS7THU; Fri, 27 Nov 2020 00:24:09 -0800 (PST)
Received: from relais-inet.orange.com (relais-inet.orange.com [80.12.70.34]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by ietfa.amsl.com (Postfix) with ESMTPS id 8901F3A14C7; Fri, 27 Nov 2020 00:24:09 -0800 (PST)
Received: from opfednr06.francetelecom.fr (unknown [xx.xx.xx.70]) by opfednr25.francetelecom.fr (ESMTP service) with ESMTP id 4Cj72J0D3vzCrL4; Fri, 27 Nov 2020 09:24:08 +0100 (CET)
DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=orange.com; s=ORANGE001; t=1606465448; bh=+/IaD0siUixKLb6OKM8ZIiNyC28YCrVoB+wQ6Fqq3DU=; h=From:To:Subject:Date:Message-ID:Content-Type: Content-Transfer-Encoding:MIME-Version; b=hlruRqCDM5XcElnFFsLEtTG92KkFuNfhitoiNpnSEOpOilLmbwT4zB0wv1uA2TsAp PurrMEMfDI9agLY0TeJczfs/4/NmtGYVXj5R0kWwgV/s5Xjw1Zx0y76dUHXwK5dkYx cXAY/8rX476reBX2/8a0S+0m97II9cFAopa/Z72s1XR4yLByDs0jRqfdGL0Ejs+TaV 4Xi5xz4GLejyjBo/uQayDhV1Z8SzwvGuJ2yc74HoV75EzhCakIAmx2QjEJ+x0+998e BqnQq/5A814nhKar0I9x7lPBdjNPTL7ybqq61hkvEDl/HlYuMcPu5YXRtEP6b9Yr0Z h4KmV8hBAxCmQ==
Received: from Exchangemail-eme6.itn.ftgroup (unknown [xx.xx.13.51]) by opfednr06.francetelecom.fr (ESMTP service) with ESMTP id 4Cj72H6SL2zDq7Q; Fri, 27 Nov 2020 09:24:07 +0100 (CET)
From: mohamed.boucadair@orange.com
To: Jan Lindblad <janl@tail-f.com>, "yang-doctors@ietf.org" <yang-doctors@ietf.org>
CC: "last-call@ietf.org" <last-call@ietf.org>, "dots@ietf.org" <dots@ietf.org>, "draft-ietf-dots-telemetry.all@ietf.org" <draft-ietf-dots-telemetry.all@ietf.org>
Thread-Topic: Yangdoctors last call review of draft-ietf-dots-telemetry-14 (First Part)
Thread-Index: AdbElqpwsrQsLYA7TWOW2f5R7wRcCA==
Date: Fri, 27 Nov 2020 08:24:06 +0000
Message-ID: <9644_1606465447_5FC0B7A7_9644_228_2_787AE7BB302AE849A7480A190F8B933031584ADF@OPEXCAUBMA2.corporate.adroot.infra.ftgroup>
Accept-Language: fr-FR, en-US
Content-Language: fr-FR
X-MS-Has-Attach:
X-MS-TNEF-Correlator:
x-originating-ip: [10.114.13.247]
Content-Type: text/plain; charset="utf-8"
Content-Transfer-Encoding: base64
MIME-Version: 1.0
Archived-At: <https://mailarchive.ietf.org/arch/msg/last-call/kBXJJJmJxOqfso6LzlsLk_yZMS8>
Subject: Re: [Last-Call] Yangdoctors last call review of draft-ietf-dots-telemetry-14 (First Part)
X-BeenThere: last-call@ietf.org
X-Mailman-Version: 2.1.29
Precedence: list
List-Id: IETF Last Calls <last-call.ietf.org>
List-Unsubscribe: <https://www.ietf.org/mailman/options/last-call>, <mailto:last-call-request@ietf.org?subject=unsubscribe>
List-Archive: <https://mailarchive.ietf.org/arch/browse/last-call/>
List-Post: <mailto:last-call@ietf.org>
List-Help: <mailto:last-call-request@ietf.org?subject=help>
List-Subscribe: <https://www.ietf.org/mailman/listinfo/last-call>, <mailto:last-call-request@ietf.org?subject=subscribe>
X-List-Received-Date: Fri, 27 Nov 2020 08:24:12 -0000

Hi Jan, 

Focusing now on the first part of the review. 

Will let my co-authors further comment as appropriate. 

Please see inline. 

Cheers,
Med

> -----Message d'origine-----
> De : Jan Lindblad via Datatracker [mailto:noreply@ietf.org]
> Envoyé : jeudi 26 novembre 2020 12:37
> À : yang-doctors@ietf.org
> Cc : last-call@ietf.org; dots@ietf.org; draft-ietf-dots-
> telemetry.all@ietf.org
> Objet : Yangdoctors last call review of draft-ietf-dots-telemetry-14
> 
> Reviewer: Jan Lindblad
> Review result: Almost Ready
> 
> Dear Dots Authors, NETMOD WG,
> 
> This is my YD LC review of draft-ietf-dots-telemetry-14. This draft
> contains two YANG modules, ietf-dots-telemetry and module ietf-dots-
> mapping. Both modules are unusual from a YANG perspective in that
> they consist of solely typedefs, groupings and sx:structures, and
> that their purpose is to define message bodies for a domain specific
> management protocol.

[Med] This comment does not apply to ietf-dots-mapping. 

> 
> Since my previous review of this module (-09, June 2020) the
> underpinnings of the modules have changed significantly with a new
> RFC in the works, addressing the fundamental issues pointed out at
> that time. Very good & impressive. I still think there are important
> issues to resolve, so I will call the current state of -14 "Almost
> Ready".
> 
> Links to previous relevant reviews:
> https://datatracker.ietf.org/doc/review-ietf-dots-rfc8782-bis-00-
> yangdoctors-early-aries-2020-09-23/
> https://datatracker.ietf.org/doc/review-ietf-dots-telemetry-09-
> yangdoctors-early-lindblad-2020-06-30/
> 
> Because of this hitherto unusual application of YANG, the usual YD
> review procedures are not really applicable. Whoever reads this
> should feel free to comment on which perspectives should be included
> (or not) in an YD review of a YANG module defining a new protocol.
> 
> I think the YD review should not be expected to cover the
> usability/interoperability of the newly defined protocol as a whole.
> E.g. which messages are sent when, what is the relevant/reasonable
> content in each message, are there any races or scalability issues,
> etc. IMO, such an analysis is essential, but too much work for an YD
> review (and outside my area of expertise). I have placed my review
> focus on the clear interpretation of the YANG modules, since that
> will be key to interoperability.
> 
> When YANG is mapped to NETCONF or RESTCONF, there are entire RFCs
> devoted to describing how that mapping is done, from what
> "mandatory" actually means in the protocol and how keys are sent,
> all the way to how the XML or JSON payloads are constructed and
> potential error messages. A lot more of that mapping is now present
> in this document, but I still find many aspects that are
> undefined/unclear.
> 
> #1 mandatory true
> 
> A few elements are marked mandatory true in the model. The meaning
> of this is not defined in the draft. I would expect this means
> clients as well as servers MUST provide a value for the mandatory
> element in each message if the parent element exists. This would be
> like how mandatory elements in YANG actions/rpcs/notifications work
> (and different from how mandatory works with configuration data in
> NETCONF/YANG).
> 
> Section 7.1 states: "DOTS telemetry attributes are optionally
> signaled and therefore MUST NOT be treated as mandatory fields in
> the DOTS signal channel protocol."

[Med] Telemetry attributes are optional from a DOTS standpoint. Hence, the text you quoted.  

"mandatory true" is used to tag attributes that must be present if the parent one was present. For example, "capacity" is a mandatory attribute if "total-pipe-capacity" is present. Still, total-pipe-capacity" is optional. 

              list total-pipe-capacity {
                key "link-id unit";
                description
                  "Total pipe capacity of a DOTS client domain.";
                leaf link-id {
                  ...
                }
                leaf capacity {
                  type uint64;
                  mandatory true;
                  description
                    "Pipe capacity.";
                }
                leaf unit {
                  ...
                }
              }
            }

Will consider adding a note to explain this. 

 This blanket statement makes
> things less clear for me. Can I trust the YANG mandatory and key
> statements to indicate what has to be included, and everything else
> is optional? If so, I would advise to state just that.
> 
> #2 key
> 
> There are many key statements around these modules. The exact
> meaning of the key keyword in this dots-signal protocol is not
> defined. Are key sets always unique in a list?

[Med] Yes. We are not deviating from the usual use of "keys". 

Note that we omit the "key" statement for some lists because the keys of these lists is sent in Uri-Path options (for requests) and may not/must not appear in a response message body. For such lists, there is an ordering requirement of these options. This ordering is needed to uniquely identify a DOTS resource. All this is already covered in the text. 

This behaviour is compliant with RFC8791: "The list-stmt is not required to have a key-stmt defined".

 Are keys mandatory?

[Med] Yes. We are not deviating from the usual use of "keys".  

> Are there any sequencing requirements on keys, e.g. do keys need to
> be sent first (as in NETCONF) in a list element?

[Med] The spec does not add any specific sequencing requirement.

> Such a requirement may not be unreasonable for servers with limited
> resources.
> 
> #3) if-feature
> 
> The ietf-dots-mapping.yang module defines one YANG feature and a few
> instances of model statements conditional on it with an if-feature
> statement. There is a description for how a server advertises
> support for this specific feature (by including a very particular
> leaf in one of the messages). From a YANG mapping perspective, it
> might have been better to have a general mechanism for advertising
> features. With the current specification, no other features can
> (ever) be added in a backwards compatible way.

[Med] Usual tools such as RFC7895 can be used, but we do need more granularity within a feature itself. We call that "capability". 

> 
> #5) augment or sx:augment-structure
> 
> The draft is using augment (but means sx:augment-structure) and
> sx:augment-structure. Are implementors allowed to use augment in
> their implementations? If so, how would a client know if an
> augmented model is in use? Section 6.1.2 states that servers MUST
> reject messages when "attribute values are not acceptable". Does
> that have any implications for augment?

[Med] I'm afraid we are mixing two points here:

* "attribute values are not acceptable" is in reference to a value of a configurable parameter that is not within an acceptable range by a server. That range can be retrieve by the client. This has nothing to do with an augment. 

* We don’t make any assumption/restriction about augments, but from DOTS protocol standpoint, what is important is to have a mapping to a CBOR key. If the key is not known to a peer, the attribute will be ignored. 

> 
> #6) deviations
> 
> Deviations are never mentioned. Are implementors allowed to deviate
> from the protocol in any way, if declared using deviation
> statements? If so, how would a client know if a deviated model is in
> use?

[Med] Some comments here: 
* A client in general does not know what model is used by a peer as what it sees is CBOR.
* A server can use distinct default values (e.g., percentile values), but this can be retrieved by a client during the telemetry-setup. 

Other than that, deviations should be avoided as this will impact message validation. 

> 
> #7) config true|false
> 
> RFC 8791 (which defines sx:structure) expressly states that config
> true and false statements have no defined meaning and will be
> ignored in sx:structure.
> Therefore it's very good that this draft defines behavior for the
> GET operation with respect to config true and config false elements.
> Nothing is said about how the config attribute plays with PUT, POST
> or DELETE however.
> 

[Med] Can you please explicit what additional consideration you have in mind? Thank you.

> #8) PATCH
> 
> Is the PATCH HTTP operation supported in this context? It is never
> mentioned.
> If so, it's is unclear how it would work in relation to the protocol
> HTTP headers, the tsid mechanism and the YANG mandatory concept. If
> not, that might be good to point out somewhere.
> 

[Med] Supported CoAP operations are those listed in https://tools.ietf.org/html/draft-ietf-dots-rfc8782-bis-02#section-4.4. 

> #9) Payload encoding references
> 
> As far as I understand, the message payloads are meant to be encoded
> in JSON or CBOR.

[Med] Not JSON. It is encoded in CBOR only: 

   Telemetry messages exchanged between DOTS agents are serialized using
   Concise Binary Object Representation (CBOR) [RFC7049].  CBOR-encoded
   payloads are used to carry signal channel specific payload messages
   which convey request parameters and response information such as
   errors.

or

   All DOTS telemetry parameters in the payload of the DOTS signal
   channel MUST be mapped to CBOR types as shown in the following table:

 This draft has no references to the relevant
> documents describing these encodings
> (https://tools.ietf.org/html/rfc7951 and
> https://tools.ietf.org/html/draft-ietf-core-yang-cbor-13).

[Med] That’s on purpose because these are listed in draft-ietf-dots-rfc8782-bis that says: 

   Messages exchanged between DOTS agents are serialized using Concise
   Binary Object Representation (CBOR) [RFC7049], a binary encoding
   scheme designed for small code and message size.  CBOR-encoded
   payloads are used to carry signal channel-specific payload messages
   that convey request parameters and response information such as
   errors.  In order to allow the reusing of data models across
   protocols, [RFC7951] specifies the JavaScript Object Notation (JSON)
   encoding of YANG-modeled data.  A similar effort for CBOR is defined
   in [I-D.ietf-core-yang-cbor].

We thought it is redundant if we restate it here as well. 

_________________________________________________________________________________________________________________________

Ce message et ses pieces jointes peuvent contenir des informations confidentielles ou privilegiees et ne doivent donc
pas etre diffuses, exploites ou copies sans autorisation. Si vous avez recu ce message par erreur, veuillez le signaler
a l'expediteur et le detruire ainsi que les pieces jointes. Les messages electroniques etant susceptibles d'alteration,
Orange decline toute responsabilite si ce message a ete altere, deforme ou falsifie. Merci.

This message and its attachments may contain confidential or privileged information that may be protected by law;
they should not be distributed, used or copied without authorisation.
If you have received this email in error, please notify the sender and delete this message and its attachments.
As emails may be altered, Orange is not liable for messages that have been modified, changed or falsified.
Thank you.