Re: [netconf] pls clarify get operation

"Rob Wilton (rwilton)" <rwilton@cisco.com> Fri, 28 June 2019 09:33 UTC

Return-Path: <rwilton@cisco.com>
X-Original-To: netconf@ietfa.amsl.com
Delivered-To: netconf@ietfa.amsl.com
Received: from localhost (localhost [127.0.0.1]) by ietfa.amsl.com (Postfix) with ESMTP id 95E381201DA; Fri, 28 Jun 2019 02:33:21 -0700 (PDT)
X-Virus-Scanned: amavisd-new at amsl.com
X-Spam-Flag: NO
X-Spam-Score: -14.499
X-Spam-Level:
X-Spam-Status: No, score=-14.499 tagged_above=-999 required=5 tests=[BAYES_00=-1.9, DKIM_SIGNED=0.1, DKIM_VALID=-0.1, DKIM_VALID_AU=-0.1, HTML_MESSAGE=0.001, RCVD_IN_DNSWL_HI=-5, SPF_PASS=-0.001, URIBL_BLOCKED=0.001, USER_IN_DEF_DKIM_WL=-7.5] autolearn=ham autolearn_force=no
Authentication-Results: ietfa.amsl.com (amavisd-new); dkim=pass (1024-bit key) header.d=cisco.com header.b=G8eznzUt; dkim=pass (1024-bit key) header.d=cisco.onmicrosoft.com header.b=kL6U/Wpw
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 eutR8aehxcst; Fri, 28 Jun 2019 02:33:17 -0700 (PDT)
Received: from rcdn-iport-9.cisco.com (rcdn-iport-9.cisco.com [173.37.86.80]) (using TLSv1.2 with cipher DHE-RSA-SEED-SHA (128/128 bits)) (No client certificate requested) by ietfa.amsl.com (Postfix) with ESMTPS id F31B31201D6; Fri, 28 Jun 2019 02:33:16 -0700 (PDT)
DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=cisco.com; i=@cisco.com; l=126695; q=dns/txt; s=iport; t=1561714396; x=1562923996; h=from:to:cc:subject:date:message-id:references: in-reply-to:mime-version; bh=iHXwXrmECxltKbM5+s2X3k7jDFwVRYvaUZvciyXj364=; b=G8eznzUtjtltKUVUDQPwBNhAQtOPcKywnyteJDO535D/w57Yy1e7KdHt IZCAuVJPmhX7B1AScVqXAS//cybwkI48zf8WPO2kW189uTpIFN+JdZnoy DAtvtkUIiqDOvZDGBXZ6MteDTneRtTbZPolXgxS9jFaddetstvBVmgJ5H Y=;
X-Files: image001.png : 5474
IronPort-PHdr: 9a23:c2lthxEo1Ve02yY0PoVXQZ1GYnJ96bzpIg4Y7IYmgLtSc6Oluo7vJ1Hb+e4z1A3SRYuO7fVChqKWqK3mVWEaqbe5+HEZON0pNVcejNkO2QkpAcqLE0r+eeT1bigmG8JqX15+9Hb9Ok9QS47z
X-IronPort-Anti-Spam-Filtered: true
X-IronPort-Anti-Spam-Result: A0AJAACO3hVd/40NJK1mGQEBAQEBAQEBAQEBAQcBAQEBAQGBVAMBAQEBAQsBgRQvKScDalUgBAsoCoQSg0cDjluCW36WRoEuFIEQA1QCBwEBAQkBAgEBIwoCAQGEQAIXgmkjNQgOAQMBAQQBAQIBBW2KNwyFSgEBAQQFDQgJAggBEgEBNwEPAgEGAhEBAwEBBgEBARgBBgMCAgIFEAEODBQDBggCBAENBAEGAgYUW4ImgWoDHQECDIsBkGACgTiIYHGBMoJ5AQEFhQwYggoHCYE0AYpAgR4XgUA/JmtGghc1PoJhAQECAYErAQsHASEDAw8ICAYJCIJMMoImi3SBJ4FEhHsjZ4dPhHeCSYVObAkCghaFRwGBC41AgiuHGI4ejA2BIIc4jByDSwIEAgQFAg4BAQWBUgE1Z3FwFTuCbAmCOIEmAQKCSIUUhT9yAYEojDQPF4ELAYEgAQE
X-IronPort-AV: E=Sophos;i="5.63,427,1557187200"; d="png'150?scan'150,208,217,150";a="497595945"
Received: from alln-core-8.cisco.com ([173.36.13.141]) by rcdn-iport-9.cisco.com with ESMTP/TLS/DHE-RSA-SEED-SHA; 28 Jun 2019 09:32:52 +0000
Received: from XCH-ALN-002.cisco.com (xch-aln-002.cisco.com [173.36.7.12]) by alln-core-8.cisco.com (8.15.2/8.15.2) with ESMTPS id x5S9WqqF018862 (version=TLSv1.2 cipher=AES256-SHA bits=256 verify=FAIL); Fri, 28 Jun 2019 09:32:52 GMT
Received: from xhs-rtp-001.cisco.com (64.101.210.228) by XCH-ALN-002.cisco.com (173.36.7.12) with Microsoft SMTP Server (TLS) id 15.0.1473.3; Fri, 28 Jun 2019 04:32:51 -0500
Received: from xhs-rtp-002.cisco.com (64.101.210.229) by xhs-rtp-001.cisco.com (64.101.210.228) with Microsoft SMTP Server (TLS) id 15.0.1473.3; Fri, 28 Jun 2019 05:32:50 -0400
Received: from NAM03-BY2-obe.outbound.protection.outlook.com (64.101.32.56) by xhs-rtp-002.cisco.com (64.101.210.229) with Microsoft SMTP Server (TLS) id 15.0.1473.3 via Frontend Transport; Fri, 28 Jun 2019 05:32:50 -0400
DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=cisco.onmicrosoft.com; s=selector2-cisco-onmicrosoft-com; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=u6iM+R3qA+h6sGOy+PoKRehhohpQPDWuUlimH5fvdjM=; b=kL6U/Wpw3NnzCd8zcDqeX5GH1/9+3kYQiGqZPMITQ2VzlIne+jgYD2+OS7klA0mWZYF94EGWreOcs5DQ0QA1SWM21FzaB42/XfZwWqZWJmlZKdNBN0z1eialsaXH/A8FCJ1S9lDEWj4wXrK8IfR8wF16RIX0u5Wnb1+nfNDnlc8=
Received: from BYAPR11MB2631.namprd11.prod.outlook.com (52.135.227.28) by BYAPR11MB3846.namprd11.prod.outlook.com (20.178.239.206) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.2032.17; Fri, 28 Jun 2019 09:32:48 +0000
Received: from BYAPR11MB2631.namprd11.prod.outlook.com ([fe80::ed99:b6a8:d6fb:5045]) by BYAPR11MB2631.namprd11.prod.outlook.com ([fe80::ed99:b6a8:d6fb:5045%4]) with mapi id 15.20.2008.018; Fri, 28 Jun 2019 09:32:48 +0000
From: "Rob Wilton (rwilton)" <rwilton@cisco.com>
To: "Fengchong (frank)" <frank.fengchong@huawei.com>, "netconf@ietf.org" <netconf@ietf.org>, "netmod@ietf.org" <netmod@ietf.org>
CC: "Zhangwei (SS)" <zhangwei70@huawei.com>
Thread-Topic: pls clarify get operation
Thread-Index: AdUsiu4JIzTUBFYNTIGSUYTtxnFLqwA1gt7QAApPi5AAAM+k8AAAh5VQAACDk+AAADh4IA==
Date: Fri, 28 Jun 2019 09:32:48 +0000
Message-ID: <BYAPR11MB263113F9F216878D63A0896DB5FC0@BYAPR11MB2631.namprd11.prod.outlook.com>
References: <5756FB984666AD4BB8E1D63E2E3AA3D001ED5E20@dggemm513-mbx.china.huawei.com> <BYAPR11MB2631D3A01E398ADDBB294588B5FC0@BYAPR11MB2631.namprd11.prod.outlook.com> <5756FB984666AD4BB8E1D63E2E3AA3D001ED6060@dggemm513-mbx.china.huawei.com> <BYAPR11MB2631E697964372E2051C671AB5FC0@BYAPR11MB2631.namprd11.prod.outlook.com> <5756FB984666AD4BB8E1D63E2E3AA3D001ED60B5@dggemm513-mbx.china.huawei.com>
In-Reply-To: <5756FB984666AD4BB8E1D63E2E3AA3D001ED60B5@dggemm513-mbx.china.huawei.com>
Accept-Language: en-US
Content-Language: en-US
X-MS-Has-Attach: yes
X-MS-TNEF-Correlator:
authentication-results: spf=none (sender IP is ) smtp.mailfrom=rwilton@cisco.com;
x-originating-ip: [173.38.220.34]
x-ms-publictraffictype: Email
x-ms-office365-filtering-correlation-id: de101ca5-22ed-48b5-6f73-08d6fbab955a
x-microsoft-antispam: BCL:0; PCL:0; RULEID:(2390118)(7020095)(4652040)(8989299)(4534185)(4627221)(201703031133081)(201702281549075)(8990200)(5600148)(711020)(4605104)(1401327)(2017052603328)(49563074)(7193020); SRVR:BYAPR11MB3846;
x-ms-traffictypediagnostic: BYAPR11MB3846:
x-ms-exchange-purlcount: 4
x-microsoft-antispam-prvs: <BYAPR11MB38469F062DE80E6F3CC2DD2AB5FC0@BYAPR11MB3846.namprd11.prod.outlook.com>
x-ms-oob-tlc-oobclassifiers: OLM:7219;
x-forefront-prvs: 00826B6158
x-forefront-antispam-report: SFV:NSPM; SFS:(10009020)(4636009)(39860400002)(366004)(346002)(136003)(376002)(396003)(199004)(189003)(51444003)(53754006)(52536014)(66946007)(7116003)(73956011)(6246003)(256004)(14444005)(5024004)(64756008)(66446008)(236005)(54896002)(54556002)(9686003)(733005)(66616009)(76116006)(66476007)(66556008)(110136005)(74316002)(33656002)(316002)(30864003)(6116002)(790700001)(3846002)(2201001)(6306002)(2906002)(86362001)(6436002)(71190400001)(71200400001)(4326008)(53386004)(3480700005)(76176011)(99936001)(14454004)(486006)(53546011)(6506007)(26005)(446003)(66066001)(476003)(11346002)(25786009)(5660300002)(99286004)(186003)(102836004)(478600001)(7696005)(2501003)(7736002)(9326002)(53936002)(55016002)(68736007)(8676002)(81156014)(8936002)(81166006)(229853002)(53946003)(606006)(569006); DIR:OUT; SFP:1101; SCL:1; SRVR:BYAPR11MB3846; H:BYAPR11MB2631.namprd11.prod.outlook.com; FPR:; SPF:None; LANG:en; PTR:InfoNoRecords; A:1; MX:1;
received-spf: None (protection.outlook.com: cisco.com does not designate permitted sender hosts)
x-ms-exchange-senderadcheck: 1
x-microsoft-antispam-message-info: U/DfSB7wYnwCUn5HOpEkZKSzDMLuk06Jxi+JZlioYuXJjk5OsD3VmGmWJKtYTabLu/aBCYS44U7p6Hqm+ZGXYbkjtJL6YzI8SQLTPSQQtfl3rPgjP5rqNI53aqV7keVu3aaCfsLQ+n7n3tJklydiatm63oiBkuCE/SIlvBDLLhVWhyFHayhF4x68E5pyAvKVJQPtQ/hQxSQlK+eenemJ2s+gauKH0BvconBWJ/agA7cLNvk5xdL7a77NTtW2/AiaDlSau9OC12dKYdqRMqUs0E2Cn3nX6mPOxOkqQ/6HztMJKL2eldTANkKfzUqOGFhvSwOv6TDgkP46VqVUgK+S7kko0BQOwXc7Bd6R8O5YLRQLCAQfxOEOV9fMxPSPnCaV9h3cNEHIb5RCbfb03BbZTAYjlgpc8E/WuFGEAAwjsWU=
Content-Type: multipart/related; boundary="_004_BYAPR11MB263113F9F216878D63A0896DB5FC0BYAPR11MB2631namp_"; type="multipart/alternative"
MIME-Version: 1.0
X-MS-Exchange-CrossTenant-Network-Message-Id: de101ca5-22ed-48b5-6f73-08d6fbab955a
X-MS-Exchange-CrossTenant-originalarrivaltime: 28 Jun 2019 09:32:48.1306 (UTC)
X-MS-Exchange-CrossTenant-fromentityheader: Hosted
X-MS-Exchange-CrossTenant-id: 5ae1af62-9505-4097-a69a-c1553ef7840e
X-MS-Exchange-CrossTenant-mailboxtype: HOSTED
X-MS-Exchange-CrossTenant-userprincipalname: rwilton@cisco.com
X-MS-Exchange-Transport-CrossTenantHeadersStamped: BYAPR11MB3846
X-OriginatorOrg: cisco.com
X-Outbound-SMTP-Client: 173.36.7.12, xch-aln-002.cisco.com
X-Outbound-Node: alln-core-8.cisco.com
Archived-At: <https://mailarchive.ietf.org/arch/msg/netconf/1YCtRl2st_AvBt-RNMqEK3dey2M>
Subject: Re: [netconf] pls clarify get operation
X-BeenThere: netconf@ietf.org
X-Mailman-Version: 2.1.29
Precedence: list
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: Fri, 28 Jun 2019 09:33:22 -0000

