Re: [OSPF] [yang-doctors] Yangdoctors last call review of draft-ietf-ospf-yang-09

Ladislav Lhotka <lhotka@nic.cz> Tue, 09 January 2018 16:08 UTC

Return-Path: <lhotka@nic.cz>
X-Original-To: ospf@ietfa.amsl.com
Delivered-To: ospf@ietfa.amsl.com
Received: from localhost (localhost [127.0.0.1]) by ietfa.amsl.com (Postfix) with ESMTP id B2F27126D0C; Tue, 9 Jan 2018 08:08:28 -0800 (PST)
X-Virus-Scanned: amavisd-new at amsl.com
X-Spam-Flag: NO
X-Spam-Score: -7.009
X-Spam-Level:
X-Spam-Status: No, score=-7.009 tagged_above=-999 required=5 tests=[BAYES_00=-1.9, DKIM_SIGNED=0.1, DKIM_VALID=-0.1, DKIM_VALID_AU=-0.1, RCVD_IN_DNSWL_HI=-5, T_RP_MATCHES_RCVD=-0.01, URIBL_BLOCKED=0.001] autolearn=ham autolearn_force=no
Authentication-Results: ietfa.amsl.com (amavisd-new); dkim=pass (1024-bit key) header.d=nic.cz
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 VSm3R9w-_Hmg; Tue, 9 Jan 2018 08:08:25 -0800 (PST)
Received: from mail.nic.cz (mail.nic.cz [217.31.204.67]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by ietfa.amsl.com (Postfix) with ESMTPS id EA2381200C5; Tue, 9 Jan 2018 08:08:24 -0800 (PST)
Received: from birdie (cst-prg-24-76.cust.vodafone.cz [46.135.24.76]) by mail.nic.cz (Postfix) with ESMTPSA id 1EBB363E14; Tue, 9 Jan 2018 17:08:22 +0100 (CET)
DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=nic.cz; s=default; t=1515514102; bh=ly1CH8aeMsyyFOsKAKDcLZj1irekzLP3dExIKhZa0NY=; h=From:To:Date; b=BNpt3mx2RkQGhOzL60punU9Xq+5aIXmNgtaozhvl4w30nkbAM0DPgUQJecIWWK99R o4WrD0eyA2tYQHAEHAwqRFA3HNMDXSNoDXR/tDFGCPveNz1okXQU5JHWAAUVolGGMB oynsK5c1YTlgyC5FVb0I1Q1WEO7k+39Un8pujmr8=
Message-ID: <1515514101.26845.52.camel@nic.cz>
From: Ladislav Lhotka <lhotka@nic.cz>
To: Martin Bjorklund <mbj@tail-f.com>
Cc: acee@cisco.com, yang-doctors@ietf.org, draft-ietf-ospf-yang.all@ietf.org, ietf@ietf.org, ospf@ietf.org
Date: Tue, 09 Jan 2018 17:08:21 +0100
In-Reply-To: <20180109.162311.49506989189385960.mbj@tail-f.com>
References: <1515484295.18448.9.camel@nic.cz> <20180109.090648.1082913423972100343.mbj@tail-f.com> <1515510536.26845.18.camel@nic.cz> <20180109.162311.49506989189385960.mbj@tail-f.com>
Organization: CZ.NIC
Content-Type: text/plain; charset="UTF-8"
X-Mailer: Evolution 3.26.3
Mime-Version: 1.0
Content-Transfer-Encoding: 8bit
X-Virus-Scanned: clamav-milter 0.99.2 at mail
X-Virus-Status: Clean
Archived-At: <https://mailarchive.ietf.org/arch/msg/ospf/D6IsjRwX2UeLHkPaeYxrUHVCiaE>
Subject: Re: [OSPF] [yang-doctors] Yangdoctors last call review of draft-ietf-ospf-yang-09
X-BeenThere: ospf@ietf.org
X-Mailman-Version: 2.1.22
Precedence: list
List-Id: The Official IETF OSPG WG Mailing List <ospf.ietf.org>
List-Unsubscribe: <https://www.ietf.org/mailman/options/ospf>, <mailto:ospf-request@ietf.org?subject=unsubscribe>
List-Archive: <https://mailarchive.ietf.org/arch/browse/ospf/>
List-Post: <mailto:ospf@ietf.org>
List-Help: <mailto:ospf-request@ietf.org?subject=help>
List-Subscribe: <https://www.ietf.org/mailman/listinfo/ospf>, <mailto:ospf-request@ietf.org?subject=subscribe>
X-List-Received-Date: Tue, 09 Jan 2018 16:08:29 -0000

On Tue, 2018-01-09 at 16:23 +0100, Martin Bjorklund wrote:
> Ladislav Lhotka <lhotka@nic.cz> wrote:
> > On Tue, 2018-01-09 at 09:06 +0100, Martin Bjorklund wrote:
> 
> > > Hi,
> 
> > > 
> 
> > > Ladislav Lhotka <lhotka@nic.cz> wrote:
> 
> > > > Hi Acee,
> 
> > > 
> 
> > > > 
> 
> > > 
> 
> > > > please see inline.
> 
> > > 
> 
> > > > 
> 
> > > 
> 
> > > > On Mon, 2018-01-08 at 19:28 +0000, Acee Lindem (acee) wrote:
> 
> > > 
> 
> > > > > Hi Lada,
> 
> > > 
> 
> > > > > 
> 
> > > 
> 
> > > > > Apologies for the delay. We somewhat got hung up on 4 and 6. See
> inline.
> 
> > > 
> 
> > > > > 
> 
> > > 
> 
> > > > > On 12/6/17, 6:26 AM, "Ladislav Lhotka" <lhotka@nic.cz> wrote:
> 
> > > 
> 
> > > > > 
> 
> > > 
> 
> > > > > > Reviewer: Ladislav Lhotka
> 
> > > 
> 
> > > > > > Review result: Ready with Issues
> 
> > > 
> 
> > > > 
> 
> > > 
> 
> > > > ...
> 
> > > 
> 
> > > > 
> 
> > > 
> 
> > > > > > 
> 
> > > 
> 
> > > > > > 3. Maybe the draft could mention that implementations should supply
> a
> 
> > > 
> 
> > > > > >   default routing domain as a system-controlled resource.
> 
> > > 
> 
> > > > > 
> 
> > > 
> 
> > > > > Isn’t this more of an RFC8022BIS statement? I guess we could state
> this as
> 
> > > 
> 
> > > > > an assumption.
> 
> > > 
> 
> > > > 
> 
> > > 
> 
> > > > Probably, but it is not a YANG issue, so I'd leave it to you routing
> folks
> 
> > > to
> 
> > > 
> 
> > > > decide.
> 
> > > 
> 
> > > > 
> 
> > > 
> 
> > > > >  
> 
> > > 
> 
> > > > > 
> 
> > > 
> 
> > > > > > 4. In "when" expressions, the module uses literal strings for
> 
> > > 
> 
> > > > > >   identities. This is known to be problematic, the XPath functions
> 
> > > 
> 
> > > > > >   derived-from() or derived-from-or-self() should be used instead.
> 
> > > 
> 
> > > > > 
> 
> > > 
> 
> > > > > Why is this problematic? Is it because the types can be extended?
> 
> > > 
> 
> > > > 
> 
> > > 
> 
> > > > That's one reason: derived identities should often also satisfy the
> 
> > > constraint.
> 
> > > 
> 
> > > > 
> 
> > > 
> 
> > > > But the more serious problem is that things like
> 
> > > 
> 
> > > > 
> 
> > > 
> 
> > > >     when "../../../../../../../rt:type = 'ospf:ospfv3'"
> 
> > > 
> 
> > > > 
> 
> > > 
> 
> > > > rely on plain string comparison that depends od the actual prefix used
> for
> 
> > > the
> 
> > > 
> 
> > > > "rt:type" value. For one, according to RFC 7951 the JSON encoding of
> this
> 
> > > value
> 
> > > 
> 
> > > > would be "ietf-ospf:ospfv3" so the above expression is always false. 
> 
> > > 
> 
> > > 
> 
> > > This is not correct; the when expression is not evaluated on the JSON
> 
> > > encoding.  See the last paragraph of section 9.10.3 in RFC 7950:
> 
> > > 
> 
> > >    The string value of a node of type "identityref" in a "must" or
> 
> > >    "when" XPath expression is the referred identity's qualified name
> 
> > >    with the prefix present.  If the referred identity is defined in an
> 
> > >    imported module, the prefix in the string value is the prefix defined
> 
> > >    in the corresponding "import" statement.  Otherwise, the prefix in
> 
> > >    the string value is the prefix for the current module.
> 
> > 
> 
> > This is weird, to say the least. The leafref instance may have an identity
> value
> 
> > that is defined in a module that (has to be implemented by the server but)
> 
> > needn't be imported in the module that contains the XPath expression. So I
> don't
> 
> > know what 'corresponding "import" statement' this paragraph is talking
> about.
> 
> 
> It has to import the module in order to give a prefix, which then can
> be used in the XPath expression.

In the XPath expression above, do you mean the "rt" prefix of "rt:type"? If so,
it is irrelevant for the string comparison, what's important is the *value* of
the "rt:type" instance, which can be an identity defined in a module that
needn't be imported by ietf-routing, ietf-ospf or whatever. Sec. 9.10.2:

   On a particular server, the valid values are further restricted to the set of
     identities defined in the modules implemented by the server.

> 
> > Also, potentially there can be a collision in prefixes and then this also
> breaks
> 
> > down.
> 
> 
> No, two modules cannot be imported with the same prefix.

I have to disagree. An identity derived from the "ietf-routing:control-protocol-
type" base identity can be defined in a module that is not imported anywhere. If
a server declares such a module as implemented, then "rt:type" may have this
value per sec. 9.10.2.

And, consequently, there may be two different modules with conflicting prefixes
defining identities that are derived from "ietf-routing:control-protocol-type". 

> 
> > A moral of the namespace/prefix story in XML was that relying of namespace
> 
> > prefixes having a particular value is a really bad idea. I know that the
> cited
> 
> > paragraph was intended to make such XPath string comparisons more
> deterministic,
> 
> > but it is also problematic and should be avoided if possible.
> 
> 
> Note that this prefix is under the control of the module designer
> writing the XPath expression.  The same identityref value might use a

No, it is not. The prefixes appear in instance data.

Lada

> different prefix in some other module.
> 
> 
> /martin
> 
> 
> 
> > 
> 
> > Lada
> 
> > 
> 
> > > 
> 
> > > So the equality test of the identityref is correct.
> 
> > > 
> 
> > > However, I agree that in most cases 'derived-from-or-self' should be
> 
> > > used, in order to handle derived identities.
> 
> > > 
> 
> > > 
> 
> > > /martin
> 
> > -- 
> 
> > Ladislav Lhotka
> 
> > Head, CZ.NIC Labs
> 
> > PGP Key ID: 0xB8F92B08A9F76C67
> 
> > 
> 
-- 
Ladislav Lhotka
Head, CZ.NIC Labs
PGP Key ID: 0xB8F92B08A9F76C67