[netconf] Yangdoctors last call review of draft-ietf-netconf-list-pagination-03

Ladislav Lhotka via Datatracker <noreply@ietf.org> Wed, 01 May 2024 09:56 UTC

Return-Path: <noreply@ietf.org>
X-Original-To: netconf@ietf.org
Delivered-To: netconf@ietfa.amsl.com
Received: from ietfa.amsl.com (localhost [IPv6:::1]) by ietfa.amsl.com (Postfix) with ESMTP id 4192DC14F6BF; Wed, 1 May 2024 02:56:49 -0700 (PDT)
MIME-Version: 1.0
Content-Type: text/plain; charset="utf-8"
Content-Transfer-Encoding: 7bit
From: Ladislav Lhotka via Datatracker <noreply@ietf.org>
To: yang-doctors@ietf.org
Cc: draft-ietf-netconf-list-pagination.all@ietf.org, last-call@ietf.org, netconf@ietf.org
X-Test-IDTracker: no
X-IETF-IDTracker: 12.11.0
Auto-Submitted: auto-generated
Precedence: bulk
Message-ID: <171455740925.30235.8535907881082250669@ietfa.amsl.com>
Reply-To: Ladislav Lhotka <ladislav@lhotka.name>
Date: Wed, 01 May 2024 02:56:49 -0700
Archived-At: <https://mailarchive.ietf.org/arch/msg/netconf/l1xX0LJsUCxqVywNW2VfxfBZ_2g>
Subject: [netconf] Yangdoctors last call review of draft-ietf-netconf-list-pagination-03
X-BeenThere: netconf@ietf.org
X-Mailman-Version: 2.1.39
List-Id: NETCONF WG list <netconf.ietf.org>
List-Unsubscribe: <https://www.ietf.org/mailman/options/netconf>, <mailto:netconf-request@ietf.org?subject=unsubscribe>
List-Archive: <https://mailarchive.ietf.org/arch/browse/netconf/>
List-Post: <mailto:netconf@ietf.org>
List-Help: <mailto:netconf-request@ietf.org?subject=help>
List-Subscribe: <https://www.ietf.org/mailman/listinfo/netconf>, <mailto:netconf-request@ietf.org?subject=subscribe>
X-List-Received-Date: Wed, 01 May 2024 09:56:49 -0000

Reviewer: Ladislav Lhotka
Review result: On the Right Track

**** General comments

- This document, together with companion I-Ds
draft-ietf-netconf-list-pagination-nc and
draft-ietf-netconf-list-pagination-rc, aims at providing a relatively
comprehensive functionality for paginating and sorting list and leaf-list
entries in NETCONF/RESTCONF server output. This is a much needed addition to
both protocols.

- I very much like the extensive set of examples in Appendix A that illustrates
a broad range of possible uses.

- The handling of "config false" lists brings about considerable complexity.
Also, it seems to cater for SQL database backends and I am not sure whether the
constraints on "config false" data can also be easily implemented with other
backend architectures that might be suitable for huge datasets, such as Xapian
or ElasticSearch. What I am missing here is a description of typical use cases
for "config false" data and a cost/benefit analysis. Perhaps it could make
sense to adopt a simpler and less flexible approach for "config false" data.

- My main concern is the use of XPath 1.0 for the "where" query parameter.
Firstly, the definition in sec. 3.1.1 does not specify the necessary context
for XPath evaluation. In particular, the "real" XPath 1.0 as defined by W3C has
no concept of default namespace, so the namespace has to be specified for every
data node in the "where" parameter - but then it is necessary to find a way for
specifying prefix bindings. Some of the examples in Appendix A also seem to use
references to XML attributes (for example,
"joined[starts-with(@timestamp,'2020')]"). I don't know if this means metadata
annotations [RFC 7952], but in any case using the attribute axis in XPath for
querying non-XML data is problematic.

**** Specific comments, nits

- sec. 3.3 paragraph 4
  s/However, arbitrary/However, translating abitrary/

- sec A.3.6.2 (and other places)
  Why "@email-address"? I think it should be "email-address" (though with
  namespace prefix, see above), because "email-address" is a normal YANG leaf
  represented as XML element in instance data. Or am I missing something?