Hi Frank,

The IETF YANG models are designed to work with implementations that support NMDA.

They can be used with pre NMDA implementations, but as you say some data cannot be returned.  As per my previous reply, the mitigation here, if required, is to use the NMDA YANG module as input to a conversion process that generates the additional duplicate state tree.  This is fairly easy to generate (either by hand or via tooling).  IIRC, some RFCs have published the additional state trees in the appendix, where they thought that this might be useful.

But fundamentally, the idea of mixing <running configuration> + operational state into a single combined dataset is flawed:

  1.  <running> represents the desired configuration state that the operator would like the device to be in.
  2.  Operational state represents the currently applied configuration and additional state for what the device is currently doing.



These two datasets are temporally distinct.  E.g. how do you return data for an interface that currently exists in the system but has been deleted in the configuration.  Any way that you try and combine these two datasets you will end up with inconsistencies and corner case bugs and warts.



Once they are treated as separate data sets, the architecture becomes much simpler, cleaner, and more consistent:

  *   <running> can ALWAYS represent the configuration input into the device.
  *   <operational> can ALWAYS represent the current operational state of the device.

Clients can use whatever mechanism they which is compare or combine these two datasets depending on their requirements and the sophistication of the management system.

Thanks,
Rob


From: Fengchong (frank) <frank.fengchong@huawei.com>
Sent: 28 June 2019 10:18
To: Rob Wilton (rwilton) <rwilton@cisco.com>; netconf@ietf.org; netmod@ietf.org
Cc: Zhangwei (SS) <zhangwei70@huawei.com>
Subject: 答复: pls clarify get operation

Hi Rob,
If we write a new NMDA-style YANG module,  this YANG module seems can’t be supported well in non-NMDA device(because no system-controlled data can be retrieved).
I think this thing will cause a lot of trouble to the implementation of the IETF models.
________________________________
华为技术有限公司 Huawei Technologies Co., Ltd.
[Company_logo]
个人签名:冯冲
手  机:13776612983
电子邮件:frank.fengchong@huawei.com<mailto:frank.fengchong@huawei.com>
公司网址:www.huawei.com<http://www.huawei.com>
________________________________
 本邮件及其附件含有华为公司的保密信息,仅限于发送给上面地址中列出的个人或群组。禁
止任何其他人以任何形式使用(包括但不限于全部或部分地泄露、复制、或散发)本邮件中
的信息。如果您错收了本邮件,请您立即电话或邮件通知发件人并删除本邮件!
This e-mail and its attachments contain confidential information from HUAWEI, which
is intended only for the person or entity whose address is listed above. Any use of the
information contained herein in any way (including, but not limited to, total or partial
disclosure, reproduction, or dissemination) by persons other than the intended
recipient(s) is prohibited. If you receive this e-mail in error, please notify the sender by
phone or email immediately and delete it!

发件人: Rob Wilton (rwilton) [mailto:rwilton@cisco.com]
发送时间: 2019年6月28日 17:10
收件人: Fengchong (frank) <frank.fengchong@huawei.com<mailto:frank.fengchong@huawei.com>>; netconf@ietf.org<mailto:netconf@ietf.org>; netmod@ietf.org<mailto:netmod@ietf.org>
抄送: Zhangwei (SS) <zhangwei70@huawei.com<mailto:zhangwei70@huawei.com>>
主题: RE: pls clarify get operation

Hi Frank,

NMDA does not change the semantics of the <get> operation at all: I.e. the operation returns the contents of the <running> datastore combined with all the operational state as well.

Going outside the standards there are probably 2 pragmatic choices:
(1)   Implement <get> as above (but may be expensive to implement for a new device).
(2)   Don’t support the <get> operation at all, requiring users to use the <get-data> equivalent instead.  This was the informal long term plan, i.e. <get> will probably eventually be deprecated.

Regarding your last question, yes, you are right that it cannot return system-controlled data.  One option here is to use the NMDA YANG module as input to a conversion process that generates old IETF style YANG models with split config/state trees (i.e. like RFC 7223).

Thanks,
Rob


From: Fengchong (frank) <frank.fengchong@huawei.com<mailto:frank.fengchong@huawei.com>>
Sent: 28 June 2019 09:55
To: Rob Wilton (rwilton) <rwilton@cisco.com<mailto:rwilton@cisco.com>>; netconf@ietf.org<mailto:netconf@ietf.org>; netmod@ietf.org<mailto:netmod@ietf.org>
Cc: Zhangwei (SS) <zhangwei70@huawei.com<mailto:zhangwei70@huawei.com>>
Subject: 答复: pls clarify get operation

Hi Rob,
Thanks for your explanation.
You mean get operation only  report running configuration and state nodes in non-NMDA scenario.
But if in NMDA scenario, what would be reported when we use the same get operation  to retrieve information? The same with non-NMDA or report all configuration including user-controlled and  system-controlled?


Another question:
If we write a NMDA-style YANG module without config false copy, when we implement this YANG in non-NMDA device, perhaps we have no way to get the information of system-controlled data.

________________________________
华为技术有限公司 Huawei Technologies Co., Ltd.
[Company_logo]
个人签名:冯冲
手  机:13776612983
电子邮件:frank.fengchong@huawei.com<mailto:frank.fengchong@huawei.com>
公司网址:www.huawei.com<http://www.huawei.com>
________________________________
 本邮件及其附件含有华为公司的保密信息,仅限于发送给上面地址中列出的个人或群组。禁
止任何其他人以任何形式使用(包括但不限于全部或部分地泄露、复制、或散发)本邮件中
的信息。如果您错收了本邮件,请您立即电话或邮件通知发件人并删除本邮件!
This e-mail and its attachments contain confidential information from HUAWEI, which
is intended only for the person or entity whose address is listed above. Any use of the
information contained herein in any way (including, but not limited to, total or partial
disclosure, reproduction, or dissemination) by persons other than the intended
recipient(s) is prohibited. If you receive this e-mail in error, please notify the sender by
phone or email immediately and delete it!

发件人: Rob Wilton (rwilton) [mailto:rwilton@cisco.com]
发送时间: 2019年6月28日 16:39
收件人: Fengchong (frank) <frank.fengchong@huawei.com<mailto:frank.fengchong@huawei.com>>; netconf@ietf.org<mailto:netconf@ietf.org>; netmod@ietf.org<mailto:netmod@ietf.org>
抄送: Zhangwei (SS) <zhangwei70@huawei.com<mailto:zhangwei70@huawei.com>>
主题: RE: pls clarify get operation

Hi Frank,

Pre NMDA:
-        You have a the <running> datastore, along with some others like <candidate> and <startup> that you can ignore for the purposes of this discussion.
-        The <running> datastore can only contains data for schema nodes that are marked as “config true” in YANG (i.e. “rw” in your tree output below).
-        The system may also have some operational state data that is marked as “config false” in YANG (i.e. “ro” in your tree output below).

The NETCONF <get-config> operation returns the contents of the <running> datastore.
The NETCONF <get> operation returns the contents of the <running> datastore combined with all the operational state as well.  Filters can be applied to return a subset of the data.

Regarding your question about user created configuration vs system created configuration, it depends on whether the devices instantiates the configuration in <running> or not.  If it does, then it would be returned in <get> and <get-config> operations.  If it doesn’t then it would not.  Different vendors/devices will likely implement this in different ways.

Generally, I think that <running> should only contain the configuration explicitly configured by the operator’s systems.  But this means that there isn’t a clean way to represent system created configuration or applied configuration, unless you make a config false copy of every config true node in YANG.  This is approach that was taken by the original IETF YANG models (e.g. RFC 7223) before they were superseded by NMDA, and also the OpenConfig YANG models (but using a different structure – which also struggles to cleanly represent system created configuration data).

The NMDA architecture was written to solve this problem in a clean way without requiring duplication in the YANG data models.

Hopefully this helps clarify.

Thanks,
Rob


From: netmod <netmod-bounces@ietf.org<mailto:netmod-bounces@ietf.org>> On Behalf Of Fengchong (frank)
Sent: 28 June 2019 04:29
To: netconf@ietf.org<mailto:netconf@ietf.org>; netmod@ietf.org<mailto:netmod@ietf.org>
Cc: Zhangwei (SS) <zhangwei70@huawei.com<mailto:zhangwei70@huawei.com>>
Subject: [netmod] 答复: pls clarify get operation

Hi all,

     Pls clarify this question. I have been confused for a long time.

________________________________
华为技术有限公司 Huawei Technologies Co., Ltd.
[Company_logo]
个人签名:冯冲
手  机:13776612983
电子邮件:frank.fengchong@huawei.com<mailto:frank.fengchong@huawei.com>
公司网址:www.huawei.com<http://www.huawei.com>
________________________________
 本邮件及其附件含有华为公司的保密信息,仅限于发送给上面地址中列出的个人或群组。禁
止任何其他人以任何形式使用(包括但不限于全部或部分地泄露、复制、或散发)本邮件中
的信息。如果您错收了本邮件,请您立即电话或邮件通知发件人并删除本邮件!
This e-mail and its attachments contain confidential information from HUAWEI, which
is intended only for the person or entity whose address is listed above. Any use of the
information contained herein in any way (including, but not limited to, total or partial
disclosure, reproduction, or dissemination) by persons other than the intended
recipient(s) is prohibited. If you receive this e-mail in error, please notify the sender by
phone or email immediately and delete it!

发件人: Fengchong (frank)
发送时间: 2019年6月27日 9:59
收件人: 'netconf@ietf.org' <netconf@ietf.org<mailto:netconf@ietf.org>>; netmod@ietf.org<mailto:netmod@ietf.org>
抄送: Yangshouchuan <yangshouchuan@huawei.com<mailto:yangshouchuan@huawei.com>>; Zhangwei (SS) <zhangwei70@huawei.com<mailto:zhangwei70@huawei.com>>
主题: pls clarify get operation

Hi all,
In RFC6241, get operation is defined as:
7.7<https://tools.ietf.org/html/rfc6241#section-7.7>.  <get>

   Description:  Retrieve running configuration and device state

      information.
This description is too simply, so I think it should be clarified.

The case is: a data node modelled by one yang can be configured by user, but also can be created/modified by system or other protocols. If client issues get operation to retrieve this node,
          The data is created/modified by system or other protocols SHOULD be returned?
          For example:
          Rib can be configured by user and also can be created by routing protocols. In RFC 8349, the rib list is defined as:



      +--rw ribs

         +--rw rib* [name]

            +--rw name              string

            +--rw address-family?   identityref

            +--ro default-rib?      boolean {multiple-ribs}?

            +--ro routes

            |  +--ro route*

            |        ...

            +---x active-route

            |  +---w input

            |  |  +---w v4ur:destination-address?   inet:ipv4-address

            |  |  +---w v6ur:destination-address?   inet:ipv6-address

            |  +--ro output

            |        ...

            +--rw description?      string



       If client issued get operation to retrieve ribs from non-NMDA device, rib instance created by routing protocols should be returned?

       Another associated question: If client issued get-config operation from non-NMDA device, only user-controlled rib instance should be returned?