rfc8795xml2.original.xml | rfc8795.xml | |||
---|---|---|---|---|
<?xml version='1.0' encoding='utf-8'?> | <?xml version='1.0' encoding='utf-8'?> | |||
<!DOCTYPE rfc SYSTEM "rfc2629.dtd" [ | <!DOCTYPE rfc SYSTEM "rfc2629-xhtml.ent"> | |||
<!ENTITY RFC2119 SYSTEM "https://xml2rfc.ietf.org/public/rfc/bibxml/reference.RF | ||||
C.2119.xml"> | ||||
<!ENTITY RFC3688 SYSTEM "https://xml2rfc.ietf.org/public/rfc/bibxml/reference.RF | ||||
C.3688.xml"> | ||||
<!ENTITY RFC3945 SYSTEM "https://xml2rfc.ietf.org/public/rfc/bibxml/reference.RF | ||||
C.3945.xml"> | ||||
<!ENTITY RFC6241 SYSTEM "https://xml2rfc.ietf.org/public/rfc/bibxml/reference.RF | ||||
C.6241.xml"> | ||||
<!ENTITY RFC6242 SYSTEM "https://xml2rfc.ietf.org/public/rfc/bibxml/reference.RF | ||||
C.6242.xml"> | ||||
<!ENTITY RFC6991 SYSTEM "https://xml2rfc.ietf.org/public/rfc/bibxml/reference.RF | ||||
C.6991.xml"> | ||||
<!ENTITY RFC7926 SYSTEM "https://xml2rfc.ietf.org/public/rfc/bibxml/reference.RF | ||||
C.7926.xml"> | ||||
<!ENTITY RFC7950 SYSTEM "https://xml2rfc.ietf.org/public/rfc/bibxml/reference.RF | ||||
C.7950.xml"> | ||||
<!ENTITY RFC8040 SYSTEM "https://xml2rfc.ietf.org/public/rfc/bibxml/reference.RF | ||||
C.8040.xml"> | ||||
<!ENTITY RFC8174 SYSTEM "https://xml2rfc.ietf.org/public/rfc/bibxml/reference.RF | ||||
C.8174.xml"> | ||||
<!ENTITY RFC8341 SYSTEM "https://xml2rfc.ietf.org/public/rfc/bibxml/reference.RF | ||||
C.8341.xml"> | ||||
<!ENTITY RFC8342 SYSTEM "https://xml2rfc.ietf.org/public/rfc/bibxml/reference.RF | ||||
C.8342.xml"> | ||||
<!ENTITY RFC8345 SYSTEM "https://xml2rfc.ietf.org/public/rfc/bibxml/reference.RF | ||||
C.8345.xml"> | ||||
<!ENTITY RFC8446 SYSTEM "https://xml2rfc.ietf.org/public/rfc/bibxml/reference.RF | ||||
C.8446.xml"> | ||||
<!ENTITY I-D.ietf-teas-yang-te-types SYSTEM "https://xml2rfc.ietf.org/public/rfc | ||||
/bibxml3/reference.I-D.draft-ietf-teas-yang-te-types-08.xml"> | ||||
<!ENTITY RFC1195 SYSTEM "https://xml2rfc.ietf.org/public/rfc/bibxml/reference.RF | ||||
C.1195.xml"> | ||||
<!ENTITY RFC2702 SYSTEM "https://xml2rfc.ietf.org/public/rfc/bibxml/reference.RF | ||||
C.2702.xml"> | ||||
<!ENTITY RFC3209 SYSTEM "https://xml2rfc.ietf.org/public/rfc/bibxml/reference.RF | ||||
C.3209.xml"> | ||||
<!ENTITY RFC3272 SYSTEM "https://xml2rfc.ietf.org/public/rfc/bibxml/reference.RF | ||||
C.3272.xml"> | ||||
<!ENTITY RFC3471 SYSTEM "https://xml2rfc.ietf.org/public/rfc/bibxml/reference.RF | ||||
C.3471.xml"> | ||||
<!ENTITY RFC3630 SYSTEM "https://xml2rfc.ietf.org/public/rfc/bibxml/reference.RF | ||||
C.3630.xml"> | ||||
<!ENTITY RFC3785 SYSTEM "https://xml2rfc.ietf.org/public/rfc/bibxml/reference.RF | ||||
C.3785.xml"> | ||||
<!ENTITY RFC4201 SYSTEM "https://xml2rfc.ietf.org/public/rfc/bibxml/reference.RF | ||||
C.4201.xml"> | ||||
<!ENTITY RFC4202 SYSTEM "https://xml2rfc.ietf.org/public/rfc/bibxml/reference.RF | ||||
C.4202.xml"> | ||||
<!ENTITY RFC4203 SYSTEM "https://xml2rfc.ietf.org/public/rfc/bibxml/reference.RF | ||||
C.4203.xml"> | ||||
<!ENTITY RFC4206 SYSTEM "https://xml2rfc.ietf.org/public/rfc/bibxml/reference.RF | ||||
C.4206.xml"> | ||||
<!ENTITY RFC4872 SYSTEM "https://xml2rfc.ietf.org/public/rfc/bibxml/reference.RF | ||||
C.4872.xml"> | ||||
<!ENTITY RFC5152 SYSTEM "https://xml2rfc.ietf.org/public/rfc/bibxml/reference.RF | ||||
C.5152.xml"> | ||||
<!ENTITY RFC5212 SYSTEM "https://xml2rfc.ietf.org/public/rfc/bibxml/reference.RF | ||||
C.5212.xml"> | ||||
<!ENTITY RFC5305 SYSTEM "https://xml2rfc.ietf.org/public/rfc/bibxml/reference.RF | ||||
C.5305.xml"> | ||||
<!ENTITY RFC5316 SYSTEM "https://xml2rfc.ietf.org/public/rfc/bibxml/reference.RF | ||||
C.5316.xml"> | ||||
<!ENTITY RFC5329 SYSTEM "https://xml2rfc.ietf.org/public/rfc/bibxml/reference.RF | ||||
C.5329.xml"> | ||||
<!ENTITY RFC5392 SYSTEM "https://xml2rfc.ietf.org/public/rfc/bibxml/reference.RF | ||||
C.5392.xml"> | ||||
<!ENTITY RFC6001 SYSTEM "https://xml2rfc.ietf.org/public/rfc/bibxml/reference.RF | ||||
C.6001.xml"> | ||||
<!ENTITY RFC7308 SYSTEM "https://xml2rfc.ietf.org/public/rfc/bibxml/reference.RF | ||||
C.7308.xml"> | ||||
<!ENTITY RFC7471 SYSTEM "https://xml2rfc.ietf.org/public/rfc/bibxml/reference.RF | ||||
C.7471.xml"> | ||||
<!ENTITY RFC7579 SYSTEM "https://xml2rfc.ietf.org/public/rfc/bibxml/reference.RF | ||||
C.7579.xml"> | ||||
<!ENTITY RFC7752 SYSTEM "https://xml2rfc.ietf.org/public/rfc/bibxml/reference.RF | ||||
C.7752.xml"> | ||||
<!ENTITY RFC8340 SYSTEM "https://xml2rfc.ietf.org/public/rfc/bibxml/reference.RF | ||||
C.8340.xml"> | ||||
<!ENTITY I-D.ietf-netconf-subscribed-notifications SYSTEM "https://xml2rfc.ietf. | ||||
org/public/rfc/bibxml3/reference.I-D.draft-ietf-netconf-subscribed-notifications | ||||
-23.xml"> | ||||
<!ENTITY I-D.ietf-netconf-yang-push SYSTEM "https://xml2rfc.ietf.org/public/rfc/ | ||||
bibxml3/reference.I-D.draft-ietf-netconf-yang-push-22.xml"> | ||||
<!ENTITY I-D.liu-netmod-yang-schedule SYSTEM "https://xml2rfc.ietf.org/public/rf | ||||
c/bibxml3/reference.I-D.draft-liu-netmod-yang-schedule-05.xml"> | ||||
<!ENTITY I-D.ietf-ccamp-wson-yang SYSTEM "https://xml2rfc.ietf.org/public/rfc/bi | ||||
bxml3/reference.I-D.draft-ietf-ccamp-wson-yang-20.xml"> | ||||
<!ENTITY I-D.ietf-ccamp-otn-topo-yang SYSTEM "https://xml2rfc.ietf.org/public/rf | ||||
c/bibxml3/reference.I-D.draft-ietf-ccamp-otn-topo-yang-06.xml"> | ||||
<!ENTITY I-D.ietf-teas-yang-l3-te-topo SYSTEM "https://xml2rfc.ietf.org/public/r | ||||
fc/bibxml3/reference.I-D.draft-ietf-teas-yang-l3-te-topo-04.xml"> | ||||
<!ENTITY I-D.ietf-teas-te-topo-and-tunnel-modeling SYSTEM "https://xml2rfc.ietf. | ||||
org/public/rfc/bibxml3/reference.I-D.draft-ietf-teas-te-topo-and-tunnel-modeling | ||||
-03.xml"> | ||||
]> | ||||
<rfc submissionType="IETF" docName="draft-ietf-teas-yang-te-topo-22" category="s | ||||
td" ipr="trust200902"> | ||||
<!-- Generated by id2xml 1.5.0 on 2019-12-18T20:08:29Z --> | ||||
<?rfc compact="yes"?> | ||||
<?rfc text-list-symbols="-o*+"?> | ||||
<?rfc subcompact="no"?> | ||||
<?rfc sortrefs="yes"?> | ||||
<?rfc symrefs="yes"?> | ||||
<?rfc strict="yes"?> | ||||
<?rfc toc="yes"?> | ||||
<front> | ||||
<title abbrev="YANG - TE Topology">YANG Data Model for Traffic Engineerin | ||||
g (TE) Topologies</title> | ||||
<author fullname="Xufeng Liu" initials="X." surname="Liu"> | ||||
<organization>Volta Networks</organization> | ||||
<address><email>xufeng.liu.ietf@gmail.com</email> | ||||
</address> | ||||
</author> | ||||
<author fullname="Igor Bryskin" initials="I." surname="Bryskin"> | ||||
<organization>Huawei Technologies</organization> | ||||
<address><email>Igor.Bryskin@huawei.com</email> | ||||
</address> | ||||
</author> | ||||
<author fullname="Vishnu Pavan Beeram" initials="V." surname="Beeram"> | ||||
<organization>Juniper Networks</organization> | ||||
<address><email>vbeeram@juniper.net</email> | ||||
</address> | ||||
</author> | ||||
<author fullname="Tarek Saad" initials="T." surname="Saad"> | ||||
<organization>Juniper Networks</organization> | ||||
<address><email>tsaad@juniper.net</email> | ||||
</address> | ||||
</author> | ||||
<author fullname="Himanshu Shah" initials="H." surname="Shah"> | ||||
<organization>Ciena</organization> | ||||
<address><email>hshah@ciena.com</email> | ||||
</address> | ||||
</author> | ||||
<author fullname="Oscar Gonzalez De Dios" initials="O." surname="Gonzalez | <rfc xmlns:xi="http://www.w3.org/2001/XInclude" submissionType="IETF" | |||
De Dios"> | consensus="true" docName="draft-ietf-teas-yang-te-topo-22" number="8795" | |||
<organization>Telefonica</organization> | category="std" ipr="trust200902" obsoletes="" updates="" xml:lang="en" | |||
<address><email>oscar.gonzalezdedios@telefonica.com</email> | sortRefs="true" symRefs="true" tocInclude="true" version="3"> | |||
</address> | ||||
</author> | ||||
<date month="January" year="2020"/> | <!-- xml2rfc v2v3 conversion 2.38.1 --> | |||
<workgroup>TEAS Working Group</workgroup> | <!-- Generated by id2xml 1.5.0 on 2019-12-18T20:08:29Z --> | |||
<front> | ||||
<title abbrev="YANG - TE Topologies">YANG Data Model for Traffic Engineering | ||||
(TE) Topologies</title> | ||||
<!-- [rfced] Please insert any keywords (beyond those that appear inthe title) f | <seriesInfo name="RFC" value="8795"/> | |||
or use on https://www.rfc-editor.org/search. --> | <author fullname="Xufeng Liu" initials="X." surname="Liu"> | |||
<organization>Volta Networks</organization> | ||||
<address> | ||||
<email>xufeng.liu.ietf@gmail.com</email> | ||||
</address> | ||||
</author> | ||||
<author fullname="Igor Bryskin" initials="I." surname="Bryskin"> | ||||
<organization>Futurewei Technologies, Inc.</organization> | ||||
<address> | ||||
<email>i_bryskin@yahoo.com</email> | ||||
</address> | ||||
</author> | ||||
<author fullname="Vishnu Pavan Beeram" initials="V." surname="Beeram"> | ||||
<organization>Juniper Networks</organization> | ||||
<address> | ||||
<email>vbeeram@juniper.net</email> | ||||
</address> | ||||
</author> | ||||
<author fullname="Tarek Saad" initials="T." surname="Saad"> | ||||
<organization>Juniper Networks</organization> | ||||
<address> | ||||
<email>tsaad@juniper.net</email> | ||||
</address> | ||||
</author> | ||||
<author fullname="Himanshu Shah" initials="H." surname="Shah"> | ||||
<organization>Ciena</organization> | ||||
<address> | ||||
<email>hshah@ciena.com</email> | ||||
</address> | ||||
</author> | ||||
<author fullname="Oscar Gonzalez de Dios" initials="O." surname="Gonzalez de | ||||
Dios"> | ||||
<organization>Telefonica</organization> | ||||
<address> | ||||
<email>oscar.gonzalezdedios@telefonica.com</email> | ||||
</address> | ||||
</author> | ||||
<date month="July" year="2020"/> | ||||
<workgroup>TEAS Working Group</workgroup> | ||||
<keyword>example</keyword> | <keyword>TE topology</keyword> | |||
<keyword>TE topology YANG model</keyword> | ||||
<keyword>Abstract TE topology</keyword> | ||||
<keyword>Native TE topology</keyword> | ||||
<keyword>Customized TE topology</keyword> | ||||
<keyword>Underlay TE topology</keyword> | ||||
<keyword>Overlay TE topology</keyword> | ||||
<abstract><t> | <abstract> | |||
This document defines a YANG data model for representing, retrieving | <t> | |||
This document defines a YANG data model for representing, retrieving, | ||||
and manipulating Traffic Engineering (TE) Topologies. The model | and manipulating Traffic Engineering (TE) Topologies. The model | |||
serves as a base model that other technology specific TE Topology | serves as a base model that other technology-specific TE topology | |||
models can augment.</t> | models can augment.</t> | |||
</abstract> | ||||
</abstract> | </front> | |||
</front> | <middle> | |||
<section anchor="sect-1" numbered="true" toc="default"> | ||||
<middle> | <name>Introduction</name> | |||
<section title="Introduction" anchor="sect-1"><t> | <t> | |||
The Traffic Engineering Database (TED) is an essential component of | The Traffic Engineering Database (TED) is an essential component of | |||
Traffic Engineered (TE) systems that are based on MPLS-TE <xref target="RFC27 | Traffic Engineered (TE) systems that are based on MPLS-TE <xref target="RFC27 | |||
02"/> | 02" format="default"/> | |||
and GMPLS <xref target="RFC3945"/>. The TED is a collection of all TE informa | and GMPLS <xref target="RFC3945" format="default"/>. The TED is a collection | |||
tion | of all TE information | |||
about all TE nodes and TE links in the network. The TE Topology is a | about all TE nodes and TE links in the network. The TE topology is a | |||
schematic arrangement of TE nodes and TE links present in a given | schematic arrangement of TE nodes and TE links present in a given | |||
TED. There could be one or more TE Topologies present in a given | TED. There could be one or more TE topologies present in a given | |||
Traffic Engineered system. A TE Topology is the topology on which | TE system. A TE topology is the topology on which | |||
path computational algorithms are run to compute Traffic Engineered | path computational algorithms are run to compute TE paths.</t> | |||
Paths (TE Paths).</t> | <t> | |||
This document defines a YANG data model <xref target="RFC7950" | ||||
<t> | format="default"/> for representing, retrieving, | |||
This document defines a YANG <xref target="RFC7950"/> data model for represen | and manipulating TE topologies. This model contains technology-agnostic TE to | |||
ting | pology building blocks that can be augmented and used | |||
and manipulating TE Topologies. This model contains technology | by other technology-specific TE topology models.</t> | |||
agnostic TE Topology building blocks that can be augmented and used | <section anchor="sect-1.1" numbered="true" toc="default"> | |||
by other technology-specific TE Topology models.</t> | <name>Terminology</name> | |||
<t>The key words "<bcp14>MUST</bcp14>", "<bcp14>MUST NOT</bcp14>", | ||||
<section title="Terminology" anchor="sect-1.1"><t> | "<bcp14>REQUIRED</bcp14>", "<bcp14>SHALL</bcp14>", | |||
The key words "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL NOT", | "<bcp14>SHALL NOT</bcp14>", "<bcp14>SHOULD</bcp14>", | |||
"SHOULD", "SHOULD NOT", "RECOMMENDED", "NOT RECOMMENDED", "MAY", and | "<bcp14>SHOULD NOT</bcp14>", | |||
"OPTIONAL" in this document are to be interpreted as described in BCP | "<bcp14>RECOMMENDED</bcp14>", "<bcp14>NOT RECOMMENDED</bcp14>", | |||
14 <xref target="RFC2119"/> <xref target="RFC8174"/> when, and only when, the | "<bcp14>MAY</bcp14>", and "<bcp14>OPTIONAL</bcp14>" in this document | |||
y appear in all | are to be interpreted as described in BCP 14 | |||
capitals, as shown here.</t> | <xref target="RFC2119"/> <xref target="RFC8174"/> when, and only | |||
when, they appear in all capitals, as shown here.</t> | ||||
<t> | <t> | |||
The reader is assumed to be familiar with general body of work | We assume that the reader is familiar with the general body of work | |||
captured in currently available TE related RFCs. <xref target="RFC7926"/> ser | captured in currently available RFCs related to Traffic Engineering. <xref ta | |||
ves as | rget="RFC7926" format="default"/> serves as | |||
a good starting point for those who may be less familiar with Traffic | a good starting point for those who may be less familiar with RFCs related to | |||
Engineering related RFCs.</t> | Traffic Engineering.</t> | |||
<t> | ||||
<t> | Some of the key terms used in this document are as follows: | |||
Some of the key terms used in this document are: | ||||
<list style="hanging" hangIndent="3"> | ||||
<t hangText="TED:">The Traffic Engineering Database is a collection of all | ||||
TE information about all TE nodes and TE links in a given network.</t> | ||||
<t hangText="TE-Topology:">The TE Topology is a schematic arrangement of TE | </t> | |||
<dl newline="false" spacing="normal" indent="3"> | ||||
<dt>TED:</dt> | ||||
<dd>The Traffic Engineering Database (TED) is a collection of all | ||||
TE information about all TE nodes and TE links in a given network.</dd> | ||||
<dt>TE topology:</dt> | ||||
<dd>The TE topology is a schematic arrangement of TE | ||||
nodes and TE links in a given TED. It forms the basis for a graph suitable | nodes and TE links in a given TED. It forms the basis for a graph suitable | |||
for TE path computations.</t> | for TE path computations.</dd> | |||
<dt>Native TE topology:</dt> | ||||
<t hangText="Native TE Topology:"> Native TE Topology is a topology that is | <dd>A Native TE topology is a topology that is | |||
native to a given provider network. Native TE topology could be discovered | native to a given provider network. A Native TE topology could be discovered | |||
via various routing protocols and/or subscribe/publish techniques. This is | via various routing protocols and/or subscribe/publish techniques. This is | |||
the topology on which path computational algorithms are run to compute TE | the topology on which path computational algorithms are run to compute TE | |||
Paths.</t> | paths.</dd> | |||
<dt>Customized TE topology:</dt> | ||||
<t hangText="Customized TE Topology:"> Customized TE Topology is a custom | <dd>A Customized TE topology is a custom | |||
topology that is produced by a provider for a given client. This topology | topology that is produced by a provider for a given client. This topology | |||
typically makes abstractions on the provider's Native TE Topology, and is | typically makes abstractions on the provider's Native TE topology and is | |||
provided to the client. The client receives the Customized TE Topology, and | provided to the client. The client receives the Customized TE topology and | |||
merges it into the client's Native TE Topology. The client's path | merges it into the client's Native TE topology. The client's path | |||
computational algorithms aren't typically run on the Customized TE | computational algorithms aren't typically run on the Customized TE | |||
Topology; they are run on the client's Native TE Topology after the | topology; they are run on the client's Native TE topology after the | |||
merge.</t> | merge.</dd> | |||
</dl> | ||||
</list> | </section> | |||
</t> | ||||
</section> | ||||
<section title="Tree Structure" anchor="sect-1.2"><t> A simplified | ||||
graphical representation of the data model is presented in Appendix | ||||
A. of this document. The tree format defined in <xref | ||||
target="RFC8340"/> is used for the YANG data model tree | ||||
representation. </t> | ||||
</section> | ||||
<section title="Prefixes in Data Node Names" anchor="sect-1.3"><t>In | <section anchor="sect-1.2" numbered="true" toc="default"> | |||
<name>Tree Structure</name> | ||||
<t> A simplified | ||||
graphical representation of the data model is presented in | ||||
<xref target="append-a"/> of this document. The tree format defined in < | ||||
xref target="RFC8340" format="default"/> is used for the YANG data model tree | ||||
representation. </t> | ||||
</section> | ||||
<section anchor="sect-1.3" numbered="true" toc="default"> | ||||
<name>Prefixes in Data Node Names</name> | ||||
<t>In | ||||
this document, names of data nodes and other data model objects are | this document, names of data nodes and other data model objects are | |||
prefixed using the standard prefix associated with the corresponding | prefixed using the standard prefix associated with the corresponding | |||
YANG imported modules, as shown in Table 1.</t> | YANG imported modules, as shown in <xref target="tab-prefixes-and-corres | |||
ponding-yang-modules"/>.</t> | ||||
<texttable title="Prefixes and corresponding YANG modules" anchor="tab-pr | <table anchor="tab-prefixes-and-corresponding-yang-modules" align="cente | |||
efixes-and-corresponding-yang-modules" style="full"><ttcol> Prefix</ttcol> | r"> | |||
<ttcol> YANG module</ttcol> | <name>Prefixes and Corresponding YANG Modules</name> | |||
<ttcol> Reference</ttcol> | <thead> | |||
<c>yang</c> | <tr> | |||
<c>ietf-yang-types</c> | <th align="left"> Prefix</th> | |||
<c>[RFC6991]</c> | <th align="left"> YANG Module</th> | |||
<c>inet</c> | <th align="left"> Reference</th> | |||
<c>ietf-inet-types</c> | </tr> | |||
<c>[RFC6991]</c> | </thead> | |||
<c>nw</c> | <tbody> | |||
<c>ietf-network</c> | <tr> | |||
<c>[RFC6991]</c> | <td align="left">yang</td> | |||
<c>nt</c> | <td align="left">ietf-yang-types</td> | |||
<c>ietf-network-topology</c> | <td align="left"><xref target="RFC6991"/></td> | |||
<c>[RFC8345]</c> | </tr> | |||
<c>te-types</c> | <tr> | |||
<c>ietf-te-types</c> | <td align="left">inet</td> | |||
<c>[I-D.ietf-teas-yang-te</c> | <td align="left">ietf-inet-types</td> | |||
<c></c> | <td align="left"><xref target="RFC6991"/></td> | |||
<c></c> | </tr> | |||
<c>-types]</c> | <tr> | |||
</texttable> | <td align="left">nw</td> | |||
</section> | <td align="left">ietf-network</td> | |||
<td align="left"><xref target="RFC8345"/></td> | ||||
</section> | </tr> | |||
<tr> | ||||
<section title="Characterizing TE Topologies" anchor="sect-2"><t> | <td align="left">nt</td> | |||
The data model proposed by this document takes the following | <td align="left">ietf-network-topology</td> | |||
characteristics of TE Topologies into account:</t> | <td align="left"><xref target="RFC8345"/></td> | |||
</tr> | ||||
<t><list style="symbols"><t>TE Topology is an abstract control-plane repr | <tr> | |||
esentation of the | <td align="left">te-types</td> | |||
data-plane topology. Hence attributes specific to the data-plane | <td align="left">ietf-te-types</td> | |||
must make their way into the corresponding TE Topology modeling. | <td align="left"><xref target="RFC8776"/></td> | |||
The TE Topology comprises of dynamic auto-discovered data as well | </tr> | |||
</tbody> | ||||
</table> | ||||
</section> | ||||
</section> | ||||
<section anchor="sect-2" numbered="true" toc="default"> | ||||
<name>Characterizing TE Topologies</name> | ||||
<t> | ||||
The data model defined by this document takes the following | ||||
characteristics of TE topologies into account:</t> | ||||
<ul spacing="normal"> | ||||
<li>The TE topology is an abstract control-plane representation of the | ||||
data-plane topology. Hence, attributes specific to the data plane | ||||
must make their way into the corresponding TE topology modeling. | ||||
The TE topology is comprised of dynamic autodiscovered data as well | ||||
as fairly static data associated with data-plane nodes and links. | as fairly static data associated with data-plane nodes and links. | |||
The dynamic data may change frequently, such as unreserved | The dynamic data, such as unreserved bandwidth available on data-plane | |||
bandwidth available on data-plane links. The static data rarely | links, may change frequently. The static data, such as layer network | |||
changes, such as layer network identification, switching and | identification, switching and adaptation capabilities and limitations, | |||
adaptation capabilities and limitations, fate sharing, and | fate-sharing, and administrative colors, rarely changes. | |||
administrative colors. It is possible for a single TE Topology to | It is possible for a single TE topology to | |||
encompass TE information at multiple switching layers.</t> | encompass TE information at multiple switching layers.</li> | |||
<li>TE topologies are protocol independent. Information about | ||||
<t>TE Topologies are protocol independent. Information about | topological elements may be learned via link-state protocols, but | |||
topological elements may be learnt via link-state protocols, but | ||||
the topology can exist without being dependent on any particular | the topology can exist without being dependent on any particular | |||
protocol.</t> | protocol.</li> | |||
<li>The TE topology may not be congruent with the routing topology in a | ||||
<t>TE Topology may not be congruent to the routing topology in a | given TE system. The routing topology is constructed based on | |||
given TE System. The routing topology is constructed based on | ||||
routing adjacencies. There isn't always a one-to-one association | routing adjacencies. There isn't always a one-to-one association | |||
between a TE-link and a routing adjacency. For example, the | between a TE link and a routing adjacency. For example, the | |||
presence of a TE link between a pair of nodes doesn't necessarily | presence of a TE link between a pair of nodes doesn't necessarily | |||
imply the existence of a routing-adjacency between these nodes. To | imply the existence of a routing adjacency between these nodes. To | |||
learn more, see <xref target="I-D.ietf-teas-te-topo-and-tunnel-modeling"/> | learn more, see <xref target="I-D.ietf-teas-te-topo-and-tunnel-modeling" fo | |||
and | rmat="default"/> and | |||
<xref target="I-D.ietf-teas-yang-l3-te-topo"/>.</t> | <xref target="YANG-L3" format="default"/>.</li> | |||
<li>Each TE topological element has at least one information source | ||||
<t>Each TE Topological element has at least one information source | ||||
associated with it. In some scenarios, there could be more than | associated with it. In some scenarios, there could be more than | |||
one information source associated with any given topological | one information source associated with any given topological | |||
element.</t> | element.</li> | |||
<li>TE topologies can be hierarchical. Each node and link of a given | ||||
<t>TE Topologies can be hierarchical. Each node and link of a given | TE topology can be associated with a respective underlay topology. | |||
TE Topology can be associated with respective underlay topology. | This means that each node and link of a given TE topology can be | |||
This means that each node and link of a given TE Topology can be | associated with an independent stack of supporting TE topologies.</li> | |||
associated with an independent stack of supporting TE Topologies.</t> | <li>TE topologies can be customized. TE topologies of a given network | |||
<t>TE Topologies can be customized. TE topologies of a given network | ||||
presented by the network provider to its client could be | presented by the network provider to its client could be | |||
customized on per-client request basis. This customization could | customized on a per-client-request basis. This customization could | |||
be performed by provider, by client or by provider/client | be performed by the provider, by the client, or by provider&wj;/client | |||
negotiation. The relationship between a customized topology and | negotiation. The relationship between a customized topology and the | |||
provider's native topology could be captured as hierarchical | provider's native topology could be captured as hierarchical | |||
(overlay-underlay), but otherwise the two topologies are decoupled | (overlay/underlay), but otherwise the two topologies are decoupled | |||
from each other. A customized topology is presented to the client, | from each other. A customized topology is presented to the client, | |||
while provider's native topology is known in its entirety to the | while the provider's native topology is known in its entirety to the | |||
provider itself.</t> | provider itself.</li> | |||
</ul> | ||||
</list> | </section> | |||
</t> | <section anchor="sect-3" numbered="true" toc="default"> | |||
<name>Modeling Abstractions and Transformations</name> | ||||
</section> | <section anchor="sect-3.1" numbered="true" toc="default"> | |||
<name>TE Topology</name> | ||||
<t> | ||||
A TE topology is a Traffic Engineering representation of one or more | ||||
layers of network topologies. A TE topology is comprised of TE nodes | ||||
(TE graph vertices) interconnected via TE links (TE graph edges). A | ||||
TE topology is mapped to a TE graph.</t> | ||||
</section> | ||||
<section anchor="sect-3.2" numbered="true" toc="default"> | ||||
<name>TE Node</name> | ||||
<t> | ||||
A TE node is an element of a TE topology, presented as a vertex on a TE | ||||
graph. A TE node represents one or several nodes, or a fraction of a | ||||
node, which can be a switch or router that is physical or virtual. A TE | ||||
node belongs to and is fully defined in exactly one TE topology. A TE | ||||
node is assigned a unique ID within the TE topology scope. TE node | ||||
attributes include information related to the data&nbhy;plane aspects of | ||||
the associated node(s) (e.g., connectivity matrix), as well as | ||||
configuration data (such as the TE node name). A given TE node can be | ||||
reached on the TE graph over one of the TE links terminated by the TE | ||||
node.</t> | ||||
<t> | ||||
Multi-layer TE nodes providing switching functions at multiple | ||||
network layers are an example where a physical node can be decomposed | ||||
into multiple logical TE nodes, which are fractions of the physical | ||||
node. Some of these (logical) TE nodes may reside in the client-layer | ||||
TE topology, while the remaining TE nodes belong to the server-layer | ||||
TE topology.</t> | ||||
<t> | ||||
In <xref target="fig1" format="default"/>, Node-1, Node-2, and Node-3 are | ||||
TE nodes.</t> | ||||
<section title="Modeling Abstractions and Transformations" anchor="sect-3 | <figure anchor="fig1"> | |||
"><figure title="TE Topology Modeling Abstractions" anchor="fig1"><artwork><![CD | <name>TE Topology Modeling Abstractions</name> | |||
ATA[ | <artwork name="" type="" align="left" alt=""><![CDATA[ | |||
| +---+ __ | | +---+ __ | |||
| | | TE Node \/ TTP o LTP | | | | TE Node \/ TTP o LTP | |||
| +---+ | | +---+ | |||
| | | | |||
| ----- TE Link | | ----- TE Link | |||
| ***** Node Connectivity Matrix, | | ***** Node Connectivity Matrix, | |||
| TTP Local Link Connectivity | | TTP Local Link Connectivity | |||
| @@@@@ TE Tunnel | | @@@@@ TE Tunnel | |||
o---------------------------------- | o---------------------------------- | |||
Node-1 Node-3 | Node-1 Node-3 | |||
+------------+ +------------+ | +------------+ +------------+ | |||
| TTP-1 | | TTP-1 | | | TTP-1 | | TTP-1 | | |||
|LTP __ | TE-Tunel-1 | __ | | |LTP __ | TE-Tunnel-1 | __ | | |||
|-6 \/@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@\/ | | |-6 \/@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@\/ | | |||
o * * oLTP-1 Node-2 LTP-6o * * o | o * * oLTP-1 Node-2 LTP-6o * * o | |||
| * * | +------------+ | * * | | | * * | +------------+ | * * | | |||
| * TTP-2* | | | | * TTP-2* | | | * TTP-2* | | | | * TTP-2* | | |||
| * __ * |LTP-2 LTP-6| |LTP-1 LTP-5| * __ * | | | * __ * |LTP-2 LTP-6| |LTP-1 LTP-5| * __ * | | |||
o* \/ *o-----------o************o-----------o* \/ *o | o* \/ *o-----------o************o-----------o* \/ *o | |||
|LTP * * | Link-12 | * | Link-23 | * * | | |LTP * * | Link-12 | * | Link-23 | * * | | |||
|-5 * * | LTP-5| * |LTP-2 | * * | | |-5 * * | LTP-5| * |LTP-2 | * * | | |||
+--o------o--+ o************o +--o------o--+ | +--o------o--+ o************o +--o------o--+ | |||
LTP-4 LTP-3 | * * * | LTP-4 LTP-3 | LTP-4 LTP-3 | * * * | LTP-4 LTP-3 | |||
| ** * | | | ** * | | |||
+--o------o--+ | +--o------o--+ | |||
LTP-4 LTP-3 | LTP-4 LTP-3 | |||
]]></artwork> | ||||
</figure> | ||||
<section title="TE Topology" anchor="sect-3.1"><t> | ||||
TE topology is a traffic engineering representation of one or more | ||||
layers of network topologies. TE topology is comprised of TE nodes | ||||
(TE graph vertices) interconnected via TE links (TE graph edges). A | ||||
TE topology is mapped to a TE graph.</t> | ||||
</section> | ||||
<section title="TE Node" anchor="sect-3.2"><t> | ||||
TE node is an element of a TE topology, presented as a vertex on TE | ||||
graph. TE node represents one or several nodes, or a fraction of a | ||||
node, which can be a switch or router that is physical or virtual. TE | ||||
node belongs to and is fully defined in exactly one TE topology. TE | ||||
node is assigned a unique ID within the TE topology scope. TE node | ||||
attributes include information related to the data plane aspects of | ||||
the associated node(s) (e.g. connectivity matrix), as well as | ||||
configuration data (such as TE node name). A given TE node can be | ||||
reached on the TE graph over one of TE links terminated by the TE | ||||
node.</t> | ||||
<t> | LTP: Link Termination Point | |||
Multi-layer TE nodes providing switching functions at multiple | TTP: Tunnel Termination Point]]></artwork> | |||
network layers are an example where a physical node can be decomposed | </figure> | |||
into multiple logical TE nodes, which are fractions of the physical | </section> | |||
node. Some of these (logical) TE nodes may reside in the client layer | <section anchor="sect-3.3" numbered="true" toc="default"> | |||
TE topology while the remaining TE nodes belong to the server layer | <name>TE Link</name> | |||
TE topology.</t> | <t> | |||
A TE link is an element of a TE topology, presented as an edge on a TE | ||||
<t> | ||||
In <xref target="fig1"/>, Node-1, Node-2, and Node-3 are TE nodes.</t> | ||||
</section> | ||||
<section title="TE Link" anchor="sect-3.3"><t> | ||||
TE link is an element of a TE topology, presented as an edge on TE | ||||
graph. The arrows on an edge indicate one or both directions of the | graph. The arrows on an edge indicate one or both directions of the | |||
TE link. When there are a pair of parallel links of opposite | TE link. When there are a pair of parallel links of opposite | |||
directions, an edge without arrows is also used. TE link represents | directions, an edge without arrows is also used. A TE link represents | |||
one or several (physical) links or a fraction of a link. TE link | one or several (physical) links or a fraction of a link. A TE link | |||
belongs to and is fully defined in exactly one TE topology. TE link | belongs to and is fully defined in exactly one TE topology. A TE link | |||
is assigned a unique ID within the TE topology scope. TE link | is assigned a unique ID within the TE topology scope. TE link | |||
attributes include parameters related to the data plane aspects of | attributes include parameters related to the data-plane aspects of | |||
the associated link(s) (e.g. unreserved bandwidth, resource | the associated link(s) (unreserved bandwidth, resource maps / resource | |||
maps/pools, etc.), as well as the configuration data (such as remote | pools, etc.), as well as the configuration data (remote | |||
node/link IDs, SRLGs, administrative colors, etc.). TE link is | node IDs / link IDs, Shared Risk Link Groups (SRLGs), | |||
connected to TE node, terminating the TE link via exactly one TE link | administrative colors, etc.). A TE link is | |||
termination point (LTP).</t> | connected to a TE node, terminating the TE link via exactly one TE Link | |||
Termination Point (LTP).</t> | ||||
<t> | <t> | |||
In <xref target="fig1"/>, Link-12 and Link-23 are TE links.</t> | In <xref target="fig1" format="default"/>, Link-12 and Link-23 are TE links.< | |||
/t> | ||||
</section> | </section> | |||
<section anchor="sect-3.4" numbered="true" toc="default"> | ||||
<section title="Transitional TE Link for Multi-Layer Topologies" anchor=" | <name>Transitional TE Link for Multi-layer Topologies</name> | |||
sect-3.4"><t> | <t> | |||
Networks are typically composed of multiple network layers where one | Networks are typically composed of multiple network layers where one | |||
or multiple signals in the client layer network can be multiplexed | or multiple signals in the client-layer network can be multiplexed | |||
and encapsulated into a server layer signal <xref target="RFC5212"/> <xref ta | and encapsulated into a server-layer signal <xref target="RFC5212" format="de | |||
rget="G.805"/>. The | fault"/> <xref target="G.805" format="default"/>. The | |||
server layer signal can be carried in the server layer network across | server-layer signal can be carried in the server-layer network across | |||
multiple nodes until the server layer signal is terminated and the | multiple nodes until the server-layer signal is terminated and the | |||
client layer signals reappear in the node that terminates the server | client-layer signals reappear in the node that terminates the | |||
layer signal. Examples of multi-layer networks are: IP over MPLS over | server-layer signal. Examples of multi-layer networks include (1) IP ove | |||
Ethernet, low order Optical Data Unit-k (ODUk) signals multiplexed | r MPLS over | |||
into a high order ODUl (l>k) carried over an Optical Channel (OCh) | Ethernet and (2) low-order Optical Data Unit-k (ODUk) signals multiplexe | |||
signal in an optical transport network as defined in <xref target="G.872"/> a | d | |||
nd | into a high-order ODUl (l>k) carried over an Optical Channel (OCh) | |||
<xref target="G.709"/>.</t> | signal in an Optical Transport Network (OTN) as defined in <xref target="G.87 | |||
2" format="default"/> and | ||||
<t> | <xref target="G.709" format="default"/>.</t> | |||
TE links as defined in <xref target="sect-3.3"/>. can be used to represent li | <t> | |||
nks | TE links as defined in <xref target="sect-3.3" format="default"/> can be used | |||
within a network layer. In case of a multi-layer network, TE nodes | to represent links | |||
and TE links only allow representation of each network layer as a | within a network layer. In the case of a multi-layer network, TE nodes | |||
separate TE topology. Each of these single layer TE topologies would | and TE links only allow the representation of each network layer as a | |||
be isolated from their client and their server layer TE topology, if | separate TE topology. Each of these single-layer TE topologies would | |||
present. The highest and the lowest network layer in the hierarchy | be isolated from their client and their server-layer TE topology, if | |||
present. The highest network layer and the lowest network layer in the hierar | ||||
chy | ||||
only have a single adjacent layer below or above, respectively. | only have a single adjacent layer below or above, respectively. | |||
Multiplexing of client layer signals and encapsulating them into a | Multiplexing client-layer signals and encapsulating them into a | |||
server layer signal requires a function that is provided inside a | server-layer signal require a function that is provided inside a | |||
node (typically realized in hardware). This function is also called | node (typically realized in hardware). This function is also called | |||
layer transition.</t> | "layer transition".</t> | |||
<t> | ||||
<t> | ||||
One of the key requirements for path computation is to be able to | One of the key requirements for path computation is to be able to | |||
calculate a path between two endpoints across a multi-layer network | calculate a path between two endpoints across a multi-layer network | |||
based on the TE topology representing this multi-layer network. This | based on the TE topology representing this multi-layer network. This | |||
means that an additional TE construct is needed that represents | means that an additional TE construct is needed that represents | |||
potential layer transitions in the multi-layer TE-topology that | potential layer transitions in the multi-layer TE topology that | |||
connects the TE-topologies representing each separate network layer. | connects the TE topologies representing each separate network layer. | |||
The so-called transitional TE link is such a construct and it | The so-called transitional TE link is such a construct, and it | |||
represents the layer transition function residing inside a node that | represents the layer transition function residing inside a node that | |||
is decomposed into multiple logical nodes that are represented as TE | is decomposed into multiple logical nodes that are represented as TE | |||
nodes (see also the transitional link definition in <xref target="G.8080"/> f | nodes (also see <xref target="G.8080" format="default"/> for the definition o | |||
or the | f a transitional link for the OTN). Hence, a transitional TE link connects a | |||
optical transport network). Hence, a transitional TE link connects a | client-layer node with a server-layer node. A TE link as defined in | |||
client layer node with a server layer node. A TE link as defined in | <xref target="sect-3.3"/> has LTPs of exactly the same kind on each link end, | |||
3.3. has LTPs of exactly the same kind on each link end whereas the | whereas the | |||
transitional TE link has client layer LTPs on the client side of the | transitional TE link has client-layer LTPs on the client side of the | |||
transitional link and in most cases a single server layer LTP on the | transitional link and, in most cases, a single server-layer LTP on the | |||
server side. It should be noted that transitional links are a helper | server side. It should be noted that transitional links are a helper | |||
construct in the multi-layer TE topology and they only exist as long | construct in the multi-layer TE topology and they only exist as long | |||
as they are not in use, as they represent potential connectivity. | as they are not in use, as they represent potential connectivity. | |||
When the server layer trail has been established between the server | When the server-layer trail has been established between the | |||
layer LTP of two transitional links in the server layer network, the | server-layer LTP of two transitional links in the server-layer network, the | |||
resulting client layer link in the data plane will be represented as | resulting client-layer link in the data plane will be represented as | |||
a normal TE link in the client layer topology. The transitional TE | a normal TE link in the client-layer topology. The transitional TE | |||
links will re-appear when the server layer trail has been torn down.</t> | links will reappear when the server-layer trail has been torn down.</t> | |||
<figure title="Modeling a Multi-Layer Node (Dual-Layer Example)" anchor="fig2"> | <figure anchor="fig2"> | |||
<artwork><![CDATA[ | <name>Modeling a Multi-layer Node (Dual-layer Example)</name> | |||
<artwork name="" type="" align="left" alt=""><![CDATA[ | ||||
| | | | | | |||
| +---+ --- | | +---+ --- | |||
| | | TE Node \ / Transitional | | | | TE Node \ / Transitional | |||
| +---+ | Link | | +---+ | Link | |||
| | | | |||
| ----- Client Layer Link | | ----- Client-Layer Link | |||
| ===== Server Layer Link | | ===== Server-Layer Link | |||
| ***** Layer Boundary | | ***** Layer Boundary | |||
o---------------------------------- | o---------------------------------- | |||
+------------------+ | +-------------------+ | |||
| +------+ | +------+ | | +-------+ | +-------+ | |||
| |Layer |---+ | | Layer |Layer | | -----|Client-|------+ | Client- -----|Client-| | |||
| +------+ | | | | +------+ | | |Layer |---+ | | Layer |Layer | | |||
| | | | | Client | | | | -----|Switch |-+ | | | Links -----|Node | | |||
| | | ---_| Layer --- --- | | +------ + | | | | +-------+ | |||
***|**********|*| \ /*|***************************\ /*\ /**** | | | | | | Client | | | | |||
| --- | | Server Transitional | | | | | | ---_| Layer --- --- | |||
| Layer \ / | | Layer Links | | | ***|***********|*| \ /*|***************************\ /*\ /**** | |||
| Term. | | | | | | | --- | | Server Transitional | | | |||
| | | | | | | | Layer \ / | | Layer Links | | | |||
| +------+ | +------+ | | Term. | | | | | | |||
=============|Server|===== Server ====|Server|==== | | | | | | | | |||
| |Layer | | Layer |Layer | | | +-------+ | +-------+ | |||
=============|Switch|===== Links ====|Node |==== | =============|Server-|===== Server- ====|Server-|==== | |||
| +------+ | +------+ | | |Layer | | Layer |Layer | | |||
+------------------+ | =============|Switch |===== Links ====|Node |==== | |||
| +-------+ | +-------+ | ||||
Physical Node View TE-Topology View | +-------------------+ | |||
]]></artwork> | ||||
</figure> | ||||
</section> | Physical Node View TE Topology View]]></artwork> | |||
</figure> | ||||
<section title="TE Link Termination Point (LTP)" anchor="sect-3.5"><t> | </section> | |||
TE link termination point (LTP) is a conceptual point of connection | <section anchor="sect-3.5" numbered="true" toc="default"> | |||
<name>TE Link Termination Point (LTP)</name> | ||||
<t> | ||||
A TE Link Termination Point (LTP) is a conceptual point of connection | ||||
of a TE node to one of the TE links, terminated by the TE node. | of a TE node to one of the TE links, terminated by the TE node. | |||
Cardinality between an LTP and the associated TE link is 1:0..1.</t> | Cardinality between an LTP and the associated TE link is 1:0..1.</t> | |||
<t> | ||||
<t> | In <xref target="fig1" format="default"/>, Node-2 has six LTPs: LTP-1 through | |||
In <xref target="fig1"/>, Node-2 has six LTPs: LTP-1 to LTP-6.</t> | LTP-6.</t> | |||
</section> | ||||
</section> | <section anchor="sect-3.6" numbered="true" toc="default"> | |||
<name>TE Tunnel Termination Point (TTP)</name> | ||||
<section title="TE Tunnel Termination Point (TTP)" anchor="sect-3.6"><t> | <t> | |||
TE tunnel termination point (TTP) is an element of TE topology | A TE Tunnel Termination Point (TTP) is an element of a TE topology | |||
representing one or several of potential transport service | representing one or several potential transport service | |||
termination points (i.e. service client adaptation points such as | termination points (i.e., service client adaptation points, such as | |||
WDM/OCh transponder). TTP is associated with (hosted by) exactly one | a WDM/OCh transponder). ("WDM" stands for "Wavelength Division Multiplexing". | |||
TE node. TTP is assigned a unique ID within the TE node scope. | ) A TTP is associated with (hosted by) exactly one | |||
TE node. A TTP is assigned a unique ID within the TE node scope. | ||||
Depending on the TE node's internal constraints, a given TTP hosted | Depending on the TE node's internal constraints, a given TTP hosted | |||
by the TE node could be accessed via one, several or all TE links | by the TE node could be accessed via one, several, or all TE links | |||
terminated by the TE node.</t> | terminated by the TE node.</t> | |||
<t> | ||||
<t> | In <xref target="fig1" format="default"/>, Node-1 has two TTPs: TTP-1 and TTP | |||
In <xref target="fig1"/>, Node-1 has two TTPs: TTP-1 and TTP-2.</t> | -2.</t> | |||
</section> | ||||
</section> | <section anchor="sect-3.7" numbered="true" toc="default"> | |||
<name>TE Node Connectivity Matrix</name> | ||||
<section title="TE Node Connectivity Matrix" anchor="sect-3.7"><t> | <t> | |||
TE node connectivity matrix is a TE node's attribute describing the | A TE node connectivity matrix is a TE node's attribute describing the | |||
TE node's switching limitations in a form of valid switching | TE node's switching limitations in the form of valid switching | |||
combinations of the TE node's LTPs (see below). From the point of | combinations of the TE node's LTPs (see below). From the point of | |||
view of a potential TE path arriving at the TE node at a given | view of a potential TE path arriving at the TE node at a given | |||
inbound LTP, the node's connectivity matrix describes valid | inbound LTP, the node's connectivity matrix describes valid | |||
(permissible) outbound LTPs for the TE path to leave the TE node | (permissible) outbound LTPs from which the TE path can leave the TE node.</t> | |||
from.</t> | ||||
<!--[rfced] id2xml converted to artwork, please review --> | ||||
<figure><artwork><![CDATA[ | ||||
In Figure 1, the connectivity matrix on Node-2 is: | ||||
{<LTP-6, LTP-1>, <LTP-5, LTP-2>, <LTP-5, LTP-4>, <LTP-4, LTP-1>, | ||||
<LTP-3, LTP-2>} | ||||
]]></artwork> | ||||
</figure> | ||||
</section> | ||||
<section title="TTP Local Link Connectivity List (LLCL)" anchor="sect-3.8 | ||||
"><t> | ||||
TTP Local Link Connectivity List (LLCL) is a List of TE links | ||||
terminated by the TTP hosting TE node (i.e. list of the TE link | ||||
LTPs), which the TTP could be connected to. From the point of view of | ||||
a potential TE path, LLCL provides a list of valid TE links the TE | ||||
path needs to start/stop on for the connection, taking the TE path, | ||||
to be successfully terminated on the TTP in question.</t> | ||||
<!--[rfced] id2xml converted to artwork, please review --> | ||||
<figure><artwork><![CDATA[ | <t>In <xref target="fig1"/>, the connectivity matrix on Node-2 is as follows:</t | |||
In Figure 1, the LLCL on Node-1 is: | > | |||
{<TTP-1, LTP-5>, <TTP-1, LTP-2>, <TTP-2, LTP-3>, <TTP-2, LTP4>} | <t>{<LTP-6, LTP-1>, <LTP-5, LTP-2>, <LTP-5, LTP-4>, <LTP-4, | |||
]]></artwork> | LTP-1>, | |||
</figure> | <LTP-3, LTP-2>}</t> | |||
</section> | </section> | |||
<section anchor="sect-3.8" numbered="true" toc="default"> | ||||
<name>TTP Local Link Connectivity List (LLCL)</name> | ||||
<t> | ||||
A TTP Local Link Connectivity List (LLCL) is a list of TE links | ||||
terminated by the TE node hosting a TTP, to which the TTP could be connected. | ||||
From the point of view of | ||||
the potential TE path of a connection, an LLCL provides a list of valid TE li | ||||
nks the TE | ||||
path needs to start/stop on for the connection to be successfully | ||||
terminated on a TTP.</t> | ||||
<t>In <xref target="fig1"/>, the LLCL on Node-1 is as follows:</t> | ||||
<t>{<TTP-1, LTP-5>, <TTP-1, LTP-2>, <TTP-2, LTP-3>, <TTP-2, | ||||
LTP-4>}</t> | ||||
<section title="TE Path" anchor="sect-3.9"><t> | </section> | |||
TE path is an ordered list of TE links and/or TE nodes on the TE | <section anchor="sect-3.9" numbered="true" toc="default"> | |||
topology graph, inter-connecting a pair of TTPs to be taken by a | <name>TE Path</name> | |||
potential connection. TE paths, for example, could be a product of | <t> | |||
A TE path is an ordered list of TE links and/or TE nodes on the TE | ||||
topology graph; this path interconnects a pair of TTPs to be used by a potent | ||||
ial connection. For example, TE paths could be a product of | ||||
successful path computation performed for a given transport service.</t> | successful path computation performed for a given transport service.</t> | |||
<t>In <xref target="fig1"/>, the TE path for TE-Tunnel-1 is as follows:</t> | ||||
<!--[rfced] id2xml converted to artwork, please review --> | <t>{Node-1:TTP-1, Link-12, Node-2, Link-23, Node-3:TTP-1}</t> | |||
</section> | ||||
<figure><artwork><![CDATA[ | <section anchor="sect-3.10" numbered="true" toc="default"> | |||
In Figure 1, the TE Path for TE-Tunnel-1 is: | <name>TE Inter-layer Lock</name> | |||
{Node-1:TTP-1, Link-12, Node-2, Link-23, Node-3:TTP1} | <t>A TE inter-layer lock is a modeling concept describing adaptation | |||
]]></artwork> | relationships between the client layer and the server layer | |||
</figure> | and hence is important for multi-layer | |||
</section> | Traffic Engineering. It is an association of M client-layer LTPs and N | |||
server-layer TTPs, within which data arriving at any of the | ||||
<section title="TE Inter-Layer Lock" anchor="sect-3.10"><t> TE | client-layer LTPs could be adopted onto any of the server-layer | |||
inter-layer lock is a modeling concept describing client-server layer | TTPs. A TE inter-layer lock is identified by an inter-layer lock ID, whi | |||
adaptation relationships and hence important for the multi-layer | ch is unique | |||
traffic engineering. It is an association of M client layer LTPs and N | across all TE topologies provided by the same provider. The | |||
server layer TTPs, within which data arriving at any of the client | client-layer LTPs and the server-layer TTPs associated within a given TE | |||
layer LTPs could be adopted onto any of the server layer TTPs. TE | inter-layer lock are annotated with the same inter-layer lock ID | |||
inter-layer lock is identified by inter-layer lock ID, which is unique | attribute.</t> | |||
across all TE topologies provided by the same provider. The client | <t> | |||
layer LTPs and the server layer TTPs associated within a given TE | In <xref target="fig3"/>, a TE inter-layer lock with an ID of IL-1 | |||
inter-layer lock are annotated with the same inter-layer lock ID | associates six client-layer LTPs (C-LTP-1 through C-LTP-6) with two | |||
attribute.</t> | server-layer TTPs (S-TTP-1 and S-TTP-2). They all have the same attribute | |||
-- TE inter-layer lock ID IL-1, which is the only thing that indicates the | ||||
<figure title="TE Inter-Layer Lock ID Associations" anchor="fig3"><artwor | association. A given LTP may have zero, one, or more inter-layer lock IDs. | |||
k><![CDATA[ | In the latter case, this means that the data arriving at the LTP may be | |||
adopted onto any of the TTPs associated with all specified inter-layer | ||||
locks. For example, C-LTP-1 could have two inter-layer lock IDs -- IL-1 and | ||||
IL-2. This would mean that C-LTP-1 for adaptation purposes could use not | ||||
just the TTPs associated with inter-layer lock IL-1 (i.e., S-TTP-1 and | ||||
S-TTP-2 in the figure) but any of the TTPs associated with inter-layer lock | ||||
IL-2 as well. Likewise, a given TTP may have one or more inter-layer lock | ||||
IDs, meaning that it can offer the adaptation service to any of the | ||||
client-layer LTPs with an inter-layer lock ID matching one of its | ||||
own. Additionally, each TTP has an unreserved adaptation bandwidth | ||||
attribute, which announces its remaining adaptation resources that are | ||||
sharable between all potential client-layer LTPs.</t> | ||||
<figure anchor="fig3"> | ||||
<name>TE Inter-layer Lock ID Associations</name> | ||||
<artwork name="" type="" align="left" alt=""><![CDATA[ | ||||
| +---+ __ | | +---+ __ | |||
| | | TE Node \/ TTP o LTP | | | | TE Node \/ TTP o LTP | |||
| +---+ | | +---+ | |||
| | | | |||
| ----- TE Link | | ----- TE Link | |||
| ***** TTP Local Link Connectivity | | ***** TTP Local Link Connectivity | |||
o---------------------------------- | o---------------------------------- | |||
(IL-1) C-LTP-1 +------------+ C-LTP-2 (IL-1) | (IL-1) C-LTP-1 +------------+ C-LTP-2 (IL-1) | |||
--------O (IL-1) O-------- | --------O (IL-1) O-------- | |||
(IL-1) C-LTP-3 | S-TTP-1 | C-LTP-4 (IL-1) | (IL-1) C-LTP-3 | S-TTP-1 | C-LTP-4 (IL-1) | |||
--------O __ 0-------- | --------O __ 0-------- | |||
(IL-1) C-LTP-5 | *\/* | C-LTP-5 (IL-1) | (IL-1) C-LTP-5 | *\/* | C-LTP-6 (IL-1) | |||
--------O * * O-------- | --------O * * O-------- | |||
| *(IL-1)* | | | *(IL-1)* | | |||
S-LTP-3 | * S-TTP-2* | S-LTP-4 | S-LTP-3 | * S-TTP-2* | S-LTP-4 | |||
--------o* __ *o-------- | --------o* __ *o-------- | |||
| *\/* | | | *\/* | | |||
| * * | | | * * | | |||
+--o------o--+ | +--o------o--+ | |||
S-LTP-1 | | S-LTP-2 | S-LTP-1 | | S-LTP-2]]></artwork> | |||
]]></artwork> | </figure> | |||
</figure> | ||||
<t> | ||||
On the picture above a TE inter-layer lock with IL_1 ID associates 6 client | ||||
layer LTPs (C-LTP-1 - C-LTP-6) with two server layer TTPs (S-TTP-1 and | ||||
S-TTP-2). They all have the same attribute - TE inter-layer lock ID: IL-1, | ||||
which is the only thing that indicates the association. A given LTP may | ||||
have 0, 1 or more inter-layer lock IDs. In the latter case this means that | ||||
the data arriving at the LTP may be adopted onto any of TTPs associated | ||||
with all specified inter-layer locks. For example, C-LTP-1 could have two | ||||
inter-layer lock IDs - IL- 1 and IL-2. This would mean that C-LTP-1 for | ||||
adaptation purposes could use not just TTPs associated with inter-layer | ||||
lock IL-1 (i.e.</t> | ||||
<t> | ||||
S-TTP-1 and S-TTP-2 on the picture), but any of TTPs associated with | ||||
inter-layer lock IL-2 as well. Likewise, a given TTP may have one or | ||||
more inter-layer lock IDs, meaning that it can offer the adaptation | ||||
service to any of client layer LTPs with inter-layer lock ID matching | ||||
one of its own. Additionally, each TTP has an attribute - Unreserved | ||||
Adaptation Bandwidth, which announces its remaining adaptation | ||||
resources sharable between all potential client LTPs.</t> | ||||
<t> | <t> | |||
LTPs and TTPs associated within the same TE inter-layer lock may be | LTPs and TTPs associated within the same TE inter-layer lock may be | |||
hosted by the same (hybrid, multi-layer) TE node or multiple TE nodes | hosted by the same (hybrid, multi-layer) TE node or multiple TE nodes | |||
located in the same or separate TE topologies. The latter is | located in the same or separate TE topologies. The latter case is | |||
especially important since TE topologies of different layer networks | especially important, since TE topologies of different layer networks | |||
could be modeled by separate augmentations of the basic (common to | could be modeled by separate augmentations of the basic (common to | |||
all layers) TE topology model.</t> | all layers) TE topology model.</t> | |||
</section> | ||||
</section> | <section anchor="sect-3.11" numbered="true" toc="default"> | |||
<name>Underlay TE Topology</name> | ||||
<section title="Underlay TE topology" anchor="sect-3.11"><t> | <t> | |||
Underlay TE topology is a TE topology that serves as a base for | An underlay TE topology is a TE topology that serves as a base for | |||
constructing of overlay TE topologies</t> | the construction of overlay TE topologies.</t> | |||
</section> | ||||
</section> | <section anchor="sect-3.12" numbered="true" toc="default"> | |||
<name>Overlay TE Topology</name> | ||||
<section title="Overlay TE topology" anchor="sect-3.12"><t> | <t> | |||
Overlay TE topology is a TE topology constructed based on one or more | An overlay TE topology is a TE topology that is constructed based on one or m | |||
ore | ||||
underlay TE topologies. Each TE node of the overlay TE topology | underlay TE topologies. Each TE node of the overlay TE topology | |||
represents an arbitrary segment of an underlay TE topology; each TE | represents an arbitrary segment of an underlay TE topology; each TE | |||
link of the overlay TE topology represents an arbitrary TE path in | link of the overlay TE topology represents an arbitrary TE path in | |||
one of the underlay TE topologies. The overlay TE topology and the | one of the underlay TE topologies. The overlay TE topology and the | |||
supporting underlay TE topologies may represent distinct layer | supporting underlay TE topologies may represent distinct layer | |||
networks (e.g. OTN/ODUk and WDM/OCh respectively) or the same layer | networks (e.g., OTN/ODUk and WDM/OCh, respectively) or the same layer | |||
network.</t> | network.</t> | |||
</section> | ||||
</section> | <section anchor="sect-3.13" numbered="true" toc="default"> | |||
<name>Abstract TE Topology</name> | ||||
<section title="Abstract TE topology" anchor="sect-3.13"><t> | <t> | |||
Abstract TE topology is a topology that contains abstract topological | An abstract TE topology is a topology that contains abstract topological | |||
elements (nodes, links, tunnel termination points). Abstract TE | elements (nodes, links, TTPs). An abstract TE | |||
topology is an overlay TE topology created by a topology provider and | topology is an overlay TE topology created by a topology provider and | |||
customized for a topology provider's client based on one or more of | customized for a topology provider's client based on one or more of | |||
the provider's native TE topologies (underlay TE topologies), the | the provider's Native TE topologies (underlay TE topologies), the | |||
provider's policies and the client's preferences. For example, a | provider's policies, and the client's preferences. For example, a | |||
first level topology provider (such as Domain Controller) can create | first-level topology provider (such as a domain controller) can create | |||
an abstract TE topology for its client (e.g. Multi-Domain Service | an abstract TE topology for its client (e.g., a multi-domain service | |||
Coordinator) based on the provider's one or more native TE | coordinator) based on one or more of the provider's Native TE | |||
topologies, local policies/profiles and the client's TE topology | topologies, local policies/profiles, and the client's TE topology | |||
configuration requests</t> | configuration requests.</t> | |||
<t><xref target="fig4" format="default"/> shows an example of an abstrac | ||||
<t><xref target="fig4"/> shows an example of abstract TE topology.</t> | t TE topology.</t> | |||
<figure anchor="fig4"> | ||||
<figure title="Abstract TE Topology" anchor="fig4"><artwork><![CDATA[ | <name>Abstract TE Topology</name> | |||
<artwork name="" type="" align="left" alt=""><![CDATA[ | ||||
| +---+ | | +---+ | |||
| | | TE Node | | | | TE Node | |||
| +---+ | | +---+ | |||
| ----- TE Link | | ----- TE Link | |||
o---------------------------------- | o---------------------------------- | |||
+---+ +---+ | +---+ +---+ | |||
|s31|--------------|S5 | | |S3 | |S5 | | |||
+---+\ / +---+ | +---+\ / +---+ | |||
\ / | \ / | |||
\ / | \ / | |||
\+---+/ +---+ | \+---+/ +---+ | |||
/|AN1|\----------------|S8 | | /|AN1|\----------------|S8 | | |||
/ +---+ \ +---+ | / +---+ \ +---+ | |||
+---+ / \ +---+ | +---+ / \ +---+ | |||
|S9 |-------------|S11| | |S9 | |S11| | |||
+---+ +---+ | +---+ +---+ | |||
Abstract TE Topology | Abstract TE Topology | |||
+---+ +---+ | +---+ +---+ | |||
|S1 |--------------------|S2 | | |S1 |--------------------|S2 | | |||
+---+ +---+ | +---+ +---+ | |||
/ \ | / \ | |||
/ \ | / \ | |||
+---+ / +---+ \ +---+ | +---+ / +---+ \ +---+ | |||
|s3 |--------------------|S4 |---------|S5 | | |S3 |--------------------|S4 |---------|S5 | | |||
+---+\ +---+ +---+ | +---+\ +---+ +---+ | |||
\ \ \ | \ \ \ | |||
\ \ \ | \ \ \ | |||
\+---+ +---+ +---+ | \+---+ +---+ +---+ | |||
/|S6 |\ |S7 |---------|S8 | | /|S6 |\ |S7 |---------|S8 | | |||
/ +---+ \ +---+\ /+---+ | / +---+ \ +---+\ /+---+ | |||
+---+ / \ +---+ +---+ / | +---+ / \ +---+ +---+ / | |||
|S9 |-------------|S10|--------------|S11|/ | |S9 |-------------|S10|--------------|S11|/ | |||
+---+ +---+ +---+ | +---+ +---+ +---+ | |||
Native TE Topology | Native TE Topology]]></artwork> | |||
]]></artwork> | </figure> | |||
</figure> | </section> | |||
</section> | </section> | |||
<section anchor="sect-4" numbered="true" toc="default"> | ||||
</section> | <name>Model Applicability</name> | |||
<section anchor="sect-4.1" numbered="true" toc="default"> | ||||
<section title="Model Applicability" anchor="sect-4"><section title="Nati | <name>Native TE Topologies</name> | |||
ve TE Topologies" anchor="sect-4.1"><t> | <t> | |||
The model discussed in this draft can be used to represent and | The model discussed in this document can be used to represent and | |||
retrieve native TE topologies on a given TE system.</t> | retrieve Native TE topologies on a given TE system.</t> | |||
<t> | ||||
Consider the network topology depicted in <xref target="fig5" format="default | ||||
"/>. R1 .. R9 | ||||
are nodes representing routers. An implementation <bcp14>MAY</bcp14> choose t | ||||
o construct a | ||||
Native TE topology using all nodes and links present in the given TED as | ||||
depicted in <xref target="fig6" format="default"/>. The data model defined in | ||||
this document | ||||
can be used to represent and retrieve this TE topology.</t> | ||||
<figure title="Example Network Topology" anchor="fig5"><artwork><![CDATA[ | <figure anchor="fig5"> | |||
<name>Example Network Topology</name> | ||||
<artwork name="" type="" align="left" alt=""><![CDATA[ | ||||
| +---+ | | +---+ | |||
| | | TE Node | | | | TE Node | |||
| +---+ | | +---+ | |||
| ----- TE Link | | ----- TE Link | |||
o---------------------------------- | o---------------------------------- | |||
+---+ +---+ +---+ +---+ +---+ | +---+ +---+ +---+ +---+ +---+ | |||
| R1|-------| R2|--------| R3|---------| R4|---------| R5| | | R1|-------| R2|--------| R3|---------| R4|---------| R5| | |||
+---+ +---+ +---+ +---+ +---+ | +---+ +---+ +---+ +---+ +---+ | |||
| / \ / \ / | | / \ / \ / | |||
| / \ / \ / | | / \ / \ / | |||
| / \ / \ / | | / \ / \ / | |||
| / \ / \ / | | / \ / \ / | |||
| / \ / \ / | | / \ / \ / | |||
+---+ +---+ +---+ +---+ | +---+ +---+ +---+ +---+ | |||
| R6|-------------| R7| | R8|---------| R9| | | R6|-------------| R7| | R8|---------| R9| | |||
+---+ +---+ +---+ +---+ | +---+ +---+ +---+ +---+]]></artwork> | |||
]]></artwork> | </figure> | |||
</figure> | ||||
<t> | ||||
Consider the network topology depicted in <xref target="fig5"/>. R1 .. R9 | ||||
are nodes representing routers. An implementation MAY choose to construct a | ||||
native TE Topology using all nodes and links present in the given TED as | ||||
depicted in <xref target="fig6"/>. The data model proposed in this document | ||||
can be used to retrieve/represent this TE topology.</t> | ||||
<figure title="Native TE Topology as seen on Node R3" anchor="fig6"><artw | <figure anchor="fig6"> | |||
ork><![CDATA[ | <name>Native TE Topology as Seen on Node R3</name> | |||
<artwork name="" type="" align="left" alt=""><![CDATA[ | ||||
--------------- | --------------- | |||
| Native | | [ ] TE Node | | Native | | [ ] TE Node | |||
| TE-Topology | | +++ TE Link | | TE Topology | | +++ TE Link | |||
--------------- o-------------- | --------------- o-------------- | |||
[R1] ++++ [R2] ++++ [R3] ++++ [R4] ++++ [R5] | [R1] ++++ [R2] ++++ [R3] ++++ [R4] ++++ [R5] | |||
+ + + + + + | + + + + + + | |||
+ + + + + + | + + + + + + | |||
+ + ++ ++ | + + ++ ++ | |||
[R6] +++++++++ [R7] [R8] ++++ [R9] | [R6] +++++++++ [R7] [R8] ++++ [R9]]]></artwork> | |||
]]></artwork> | </figure> | |||
</figure> | <t> | |||
<t> | Consider the case where the topology is split in a way that some nodes | |||
Consider the case of the topology being split in a way that some nodes | participate in OSPF-TE while others participate in ISIS-TE (<xref target="fig | |||
participate in OSPF-TE while others participate in ISIS-TE (<xref | 7" format="default"/>). An implementation <bcp14>MAY</bcp14> choose to construct | |||
target="fig7"/>). An implementation MAY choose to construct separate TE | separate TE | |||
Topologies based on the information source. The native TE Topologies | topologies based on the information source. The Native TE topologies | |||
constructed using only nodes and links that were learnt via a specific | constructed using only nodes and links that were learned via a specific | |||
information source are depicted in <xref target="fig8"/>. The data model | information source are depicted in <xref target="fig8" format="default"/>. Th | |||
proposed in this document can be used to retrieve/represent these TE | e data model | |||
defined in this document can be used to represent and retrieve these TE | ||||
topologies.</t> | topologies.</t> | |||
<figure anchor="fig7"> | ||||
<t> | <name>Example Split Network Topology</name> | |||
Similarly, the data model can be used to represent/retrieve a TE | <artwork name="" type="" align="left" alt=""><![CDATA[ | |||
Topology that is constructed using only nodes and links that belong | ||||
to a particular technology layer. The data model is flexible enough | ||||
to retrieve and represent many such native TE Topologies.</t> | ||||
<figure title="Example Network Topology" anchor="fig7"><artwork><![CDATA[ | ||||
: | : | |||
TE info distributed via ISIS-TE : TE info distributed via OSPF-TE | TE Info Distributed via ISIS-TE : TE Info Distributed via OSPF-TE | |||
: | : | |||
+---+ +---+ +---+ +---+ +---+ | +---+ +---+ +---+ +---+ +---+ | |||
| R1|-------| R2|--------| R3|---------| R4|---------| R5| | | R1|-------| R2|--------| R3|---------| R4|---------| R5| | |||
+---+ +---+ +---+ +---+ +---+ | +---+ +---+ +---+ +---+ +---+ | |||
| / : \ / \ / | | / : \ / \ / | |||
| / : \ / \ / | | / : \ / \ / | |||
| / : \ / \ / | | / : \ / \ / | |||
| / : \ / \ / | | / : \ / \ / | |||
| / : \ / \ / | | / : \ / \ / | |||
+---+ +---+ : +---+ +---+ | +---+ +---+ : +---+ +---+ | |||
| R6|-------------| R7| : | R8|---------| R9| | | R6|-------------| R7| : | R8|---------| R9| | |||
+---+ +---+ : +---+ +---+ | +---+ +---+ : +---+ +---+ | |||
: | :]]></artwork> | |||
]]></artwork> | </figure> | |||
</figure> | <figure anchor="fig8"> | |||
<figure title="Native TE Topologies as seen on Node R3" anchor="fig8"><ar | <name>Native TE Topologies as Seen on Node R3</name> | |||
twork><![CDATA[ | <artwork name="" type="" align="left" alt=""><![CDATA[ | |||
----------------------- : ----------------------- | ----------------------- : ----------------------- | |||
|Native TE Topology | : |Native TE Topology | | |Native TE Topology | : |Native TE Topology | | |||
|Info-Source: ISIS-TE | : |Info-Source: OSPF-TE | | |Info-Source: ISIS-TE | : |Info-Source: OSPF-TE | | |||
----------------------- : ----------------------- | ----------------------- : ----------------------- | |||
: | : | |||
[R1] ++++ [R2] ++++ [R3] : [R3'] ++++ [R4] ++++ [R5] | [R1] ++++ [R2] ++++ [R3] : [R3'] ++++ [R4] ++++ [R5] | |||
+ + : + + + + | + + : + + + + | |||
+ + : + + + + | + + : + + + + | |||
+ + : ++ ++ | + + : ++ ++ | |||
[R6] +++++++++ [R7] : [R8] ++++ [R9] | [R6] +++++++++ [R7] : [R8] ++++ [R9]]]></artwork> | |||
]]></artwork> | </figure> | |||
</figure> | <t>Similarly, the data model can be used to represent and retrieve a TE | |||
</section> | topology that is constructed using only nodes and links that belong | |||
to a particular technology layer. The data model is flexible enough | ||||
<section title="Customized TE Topologies" anchor="sect-4.2"><t> | to represent and retrieve many such Native TE topologies.</t> | |||
Customized TE topology is a topology that was modified by the | </section> | |||
<section anchor="sect-4.2" numbered="true" toc="default"> | ||||
<name>Customized TE Topologies</name> | ||||
<t> | ||||
A Customized TE topology is a topology that was modified by the | ||||
provider to honor a particular client's requirements or preferences. | provider to honor a particular client's requirements or preferences. | |||
The model discussed in this draft can be used to represent, retrieve | The model discussed in this document can be used to represent, retrieve, | |||
and manipulate customized TE Topologies. The model allows the | and manipulate Customized TE topologies. The model allows the | |||
provider to present the network in abstract TE Terms on a per client | provider to present the network in abstract TE terms on a per&nbhy;client | |||
basis. These customized topologies contain sufficient information for | basis. These customized topologies contain sufficient information for | |||
the path computing client to select paths according to its policies.</t> | the client to compute and select paths according to its policies.</t> | |||
<t> | ||||
<figure title="Example packet optical topology" anchor="fig9"><artwork><! | Consider the network topology depicted in <xref target="fig9" format="default | |||
[CDATA[ | "/>. This is a | |||
typical packet optical transport deployment scenario where the WDM-layer | ||||
network domain serves as a server network domain providing transport | ||||
connectivity to the packet-layer network domain (client network | ||||
domain). Nodes R1, R2, R3, and R4 are IP routers that are connected to an | ||||
optical WDM transport network. A, B, C, D, E, and F are WDM nodes that | ||||
constitute the server network domain.</t> | ||||
<figure anchor="fig9"> | ||||
<name>Example Packet Optical Topology</name> | ||||
<artwork name="" type="" align="left" alt=""><![CDATA[ | ||||
| +---+ /-\ | | +---+ /-\ | |||
| | | Router ( ) WDM | | | | Router ( ) WDM | |||
| +---+ Node \-/ node | | +---+ Node \-/ Node | |||
| | | | |||
o---------------------------- | o---------------------------- | |||
+---+ /-\ /-\ /-\ +---+ | +---+ /-\ /-\ /-\ +---+ | |||
| R1|-------( A )--------( C )---------( E )---------| R3| | | R1|-------( A )--------( C )---------( E )---------| R3| | |||
+---+ \-/ \-/ \-/ +---+ | +---+ \-/ \-/ \-/ +---+ | |||
/ \ / \ | / \ / \ | |||
/ \ / \ | / \ / \ | |||
/ \ / \ | / \ / \ | |||
/ \ / \ | / \ / \ | |||
/ \ / \ | / \ / \ | |||
+---+ /-\ /-\ /-\ +---+ | +---+ /-\ /-\ /-\ +---+ | |||
| R2|---------( B )---------( D )---------( F )---------| R4| | | R2|---------( B )---------( D )---------( F )---------| R4| | |||
+---+ \-/ \-/ \-/ +---+ | +---+ \-/ \-/ \-/ +---+]]></artwork> | |||
]]></artwork> | </figure> | |||
</figure> | <t> | |||
<t> | The goal here is to augment the client's TE topology with a Customized TE | |||
Consider the network topology depicted in <xref target="fig9"/>. This is a | topology provided by the WDM network. Given the availability of the paths | |||
typical packet optical transport deployment scenario where the WDM layer | A-E, B-F, and B-E (<xref target="fig10" format="default"/>), a Customized TE | |||
network domain serves as a Server Network Domain providing transport | topology as | |||
connectivity to the packet layer network Domain (Client Network | depicted in <xref target="fig11" format="default"/> is provided to the client | |||
Domain). Nodes R1, R2, R3 and R4 are IP routers that are connected to an | . This Customized TE | |||
Optical WDM transport network. A, B, C, D, E and F are WDM nodes that | topology is merged with the client's Native TE topology, and the resulting | |||
constitute the Server Network Domain.</t> | topology is depicted in <xref target="fig12" format="default"/>.</t> | |||
<figure anchor="fig10"> | ||||
<figure title="Paths within the provider domain" anchor="fig10"><artwork> | <name>Paths within the Provider Domain</name> | |||
<![CDATA[ | <artwork name="" type="" align="left" alt=""><![CDATA[ | |||
| ***** B-F WDM Path | | ***** B-F WDM Path | |||
| @@@@@ B-E WDM Path | | @@@@@ B-E WDM Path | |||
| $$$$$ A-E WDM Path | | $$$$$ A-E WDM Path | |||
o-------------------- | o-------------------- | |||
+---+ /-\ $$$$$$$$ /-\ $$$$$$$$$ /-\ +---+ | +---+ /-\ $$$$$$$$ /-\ $$$$$$$$$ /-\ +---+ | |||
| R1|-------( A )--------( C )---------( E )---------| R3| | | R1|-------( A )--------( C )---------( E )---------| R3| | |||
+---+ \-/ @\-/ @@@@@@@@@ \-/ +---+ | +---+ \-/ @\-/ @@@@@@@@@ \-/ +---+ | |||
@/ \ / \ | @/ \ / \ | |||
@/ \ / \ | @/ \ / \ | |||
@/ \ / \ | @/ \ / \ | |||
@/ \ / \ | @/ \ / \ | |||
@/ \ / \ | @/ \ / \ | |||
+---+ /-\ ********* /-\ ********* /-\ +---+ | +---+ /-\ ********* /-\ ********* /-\ +---+ | |||
| R2|---------( B )---------( D )---------( F )---------| R4| | | R2|---------( B )---------( D )---------( F )---------| R4| | |||
+---+ \-/ \-/ \-/ +---+ | +---+ \-/ \-/ \-/ +---+]]></artwork> | |||
]]></artwork> | </figure> | |||
</figure> | <figure anchor="fig11"> | |||
<figure title="Customized TE Topology provided to the Client" anchor="fig | <name>Customized TE Topology Provided to the Client</name> | |||
11"><artwork><![CDATA[ | <artwork name="" type="" align="left" alt=""><![CDATA[ | |||
++++++++ [A] ++++++++++++++++++++ [E] +++++++++ | ++++++++ [A] ++++++++++++++++++++ [E] +++++++++ | |||
+++++ | +++++ | |||
++++ | ++++ | |||
++++ | ++++ | |||
++++ | ++++ | |||
++++ | ++++ | |||
++++++++ [B] ++++++++++++++++++++ [F] +++++++++ | ++++++++ [B] ++++++++++++++++++++ [F] +++++++++]]></artwork> | |||
]]></artwork> | </figure> | |||
</figure> | <figure anchor="fig12"> | |||
<t> | <name>Customized TE Topology Merged with the Client's Native | |||
The goal here is to augment the Client TE Topology with a customized TE | TE Topology</name> | |||
Topology provided by the WDM network. Given the availability of the paths | <artwork name="" type="" align="left" alt=""><![CDATA[ | |||
A-E, B-F and B-E (<xref target="fig10"/>), a customized TE Topology as | ||||
depicted in <xref target="fig11"/> is provided to the Client. This customized | ||||
TE | ||||
Topology is merged with the Client's Native TE Topology and the resulting | ||||
topology is depicted in <xref target="fig12"/>.</t> | ||||
<figure title="Customized TE Topology merged with the Client's Native TE | ||||
Topology" anchor="fig12"><artwork><![CDATA[ | ||||
[R1] ++++++++ [A] ++++++++++++++++++++ [E] +++++++++ [R3] | [R1] ++++++++ [A] ++++++++++++++++++++ [E] +++++++++ [R3] | |||
+++++ | +++++ | |||
++++ | ++++ | |||
++++ | ++++ | |||
++++ | ++++ | |||
++++ | ++++ | |||
[R2] ++++++++ [B] ++++++++++++++++++++ [F] +++++++++ [R4] | [R2] ++++++++ [B] ++++++++++++++++++++ [F] +++++++++ [R4]]]></artwork> | |||
]]></artwork> | </figure> | |||
</figure> | <t> | |||
<t> | The data model defined in this document can be used to | |||
The data model proposed in this document can be used to | represent, retrieve, and manipulate the Customized TE topology depicted in | |||
retrieve/represent/manipulate the customized TE Topology depicted in | <xref target="fig11" format="default"/>.</t> | |||
<xref target="fig11"/>.</t> | <t> | |||
A Customized TE topology is not necessarily an abstract TE topology. | ||||
<t> | The provider may produce, for example, an abstract TE topology of a | |||
A customized TE topology is not necessarily an abstract TE topology. | certain type (a single-abstract-node-with-connectivity-matrix | |||
The provider may produce, for example, an abstract TE topology of | ||||
certain type (e.g. single-abstract-node-with-connectivity-matrix | ||||
topology, a border-nodes-connected-via-mesh-of-abstract-links | topology, a border-nodes-connected-via-mesh-of-abstract-links | |||
topology, etc.) and expose it to all/some clients in expectation that | topology, etc.) and expose it to all or some clients in the expectation that | |||
the clients will use it without customization. | the clients will use it without customization. | |||
On the other hand, a client may request a customized version of the | On the other hand, a client may request a customized version of the | |||
provider's native TE topology (e.g. by requesting removal of TE links | provider's Native TE topology (e.g., by requesting the removal of TE links | |||
which belong to certain layers, are too slow, not protected and/or | that belong to certain layers, are too slow, are not protected, and/or | |||
have a certain affinity). Note that the resulting TE topology will | have a certain affinity). Note that the resulting TE topology will | |||
not be abstract (because it will not contain abstract elements), but | not be abstract (because it will not contain abstract elements) but will be | |||
customized (modified upon client's instructions).</t> | customized (modified upon the client's instructions).</t> | |||
<t> | ||||
<t> | The client ID field in the TE topology identifier (<xref target="sect-5.4" fo | |||
The client ID field in the TE topology identifier (<xref target="sect-5.4"/>. | rmat="default"/>) | |||
) | ||||
indicates which client the TE topology is customized for. Although an | indicates which client the TE topology is customized for. Although an | |||
authorized client MAY receive a TE topology with the client ID field | authorized client <bcp14>MAY</bcp14> receive a TE topology with the client ID field | |||
matching some other client, the client can customize only TE | matching some other client, the client can customize only TE | |||
topologies with the client ID field either 0 or matching the ID of | topologies with the client ID field either set to 0 or matching the ID of | |||
the client in question. If the client starts reconfiguration of a | the client in question. If the client starts the reconfiguration of a | |||
topology its client ID will be automatically set in the topology ID | topology, its client ID will be automatically set in the topology ID | |||
field for all future configurations and updates wrt. the topology in | field for all future configurations and updates with regard to the topology i | |||
n | ||||
question.</t> | question.</t> | |||
<t> | ||||
<t> | The provider, by setting its own ID in the client ID field of the topology | |||
The provider MAY tell the client that a given TE topology cannot be | ID, <bcp14>MAY</bcp14> tell the client that a given TE topology | |||
re-negotiated, by setting its own (provider's) ID in the client ID | cannot be renegotiated.</t> | |||
field of the topology ID.</t> | <t> | |||
Even though this data model allows the access of TE topology information | ||||
<t> | across clients, implementations <bcp14>MAY</bcp14> restrict access for partic | |||
Even though this data model allows to access TE topology information | ular | |||
across clients, implementations MAY restrict access for particular | clients to particular data fields. The Network Configuration Access Control M | |||
clients to particular data fields. The Network Configuration Access | odel (NACM) <xref target="RFC8341" format="default"/> provides such a mechanism. | |||
Control Model (NACM) <xref target="RFC8341"/> provides such a mechanism.</t> | </t> | |||
</section> | ||||
</section> | <section anchor="sect-4.3" numbered="true" toc="default"> | |||
<name>Merging TE Topologies Provided by Multiple Providers</name> | ||||
<section title="Merging TE Topologies Provided by Multiple Providers" anc | <t> | |||
hor="sect-4.3"><t> | ||||
A client may receive TE topologies provided by multiple providers, | A client may receive TE topologies provided by multiple providers, | |||
each of which managing a separate domain of multi-domain network. In | each of which manages a separate domain of a multi-domain network. In | |||
order to make use of said topologies, the client is expected to merge | order to make use of said topologies, the client is expected to merge | |||
the provided TE topologies into one or more client's native TE | the provided TE topologies into one or more of its own Native TE | |||
topologies, each of which homogeneously representing the multi-domain | topologies, each of which homogeneously represents the multi-domain | |||
network. This makes it possible for the client to select end-to-end | network. This makes it possible for the client to select end-to-end | |||
TE paths for its services traversing multiple domains.</t> | TE paths for its services traversing multiple domains.</t> | |||
<t> | ||||
<t> | ||||
In particular, the process of merging TE topologies includes:</t> | In particular, the process of merging TE topologies includes:</t> | |||
<ul spacing="normal"> | ||||
<t><list style="symbols"> | <li>Identifying neighboring domains and locking their topologies | |||
<t>Identifying neighboring domains and locking their topologies | horizontally by connecting their inter-domain open-ended TE links.</li> | |||
horizontally by connecting their inter-domain open-ended TE links;</t> | <li>Renaming TE node IDs, link IDs, and SRLG IDs to IDs allocated from | |||
a | ||||
<t>Renaming TE node, link, and SRLG IDs to ones allocated from a | separate namespace; this is necessary because all TE topologies | |||
separate name space; this is necessary because all TE topologies | are considered to be, generally speaking, independent, and clashes among | |||
are considered to be, generally speaking, independent with a | TE node IDs, link IDs, or SRLG IDs are possible.</li> | |||
possibility of clashes among TE node, link or SRLG IDs;</t> | <li>Locking, vertically, TE topologies associated with different layer | |||
networks, according to provided topology inter-layer locks; this is done | ||||
<t>Locking, vertically, TE topologies associated with different layer | ||||
networks, according to provided topology inter-layer locks; this is | ||||
to facilitate inter-layer path computations across multiple TE | to facilitate inter-layer path computations across multiple TE | |||
topologies provided by the same topology provider.</t> | topologies provided by the same topology provider.</li> | |||
</ul> | ||||
</list> | <t> | |||
</t> | <xref target="fig13" format="default"/> illustrates the process whereby the | |||
client merges the TE topologies furnished by its providers.</t> | ||||
<figure title="Merging Domain TE Topologies" anchor="fig13"><artwork><![C | <figure anchor="fig13"> | |||
DATA[ | <name>Merging Domain TE Topologies: An Example</name> | |||
<artwork name="" type="" align="left" alt=""><![CDATA[ | ||||
/---\ +---+ +---+ +---+ +---+ /---\ | /---\ +---+ +---+ +---+ +---+ /---\ | |||
|s3 |------|S13|----|S15|------|S23|----|S25|------|C21| | |C11|------|S13|----|S15|------|S23|----|S25|------|C21| | |||
\---/ +---+\ +---+ +---+ /+---+ \---/ | \---/ +---+\ +---+ +---+ /+---+ \---/ | |||
\ / | \ / | |||
\ / | \ / | |||
\+---+ +---+/ +---+ /---\ | \+---+ +---+/ +---+ /---\ | |||
|S18|------|S24| |S28|------|C22| | |S18|------|S24| |S28|------|C22| | |||
+---+ +---+\ /+---+ \---/ | +---+ +---+\ /+---+ \---/ | |||
\/ | \/ | |||
/\ | /\ | |||
/---\ +---+ +---+ +---+/ \+---+ /---\ | /---\ +---+ +---+ +---+/ \+---+ /---\ | |||
|C12|------|S19|----|S17|------|S29|----|S27|------|C23| | |C12|------|S19|----|S17|------|S29|----|S27|------|C23| | |||
\---/ +---+ +---+ +---+ +---+ \---/ | \---/ +---+ +---+ +---+ +---+ \---/ | |||
Domain 1 TE Topology Domain 2 TE Topology | Domain 1 TE Topology Domain 2 TE Topology | |||
+---+ +---+ +---+ +---+ | +---+ +---+ +---+ +---+ | |||
-----|S13|----|S15|---- ----|S23|----|S25|---- | -----|S13|----|S15|---- ----|S23|----|S25|---- | |||
+---+\ +---+ +---+ /+---+ | +---+\ +---+ +---+ /+---+ | |||
\ / | \ / | |||
\ / | \ / | |||
\+---+ +---+/ +---+ | \+---+ +---+/ +---+ | |||
|S18|---- ----|S24| |S28|---- | |S18|---- ----|S24| |S28|---- | |||
+---+ +---+\ /+---+ | +---+ +---+\ /+---+ | |||
\/ | \/ | |||
/\ | /\ | |||
+---+ +---+ +---+/ \+---+ | +---+ +---+ +---+/ \+---+ | |||
-----|S19|----|S17|---- ----|S29|----|S27|---- | -----|S19|----|S17|---- ----|S29|----|S27|---- | |||
+---+ +---+ +---+ +---+ | +---+ +---+ +---+ +---+]]></artwork> | |||
]]></artwork> | </figure> | |||
</figure> | <t>In <xref target="fig13"/>, each of | |||
<t> | the two providers caters to the client (abstract or Native) TE | |||
<xref target="fig13"/> illustrates the process of merging, by the client, of | ||||
TE | ||||
topologies provided by the client's providers. In the Figure, each of | ||||
the two providers caters to the client (abstract or native) TE | ||||
topology, describing the network domain under the respective | topology, describing the network domain under the respective | |||
provider's control. The client, by consulting the attributes of the | provider's control. The client, by consulting such attributes of the | |||
inter-domain TE links - such as inter-domain plug IDs or remote TE | inter-domain TE links as inter-domain plug IDs or remote TE | |||
node/link IDs (as defined by the TE Topology model) - is able to | node IDs / link IDs (as defined by the TE topology model), is able | |||
to | ||||
determine that:</t> | determine that:</t> | |||
<ol spacing="normal" type="1"> | ||||
<t><list style="format (%c)"> | <li>the two domains are adjacent and are interconnected via three | |||
inter-domain TE links, and</li> | ||||
<t>the two domains are adjacent and are inter-connected via three | <li> each domain is connected to a separate customer site, connecting | |||
inter-domain TE links, and; </t> | the domain on the left in the figure to customer devices C11 and C12, an | |||
d | ||||
<t> each domain is connected to a separate customer site, connecting | the domain on the right to customer devices C21, C22, and C23.</li> | |||
the left domain in the Figure to customer devices C-11 and C-12, and | </ol> | |||
the right domain to customer devices C-21, C-22 and C-23. | <t> | |||
</t> | Therefore, the client interconnects the open-ended TE links, as | |||
shown on the upper part of the figure.</t> | ||||
</list> | <t> | |||
</t> | As mentioned previously, one way to interconnect the open-ended inter-domain | |||
TE links | ||||
<t> | of neighboring domains is to mandate that the providers specify a remote | |||
Therefore, the client inter-connects the open-ended TE links, as | node ID / link ID attribute in the provided inter-domain TE | |||
shown on the upper part of the Figure.</t> | links. However, this may prove not to be flexible. For example, the providers | |||
may not | ||||
<t> | know the respective remote node IDs / link IDs. More importantly, t | |||
As mentioned, one way to inter-connect the open-ended inter-domain TE links | his option | |||
of neighboring domains is to mandate the providers to specify remote | does not allow the client to mix and match multiple topologies (more than | |||
nodeID/linkID attribute in the provided inter-domain TE links. This, | one topology) catered by the same providers (see below). Another option | |||
however, may prove to be not flexible. For example, the providers may not | (which is more flexible) for resolving the open-ended inter-domain TE links i | |||
know the respective remote nodeIDs/ linkIDs. More importantly, this option | s to | |||
does not allow for the client to mix-n-match multiple (more than one) | annotate them with the inter-domain plug ID attribute. The inter-domain plug | |||
topologies catered by the same providers (see below). Another, more | ||||
flexible, option to resolve the open-ended inter-domain TE links is by | ||||
annotating them with the inter-domain plug ID attribute. Inter-domain plug | ||||
ID is a network-wide unique number that identifies on the network a | ID is a network-wide unique number that identifies on the network a | |||
connectivity supporting a given inter-domain TE link. Instead of specifying | connection that supports a given inter-domain TE link. Instead of specifying | |||
remote node ID/link ID, an inter-domain TE link may provide a non-zero | a remote node ID / link ID, an inter-domain TE link may provide a non-zero | |||
inter-domain plug ID. It is expected that two neighboring domain TE | inter-domain plug ID. It is expected that two neighboring domain TE | |||
topologies (provided by separate providers) will have each at least one | topologies (provided by separate providers) will each have at least one | |||
open-ended inter-domain TE link with an inter-domain plug ID matching to | open-ended inter-domain TE link with an inter-domain plug ID matching | |||
one provided by its neighbor. For example, the inter-domain TE link | an ID provided by its neighbor. For example, the inter-domain TE link | |||
originating from node S15 of the Domain 1 TE topology (<xref | originating from node S15 of the Domain 1 TE topology (<xref target="fig13" | |||
target="fig13"/>) and the inter-domain TE link coming from node S23 of | format="default"/>) and the inter-domain TE link coming from node S23 of the | |||
Domain 2 TE topology may specify matching inter-domain plug ID | Domain 2 TE topology may specify a matching inter-domain plug ID | |||
(e.g. 175344). This allows for the client to identify adjacent nodes in the | (e.g., 175344). This allows the client to identify adjacent nodes in the | |||
separate neighboring TE topologies and resolve the inter-domain TE links | separate neighboring TE topologies and resolve the inter-domain TE links | |||
connecting them regardless of their respective nodeIDs/linkIDs (which, as | connecting them, regardless of their respective node IDs / link IDs | |||
mentioned, could be allocated from independent name spaces). Inter-domain | (which, as | |||
mentioned previously, could be allocated from independent namespaces). Inter- | ||||
domain | ||||
plug IDs may be assigned and managed by a central network authority. | plug IDs may be assigned and managed by a central network authority. | |||
Alternatively, inter-domain plug IDs could be dynamically auto-discovered | Alternatively, inter-domain plug IDs could be dynamically autodiscovered | |||
(e.g. via LMP protocol).</t> | (e.g., via the Link Management Protocol (LMP)).</t> | |||
<t> | ||||
<t> | Furthermore, the client renames the TE nodes, links, and SRLGs offered | |||
Furthermore, the client renames the TE nodes, links and SRLGs offered | ||||
in the abstract TE topologies by assigning to them IDs allocated from | in the abstract TE topologies by assigning to them IDs allocated from | |||
a separate name space managed by the client. Such renaming is | a separate namespace managed by the client. Such renaming is | |||
necessary, because the two abstract TE topologies may have their own | necessary, because the two abstract TE topologies may have their own | |||
name spaces, generally speaking, independent one from another; hence, | namespaces, generally speaking, independent one from another; hence, | |||
ID overlaps/clashes are possible. For example, both TE topologies | ID overlaps/clashes are possible. For example, both TE topologies | |||
have TE nodes named S7, which, after renaming, appear in the merged | have TE nodes named S7, which, after renaming, appear in the merged | |||
TE topology as S17 and S27, respectively.</t> | TE topology as S17 and S27, respectively.</t> | |||
<t> | ||||
<t> | ||||
Once the merging process is complete, the client can use the merged | Once the merging process is complete, the client can use the merged | |||
TE topology for path computations across both domains, for example, | TE topology for path computations across both domains -- for example, | |||
to compute a TE path connecting C-11 to C-23.</t> | to compute a TE path connecting C11 to C23.</t> | |||
</section> | ||||
</section> | <section anchor="sect-4.4" numbered="true" toc="default"> | |||
<name>Dealing with Multiple Abstract TE Topologies Provided by the Same | ||||
<section title="Dealing with Multiple Abstract TE Topologies Provided by | Provider</name> | |||
the Same Provider" anchor="sect-4.4"> | <t> | |||
Based on local configuration, templates, and/or policies pushed by the | ||||
<figure title="Merging Domain TE Topologies" anchor="fig14"><artwork><![C | client, a given provider may expose more than one abstract TE | |||
DATA[ | topology to the client. For example, one abstract TE topology could | |||
be optimized based on a lowest-cost criterion, while another one | ||||
could be based on best possible delay metrics, while yet another one | ||||
could be based on maximum bandwidth availability for the client | ||||
services. Furthermore, the client may request all or some providers | ||||
to expose additional abstract TE topologies, possibly of a different | ||||
type and/or optimized differently, as compared to already-provided TE | ||||
topologies. In any case, the client should be prepared for a provider | ||||
to offer to the client more than one abstract TE topology.</t> | ||||
<t> | ||||
It should be up to the client (based on the client's local configuration | ||||
and/or policies conveyed to the client by the client's clients) to decide | ||||
how to mix and match multiple abstract TE topologies provided by each or | ||||
some of the providers, as well as how to merge them into the client's | ||||
Native TE topologies. The client also decides how many such merged TE | ||||
topologies it needs to produce and maintain. For example, in addition to | ||||
the merged TE topology depicted in the upper part of <xref target="fig13" for | ||||
mat="default"/>, the client may merge the abstract TE topologies received | ||||
from the two providers, as shown in <xref target="fig14" format="default"/>, | ||||
into the client's additional | ||||
Native TE topologies, as shown in <xref target="fig15" | ||||
format="default"/>.</t> | ||||
<figure anchor="fig14"> | ||||
<name>Merging Domain TE Topologies: Another Example</name> | ||||
<artwork name="" type="" align="left" alt=""><![CDATA[ | ||||
Domain 1 Abstract TE Topology 1 Domain 2 Abstract TE Topology 1 | Domain 1 Abstract TE Topology 1 Domain 2 Abstract TE Topology 1 | |||
+---+ +---+ +---+ +---+ | +---+ +---+ +---+ +---+ | |||
-----|S13|----|S15|---- ----|S23|----|S25|---- | -----|S13|----|S15|---- ----|S23|----|S25|---- | |||
+---+\ +---+ +---+ /+---+ | +---+\ +---+ +---+ /+---+ | |||
\ / | \ / | |||
\ / | \ / | |||
\+---+ +---+/ +---+ | \+---+ +---+/ +---+ | |||
|S18|---- ----|S24| |S28|---- | |S18|---- ----|S24| |S28|---- | |||
+---+ +---+\ /+---+ | +---+ +---+\ /+---+ | |||
\/ | \/ | |||
/\ | /\ | |||
+---+ +---+ +---+/ \+---+ | +---+ +---+ +---+/ \+---+ | |||
-----|S19|----|S17|---- ----|S29|----|S27|---- | -----|S19|----|S17|---- ----|S29|----|S27|---- | |||
+---+ +---+ +---+ +---+ | +---+ +---+ +---+ +---+ | |||
Domain 1 Abstract TE Topology 1 Domain 2 Abstract TE Topology 1 | Domain 1 Abstract TE Topology 2 Domain 2 Abstract TE Topology 2 | |||
+------------+ +------------+ | +------------+ +------------+ | |||
-----| |---- ----| |---- | -----| |---- ----| |---- | |||
| | | | | | | | | | |||
| AN1 |---- ----| AN1 |---- | | AN1 |---- ----| AN1 |---- | |||
| | | | | | | | | | |||
-----| |---- ----| |---- | -----| |---- ----| |---- | |||
+------------+ +------------+ | +------------+ +------------+]]></artwork> | |||
]]></artwork> | </figure> | |||
</figure> | ||||
<t> | ||||
Based on local configuration, templates and/or policies pushed by the | ||||
client, a given provider may expose more than one abstract TE | ||||
topology to the client. For example, one abstract TE topology could | ||||
be optimized based on a lowest-cost criterion, while another one | ||||
could be based on best possible delay metrics, while yet another one | ||||
could be based on maximum bandwidth availability for the client | ||||
services. Furthermore, the client may request all or some providers | ||||
to expose additional abstract TE topologies, possibly of a different | ||||
type and/or optimized differently, as compared to already-provided TE | ||||
topologies. In any case, the client should be prepared for a provider | ||||
to offer to the client more than one abstract TE topology.</t> | ||||
<t> | ||||
It should be up to the client (based on the client's local configuration | ||||
and/or policies conveyed to the client by the client's clients) to decide | ||||
how to mix-and-match multiple abstract TE topologies provided by each or | ||||
some of the providers, as well as how to merge them into the client's | ||||
native TE topologies. The client also decides how many such merged TE | ||||
topologies it needs to produce and maintain. For example, in addition to | ||||
the merged TE topology depicted in the upper part of <xref | ||||
target="fig13"/>, the client may merge the abstract TE topologies received | ||||
from the two providers, as shown in <xref target="fig14"/>, into the client's | ||||
additional | ||||
native TE topologies, as shown in <xref target="fig15"/>.</t> | ||||
<t> | ||||
Note that allowing for the client mix-n-matching of multiple TE | ||||
topologies assumes that inter-domain plug IDs (rather than remote | ||||
nodeID/linkID) option is used for identifying neighboring domains and | ||||
inter-domain TE link resolution.</t> | ||||
<figure title="Multiple Native (Merged) Client's TE Topologies" anchor="f | ||||
ig15"><artwork><![CDATA[ | ||||
<figure anchor="fig15"> | ||||
<name>Multiple Native (Merged) Client's TE Topologies</name> | ||||
<artwork name="" type="" align="left" alt=""><![CDATA[ | ||||
Client's Merged TE Topology 2 | Client's Merged TE Topology 2 | |||
/---\ +------------+ +------------+ /---\ | /---\ +------------+ +------------+ /---\ | |||
|s3 |------| |------| |------|C21| | |C11|------| |------| |------|C21| | |||
\---/ | | | | \---/ | \---/ | | | | \---/ | |||
| | | | | | | | | | |||
| | | | | | | | | | |||
| | | | /---\ | | | | | /---\ | |||
| AN11 |------| AN21 |------|C22| | | AN11 |------| AN21 |------|C22| | |||
| | | | \---/ | | | | | \---/ | |||
| | | | | | | | | | |||
| | | | | | | | | | |||
/---\ | | | | /---\ | /---\ | | | | /---\ | |||
|C12|------| |------| |------|C23| | |C12|------| |------| |------|C23| | |||
\---/ +------------+ +------------+ \---/ | \---/ +------------+ +------------+ \---/ | |||
Client's Merged TE Topology 3 | Client's Merged TE Topology 3 | |||
/---\ +------------+ +---+ +---+ /---\ | /---\ +------------+ +---+ +---+ /---\ | |||
|s3 |------| |------|S23|----|S25|------|C21| | |C11|------| |------|S23|----|S25|------|C21| | |||
\---/ | | +---+ /+---+ \---/ | \---/ | | +---+ /+---+ \---/ | |||
| | / | | | / | |||
| | / | | | / | |||
| | +---+/ +---+ /---\ | | | +---+/ +---+ /---\ | |||
| AN11 |------|S24| |S28|------|C22| | | AN11 |------|S24| |S28|------|C22| | |||
| | +---+\ /+---+ \---/ | | | +---+\ /+---+ \---/ | |||
| | \/ | | | \/ | |||
| | /\ | | | /\ | |||
/---\ | | +---+/ \+---+ /---\ | /---\ | | +---+/ \+---+ /---\ | |||
|C12|------| |------|S29|----|S27|------|C23| | |C12|------| |------|S29|----|S27|------|C23| | |||
\---/ +------------+ +---+ +---+ \---/ | \---/ +------------+ +---+ +---+ \---/]]></artwork> | |||
]]></artwork> | </figure> | |||
</figure> | ||||
<t> | ||||
It is important to note that each of the three native (merged) TE | ||||
topologies could be used by the client for computing TE paths for any | ||||
of the multi-domain services. The choice as to which topology to use | ||||
for a given service depends on the service parameters/requirements | ||||
and the topology's style, optimization criteria and the level of | ||||
details.</t> | ||||
</section> | ||||
</section> | ||||
<section title="Modeling Considerations" anchor="sect-5"><section title=" | ||||
Network topology building blocks" anchor="sect-5.1"><t> | ||||
The network topology building blocks are discussed in <xref target="RFC8345"/ | ||||
>. The | ||||
TE Topology model proposed in this document augments and uses the | ||||
ietf-network-topology module defined in <xref target="RFC8345"/>.</t> | ||||
<figure title="Augmenting the Network Topology Model" anchor="fig16"><art | ||||
work><![CDATA[ | ||||
+------------------------+ | ||||
| | | ||||
| Network Topology Model | | ||||
| (ietf-network-topology)| | ||||
+------------------------+ | ||||
| | ||||
| | ||||
| | ||||
V | ||||
+------------------------+ | ||||
| TE Topology | | ||||
| Model | | ||||
| | | ||||
+------------------------+ | ||||
]]></artwork> | ||||
</figure> | ||||
</section> | ||||
<section title="Technology agnostic TE Topology model" anchor="sect-5.2"> | ||||
<t> | ||||
The TE Topology model proposed in this document is meant to be | ||||
network technology agnostic. Other technology specific TE Topology | ||||
models can augment and use the building blocks provided by the | ||||
proposed model.</t> | ||||
<figure title="Augmenting the Technology agnostic TE Topology model" anch | <t> | |||
or="fig17"><artwork><![CDATA[ | Note that allowing the client to mix and match multiple TE | |||
+-----------------------------+ | topologies assumes that inter-domain plug IDs (rather than a remote | |||
| TE Topology Model | | node ID / link ID) are used as the option for identifying neighbori | |||
| (Defined in This Document) | | ng domains and | |||
+-----------------------------+ | inter-domain TE link resolution.</t> | |||
| | <t> | |||
+-------------+-------------+-------------+ | It is important to note that each of the three Native (merged) TE | |||
| | | | | topologies could be used by the client for computing TE paths for any | |||
V V V V | of the multi-domain services. The choice of which topology to use | |||
+------------+ +------------+ | for a given service depends on the service parameters/requirements, | |||
| Technology | | Technology | | the topology's style and optimization criteria, and the level of | |||
| Specific | ...................... | Specific | | detail.</t> | |||
| TE Topology| | TE Topology| | </section> | |||
| Model 1 | | Model n | | </section> | |||
+------------+ +------------+ | <section anchor="sect-5" numbered="true" toc="default"> | |||
]]></artwork> | <name>Modeling Considerations</name> | |||
</figure> | <section anchor="sect-5.1" numbered="true" toc="default"> | |||
</section> | <name>Network Topology Building Blocks</name> | |||
<t> | ||||
The network topology building blocks are discussed in <xref target="RFC8345" | ||||
format="default"/>. The | ||||
TE topology model defined in this document augments and uses the | ||||
"ietf-network-topology" module defined in <xref target="RFC8345" format="defa | ||||
ult"/>.</t> | ||||
<figure anchor="fig16"> | ||||
<name>Augmenting the Network Topology Model</name> | ||||
<artwork name="" type="" align="left" alt=""><![CDATA[ | ||||
+------------------------+ | ||||
| Network Topology Model | | ||||
| (ietf-network-topology)| | ||||
+------------------------+ | ||||
| | ||||
| | ||||
| | ||||
V | ||||
+------------------------+ | ||||
| TE Topology | | ||||
| Model | | ||||
+------------------------+]]></artwork> | ||||
</figure> | ||||
</section> | ||||
<section anchor="sect-5.2" numbered="true" toc="default"> | ||||
<name>Technology-Agnostic TE Topology Model</name> | ||||
<t> | ||||
The TE topology model defined in this document is meant to be | ||||
network technology agnostic. Other technology-specific TE topology | ||||
models can augment and use the building blocks provided by this model, | ||||
as illustrated in <xref target="fig17"/>.</t> | ||||
<figure anchor="fig17"> | ||||
<name>Augmenting the Technology-Agnostic TE Topology Model</name> | ||||
<artwork name="" type="" align="left" alt=""><![CDATA[ | ||||
+-----------------------------+ | ||||
| TE Topology Model | | ||||
+-----------------------------+ | ||||
| | ||||
+-------------+-------------+-------------+ | ||||
| | | | | ||||
V V V V | ||||
+-------------+ +-------------+ | ||||
| Technology- | | Technology- | | ||||
| Specific | ...................... | Specific | | ||||
| TE Topology | | TE Topology | | ||||
| Model 1 | | Model n | | ||||
+-------------+ +-------------+]]></artwork> | ||||
</figure> | ||||
</section> | ||||
<section anchor="sect-5.3" numbered="true" toc="default"> | ||||
<name>Model Structure</name> | ||||
<section title="Model Structure" anchor="sect-5.3"><t> | <t> | |||
The high-level model structure proposed by this document is as shown | The high-level model structure defined by this document is as shown | |||
below:</t> | below:</t> | |||
<sourcecode name="" type="yangtree"><![CDATA[ | ||||
<figure><artwork><![CDATA[ | ||||
module: ietf-te-topology | module: ietf-te-topology | |||
augment /nw:networks/nw:network/nw:network-types: | augment /nw:networks/nw:network/nw:network-types: | |||
+--rw te-topology! | +--rw te-topology! | |||
augment /nw:networks: | ||||
+--rw te! | ||||
+--rw templates | ||||
+--rw node-template* [name] {template}? | ||||
| ............ | ||||
+--rw link-template* [name] {template}? | ||||
............ | ||||
augment /nw:networks/nw:network: | ||||
+--rw te-topology-identifier | ||||
| +--rw provider-id? te-global-id | ||||
| +--rw client-id? te-global-id | ||||
| +--rw topology-id? te-topology-id | ||||
+--rw te! | ||||
| ............ | ||||
augment /nw:networks/nw:network/nw:node: | ||||
+--rw te-node-id? te-types:te-node-id | ||||
+--rw te! | ||||
| ............ | ||||
+--rw tunnel-termination-point* [tunnel-tp-id] | ||||
+--rw tunnel-tp-id binary | ||||
| ............ | ||||
+--rw supporting-tunnel-termination-point* [node-ref tunnel- | ||||
tp-ref] | ||||
| ............ | ||||
augment /nw:networks/nw:network/nt:link: | ||||
+--rw te! | ||||
| .......... | ||||
augment /nw:networks/nw:network/nw:node/nt:termination-point: | augment /nw:networks: | |||
+--rw te-tp-id? te-types:te-tp-id | +--rw te! | |||
+--rw te! | +--rw templates | |||
| ............ | +--rw node-template* [name] {template}? | |||
]]></artwork> | | ............ | |||
</figure> | +--rw link-template* [name] {template}? | |||
</section> | ............ | |||
<section title="Topology Identifiers" anchor="sect-5.4"><t> | augment /nw:networks/nw:network: | |||
The TE-Topology is uniquely identified by a key that has 3 | +--rw te-topology-identifier | |||
constituents - topology-id, provider-id and client-id. The | | +--rw provider-id? te-global-id | |||
combination of provider-id and topology-id uniquely identifies a | | +--rw client-id? te-global-id | |||
native TE Topology on a given provider. The client-id is used only | | +--rw topology-id? te-topology-id | |||
when Customized TE Topologies come into play; a value of "0" is used | +--rw te! | |||
as the client-id for native TE Topologies.</t> | | ............ | |||
<figure><artwork><![CDATA[ | augment /nw:networks/nw:network/nw:node: | |||
augment /nw:networks/nw:network: | +--rw te-node-id? te-types:te-node-id | |||
+--rw te-topology-identifier | +--rw te! | |||
| +--rw provider-id? te-global-id | | ............ | |||
| +--rw client-id? te-global-id | +--rw tunnel-termination-point* [tunnel-tp-id] | |||
| +--rw topology-id? te-topology-id | +--rw tunnel-tp-id binary | |||
+--rw te! | | ............ | |||
| ............ | +--rw supporting-tunnel-termination-point* | |||
]]></artwork> | [node-ref tunnel-tp-ref] | |||
</figure> | | ............ | |||
</section> | ||||
<section title="Generic TE Link Attributes" anchor="sect-5.5"><t> | augment /nw:networks/nw:network/nt:link: | |||
The model covers the definitions for generic TE Link attributes - | +--rw te! | |||
bandwidth, admin groups, SRLGs, switching capabilities, TE metric | | .......... | |||
extensions etc.</t> | ||||
<figure><artwork><![CDATA[ | augment /nw:networks/nw:network/nw:node/nt:termination-point: | |||
+--rw te-tp-id? te-types:te-tp-id | ||||
+--rw te! | ||||
| ............]]></sourcecode> | ||||
</section> | ||||
<section anchor="sect-5.4" numbered="true" toc="default"> | ||||
<name>Topology Identifiers</name> | ||||
<t> | ||||
The TE topology is uniquely identified by a key that has three | ||||
constituents -- "topology-id", "provider-id", and "client-id". The | ||||
combination of "provider-id" and "topology-id" uniquely identifies a | ||||
Native TE topology on a given provider. "client-id" is used only | ||||
when Customized TE topologies come into play; a "client-id" value of "0" is | ||||
used for Native TE topologies.</t> | ||||
<sourcecode name="" type="yangtree"><![CDATA[ | ||||
augment /nw:networks/nw:network: | ||||
+--rw te-topology-identifier | ||||
| +--rw provider-id? te-global-id | ||||
| +--rw client-id? te-global-id | ||||
| +--rw topology-id? te-topology-id | ||||
+--rw te! | ||||
| ............]]></sourcecode> | ||||
</section> | ||||
<section anchor="sect-5.5" numbered="true" toc="default"> | ||||
<name>Generic TE Link Attributes</name> | ||||
<t> | ||||
The model covers the definitions for generic TE link attributes -- | ||||
bandwidth, administrative groups, SRLGs, switching capabilities, TE metric | ||||
extensions, etc.</t> | ||||
<sourcecode name="" type="yangtree"><![CDATA[ | ||||
+--rw te-link-attributes | +--rw te-link-attributes | |||
..................... | ..................... | |||
+--rw admin-status? te-admin-status | +--rw admin-status? te-admin-status | |||
| ..................... | | ..................... | |||
+--rw link-index? uint64 | +--rw link-index? uint64 | |||
+--rw administrative-group? te-types:admin-groups | +--rw administrative-group? te-types:admin-groups | |||
+--rw link-protection-type? enumeration | +--rw link-protection-type? enumeration | |||
+--rw max-link-bandwidth? te-bandwidth | +--rw max-link-bandwidth? te-bandwidth | |||
+--rw max-resv-link-bandwidth? te-bandwidth | +--rw max-resv-link-bandwidth? te-bandwidth | |||
+--rw unreserved-bandwidth* [priority] | +--rw unreserved-bandwidth* [priority] | |||
| ..................... | | ..................... | |||
+--rw te-default-metric? uint32 | +--rw te-default-metric? uint32 | |||
| ..................... | | ..................... | |||
+--rw te-srlgs | +--rw te-srlgs | |||
+--rw te-nsrlgs {nsrlg}? ..................... | +--rw te-nsrlgs {nsrlg}? .....................]]></sourcecode> | |||
]]></artwork> | </section> | |||
</figure> | <section anchor="sect-5.6" numbered="true" toc="default"> | |||
</section> | <name>Generic TE Node Attributes</name> | |||
<t> | ||||
<section title="Generic TE Node Attributes" anchor="sect-5.6"><t> | The model covers the definitions for generic TE node attributes.</t> | |||
The model covers the definitions for generic TE Node attributes.</t> | <t>The definition of a generic connectivity matrix is shown below:</t> | |||
<sourcecode name="" type="yangtree"><![CDATA[ | ||||
<t>The definition of a generic connectivity matrix is shown below:</t> | ||||
<figure><artwork><![CDATA[ | ||||
+--rw te-node-attributes | +--rw te-node-attributes | |||
........... | ........... | |||
+--rw connectivity-matrices | +--rw connectivity-matrices | |||
........... | ........... | |||
| +--rw connectivity-matrix* [id] | | +--rw connectivity-matrix* [id] | |||
| | +--rw id uint32 | | | +--rw id uint32 | |||
| | +--rw from | | | +--rw from | |||
| | | +--rw tp-ref? leafref | | | | +--rw tp-ref? leafref | |||
| | | +--rw label-restrictions | | | | +--rw label-restrictions | |||
| | +--rw to | | | +--rw to | |||
skipping to change at line 1293 ¶ | skipping to change at line 1215 ¶ | |||
| | | +--rw label-restrictions | | | | +--rw label-restrictions | |||
| | +--rw is-allowed? boolean | | | +--rw is-allowed? boolean | |||
........... | ........... | |||
| | +--rw underlay! {te-topology-hierarchy}? | | | +--rw underlay! {te-topology-hierarchy}? | |||
........... | ........... | |||
| | +--rw path-constraints | | | +--rw path-constraints | |||
........... | ........... | |||
| | +--rw optimizations | | | +--rw optimizations | |||
........... | ........... | |||
| | +--ro path-properties | | | +--ro path-properties | |||
........... | ...........]]></sourcecode> | |||
]]></artwork> | <t>The definition of a TTP Local Link Connectivity List is shown below:< | |||
</figure> | /t> | |||
<sourcecode name="" type="yangtree"><![CDATA[ | ||||
<t>The definition of a TTP Local Link Connectivity List is shown below:</t> | ||||
<figure><artwork><![CDATA[ | ||||
+--rw tunnel-termination-point* [tunnel-tp-id] | +--rw tunnel-termination-point* [tunnel-tp-id] | |||
+--rw tunnel-tp-id binary | +--rw tunnel-tp-id binary | |||
+--rw admin-status? te-types:te-admin-status | +--rw admin-status? te-types:te-admin-status | |||
+--rw name? string | +--rw name? string | |||
+--rw switching-capability? identityref | +--rw switching-capability? identityref | |||
+--rw encoding? identityref | +--rw encoding? identityref | |||
+--rw inter-layer-lock-id* uint32 | +--rw inter-layer-lock-id* uint32 | |||
+--rw protection-type? Identityref | +--rw protection-type? identityref | |||
+--rw client-layer-adaptation | +--rw client-layer-adaptation | |||
........... | ........... | |||
+--rw local-link-connectivities | +--rw local-link-connectivities | |||
........... | ........... | |||
| +--rw local-link-connectivity* [link-tp-ref] | | +--rw local-link-connectivity* [link-tp-ref] | |||
| +--rw link-tp-ref leafref | | +--rw link-tp-ref leafref | |||
| +--rw label-restrictions | | +--rw label-restrictions | |||
........... | ........... | |||
| +--rw is-allowed? boolean | | +--rw is-allowed? boolean | |||
| +--rw underlay {te-topology-hierarchy}? | | +--rw underlay {te-topology-hierarchy}? | |||
........... | ........... | |||
| +--rw path-constraints | | +--rw path-constraints | |||
........... | ........... | |||
| +--rw optimizations | | +--rw optimizations | |||
........... | ........... | |||
| +--ro path-properties | | +--ro path-properties | |||
........... | ........... | |||
+--rw supporting-tunnel-termination-point* [node-ref tunnel-tp- | +--rw supporting-tunnel-termination-point* | |||
ref] | [node-ref tunnel-tp-ref] | |||
+--rw node-ref inet:uri | +--rw node-ref inet:uri | |||
+--rw tunnel-tp-ref binary | +--rw tunnel-tp-ref binary]]></sourcecode> | |||
]]></artwork> | ||||
</figure> | ||||
<t> | ||||
The attributes directly under container connectivity-matrices are the | ||||
default attributes for all connectivity-matrix entries when the per entry | ||||
corresponding attribute is not specified. When a per entry attribute is | ||||
specified, it overrides the corresponding attribute directly under the | ||||
container connectivity-matrices. The same rule applies to the attributes | ||||
directly under container local-link-connectivities.</t> | ||||
<t> | <t> | |||
Each TTP (Tunnel Termination Point) MAY be supported by one or more | The attributes directly under container "connectivity-matrices" are the | |||
default attributes for all connectivity matrix entries when the per&nbhy;entr | ||||
y | ||||
corresponding attribute is not specified. When a per-entry attribute is | ||||
specified, it overrides the corresponding attribute directly under the | ||||
container "connectivity-matrices". The same rule applies to the attributes | ||||
directly under container "local&nbhy;link&nbhy;connectivities".</t> | ||||
<t> | ||||
Each TTP <bcp14>MAY</bcp14> be supported by one or more | ||||
supporting TTPs. If the TE node hosting the TTP in question refers to | supporting TTPs. If the TE node hosting the TTP in question refers to | |||
a supporting TE node, then the supporting TTPs are hosted by the | a supporting TE node, then the supporting TTPs are hosted by the | |||
supporting TE node. If the TE node refers to an underlay TE topology, | supporting TE node. If the TE node refers to an underlay TE topology, | |||
the supporting TTPs are hosted by one or more specified TE nodes of | the supporting TTPs are hosted by one or more specified TE nodes of | |||
the underlay TE topology.</t> | the underlay TE topology.</t> | |||
</section> | ||||
</section> | <section anchor="sect-5.7" numbered="true" toc="default"> | |||
<name>TED Information Sources</name> | ||||
<section title="TED Information Sources" anchor="sect-5.7"><t> | <t> | |||
The model allows each TE topological element to have multiple TE | The model allows each TE topological element to have multiple TE | |||
information sources (OSPF-TE, ISIS-TE, BGP-LS, User-Configured, | information sources (OSPF-TE, ISIS-TE, Border Gateway Protocol - Link State | |||
System-Processed, Other). Each information source is associated with | (BGP-LS), user-configured, | |||
system-processed, other). Each information source is associated with | ||||
a credibility preference to indicate precedence. In scenarios where a | a credibility preference to indicate precedence. In scenarios where a | |||
customized TE Topology is merged into a Client's native TE Topology, | Customized TE topology is merged into a client's Native TE topology, | |||
the merged topological elements would point to the corresponding | the merged topological elements would point to the corresponding | |||
customized TE Topology as its information source.</t> | Customized TE topology as its information source.</t> | |||
<sourcecode name="" type="yangtree"><![CDATA[ | ||||
<figure><artwork><![CDATA[ | augment /nw:networks/nw:network/nw:node: | |||
augment /nw:networks/nw:network/nw:node: | +--rw te! | |||
+--rw te! | ........... | |||
........... | +--ro information-source? te-info-source | |||
+--ro information-source? te-info-source | +--ro information-source-instance? string | |||
+--ro information-source-instance? string | +--ro information-source-state | |||
+--ro information-source-state | | +--ro credibility-preference? uint16 | |||
| +--ro credibility-preference? uint16 | | +--ro logical-network-element? string | |||
| +--ro logical-network-element? string | | +--ro network-instance? string | |||
| +--ro network-instance? string | | +--ro topology | |||
| +--ro topology | | +--ro node-ref? leafref | |||
| +--ro node-ref? leafref | | +--ro network-ref? leafref | |||
| +--ro network-ref? leafref | +--ro information-source-entry* | |||
+--ro information-source-entry* | | [information-source information-source-instance] | |||
| [information-source information-source-instance] | | +--ro information-source te-info-source | |||
| +--ro information-source te-info-source | | +--ro information-source-instance string | |||
| +--ro information-source-instance string | ............ | |||
............ | ||||
augment /nw:networks/nw:network/nt:link: | ||||
+--rw te! | ||||
........... | ||||
+--ro information-source? te-info-source | ||||
+--ro information-source-instance? string | ||||
+--ro information-source-state | ||||
| +--ro credibility-preference? uint16 | ||||
| +--ro logical-network-element? string | ||||
| +--ro network-instance? string | ||||
| +--ro topology | ||||
| +--ro link-ref? leafref | ||||
| +--ro network-ref? leafref | ||||
+--ro information-source-entry* | ||||
| [information-source information-source-instance] | ||||
| +--ro information-source te-info-source | ||||
| +--ro information-source-instance string | ||||
............ | ||||
]]></artwork> | ||||
</figure> | ||||
</section> | ||||
<section title="Overlay/Underlay Relationship" anchor="sect-5.8"><t> | augment /nw:networks/nw:network/nt:link: | |||
The model captures overlay and underlay relationship for TE | +--rw te! | |||
nodes/links. For example - in networks where multiple TE Topologies | ........... | |||
+--ro information-source? te-info-source | ||||
+--ro information-source-instance? string | ||||
+--ro information-source-state | ||||
| +--ro credibility-preference? uint16 | ||||
| +--ro logical-network-element? string | ||||
| +--ro network-instance? string | ||||
| +--ro topology | ||||
| +--ro link-ref? leafref | ||||
| +--ro network-ref? leafref | ||||
+--ro information-source-entry* | ||||
| [information-source information-source-instance] | ||||
| +--ro information-source te-info-source | ||||
| +--ro information-source-instance string | ||||
............]]></sourcecode> | ||||
</section> | ||||
<section anchor="sect-5.8" numbered="true" toc="default"> | ||||
<name>Overlay/Underlay Relationship</name> | ||||
<t> | ||||
The model captures the overlay and underlay relationship for TE | ||||
nodes/links. For example, in networks where multiple TE topologies | ||||
are built hierarchically, this model allows the user to start from a | are built hierarchically, this model allows the user to start from a | |||
specific topological element in the top most topology and traverse | specific topological element in the topmost topology and traverse | |||
all the way down to the supporting topological elements in the bottom | all the way down to the supporting topological elements in the | |||
most topology.</t> | bottommost topology.</t> | |||
<t> | ||||
<t> | ||||
This relationship is captured via the "underlay-topology" field for | This relationship is captured via the "underlay-topology" field for | |||
the node and via the "underlay" field for the link. The use of these | the node and via the "underlay" field for the link. The use of these | |||
fields is optional and this functionality is tagged as a "feature" | fields is optional, and this functionality is tagged as a "feature" | |||
("te-topology-hierarchy").</t> | ("te-topology-hierarchy").</t> | |||
<sourcecode name="" type="yangtree"><![CDATA[ | ||||
augment /nw:networks/nw:network/nw:node: | ||||
+--rw te-node-id? te-types:te-node-id | ||||
+--rw te! | ||||
+--rw te-node-template* leafref {template}? | ||||
+--rw te-node-attributes | ||||
| +--rw admin-status? te-types:te-admin-status | ||||
| | .................... | ||||
| +--rw underlay-topology {te-topology-hierarchy}? | ||||
| +--rw network-ref? leafref | ||||
<figure><artwork><![CDATA[ | augment /nw:networks/nw:network/nt:link: | |||
augment /nw:networks/nw:network/nw:node: | +--rw te! | |||
+--rw te-node-id? te-types:te-node-id | +--rw te-link-attributes | |||
+--rw te! | | .................... | |||
+--rw te-node-template* leafref {template}? | | +--rw underlay {te-topology-hierarchy}? | |||
+--rw te-node-attributes | | | +--rw enabled? boolean | |||
| +--rw admin-status? te-types:te-admin-status | | | +--rw primary-path | |||
| | .................... | | | | +--rw network-ref? leafref | |||
| +--rw underlay-topology {te-topology-hierarchy}? | | | | .................... | |||
| +--rw network-ref? leafref | | | +--rw backup-path* [index] | |||
| | | +--rw index uint32 | ||||
augment /nw:networks/nw:network/nt:link: | | | | +--rw network-ref? leafref | |||
+--rw te! | | | | .................... | |||
+--rw te-link-attributes | | | +--rw protection-type? identityref | |||
| .................... | | | +--rw tunnel-termination-points | |||
| +--rw underlay {te-topology-hierarchy}? | | | | +--rw source? binary | |||
| | +--rw enabled? boolean | | | | +--rw destination? binary | |||
| | +--rw primary-path | | | +--rw tunnels | |||
| | | +--rw network-ref? leafref | | | | ....................]]></sourcecode> | |||
| | | .................... | </section> | |||
| | +--rw backup-path* [index] | <section anchor="sect-5.9" numbered="true" toc="default"> | |||
| | | +--rw index uint32 | <name>Templates</name> | |||
| | | +--rw network-ref? leafref | <t> | |||
| | | .................... | The data model provides users with the ability to define | |||
| | +--rw protection-type? identityref | ||||
| | +--rw tunnel-termination-points | ||||
| | | +--rw source? binary | ||||
| | | +--rw destination? binary | ||||
| | +--rw tunnels | ||||
| | | .................... | ||||
]]></artwork> | ||||
</figure> | ||||
</section> | ||||
<section title="Templates" anchor="sect-5.9"><t> | ||||
The data model provides the users with the ability to define | ||||
templates and apply them to link and node configurations. The use of | templates and apply them to link and node configurations. The use of | |||
"template" configuration is optional and this functionality is tagged | the "template" configuration is optional, and this functionality is tagged | |||
as a "feature" ("template").</t> | as a "feature" ("template").</t> | |||
<sourcecode name="" type="yangtree"><![CDATA[ | ||||
augment /nw:networks/nw:network/nw:node: | ||||
+--rw te-node-id? te-types:te-node-id | ||||
+--rw te! | ||||
+--rw te-node-template* | ||||
| -> ../../../../te/templates/node-template/name | ||||
| {template}? | ||||
<figure><artwork><![CDATA[ | augment /nw:networks/nw:network/nt:link: | |||
augment /nw:networks/nw:network/nw:node: | +--rw te! | |||
+--rw te-node-id? te-types:te-node-id | +--rw te-link-template* | |||
+--rw te! | | -> ../../../../te/templates/link-template/name | |||
+--rw te-node-template* | | {template}? | |||
| -> ../../../../te/templates/node-template/name | ||||
| {template}? | ||||
augment /nw:networks/nw:network/nt:link: | ||||
+--rw te! | ||||
+--rw te-link-template* | ||||
| -> ../../../../te/templates/link-template/name | ||||
| {template}? | ||||
augment /nw:networks: | augment /nw:networks: | |||
+--rw te! | +--rw te! | |||
+--rw templates | +--rw templates | |||
+--rw node-template* [name] {template}? | +--rw node-template* [name] {template}? | |||
| +--rw name | | +--rw name | |||
| | te-types:te-template-name | | | te-types:te-template-name | |||
| +--rw priority? uint16 | | +--rw priority? uint16 | |||
| +--rw reference-change-policy? enumeration | | +--rw reference-change-policy? enumeration | |||
| +--rw te-node-attributes | | +--rw te-node-attributes | |||
.......... | .......... | |||
+--rw link-template* [name] {template}? | +--rw link-template* [name] {template}? | |||
+--rw name | +--rw name | |||
| te-types:te-template-name | | te-types:te-template-name | |||
+--rw priority? uint16 | +--rw priority? uint16 | |||
+--rw reference-change-policy? enumeration | +--rw reference-change-policy? enumeration | |||
+--rw te-link-attributes | +--rw te-link-attributes | |||
.......... | ..........]]></sourcecode> | |||
]]></artwork> | <t> | |||
</figure> | Multiple templates can be specified for a configuration element. When | |||
<t> | ||||
Multiple templates can be specified to a configuration element. When | ||||
two or more templates specify values for the same configuration | two or more templates specify values for the same configuration | |||
field, the value from the template with the highest priority is used. | field, the value from the template with the highest priority is used. | |||
The range of the priority is from 0 to 65535, with a lower number | The range of the priority is from 0 to 65535, with a lower number | |||
indicating a higher priority. The reference-change-policy specifies | indicating a higher priority. The "reference-change-policy" parameter specifi es | |||
the action that needs to be taken when the template changes on a | the action that needs to be taken when the template changes on a | |||
configuration element that has a reference to this template. The | configuration element that has a reference to this template. The | |||
choices of action include taking no action, rejecting the change to | choices of action include taking no action, rejecting the change to | |||
the template and applying the change to the corresponding | the template, and applying the change to the corresponding | |||
configuration.</t> | configuration.</t> | |||
</section> | ||||
</section> | <section anchor="sect-5.10" numbered="true" toc="default"> | |||
<name>Scheduling Parameters</name> | ||||
<section title="Scheduling Parameters" anchor="sect-5.10"><t> | <t> | |||
The model allows time scheduling parameters to be specified for each | The model allows time-scheduling parameters to be specified for each | |||
topological element or for the topology as a whole. These parameters | topological element or for the topology as a whole. These parameters | |||
allow the provider to present different topological views to the | allow the provider to present different topological views to the | |||
client at different time slots. The use of "scheduling parameters" is | client at different time slots. The use of time-scheduling parameters is | |||
optional.</t> | optional.</t> | |||
<t> | ||||
<t> | The YANG data model for configuration scheduling is defined in <xref target=" | |||
The YANG data model for configuration scheduling is defined in <xref | YANG-CFG-SCHED" format="default"/>, which allows specifying | |||
target="I-D.liu-netmod-yang-schedule"/>, which allows specifying | ||||
configuration schedules without altering this data model.</t> | configuration schedules without altering this data model.</t> | |||
</section> | ||||
</section> | <section anchor="sect-5.11" numbered="true" toc="default"> | |||
<name>Notifications</name> | ||||
<section title="Notifications" anchor="sect-5.11"><t> | <t> | |||
Notifications are a key component of any topology data model.</t> | Notifications are a key component of any topology data model.</t> | |||
<t> | ||||
<t> | <xref target="RFC8639" format="default"/> and <xref target="RFC8641"/> | |||
<xref target="I-D.ietf-netconf-subscribed-notifications"/> and <xref | define a subscription mechanism and a push | |||
target="I-D.ietf-netconf-yang-push"/> define a subscription and push | mechanism for YANG datastores. These mechanisms currently allow the user | |||
mechanism for YANG datastores. This mechanism currently allows the user | ||||
to:</t> | to:</t> | |||
<ul spacing="normal"> | ||||
<t><list style="symbols"><t>Subscribe notifications on a per client basis | <li>Subscribe to notifications on a per-client basis.</li> | |||
</t> | <li>Specify subtree filters or XML Path Language (XPath) filters so th | |||
at only | ||||
<t>Specify subtree filters or xpath filters so that only interested | contents of interest will be sent.</li> | |||
contents will be sent.</t> | <li>Specify either periodic or on-demand notifications.</li> | |||
</ul> | ||||
<t>Specify either periodic or on-demand notifications.</t> | </section> | |||
</section> | ||||
</list> | <section anchor="sect-6" numbered="true" toc="default"> | |||
</t> | <name>Guidance for Writing Technology-Specific TE Topology Augmentations</ | |||
name> | ||||
</section> | <t> | |||
The TE topology model defined in this document is technology agnostic, | ||||
</section> | as it defines concepts, abstractions, and attributes that are common | |||
<section title="Guidance for Writing Technology Specific TE Topology Augm | ||||
entations" anchor="sect-6"><t> | ||||
The TE topology model defined in this document is technology agnostic | ||||
as it defines concepts, abstractions and attributes that are common | ||||
across multiple network technologies. It is envisioned that this base | across multiple network technologies. It is envisioned that this base | |||
model will be widely used when defining technology specific TE | model will be widely used when defining technology-specific TE | |||
topology models for various layer networks. | topology models for various layer networks. | |||
<xref target="I-D.ietf-ccamp-wson-yang"/>, <xref target="I-D.ietf-ccamp-otn-t | <xref target="YANG-WSON" format="default"/>, <xref target="YANG-OTN" format=" | |||
opo-yang"/>, and | default"/>, and | |||
<xref target="I-D.ietf-teas-yang-l3-te-topo"/> are some examples of technolog | <xref target="YANG-L3" format="default"/> are some examples of | |||
y | technology-specific TE topology models. Writers of such models are encouraged | |||
specific TE Topology models. Writers of such models are encouraged to | to | |||
augment the basic TE topology model's containers, such as TE | augment the basic TE topology model's containers, such as those for TE | |||
Topology, TE Node, TE Link, Link Termination Point (LTP), Tunnel | topologies, TE nodes, TE links, Link Termination Points (LTPs), Tunnel | |||
Termination Point (TTP), Bandwidth and Label with the layer specific | Termination Points (TTPs), bandwidth, and labels, with the layer-specific | |||
attributes instead of defining new containers.</t> | attributes instead of defining new containers.</t> | |||
<t> | ||||
Consider the following technology-specific example-topology model:</t> | ||||
<t> | <sourcecode name="" type="yangtree"><![CDATA[ | |||
Consider the following technology specific example-topology model:</t> | ||||
<figure><artwork><![CDATA[ | ||||
module: example-topology | module: example-topology | |||
augment /nw:networks/nw:network/nw:network-types/tet:te-topology: | augment /nw:networks/nw:network/nw:network-types/tet:te-topology: | |||
+--rw example-topology! | +--rw example-topology! | |||
augment /nw:networks/nw:network/tet:te: | augment /nw:networks/nw:network/tet:te: | |||
+--rw attributes | +--rw attributes | |||
+--rw attribute-1? uint8 | +--rw attribute-1? uint8 | |||
augment /nw:networks/nw:network/nw:node/tet:te | augment /nw:networks/nw:network/nw:node/tet:te | |||
/tet:te-node-attributes: | /tet:te-node-attributes: | |||
+--rw attributes | +--rw attributes | |||
+--rw attribute-2? uint8 | +--rw attribute-2? uint8 | |||
skipping to change at line 1583 ¶ | skipping to change at line 1484 ¶ | |||
/tet:tunnel-termination-point: | /tet:tunnel-termination-point: | |||
+--rw attributes | +--rw attributes | |||
+--rw attribute-4? uint8 | +--rw attribute-4? uint8 | |||
augment /nw:networks/nw:network/nw:node/nt:termination-point | augment /nw:networks/nw:network/nw:node/nt:termination-point | |||
/tet:te: | /tet:te: | |||
+--rw attributes | +--rw attributes | |||
+--rw attribute-5? uint8 | +--rw attribute-5? uint8 | |||
augment /nw:networks/nw:network/nt:link/tet:te | augment /nw:networks/nw:network/nt:link/tet:te | |||
/tet:te-link-attributes: | /tet:te-link-attributes: | |||
+--rw attributes | +--rw attributes | |||
+--rw attribute-6? uint8 | +--rw attribute-6? uint8]]></sourcecode> | |||
]]></artwork> | <t> | |||
</figure> | The technology-specific TE bandwidth for this example topology can be | |||
<t> | ||||
The technology specific TE bandwidth for this example topology can be | ||||
specified using the following augment statements:</t> | specified using the following augment statements:</t> | |||
<sourcecode name="" type="yangtree"><![CDATA[ | ||||
<figure><artwork><![CDATA[ | ||||
augment /nw:networks/tet:te/tet:templates/tet:link-template | augment /nw:networks/tet:te/tet:templates/tet:link-template | |||
/tet:te-link-attributes | /tet:te-link-attributes | |||
/tet:interface-switching-capability/tet:max-lsp-bandwidth | /tet:interface-switching-capability/tet:max-lsp-bandwidth | |||
/tet:te-bandwidth/tet:technology: | /tet:te-bandwidth/tet:technology: | |||
+--:(example) | +--:(example) | |||
+--rw example | +--rw example | |||
+--rw bandwidth-1? uint32 | +--rw bandwidth-1? uint32 | |||
augment /nw:networks/tet:te/tet:templates/tet:link-template | augment /nw:networks/tet:te/tet:templates/tet:link-template | |||
/tet:te-link-attributes/tet:max-link-bandwidth | /tet:te-link-attributes/tet:max-link-bandwidth | |||
/tet:te-bandwidth/tet:technology: | /tet:te-bandwidth/tet:technology: | |||
skipping to change at line 1714 ¶ | skipping to change at line 1611 ¶ | |||
/tet:information-source-entry/tet:unreserved-bandwidth | /tet:information-source-entry/tet:unreserved-bandwidth | |||
/tet:te-bandwidth/tet:technology: | /tet:te-bandwidth/tet:technology: | |||
+--:(example) | +--:(example) | |||
+--ro example | +--ro example | |||
+--ro bandwidth-1? uint32 | +--ro bandwidth-1? uint32 | |||
augment /nw:networks/nw:network/nw:node/nt:termination-point/tet:te | augment /nw:networks/nw:network/nw:node/nt:termination-point/tet:te | |||
/tet:interface-switching-capability/tet:max-lsp-bandwidth | /tet:interface-switching-capability/tet:max-lsp-bandwidth | |||
/tet:te-bandwidth/tet:technology: | /tet:te-bandwidth/tet:technology: | |||
+--:(example) | +--:(example) | |||
+--rw example | +--rw example | |||
+--rw bandwidth-1? uint32 | +--rw bandwidth-1? uint32]]></sourcecode> | |||
]]></artwork> | <t> | |||
</figure> | The technology-specific TE label for this example topology can be | |||
<t> | ||||
The technology specific TE label for this example topology can be | ||||
specified using the following augment statements:</t> | specified using the following augment statements:</t> | |||
<sourcecode name="" type="yangtree"><![CDATA[ | ||||
<figure><artwork><![CDATA[ | ||||
augment /nw:networks/tet:te/tet:templates/tet:link-template | augment /nw:networks/tet:te/tet:templates/tet:link-template | |||
/tet:te-link-attributes/tet:underlay/tet:primary-path | /tet:te-link-attributes/tet:underlay/tet:primary-path | |||
/tet:path-element/tet:type/tet:label/tet:label-hop | /tet:path-element/tet:type/tet:label/tet:label-hop | |||
/tet:te-label/tet:technology: | /tet:te-label/tet:technology: | |||
+--:(example) | +--:(example) | |||
+--rw example | +--rw example | |||
+--rw label-1? uint32 | +--rw label-1? uint32 | |||
augment /nw:networks/tet:te/tet:templates/tet:link-template | augment /nw:networks/tet:te/tet:templates/tet:link-template | |||
/tet:te-link-attributes/tet:underlay/tet:backup-path | /tet:te-link-attributes/tet:underlay/tet:backup-path | |||
/tet:path-element/tet:type/tet:label/tet:label-hop | /tet:path-element/tet:type/tet:label/tet:label-hop | |||
skipping to change at line 2061 ¶ | skipping to change at line 1954 ¶ | |||
/tet:technology: | /tet:technology: | |||
+--:(example) | +--:(example) | |||
+--ro example | +--ro example | |||
+--ro label-1? uint32 | +--ro label-1? uint32 | |||
augment /nw:networks/nw:network/nt:link/tet:te | augment /nw:networks/nw:network/nt:link/tet:te | |||
/tet:information-source-entry/tet:label-restrictions | /tet:information-source-entry/tet:label-restrictions | |||
/tet:label-restriction/tet:label-end/tet:te-label | /tet:label-restriction/tet:label-end/tet:te-label | |||
/tet:technology: | /tet:technology: | |||
+--:(example) | +--:(example) | |||
+--ro example | +--ro example | |||
+--ro label-1? uint32 | +--ro label-1? uint32]]></sourcecode> | |||
]]></artwork> | <t> | |||
</figure> | The example YANG module that implements the above example topology is | |||
<t> | provided in <xref target="append-c"/>.</t> | |||
The YANG module to implement the above example topology can be seen | </section> | |||
in Appendix C.</t> | <section anchor="sect-7" numbered="true" toc="default"> | |||
<name>TE Topology YANG Module</name> | ||||
</section> | <t> | |||
<section title="TE Topology YANG Module" anchor="sect-7"><t> | ||||
This module references [<xref target="RFC1195"/>], [<xref target="RFC3209"/>], | This module references <xref target="RFC1195" format="default"/>, <xref | |||
[<xref target="RFC3272"/>], [<xref target="RFC3471"/>], [<xref | target="RFC3209" format="default"/>, <xref target="RFC3272" | |||
target="RFC3630"/>], [<xref target="RFC3785"/>], [<xref target="RFC4201"/>], | format="default"/>, <xref target="RFC3471" format="default"/>, <xref | |||
[<xref target="RFC4202"/>], [<xref target="RFC4203"/>], [<xref | target="RFC3630" format="default"/>, <xref target="RFC3785" | |||
target="RFC4206"/>], [<xref target="RFC4872"/>], [<xref target="RFC5152"/>], | format="default"/>, <xref target="RFC4201" format="default"/>, <xref | |||
[<xref target="RFC5212"/>], [<xref target="RFC5305"/>], [<xref | target="RFC4202" format="default"/>, <xref target="RFC4203" | |||
target="RFC5316"/>], [<xref target="RFC5329"/>], [<xref target="RFC5392"/>], | format="default"/>, <xref target="RFC4206" format="default"/>, <xref | |||
[<xref target="RFC6001"/>], [<xref target="RFC6241"/>], [<xref | target="RFC4872" format="default"/>, <xref target="RFC5152" | |||
target="RFC6991"/>], [<xref target="RFC7308"/>], [<xref target="RFC7471"/>], | format="default"/>, <xref target="RFC5212" format="default"/>, <xref | |||
[<xref target="RFC7579"/>], [<xref target="RFC7752"/>], [<xref | target="RFC5305" format="default"/>, <xref target="RFC5316" | |||
target="RFC8345"/>], and [<xref target="I-D.ietf-teas-yang-te-types"/>].</t> | format="default"/>, <xref target="RFC5392" format="default"/>, <xref | |||
target="RFC6001" format="default"/>, <xref target="RFC6241" | ||||
format="default"/>, <xref target="RFC6991" format="default"/>, <xref | ||||
target="RFC7308" format="default"/>, <xref target="RFC7471" | ||||
format="default"/>, <xref target="RFC7579" format="default"/>, <xref | ||||
target="RFC7752" format="default"/>, <xref target="RFC8345" | ||||
format="default"/>, and <xref target="RFC8776"/>.</t> | ||||
<figure><artwork><![CDATA[ | <sourcecode name="ietf-te-topology@2020-06-29.yang" type="yang" markers="true">< | |||
<CODE BEGINS> file "ietf-te-topology@2019-02-07.yang" | ![CDATA[ | |||
module ietf-te-topology { | module ietf-te-topology { | |||
yang-version 1.1; | yang-version 1.1; | |||
namespace "urn:ietf:params:xml:ns:yang:ietf-te-topology"; | namespace "urn:ietf:params:xml:ns:yang:ietf-te-topology"; | |||
prefix tet; | ||||
prefix "tet"; | ||||
import ietf-yang-types { | import ietf-yang-types { | |||
prefix "yang"; | prefix yang; | |||
reference "RFC 6991: Common YANG Data Types"; | reference | |||
"RFC 6991: Common YANG Data Types"; | ||||
} | } | |||
import ietf-inet-types { | import ietf-inet-types { | |||
prefix "inet"; | prefix inet; | |||
reference "RFC 6991: Common YANG Data Types"; | reference | |||
"RFC 6991: Common YANG Data Types"; | ||||
} | } | |||
import ietf-te-types { | import ietf-te-types { | |||
prefix "te-types"; | prefix te-types; | |||
reference | reference | |||
"I-D.ietf-teas-yang-te-types: Traffic Engineering Common YANG | "RFC 8776: Common YANG Data Types for Traffic Engineering"; | |||
Types"; | ||||
} | } | |||
import ietf-network { | import ietf-network { | |||
prefix "nw"; | prefix nw; | |||
reference "RFC 8345: A YANG Data Model for Network Topologies"; | reference | |||
"RFC 8345: A YANG Data Model for Network Topologies"; | ||||
} | } | |||
import ietf-network-topology { | import ietf-network-topology { | |||
prefix "nt"; | prefix nt; | |||
reference "RFC 8345: A YANG Data Model for Network Topologies"; | reference | |||
"RFC 8345: A YANG Data Model for Network Topologies"; | ||||
} | } | |||
organization | organization | |||
"IETF Traffic Engineering Architecture and Signaling (TEAS) | "IETF Traffic Engineering Architecture and Signaling (TEAS) | |||
Working Group"; | Working Group"; | |||
contact | contact | |||
"WG Web: <http://tools.ietf.org/wg/teas/> | "WG Web: <https://datatracker.ietf.org/wg/teas/> | |||
WG List: <mailto:teas@ietf.org> | WG List: <mailto:teas@ietf.org> | |||
Editor: Xufeng Liu | Editor: Xufeng Liu | |||
<mailto:xufeng.liu.ietf@gmail.com> | <mailto:xufeng.liu.ietf@gmail.com> | |||
Editor: Igor Bryskin | Editor: Igor Bryskin | |||
<mailto:Igor.Bryskin@huawei.com> | <mailto:i_bryskin@yahoo.com> | |||
Editor: Vishnu Pavan Beeram | Editor: Vishnu Pavan Beeram | |||
<mailto:vbeeram@juniper.net> | <mailto:vbeeram@juniper.net> | |||
Editor: Tarek Saad | Editor: Tarek Saad | |||
<mailto:tsaad@juniper.net> | <mailto:tsaad@juniper.net> | |||
Editor: Himanshu Shah | Editor: Himanshu Shah | |||
<mailto:hshah@ciena.com> | <mailto:hshah@ciena.com> | |||
Editor: Oscar Gonzalez De Dios | Editor: Oscar Gonzalez de Dios | |||
<mailto:oscar.gonzalezdedios@telefonica.com>"; | <mailto:oscar.gonzalezdedios@telefonica.com>"; | |||
description | description | |||
"TE topology model for representing and manipulating technology | "This YANG module defines a TE topology model for representing, | |||
agnostic TE Topologies. | retrieving, and manipulating technology-agnostic TE topologies. | |||
Copyright (c) 2019 IETF Trust and the persons identified as | Copyright (c) 2020 IETF Trust and the persons identified as | |||
authors of the code. All rights reserved. | authors of the code. All rights reserved. | |||
Redistribution and use in source and binary forms, with or | Redistribution and use in source and binary forms, with or | |||
without modification, is permitted pursuant to, and subject to | without modification, is permitted pursuant to, and subject to | |||
the license terms contained in, the Simplified BSD License set | the license terms contained in, the Simplified BSD License set | |||
forth in Section 4.c of the IETF Trust's Legal Provisions | forth in Section 4.c of the IETF Trust's Legal Provisions | |||
Relating to IETF Documents | Relating to IETF Documents | |||
(http://trustee.ietf.org/license-info). | (https://trustee.ietf.org/license-info). | |||
This version of this YANG module is part of RFC XXXX; see the | This version of this YANG module is part of RFC 8795; see the | |||
RFC itself for full legal notices."; | RFC itself for full legal notices."; | |||
revision "2019-02-07" { | revision 2020-06-29 { | |||
description "Initial revision"; | description | |||
reference "RFC XXXX: YANG Data Model for TE Topologies"; | "Initial revision."; | |||
// RFC Ed.: replace XXXX with actual RFC number and remove | reference | |||
// this note | "RFC 8795: YANG Data Model for Traffic Engineering (TE) | |||
Topologies"; | ||||
} | } | |||
/* | /* | |||
* Features | * Features | |||
*/ | */ | |||
feature nsrlg { | feature nsrlg { | |||
description | description | |||
"This feature indicates that the system supports NSRLG | "This feature indicates that the system supports NSRLGs | |||
(Not Sharing Risk Link Group)."; | (Non-Shared Risk Link Groups)."; | |||
} | } | |||
feature te-topology-hierarchy { | feature te-topology-hierarchy { | |||
description | description | |||
"This feature indicates that the system allows underlay | "This feature indicates that the system allows an underlay | |||
and/or overlay TE topology hierarchy."; | and/or overlay TE topology hierarchy."; | |||
} | } | |||
feature template { | feature template { | |||
description | description | |||
"This feature indicates that the system supports | "This feature indicates that the system supports | |||
template configuration."; | template configuration."; | |||
} | } | |||
/* | /* | |||
skipping to change at line 2192 ¶ | skipping to change at line 2087 ¶ | |||
feature template { | feature template { | |||
description | description | |||
"This feature indicates that the system supports | "This feature indicates that the system supports | |||
template configuration."; | template configuration."; | |||
} | } | |||
/* | /* | |||
* Typedefs | * Typedefs | |||
*/ | */ | |||
typedef geographic-coordinate-degree { | typedef geographic-coordinate-degree { | |||
type decimal64 { | type decimal64 { | |||
fraction-digits 8; | fraction-digits 8; | |||
} | } | |||
description | description | |||
"Decimal degree (DD) used to express latitude and longitude | "Decimal degree (DD) used to express latitude and longitude | |||
geographic coordinates."; | geographic coordinates."; | |||
} // geographic-coordinate-degree | } | |||
// geographic-coordinate-degree | ||||
typedef te-info-source { | typedef te-info-source { | |||
type enumeration { | type enumeration { | |||
enum "unknown" { | enum unknown { | |||
description "The source is unknown."; | description | |||
"The source is unknown."; | ||||
} | } | |||
enum "locally-configured" { | enum locally-configured { | |||
description "Configured entity."; | description | |||
"Configured entity."; | ||||
} | } | |||
enum "ospfv2" { | enum ospfv2 { | |||
description "OSPFv2."; | description | |||
"OSPFv2."; | ||||
} | } | |||
enum "ospfv3" { | enum ospfv3 { | |||
description "OSPFv3."; | description | |||
"OSPFv3."; | ||||
} | } | |||
enum "isis" { | enum isis { | |||
description "ISIS."; | description | |||
"IS-IS."; | ||||
} | } | |||
enum "bgp-ls" { | enum bgp-ls { | |||
description "BGP-LS."; | description | |||
"BGP-LS."; | ||||
reference | reference | |||
"RFC 7752: North-Bound Distribution of Link-State and | "RFC 7752: North-Bound Distribution of Link-State and | |||
Traffic Engineering (TE) Information Using BGP"; | Traffic Engineering (TE) Information Using BGP"; | |||
} | } | |||
enum "system-processed" { | enum system-processed { | |||
description "System processed entity."; | description | |||
"System-processed entity."; | ||||
} | } | |||
enum "other" { | enum other { | |||
description "Other source."; | description | |||
"Other source."; | ||||
} | } | |||
} | } | |||
description | description | |||
"Describining the type of source that has provided the | "Describes the type of source that has provided the | |||
related information, and the source credibility."; | related information, and the source's credibility."; | |||
} // te-info-source | } | |||
// te-info-source | ||||
/* | /* | |||
* Groupings | * Groupings | |||
*/ | */ | |||
grouping connectivity-matrix-entry-path-attributes { | grouping connectivity-matrix-entry-path-attributes { | |||
description | description | |||
"Attributes of connectivity matrix entry."; | "Attributes of a connectivity matrix entry."; | |||
leaf is-allowed { | leaf is-allowed { | |||
type boolean; | type boolean; | |||
description | description | |||
"true - switching is allowed, | "'true' - switching is allowed; | |||
false - switching is disallowed."; | 'false' - switching is disallowed."; | |||
} | } | |||
container underlay { | container underlay { | |||
if-feature te-topology-hierarchy; | if-feature "te-topology-hierarchy"; | |||
description "Attributes of the te-link underlay."; | description | |||
"Attributes of the TE link underlay."; | ||||
reference | reference | |||
"RFC 4206: Label Switched Paths (LSP) Hierarchy with | "RFC 4206: Label Switched Paths (LSP) Hierarchy with | |||
Generalized Multi-Protocol Label Switching (GMPLS) | Generalized Multi-Protocol Label Switching (GMPLS) | |||
Traffic Engineering (TE)"; | Traffic Engineering (TE)"; | |||
uses te-link-underlay-attributes; | uses te-link-underlay-attributes; | |||
} // underlay | } | |||
uses te-types:generic-path-constraints; | uses te-types:generic-path-constraints; | |||
uses te-types:generic-path-optimization; | uses te-types:generic-path-optimization; | |||
uses te-types:generic-path-properties; | uses te-types:generic-path-properties; | |||
} // connectivity-matrix-entry-path-attributes | } | |||
// connectivity-matrix-entry-path-attributes | ||||
grouping geolocation-container { | grouping geolocation-container { | |||
description | description | |||
"A container containing a GPS location."; | "Contains a GPS location."; | |||
container geolocation{ | container geolocation { | |||
config false; | config false; | |||
description | description | |||
"A container containing a GPS location."; | "Contains a GPS location."; | |||
leaf altitude { | leaf altitude { | |||
type int64; | type int64; | |||
units millimeter; | units "millimeters"; | |||
description | description | |||
"Distance above the sea level."; | "Distance above sea level."; | |||
} | } | |||
leaf latitude { | leaf latitude { | |||
type geographic-coordinate-degree { | type geographic-coordinate-degree { | |||
range "-90..90"; | range "-90..90"; | |||
} | } | |||
description | description | |||
"Relative position north or south on the Earth's surface."; | "Relative position north or south on the Earth's surface."; | |||
} | } | |||
leaf longitude { | leaf longitude { | |||
type geographic-coordinate-degree { | type geographic-coordinate-degree { | |||
range "-180..180"; | range "-180..180"; | |||
} | } | |||
description | description | |||
"Angular distance east or west on the Earth's surface."; | "Angular distance east or west on the Earth's surface."; | |||
} | } | |||
} // gps-location | } | |||
} // geolocation-container | // geolocation | |||
} | ||||
// geolocation-container | ||||
grouping information-source-state-attributes { | grouping information-source-state-attributes { | |||
description | description | |||
"The attributes identifying source that has provided the | "The attributes identifying the source that has provided the | |||
related information, and the source credibility."; | related information, and the source's credibility."; | |||
leaf credibility-preference { | leaf credibility-preference { | |||
type uint16; | type uint16; | |||
description | description | |||
"The preference value to calculate the traffic | "The preference value for calculating the Traffic | |||
engineering database credibility value used for | Engineering database credibility value used for | |||
tie-break selection between different | tie-break selection between different information-source | |||
information-source values. | values. A higher value is preferable."; | |||
Higher value is more preferable."; | ||||
} | } | |||
leaf logical-network-element { | leaf logical-network-element { | |||
type string; | type string; | |||
description | description | |||
"When applicable, this is the name of a logical network | "When applicable, this is the name of a logical network | |||
element from which the information is learned."; | element from which the information is learned."; | |||
} // logical-network-element | } | |||
leaf network-instance { | leaf network-instance { | |||
type string; | type string; | |||
description | description | |||
"When applicable, this is the name of a network-instance | "When applicable, this is the name of a network instance | |||
from which the information is learned."; | from which the information is learned."; | |||
} // network-instance | } | |||
} // information-source-state-attributes | } | |||
// information-source-state-attributes | ||||
grouping information-source-per-link-attributes { | grouping information-source-per-link-attributes { | |||
description | description | |||
"Per node container of the attributes identifying source that | "Per-node container of the attributes identifying the source | |||
has provided the related information, and the source | that has provided the related information, and the source's | |||
credibility."; | credibility."; | |||
leaf information-source { | leaf information-source { | |||
type te-info-source; | type te-info-source; | |||
config false; | config false; | |||
description | description | |||
"Indicates the type of the information source."; | "Indicates the type of information source."; | |||
} | } | |||
leaf information-source-instance { | leaf information-source-instance { | |||
type string; | type string; | |||
config false; | config false; | |||
description | description | |||
"The name indicating the instance of the information | "The name indicating the instance of the information | |||
source."; | source."; | |||
} | } | |||
container information-source-state { | container information-source-state { | |||
config false; | config false; | |||
description | description | |||
"The container contains state attributes related to | "Contains state attributes related to the information | |||
the information source."; | source."; | |||
uses information-source-state-attributes; | uses information-source-state-attributes; | |||
container topology { | container topology { | |||
description | description | |||
"When the information is processed by the system, | "When the information is processed by the system, | |||
the attributes in this container indicate which topology | the attributes in this container indicate which topology | |||
is used to process to generate the result information."; | is used to generate the result information."; | |||
uses nt:link-ref; | uses nt:link-ref; | |||
} // topology | } | |||
} // information-source-state | } | |||
} // information-source-per-link-attributes | } | |||
// information-source-per-link-attributes | ||||
grouping information-source-per-node-attributes { | grouping information-source-per-node-attributes { | |||
description | description | |||
"Per node container of the attributes identifying source that | "Per-node container of the attributes identifying the source | |||
has provided the related information, and the source | that has provided the related information, and the source's | |||
credibility."; | credibility."; | |||
leaf information-source { | leaf information-source { | |||
type te-info-source; | type te-info-source; | |||
config false; | config false; | |||
description | description | |||
"Indicates the type of the information source."; | "Indicates the type of information source."; | |||
} | } | |||
leaf information-source-instance { | leaf information-source-instance { | |||
type string; | type string; | |||
config false; | config false; | |||
description | description | |||
"The name indicating the instance of the information | "The name indicating the instance of the information | |||
source."; | source."; | |||
} | } | |||
container information-source-state { | container information-source-state { | |||
config false; | config false; | |||
description | description | |||
"The container contains state attributes related to | "Contains state attributes related to the information | |||
the information source."; | source."; | |||
uses information-source-state-attributes; | uses information-source-state-attributes; | |||
container topology { | container topology { | |||
description | description | |||
"When the information is processed by the system, | "When the information is processed by the system, | |||
the attributes in this container indicate which topology | the attributes in this container indicate which topology | |||
is used to process to generate the result information."; | is used to generate the result information."; | |||
uses nw:node-ref; | uses nw:node-ref; | |||
} // topology | } | |||
} // information-source-state | } | |||
} // information-source-per-node-attributes | } | |||
// information-source-per-node-attributes | ||||
grouping interface-switching-capability-list { | grouping interface-switching-capability-list { | |||
description | description | |||
"List of Interface Switching Capabilities Descriptors (ISCD)"; | "List of Interface Switching Capability Descriptors (ISCDs)."; | |||
list interface-switching-capability { | list interface-switching-capability { | |||
key "switching-capability encoding"; | key "switching-capability encoding"; | |||
description | description | |||
"List of Interface Switching Capabilities Descriptors (ISCD) | "List of ISCDs for this link."; | |||
for this link."; | ||||
reference | reference | |||
"RFC 3471: Generalized Multi-Protocol Label Switching (GMPLS) | "RFC 3471: Generalized Multi-Protocol Label Switching (GMPLS) | |||
Signaling Functional Description. | Signaling Functional Description | |||
RFC 4203: OSPF Extensions in Support of Generalized | RFC 4203: OSPF Extensions in Support of Generalized | |||
Multi-Protocol Label Switching (GMPLS)."; | Multi-Protocol Label Switching (GMPLS)"; | |||
leaf switching-capability { | leaf switching-capability { | |||
type identityref { | type identityref { | |||
base te-types:switching-capabilities; | base te-types:switching-capabilities; | |||
} | } | |||
description | description | |||
"Switching Capability for this interface."; | "Switching capability for this interface."; | |||
} | } | |||
leaf encoding { | leaf encoding { | |||
type identityref { | type identityref { | |||
base te-types:lsp-encoding-types; | base te-types:lsp-encoding-types; | |||
} | } | |||
description | description | |||
"Encoding supported by this interface."; | "Encoding supported by this interface."; | |||
} | } | |||
uses te-link-iscd-attributes; | uses te-link-iscd-attributes; | |||
} // interface-switching-capability | } | |||
} // interface-switching-capability-list | // interface-switching-capability | |||
} | ||||
// interface-switching-capability-list | ||||
grouping statistics-per-link { | grouping statistics-per-link { | |||
description | description | |||
"Statistics attributes per TE link."; | "Statistics attributes per TE link."; | |||
leaf discontinuity-time { | leaf discontinuity-time { | |||
type yang:date-and-time; | type yang:date-and-time; | |||
description | description | |||
"The time on the most recent occasion at which any one or | "The time of the most recent occasion at which any one or | |||
more of this interface's counters suffered a | more of this interface's counters suffered a | |||
discontinuity. If no such discontinuities have occurred | discontinuity. If no such discontinuities have occurred | |||
since the last re-initialization of the local management | since the last re-initialization of the local management | |||
subsystem, then this node contains the time the local | subsystem, then this node contains the time the local | |||
management subsystem re-initialized itself."; | management subsystem re-initialized itself."; | |||
} | } | |||
/* Administrative attributes */ | /* Administrative attributes */ | |||
leaf disables { | leaf disables { | |||
type yang:counter32; | type yang:counter32; | |||
description | description | |||
"Number of times that link was disabled."; | "Number of times that a link was disabled."; | |||
} | } | |||
leaf enables { | leaf enables { | |||
type yang:counter32; | type yang:counter32; | |||
description | description | |||
"Number of times that link was enabled."; | "Number of times that a link was enabled."; | |||
} | } | |||
leaf maintenance-clears { | leaf maintenance-clears { | |||
type yang:counter32; | type yang:counter32; | |||
description | description | |||
"Number of times that link was put out of maintenance."; | "Number of times that a link was taken out of maintenance."; | |||
} | } | |||
leaf maintenance-sets { | leaf maintenance-sets { | |||
type yang:counter32; | type yang:counter32; | |||
description | description | |||
"Number of times that link was put in maintenance."; | "Number of times that a link was put in maintenance."; | |||
} | } | |||
leaf modifies { | leaf modifies { | |||
type yang:counter32; | type yang:counter32; | |||
description | description | |||
"Number of times that link was modified."; | "Number of times that a link was modified."; | |||
} | } | |||
/* Operational attributes */ | /* Operational attributes */ | |||
leaf downs { | leaf downs { | |||
type yang:counter32; | type yang:counter32; | |||
description | description | |||
"Number of times that link was set to operational down."; | "Number of times that a link was set to an operational state | |||
of 'down'."; | ||||
} | } | |||
leaf ups { | leaf ups { | |||
type yang:counter32; | type yang:counter32; | |||
description | description | |||
"Number of times that link was set to operational up."; | "Number of times that a link was set to an operational state | |||
of 'up'."; | ||||
} | } | |||
/* Recovery attributes */ | /* Recovery attributes */ | |||
leaf fault-clears { | leaf fault-clears { | |||
type yang:counter32; | type yang:counter32; | |||
description | description | |||
"Number of times that link experienced fault clear event."; | "Number of times that a link experienced a fault-clear | |||
event."; | ||||
} | } | |||
leaf fault-detects { | leaf fault-detects { | |||
type yang:counter32; | type yang:counter32; | |||
description | description | |||
"Number of times that link experienced fault detection."; | "Number of times that a link experienced fault detection."; | |||
} | } | |||
leaf protection-switches { | leaf protection-switches { | |||
type yang:counter32; | type yang:counter32; | |||
description | description | |||
"Number of times that link experienced protection | "Number of times that a link experienced protection | |||
switchover."; | switchover."; | |||
} | } | |||
leaf protection-reverts { | leaf protection-reverts { | |||
type yang:counter32; | type yang:counter32; | |||
description | description | |||
"Number of times that link experienced protection | "Number of times that a link experienced protection | |||
reversion."; | reversion."; | |||
} | } | |||
leaf restoration-failures { | leaf restoration-failures { | |||
type yang:counter32; | type yang:counter32; | |||
description | description | |||
"Number of times that link experienced restoration | "Number of times that a link experienced restoration | |||
failure."; | failure."; | |||
} | } | |||
leaf restoration-starts { | leaf restoration-starts { | |||
type yang:counter32; | type yang:counter32; | |||
description | description | |||
"Number of times that link experienced restoration | "Number of times that a link experienced restoration | |||
start."; | start."; | |||
} | } | |||
leaf restoration-successes { | leaf restoration-successes { | |||
type yang:counter32; | type yang:counter32; | |||
description | description | |||
"Number of times that link experienced restoration | "Number of times that a link experienced restoration | |||
success."; | success."; | |||
} | } | |||
leaf restoration-reversion-failures { | leaf restoration-reversion-failures { | |||
type yang:counter32; | type yang:counter32; | |||
description | description | |||
"Number of times that link experienced restoration reversion | "Number of times that a link experienced restoration | |||
failure."; | reversion failure."; | |||
} | } | |||
leaf restoration-reversion-starts { | leaf restoration-reversion-starts { | |||
type yang:counter32; | type yang:counter32; | |||
description | description | |||
"Number of times that link experienced restoration reversion | "Number of times that a link experienced restoration | |||
start."; | reversion start."; | |||
} | } | |||
leaf restoration-reversion-successes { | leaf restoration-reversion-successes { | |||
type yang:counter32; | type yang:counter32; | |||
description | description | |||
"Number of times that link experienced restoration reversion | "Number of times that a link experienced restoration | |||
success."; | reversion success."; | |||
} | } | |||
} // statistics-per-link | } | |||
// statistics-per-link | ||||
grouping statistics-per-node { | grouping statistics-per-node { | |||
description | description | |||
"Statistics attributes per TE node."; | "Statistics attributes per TE node."; | |||
leaf discontinuity-time { | leaf discontinuity-time { | |||
type yang:date-and-time; | type yang:date-and-time; | |||
description | description | |||
"The time on the most recent occasion at which any one or | "The time of the most recent occasion at which any one or | |||
more of this interface's counters suffered a | more of this interface's counters suffered a | |||
discontinuity. If no such discontinuities have occurred | discontinuity. If no such discontinuities have occurred | |||
since the last re-initialization of the local management | since the last re-initialization of the local management | |||
subsystem, then this node contains the time the local | subsystem, then this node contains the time the local | |||
management subsystem re-initialized itself."; | management subsystem re-initialized itself."; | |||
} | } | |||
container node { | container node { | |||
description | description | |||
"Containing TE node level statistics attributes."; | "Contains statistics attributes at the TE node level."; | |||
leaf disables { | leaf disables { | |||
type yang:counter32; | type yang:counter32; | |||
description | description | |||
"Number of times that node was disabled."; | "Number of times that a node was disabled."; | |||
} | } | |||
leaf enables { | leaf enables { | |||
type yang:counter32; | type yang:counter32; | |||
description | description | |||
"Number of times that node was enabled."; | "Number of times that a node was enabled."; | |||
} | } | |||
leaf maintenance-sets { | leaf maintenance-sets { | |||
type yang:counter32; | type yang:counter32; | |||
description | description | |||
"Number of times that node was put in maintenance."; | "Number of times that a node was put in maintenance."; | |||
} | } | |||
leaf maintenance-clears { | leaf maintenance-clears { | |||
type yang:counter32; | type yang:counter32; | |||
description | description | |||
"Number of times that node was put out of maintenance."; | "Number of times that a node was taken out of | |||
maintenance."; | ||||
} | } | |||
leaf modifies { | leaf modifies { | |||
type yang:counter32; | type yang:counter32; | |||
description | description | |||
"Number of times that node was modified."; | "Number of times that a node was modified."; | |||
} | } | |||
} // node | } | |||
// node | ||||
container connectivity-matrix-entry { | container connectivity-matrix-entry { | |||
description | description | |||
"Containing connectivity matrix entry level statistics | "Contains statistics attributes at the level of a | |||
attributes."; | connectivity matrix entry."; | |||
leaf creates { | leaf creates { | |||
type yang:counter32; | type yang:counter32; | |||
description | description | |||
"Number of times that a connectivity matrix entry was | "Number of times that a connectivity matrix entry was | |||
created."; | created."; | |||
reference | reference | |||
"RFC 6241. Section 7.2 for 'create' operation. "; | "RFC 6241: Network Configuration Protocol (NETCONF), | |||
Section 7.2, 'create' operation"; | ||||
} | } | |||
leaf deletes { | leaf deletes { | |||
type yang:counter32; | type yang:counter32; | |||
description | description | |||
"Number of times that a connectivity matrix entry was | "Number of times that a connectivity matrix entry was | |||
deleted."; | deleted."; | |||
reference | reference | |||
"RFC 6241. Section 7.2 for 'delete' operation. "; | "RFC 6241: Network Configuration Protocol (NETCONF), | |||
Section 7.2, 'delete' operation"; | ||||
} | } | |||
leaf disables { | leaf disables { | |||
type yang:counter32; | type yang:counter32; | |||
description | description | |||
"Number of times that a connectivity matrix entry was | "Number of times that a connectivity matrix entry was | |||
disabled."; | disabled."; | |||
} | } | |||
leaf enables { | leaf enables { | |||
type yang:counter32; | type yang:counter32; | |||
description | description | |||
"Number of times that a connectivity matrix entry was | "Number of times that a connectivity matrix entry was | |||
enabled."; | enabled."; | |||
} | } | |||
leaf modifies { | leaf modifies { | |||
type yang:counter32; | type yang:counter32; | |||
description | description | |||
"Number of times that a connectivity matrix entry was | "Number of times that a connectivity matrix entry was | |||
modified."; | modified."; | |||
} | } | |||
} // connectivity-matrix-entry | } | |||
} // statistics-per-node | // connectivity-matrix-entry | |||
} | ||||
// statistics-per-node | ||||
grouping statistics-per-ttp { | grouping statistics-per-ttp { | |||
description | description | |||
"Statistics attributes per TE TTP (Tunnel Termination Point)."; | "Statistics attributes per TE TTP (Tunnel Termination Point)."; | |||
leaf discontinuity-time { | leaf discontinuity-time { | |||
type yang:date-and-time; | type yang:date-and-time; | |||
description | description | |||
"The time on the most recent occasion at which any one or | "The time of the most recent occasion at which any one or | |||
more of this interface's counters suffered a | more of this interface's counters suffered a | |||
discontinuity. If no such discontinuities have occurred | discontinuity. If no such discontinuities have occurred | |||
since the last re-initialization of the local management | since the last re-initialization of the local management | |||
subsystem, then this node contains the time the local | subsystem, then this node contains the time the local | |||
management subsystem re-initialized itself."; | management subsystem re-initialized itself."; | |||
} | } | |||
container tunnel-termination-point { | container tunnel-termination-point { | |||
description | description | |||
"Containing TE TTP (Tunnel Termination Point) level | "Contains statistics attributes at the TE TTP level."; | |||
statistics attributes."; | ||||
/* Administrative attributes */ | /* Administrative attributes */ | |||
leaf disables { | leaf disables { | |||
type yang:counter32; | type yang:counter32; | |||
description | description | |||
"Number of times that TTP was disabled."; | "Number of times that a TTP was disabled."; | |||
} | } | |||
leaf enables { | leaf enables { | |||
type yang:counter32; | type yang:counter32; | |||
description | description | |||
"Number of times that TTP was enabled."; | "Number of times that a TTP was enabled."; | |||
} | } | |||
leaf maintenance-clears { | leaf maintenance-clears { | |||
type yang:counter32; | type yang:counter32; | |||
description | description | |||
"Number of times that TTP was put out of maintenance."; | "Number of times that a TTP was taken out of maintenance."; | |||
} | } | |||
leaf maintenance-sets { | leaf maintenance-sets { | |||
type yang:counter32; | type yang:counter32; | |||
description | description | |||
"Number of times that TTP was put in maintenance."; | "Number of times that a TTP was put in maintenance."; | |||
} | } | |||
leaf modifies { | leaf modifies { | |||
type yang:counter32; | type yang:counter32; | |||
description | description | |||
"Number of times that TTP was modified."; | "Number of times that a TTP was modified."; | |||
} | } | |||
/* Operational attributes */ | /* Operational attributes */ | |||
leaf downs { | leaf downs { | |||
type yang:counter32; | type yang:counter32; | |||
description | description | |||
"Number of times that TTP was set to operational down."; | "Number of times that a TTP was set to an operational state | |||
of 'down'."; | ||||
} | } | |||
leaf ups { | leaf ups { | |||
type yang:counter32; | type yang:counter32; | |||
description | description | |||
"Number of times that TTP was set to operational up."; | "Number of times that a TTP was set to an operational state | |||
of 'up'."; | ||||
} | } | |||
leaf in-service-clears { | leaf in-service-clears { | |||
type yang:counter32; | type yang:counter32; | |||
description | description | |||
"Number of times that TTP was taken out of service | "Number of times that a TTP was taken out of service | |||
(TE tunnel was released)."; | (TE tunnel was released)."; | |||
} | } | |||
leaf in-service-sets { | leaf in-service-sets { | |||
type yang:counter32; | type yang:counter32; | |||
description | description | |||
"Number of times that TTP was put in service by a TE | "Number of times that a TTP was put in service by a TE | |||
tunnel (TE tunnel was set up)."; | tunnel (TE tunnel was set up)."; | |||
} | } | |||
} // tunnel-termination-point | } | |||
// tunnel-termination-point | ||||
container local-link-connectivity { | container local-link-connectivity { | |||
description | description | |||
"Containing TE LLCL (Local Link Connectivity List) level | "Contains statistics attributes at the TE LLCL (Local Link | |||
statistics attributes."; | Connectivity List) level."; | |||
leaf creates { | leaf creates { | |||
type yang:counter32; | type yang:counter32; | |||
description | description | |||
"Number of times that an LLCL entry was created."; | "Number of times that an LLCL entry was created."; | |||
reference | reference | |||
"RFC 6241. Section 7.2 for 'create' operation."; | "RFC 6241: Network Configuration Protocol (NETCONF), | |||
Section 7.2, 'create' operation"; | ||||
} | } | |||
leaf deletes { | leaf deletes { | |||
type yang:counter32; | type yang:counter32; | |||
description | description | |||
"Number of times that an LLCL entry was deleted."; | "Number of times that an LLCL entry was deleted."; | |||
reference | reference | |||
"RFC 6241. Section 7.2 for 'delete' operation."; | "RFC 6241: Network Configuration Protocol (NETCONF), | |||
Section 7.2, 'delete' operation"; | ||||
} | } | |||
leaf disables { | leaf disables { | |||
type yang:counter32; | type yang:counter32; | |||
description | description | |||
"Number of times that an LLCL entry was disabled."; | "Number of times that an LLCL entry was disabled."; | |||
} | } | |||
leaf enables { | leaf enables { | |||
type yang:counter32; | type yang:counter32; | |||
description | description | |||
"Number of times that an LLCL entry was enabled."; | "Number of times that an LLCL entry was enabled."; | |||
} | } | |||
leaf modifies { | leaf modifies { | |||
type yang:counter32; | type yang:counter32; | |||
description | description | |||
"Number of times that an LLCL entry was modified."; | "Number of times that an LLCL entry was modified."; | |||
} | } | |||
} // local-link-connectivity | } | |||
} // statistics-per-ttp | // local-link-connectivity | |||
} | ||||
// statistics-per-ttp | ||||
grouping te-link-augment { | grouping te-link-augment { | |||
description | description | |||
"Augmentation for TE link."; | "Augmentation for a TE link."; | |||
uses te-link-config; | uses te-link-config; | |||
uses te-link-state-derived; | uses te-link-state-derived; | |||
container statistics { | container statistics { | |||
config false; | config false; | |||
description | description | |||
"Statistics data."; | "Statistics data."; | |||
uses statistics-per-link; | uses statistics-per-link; | |||
} // statistics | } | |||
} // te-link-augment | } | |||
// te-link-augment | ||||
grouping te-link-config { | grouping te-link-config { | |||
description | description | |||
"TE link configuration grouping."; | "TE link configuration grouping."; | |||
choice bundle-stack-level { | choice bundle-stack-level { | |||
description | description | |||
"The TE link can be partitioned into bundled | "The TE link can be partitioned into bundled links or | |||
links, or component links."; | component links."; | |||
case bundle { | case bundle { | |||
container bundled-links { | container bundled-links { | |||
description | description | |||
"A set of bundled links."; | "A set of bundled links."; | |||
reference | reference | |||
"RFC 4201: Link Bundling in MPLS Traffic Engineering | "RFC 4201: Link Bundling in MPLS Traffic | |||
(TE)."; | Engineering (TE)"; | |||
list bundled-link { | list bundled-link { | |||
key "sequence"; | key "sequence"; | |||
description | description | |||
"Specify a bundled interface that is | "Specifies a bundled interface that is | |||
further partitioned."; | further partitioned."; | |||
leaf sequence { | leaf sequence { | |||
type uint32; | type uint32; | |||
description | description | |||
"Identify the sequence in the bundle."; | "Identifies the sequence in the bundle."; | |||
} | } | |||
} // list bundled-link | } | |||
} | } | |||
} | } | |||
case component { | case component { | |||
container component-links { | container component-links { | |||
description | description | |||
"A set of component links"; | "A set of component links."; | |||
list component-link { | list component-link { | |||
key "sequence"; | key "sequence"; | |||
description | description | |||
"Specify a component interface that is | "Specifies a component interface that is | |||
sufficient to unambiguously identify the | sufficient to unambiguously identify the | |||
appropriate resources"; | appropriate resources."; | |||
leaf sequence { | leaf sequence { | |||
type uint32; | type uint32; | |||
description | description | |||
"Identify the sequence in the bundle."; | "Identifies the sequence in the bundle."; | |||
} | } | |||
leaf src-interface-ref { | leaf src-interface-ref { | |||
type string; | type string; | |||
description | description | |||
"Reference to component link interface on the | "Reference to a component link interface on the | |||
source node."; | source node."; | |||
} | } | |||
leaf des-interface-ref { | leaf des-interface-ref { | |||
type string; | type string; | |||
description | description | |||
"Reference to component link interface on the | "Reference to a component link interface on the | |||
destinatioin node."; | destination node."; | |||
} | } | |||
} | } | |||
} | } | |||
} | } | |||
} // bundle-stack-level | } | |||
// bundle-stack-level | ||||
leaf-list te-link-template { | leaf-list te-link-template { | |||
if-feature template; | if-feature "template"; | |||
type leafref { | type leafref { | |||
path "../../../../te/templates/link-template/name"; | path "../../../../te/templates/link-template/name"; | |||
} | } | |||
description | description | |||
"The reference to a TE link template."; | "The reference to a TE link template."; | |||
} | } | |||
uses te-link-config-attributes; | uses te-link-config-attributes; | |||
} // te-link-config | } | |||
// te-link-config | ||||
grouping te-link-config-attributes { | grouping te-link-config-attributes { | |||
description | description | |||
"Link configuration attributes in a TE topology."; | "Link configuration attributes in a TE topology."; | |||
container te-link-attributes { | container te-link-attributes { | |||
description "Link attributes in a TE topology."; | description | |||
"Link attributes in a TE topology."; | ||||
leaf access-type { | leaf access-type { | |||
type te-types:te-link-access-type; | type te-types:te-link-access-type; | |||
description | description | |||
"Link access type, which can be point-to-point or | "Link access type, which can be point-to-point or | |||
multi-access."; | multi-access."; | |||
} | } | |||
container external-domain { | container external-domain { | |||
description | description | |||
"For an inter-domain link, specify the attributes of | "For an inter-domain link, specifies the attributes of | |||
the remote end of link, to facilitate the signalling at | the remote end of the link, to facilitate the signaling at | |||
local end."; | the local end."; | |||
uses nw:network-ref; | uses nw:network-ref; | |||
leaf remote-te-node-id { | leaf remote-te-node-id { | |||
type te-types:te-node-id; | type te-types:te-node-id; | |||
description | description | |||
"Remote TE node identifier, used together with | "Remote TE node identifier, used together with | |||
remote-te-link-id to identify the remote link | 'remote-te-link-tp-id' to identify the remote Link | |||
termination point in a different domain."; | Termination Point (LTP) in a different domain."; | |||
} | } | |||
leaf remote-te-link-tp-id { | leaf remote-te-link-tp-id { | |||
type te-types:te-tp-id; | type te-types:te-tp-id; | |||
description | description | |||
"Remote TE link termination point identifier, used | "Remote TE LTP identifier, used together with | |||
together with remote-te-node-id to identify the remote | 'remote-te-node-id' to identify the remote LTP in a | |||
link termination point in a different domain."; | different domain."; | |||
} | } | |||
} | } | |||
leaf is-abstract { | leaf is-abstract { | |||
type empty; | type empty; | |||
description "Present if the link is abstract."; | description | |||
"Present if the link is abstract."; | ||||
} | } | |||
leaf name { | leaf name { | |||
type string; | type string; | |||
description "Link Name."; | description | |||
"Link name."; | ||||
} | } | |||
container underlay { | container underlay { | |||
if-feature te-topology-hierarchy; | if-feature "te-topology-hierarchy"; | |||
description "Attributes of the te-link underlay."; | description | |||
"Attributes of the TE link underlay."; | ||||
reference | reference | |||
"RFC 4206: Label Switched Paths (LSP) Hierarchy with | "RFC 4206: Label Switched Paths (LSP) Hierarchy with | |||
Generalized Multi-Protocol Label Switching (GMPLS) | Generalized Multi-Protocol Label Switching (GMPLS) | |||
Traffic Engineering (TE)"; | Traffic Engineering (TE)"; | |||
uses te-link-underlay-attributes; | uses te-link-underlay-attributes; | |||
} // underlay | } | |||
leaf admin-status { | leaf admin-status { | |||
type te-types:te-admin-status; | type te-types:te-admin-status; | |||
description | description | |||
"The administrative state of the link."; | "The administrative state of the link."; | |||
} | } | |||
uses te-link-info-attributes; | uses te-link-info-attributes; | |||
} // te-link-attributes | } | |||
} // te-link-config-attributes | // te-link-attributes | |||
} | ||||
// te-link-config-attributes | ||||
grouping te-link-info-attributes { | grouping te-link-info-attributes { | |||
description | description | |||
"Advertised TE information attributes."; | "Advertised TE information attributes."; | |||
leaf link-index { | leaf link-index { | |||
type uint64; | type uint64; | |||
description | description | |||
"The link identifier. If OSPF is used, this represents an | "The link identifier. If OSPF is used, this object | |||
ospfLsdbID. If IS-IS is used, this represents an isisLSPID. | represents an ospfLsdbID. If IS-IS is used, this object | |||
If a locally configured link is used, this object represents | represents an isisLSPID. If a locally configured link is | |||
a unique value, which is locally defined in a router."; | used, this object represents a unique value, which is | |||
locally defined in a router."; | ||||
} | } | |||
leaf administrative-group { | leaf administrative-group { | |||
type te-types:admin-groups; | type te-types:admin-groups; | |||
description | description | |||
"Administrative group or color of the link. | "Administrative group or color of the link. | |||
This attribute covers both administrative group (defined in | This attribute covers both administrative groups (defined | |||
RFC 3630, RFC 5305 and RFC 5329), and extended | in RFCs 3630 and 5305) and Extended Administrative Groups | |||
administrative group (defined in RFC 7308)."; | (defined in RFC 7308)."; | |||
reference | ||||
"RFC 3630: Traffic Engineering (TE) Extensions to OSPF | ||||
Version 2 | ||||
RFC 5305: IS-IS Extensions for Traffic Engineering | ||||
RFC 7308: Extended Administrative Groups in MPLS Traffic | ||||
Engineering (MPLS-TE)"; | ||||
} | } | |||
uses interface-switching-capability-list; | uses interface-switching-capability-list; | |||
uses te-types:label-set-info; | uses te-types:label-set-info; | |||
leaf link-protection-type { | leaf link-protection-type { | |||
type identityref { | type identityref { | |||
base te-types:link-protection-type; | base te-types:link-protection-type; | |||
} | } | |||
description | description | |||
"Link Protection Type desired for this link."; | "Link Protection Type desired for this link."; | |||
reference | reference | |||
"RFC 4202: Routing Extensions in Support of | "RFC 4202: Routing Extensions in Support of | |||
Generalized Multi-Protocol Label Switching (GMPLS)."; | Generalized Multi-Protocol Label Switching (GMPLS)"; | |||
} | } | |||
container max-link-bandwidth { | container max-link-bandwidth { | |||
uses te-types:te-bandwidth; | uses te-types:te-bandwidth; | |||
description | description | |||
"Maximum bandwidth that can be seen on this link in this | "Maximum bandwidth that can be seen on this link in this | |||
direction. Units in bytes per second."; | direction. Units are in bytes per second."; | |||
reference | reference | |||
"RFC 3630: Traffic Engineering (TE) Extensions to OSPF | "RFC 3630: Traffic Engineering (TE) Extensions to OSPF | |||
Version 2. | Version 2 | |||
RFC 5305: IS-IS Extensions for Traffic Engineering."; | RFC 5305: IS-IS Extensions for Traffic Engineering"; | |||
} | } | |||
container max-resv-link-bandwidth { | container max-resv-link-bandwidth { | |||
uses te-types:te-bandwidth; | uses te-types:te-bandwidth; | |||
description | description | |||
"Maximum amount of bandwidth that can be reserved in this | "Maximum amount of bandwidth that can be reserved in this | |||
direction in this link. Units in bytes per second."; | direction in this link. Units are in bytes per second."; | |||
reference | reference | |||
"RFC 3630: Traffic Engineering (TE) Extensions to OSPF | "RFC 3630: Traffic Engineering (TE) Extensions to OSPF | |||
Version 2. | Version 2 | |||
RFC 5305: IS-IS Extensions for Traffic Engineering."; | RFC 5305: IS-IS Extensions for Traffic Engineering"; | |||
} | } | |||
list unreserved-bandwidth { | list unreserved-bandwidth { | |||
key "priority"; | key "priority"; | |||
max-elements "8"; | max-elements 8; | |||
description | description | |||
"Unreserved bandwidth for 0-7 priority levels. Units in | "Unreserved bandwidth for priority levels 0-7. Units are in | |||
bytes per second."; | bytes per second."; | |||
reference | reference | |||
"RFC 3630: Traffic Engineering (TE) Extensions to OSPF | "RFC 3630: Traffic Engineering (TE) Extensions to OSPF | |||
Version 2. | Version 2 | |||
RFC 5305: IS-IS Extensions for Traffic Engineering."; | RFC 5305: IS-IS Extensions for Traffic Engineering"; | |||
leaf priority { | leaf priority { | |||
type uint8 { | type uint8 { | |||
range "0..7"; | range "0..7"; | |||
} | } | |||
description "Priority."; | description | |||
"Priority."; | ||||
} | } | |||
uses te-types:te-bandwidth; | uses te-types:te-bandwidth; | |||
} | } | |||
leaf te-default-metric { | leaf te-default-metric { | |||
type uint32; | type uint32; | |||
description | description | |||
"Traffic engineering metric."; | "Traffic Engineering metric."; | |||
reference | reference | |||
"RFC 3630: Traffic Engineering (TE) Extensions to OSPF | "RFC 3630: Traffic Engineering (TE) Extensions to OSPF | |||
Version 2. | Version 2 | |||
RFC 5305: IS-IS Extensions for Traffic Engineering."; | RFC 5305: IS-IS Extensions for Traffic Engineering"; | |||
} | } | |||
leaf te-delay-metric { | leaf te-delay-metric { | |||
type uint32; | type uint32; | |||
description | description | |||
"Traffic engineering delay metric."; | "Traffic Engineering delay metric."; | |||
reference | reference | |||
"RFC 7471: OSPF Traffic Engineering (TE) Metric Extensions."; | "RFC 7471: OSPF Traffic Engineering (TE) Metric Extensions"; | |||
} | } | |||
leaf te-igp-metric { | leaf te-igp-metric { | |||
type uint32; | type uint32; | |||
description | description | |||
"IGP metric used for traffic engineering."; | "IGP metric used for Traffic Engineering."; | |||
reference | reference | |||
"RFC 3785: Use of Interior Gateway Protocol (IGP) Metric as a | "RFC 3785: Use of Interior Gateway Protocol (IGP) Metric as a | |||
Second MPLS Traffic Engineering (TE) Metric."; | second MPLS Traffic Engineering (TE) Metric"; | |||
} | } | |||
container te-srlgs { | container te-srlgs { | |||
description | description | |||
"Containing a list of SLRGs."; | "Contains a list of SRLGs."; | |||
leaf-list value { | leaf-list value { | |||
type te-types:srlg; | type te-types:srlg; | |||
description "SRLG value."; | description | |||
"SRLG value."; | ||||
reference | reference | |||
"RFC 4202: Routing Extensions in Support of | "RFC 4202: Routing Extensions in Support of | |||
Generalized Multi-Protocol Label Switching (GMPLS)."; | Generalized Multi-Protocol Label Switching (GMPLS)"; | |||
} | } | |||
} | } | |||
container te-nsrlgs { | container te-nsrlgs { | |||
if-feature nsrlg; | if-feature "nsrlg"; | |||
description | description | |||
"Containing a list of NSRLGs (Not Sharing Risk Link | "Contains a list of NSRLGs (Non-Shared Risk Link Groups). | |||
Groups). | ||||
When an abstract TE link is configured, this list specifies | When an abstract TE link is configured, this list specifies | |||
the request that underlay TE paths need to be mutually | the request that underlay TE paths need to be mutually | |||
disjoint with other TE links in the same groups."; | disjoint with other TE links in the same groups."; | |||
leaf-list id { | leaf-list id { | |||
type uint32; | type uint32; | |||
description | description | |||
"NSRLG ID, uniquely configured within a topology."; | "NSRLG ID, uniquely configured within a topology."; | |||
reference | reference | |||
"RFC 4872: RSVP-TE Extensions in Support of End-to-End | "RFC 4872: RSVP-TE Extensions in Support of End-to-End | |||
Generalized Multi-Protocol Label Switching (GMPLS) | Generalized Multi-Protocol Label Switching (GMPLS) | |||
Recovery"; | Recovery"; | |||
} | } | |||
} | } | |||
} // te-link-info-attributes | } | |||
// te-link-info-attributes | ||||
grouping te-link-iscd-attributes { | grouping te-link-iscd-attributes { | |||
description | description | |||
"TE link ISCD (Interface Switching Capability Descriptor) | "TE link ISCD attributes."; | |||
attributes."; | ||||
reference | reference | |||
"Sec 1.4, RFC 4203: OSPF Extensions in Support of Generalized | "RFC 4203: OSPF Extensions in Support of Generalized | |||
Multi-Protocol Label Switching (GMPLS). Section 1.4."; | Multi-Protocol Label Switching (GMPLS), Section 1.4"; | |||
list max-lsp-bandwidth { | list max-lsp-bandwidth { | |||
key "priority"; | key "priority"; | |||
max-elements "8"; | max-elements 8; | |||
description | description | |||
"Maximum LSP Bandwidth at priorities 0-7."; | "Maximum Label Switched Path (LSP) bandwidth at | |||
priorities 0-7."; | ||||
leaf priority { | leaf priority { | |||
type uint8 { | type uint8 { | |||
range "0..7"; | range "0..7"; | |||
} | } | |||
description "Priority."; | description | |||
"Priority."; | ||||
} | } | |||
uses te-types:te-bandwidth; | uses te-types:te-bandwidth; | |||
} | } | |||
} // te-link-iscd-attributes | } | |||
// te-link-iscd-attributes | ||||
grouping te-link-state-derived { | grouping te-link-state-derived { | |||
description | description | |||
"Link state attributes in a TE topology."; | "Link state attributes in a TE topology."; | |||
leaf oper-status { | leaf oper-status { | |||
type te-types:te-oper-status; | type te-types:te-oper-status; | |||
config false; | config false; | |||
description | description | |||
"The current operational state of the link."; | "The current operational state of the link."; | |||
} | } | |||
leaf is-transitional { | leaf is-transitional { | |||
type empty; | type empty; | |||
config false; | config false; | |||
description | description | |||
"Present if the link is transitional, used as an | "Present if the link is transitional; used as an | |||
alternative approach in lieu of inter-layer-lock-id | alternative approach in lieu of 'inter-layer-lock-id' | |||
for path computation in a TE topology covering multiple | for path computation in a TE topology covering multiple | |||
layers or multiple regions."; | layers or multiple regions."; | |||
reference | reference | |||
"RFC 5212: Requirements for GMPLS-Based Multi-Region and | "RFC 5212: Requirements for GMPLS-Based Multi-Region and | |||
Multi-Layer Networks (MRN/MLN). | Multi-Layer Networks (MRN/MLN) | |||
RFC 6001: Generalized MPLS (GMPLS) Protocol Extensions | RFC 6001: Generalized MPLS (GMPLS) Protocol Extensions | |||
for Multi-Layer and Multi-Region Networks (MLN/MRN)."; | for Multi-Layer and Multi-Region Networks (MLN/MRN)"; | |||
} | } | |||
uses information-source-per-link-attributes; | uses information-source-per-link-attributes; | |||
list information-source-entry { | list information-source-entry { | |||
key "information-source information-source-instance"; | key "information-source information-source-instance"; | |||
config false; | config false; | |||
description | description | |||
"A list of information sources learned, including the one | "A list of information sources learned, including the source | |||
used."; | that is used."; | |||
uses information-source-per-link-attributes; | uses information-source-per-link-attributes; | |||
uses te-link-info-attributes; | uses te-link-info-attributes; | |||
} | } | |||
container recovery { | container recovery { | |||
config false; | config false; | |||
description | description | |||
"Status of the recovery process."; | "Status of the recovery process."; | |||
leaf restoration-status { | leaf restoration-status { | |||
type te-types:te-recovery-status; | type te-types:te-recovery-status; | |||
description | description | |||
"Restoration status."; | "Restoration status."; | |||
} | } | |||
leaf protection-status { | leaf protection-status { | |||
type te-types:te-recovery-status; | type te-types:te-recovery-status; | |||
description | description | |||
"Protection status."; | "Protection status."; | |||
} | } | |||
} | } | |||
container underlay { | container underlay { | |||
if-feature te-topology-hierarchy; | if-feature "te-topology-hierarchy"; | |||
config false; | config false; | |||
description "State attributes for te-link underlay."; | description | |||
"State attributes for the TE link underlay."; | ||||
leaf dynamic { | leaf dynamic { | |||
type boolean; | type boolean; | |||
description | description | |||
"true if the underlay is dynamically created."; | "'true' if the underlay is dynamically created."; | |||
} | } | |||
leaf committed { | leaf committed { | |||
type boolean; | type boolean; | |||
description | description | |||
"true if the underlay is committed."; | "'true' if the underlay is committed."; | |||
} | } | |||
} | } | |||
} // te-link-state-derived | } | |||
// te-link-state-derived | ||||
grouping te-link-underlay-attributes { | grouping te-link-underlay-attributes { | |||
description "Attributes for te-link underlay."; | description | |||
"Attributes for the TE link underlay."; | ||||
reference | reference | |||
"RFC 4206: Label Switched Paths (LSP) Hierarchy with | "RFC 4206: Label Switched Paths (LSP) Hierarchy with | |||
Generalized Multi-Protocol Label Switching (GMPLS) | Generalized Multi-Protocol Label Switching (GMPLS) | |||
Traffic Engineering (TE)"; | Traffic Engineering (TE)"; | |||
leaf enabled { | leaf enabled { | |||
type boolean; | type boolean; | |||
description | description | |||
"'true' if the underlay is enabled. | "'true' if the underlay is enabled. | |||
'false' if the underlay is disabled."; | 'false' if the underlay is disabled."; | |||
} | } | |||
skipping to change at line 3098 ¶ | skipping to change at line 3042 ¶ | |||
description | description | |||
"The service path on the underlay topology that | "The service path on the underlay topology that | |||
supports this link."; | supports this link."; | |||
uses nw:network-ref; | uses nw:network-ref; | |||
list path-element { | list path-element { | |||
key "path-element-id"; | key "path-element-id"; | |||
description | description | |||
"A list of path elements describing the service path."; | "A list of path elements describing the service path."; | |||
leaf path-element-id { | leaf path-element-id { | |||
type uint32; | type uint32; | |||
description "To identify the element in a path."; | description | |||
"To identify the element in a path."; | ||||
} | } | |||
uses te-path-element; | uses te-path-element; | |||
} | } | |||
} // primary-path | } | |||
// primary-path | ||||
list backup-path { | list backup-path { | |||
key "index"; | key "index"; | |||
description | description | |||
"A list of backup service paths on the underlay topology that | "A list of backup service paths on the underlay topology that | |||
protect the underlay primary path. If the primary path is | protect the underlay primary path. If the primary path is | |||
not protected, the list contains zero elements. If the | not protected, the list contains zero elements. If the | |||
primary path is protected, the list contains one or more | primary path is protected, the list contains one or more | |||
elements."; | elements."; | |||
leaf index { | leaf index { | |||
type uint32; | type uint32; | |||
description | description | |||
"A sequence number to identify a backup path."; | "A sequence number to identify a backup path."; | |||
} | } | |||
uses nw:network-ref; | uses nw:network-ref; | |||
list path-element { | list path-element { | |||
key "path-element-id"; | key "path-element-id"; | |||
description | description | |||
"A list of path elements describing the backup service | "A list of path elements describing the backup service | |||
path"; | path."; | |||
leaf path-element-id { | leaf path-element-id { | |||
type uint32; | type uint32; | |||
description "To identify the element in a path."; | description | |||
"To identify the element in a path."; | ||||
} | } | |||
uses te-path-element; | uses te-path-element; | |||
} | } | |||
} // underlay-backup-path | } | |||
// backup-path | ||||
leaf protection-type { | leaf protection-type { | |||
type identityref { | type identityref { | |||
base te-types:lsp-protection-type; | base te-types:lsp-protection-type; | |||
} | } | |||
description | description | |||
"Underlay protection type desired for this link."; | "Underlay protection type desired for this link."; | |||
} | } | |||
container tunnel-termination-points { | container tunnel-termination-points { | |||
description | description | |||
"Underlay TTP(Tunnel Termination Points) desired for this | "Underlay TTPs desired for this link."; | |||
link."; | ||||
leaf source { | leaf source { | |||
type binary; | type binary; | |||
description | description | |||
"Source tunnel termination point identifier."; | "Source TTP identifier."; | |||
} | } | |||
leaf destination { | leaf destination { | |||
type binary; | type binary; | |||
description | description | |||
"Destination tunnel termination point identifier."; | "Destination TTP identifier."; | |||
} | } | |||
} | } | |||
container tunnels { | container tunnels { | |||
description | description | |||
"Underlay TE tunnels supporting this TE link."; | "Underlay TE tunnels supporting this TE link."; | |||
leaf sharing { | leaf sharing { | |||
type boolean; | type boolean; | |||
default true; | default "true"; | |||
description | description | |||
"'true' if the underlay tunnel can be shared with other | "'true' if the underlay tunnel can be shared with other | |||
TE links; | TE links; | |||
'false' if the underlay tunnel is dedicated to this | 'false' if the underlay tunnel is dedicated to this | |||
TE link. | TE link. | |||
This leaf is the default option for all TE tunnels, | This leaf is the default option for all TE tunnels | |||
and may be overridden by the per TE tunnel value."; | and may be overridden by the per-TE-tunnel value."; | |||
} | } | |||
list tunnel { | list tunnel { | |||
key "tunnel-name"; | key "tunnel-name"; | |||
description | description | |||
"Zero, one or more underlay TE tunnels that support this TE | "Zero, one, or more underlay TE tunnels that support this | |||
link."; | TE link."; | |||
leaf tunnel-name { | leaf tunnel-name { | |||
type string; | type string; | |||
description | description | |||
"A tunnel name uniquely identifies an underlay TE tunnel, | "A tunnel name uniquely identifies an underlay TE tunnel, | |||
used together with the source-node of this link. | used together with the 'source-node' value for this | |||
The detailed information of this tunnel can be retrieved | link."; | |||
from the ietf-te model."; | reference | |||
reference "RFC 3209"; | "RFC 3209: RSVP-TE: Extensions to RSVP for LSP Tunnels"; | |||
} | } | |||
leaf sharing { | leaf sharing { | |||
type boolean; | type boolean; | |||
description | description | |||
"'true' if the underlay tunnel can be shared with other | "'true' if the underlay tunnel can be shared with other | |||
TE links; | TE links; | |||
'false' if the underlay tunnel is dedicated to this | 'false' if the underlay tunnel is dedicated to this | |||
TE link."; | TE link."; | |||
} | } | |||
} // tunnel | } | |||
} // tunnels | // tunnel | |||
} // te-link-underlay-attributes | } | |||
// tunnels | ||||
} | ||||
// te-link-underlay-attributes | ||||
grouping te-node-augment { | grouping te-node-augment { | |||
description | description | |||
"Augmentation for TE node."; | "Augmentation for a TE node."; | |||
uses te-node-config; | uses te-node-config; | |||
uses te-node-state-derived; | uses te-node-state-derived; | |||
container statistics { | container statistics { | |||
config false; | config false; | |||
description | description | |||
"Statistics data."; | "Statistics data."; | |||
uses statistics-per-node; | uses statistics-per-node; | |||
} // statistics | } | |||
list tunnel-termination-point { | list tunnel-termination-point { | |||
key "tunnel-tp-id"; | key "tunnel-tp-id"; | |||
description | description | |||
"A termination point can terminate a tunnel."; | "A termination point can terminate a tunnel."; | |||
leaf tunnel-tp-id { | leaf tunnel-tp-id { | |||
type binary; | type binary; | |||
description | description | |||
"Tunnel termination point identifier."; | "TTP identifier."; | |||
} | } | |||
uses te-node-tunnel-termination-point-config; | uses te-node-tunnel-termination-point-config; | |||
leaf oper-status { | leaf oper-status { | |||
type te-types:te-oper-status; | type te-types:te-oper-status; | |||
config false; | config false; | |||
description | description | |||
"The current operational state of the tunnel | "The current operational state of the TTP."; | |||
termination point."; | ||||
} | } | |||
uses geolocation-container; | uses geolocation-container; | |||
container statistics { | container statistics { | |||
config false; | config false; | |||
description | description | |||
"Statistics data."; | "Statistics data."; | |||
uses statistics-per-ttp; | uses statistics-per-ttp; | |||
} // statistics | } | |||
// Relationship to other TTPs | ||||
// Relations to other tunnel termination points | ||||
list supporting-tunnel-termination-point { | list supporting-tunnel-termination-point { | |||
key "node-ref tunnel-tp-ref"; | key "node-ref tunnel-tp-ref"; | |||
description | description | |||
"Identifies the tunnel termination points, that this | "Identifies the TTPs on which this TTP depends."; | |||
tunnel termination point is depending on."; | ||||
leaf node-ref { | leaf node-ref { | |||
type inet:uri; | type inet:uri; | |||
description | description | |||
"This leaf identifies the node in which the supporting | "This leaf identifies the node in which the supporting | |||
tunnel termination point is present. | TTP is present. | |||
This node is either the supporting node or a node in | This node is either the supporting node or a node in | |||
an underlay topology."; | an underlay topology."; | |||
} | } | |||
leaf tunnel-tp-ref { | leaf tunnel-tp-ref { | |||
type binary; | type binary; | |||
description | description | |||
"Reference to a tunnel terminiation point, which is | "Reference to a TTP that is in either the supporting node | |||
either in the supporting node or a node in an | or a node in an underlay topology."; | |||
underlay topology."; | ||||
} | } | |||
} // supporting-tunnel-termination-point | } | |||
} // tunnel-termination-point | // supporting-tunnel-termination-point | |||
} // te-node-augment | } | |||
// tunnel-termination-point | ||||
} | ||||
// te-node-augment | ||||
grouping te-node-config { | grouping te-node-config { | |||
description "TE node configuration grouping."; | description | |||
"TE node configuration grouping."; | ||||
leaf-list te-node-template { | leaf-list te-node-template { | |||
if-feature template; | if-feature "template"; | |||
type leafref { | type leafref { | |||
path "../../../../te/templates/node-template/name"; | path "../../../../te/templates/node-template/name"; | |||
} | } | |||
description | description | |||
"The reference to a TE node template."; | "The reference to a TE node template."; | |||
} | } | |||
uses te-node-config-attributes; | uses te-node-config-attributes; | |||
} // te-node-config | } | |||
// te-node-config | ||||
grouping te-node-config-attributes { | grouping te-node-config-attributes { | |||
description "Configuration node attributes in a TE topology."; | description | |||
"Configuration node attributes in a TE topology."; | ||||
container te-node-attributes { | container te-node-attributes { | |||
description "Containing node attributes in a TE topology."; | description | |||
"Contains node attributes in a TE topology."; | ||||
leaf admin-status { | leaf admin-status { | |||
type te-types:te-admin-status; | type te-types:te-admin-status; | |||
description | description | |||
"The administrative state of the link."; | "The administrative state of the link."; | |||
} | } | |||
uses te-node-connectivity-matrices; | uses te-node-connectivity-matrices; | |||
uses te-node-info-attributes; | uses te-node-info-attributes; | |||
} // te-node-attributes | } | |||
} // te-node-config-attributes | } | |||
// te-node-config-attributes | ||||
grouping te-node-config-attributes-template { | grouping te-node-config-attributes-template { | |||
description | description | |||
"Configuration node attributes for template in a TE topology."; | "Configuration node attributes for a template in a TE | |||
topology."; | ||||
container te-node-attributes { | container te-node-attributes { | |||
description "Containing node attributes in a TE topology."; | description | |||
"Contains node attributes in a TE topology."; | ||||
leaf admin-status { | leaf admin-status { | |||
type te-types:te-admin-status; | type te-types:te-admin-status; | |||
description | description | |||
"The administrative state of the link."; | "The administrative state of the link."; | |||
} | } | |||
uses te-node-info-attributes; | uses te-node-info-attributes; | |||
} // te-node-attributes | } | |||
} // te-node-config-attributes-template | } | |||
// te-node-config-attributes-template | ||||
grouping te-node-connectivity-matrices { | grouping te-node-connectivity-matrices { | |||
description "Connectivity matrix on a TE node."; | description | |||
"Connectivity matrix on a TE node."; | ||||
container connectivity-matrices { | container connectivity-matrices { | |||
description | description | |||
"Containing connectivity matrix on a TE node."; | "Contains a connectivity matrix on a TE node."; | |||
leaf number-of-entries { | leaf number-of-entries { | |||
type uint16; | type uint16; | |||
description | description | |||
"The number of connectivity matrix entries. | "The number of connectivity matrix entries. | |||
If this number is specified in the configuration request, | If this number is specified in the configuration request, | |||
the number is requested number of entries, which may not | the number is the requested number of entries, which may | |||
all be listed in the list; | not all be listed in the list; | |||
if this number is reported in the state data, | if this number is reported in the state data, | |||
the number is the current number of operational entries."; | the number is the current number of operational entries."; | |||
} | } | |||
uses te-types:label-set-info; | uses te-types:label-set-info; | |||
uses connectivity-matrix-entry-path-attributes; | uses connectivity-matrix-entry-path-attributes; | |||
list connectivity-matrix { | list connectivity-matrix { | |||
key "id"; | key "id"; | |||
description | description | |||
"Represents node's switching limitations, i.e. limitations | "Represents a node's switching limitations, i.e., | |||
in interconnecting network TE links across the node."; | limitations in the interconnecting network TE links | |||
across the node."; | ||||
reference | reference | |||
"RFC 7579: General Network Element Constraint Encoding | "RFC 7579: General Network Element Constraint Encoding | |||
for GMPLS-Controlled Networks."; | for GMPLS-Controlled Networks"; | |||
leaf id { | leaf id { | |||
type uint32; | type uint32; | |||
description "Identifies the connectivity-matrix entry."; | description | |||
"Identifies the connectivity matrix entry."; | ||||
} | } | |||
} // connectivity-matrix | } | |||
} // connectivity-matrices | // connectivity-matrix | |||
} // te-node-connectivity-matrices | } | |||
// connectivity-matrices | ||||
} | ||||
// te-node-connectivity-matrices | ||||
grouping te-node-connectivity-matrix-attributes { | grouping te-node-connectivity-matrix-attributes { | |||
description | description | |||
"Termination point references of a connectivity matrix entry."; | "Termination point references of a connectivity matrix entry."; | |||
container from { | container from { | |||
description | description | |||
"Reference to source link termination point."; | "Reference to a source LTP."; | |||
leaf tp-ref { | leaf tp-ref { | |||
type leafref { | type leafref { | |||
path "../../../../../../nt:termination-point/nt:tp-id"; | path "../../../../../../nt:termination-point/nt:tp-id"; | |||
} | } | |||
description | description | |||
"Relative reference to a termination point."; | "Relative reference to a termination point."; | |||
} | } | |||
uses te-types:label-set-info; | uses te-types:label-set-info; | |||
} | } | |||
container to { | container to { | |||
description | description | |||
"Reference to destination link termination point."; | "Reference to a destination LTP."; | |||
leaf tp-ref { | leaf tp-ref { | |||
type leafref { | type leafref { | |||
path "../../../../../../nt:termination-point/nt:tp-id"; | path "../../../../../../nt:termination-point/nt:tp-id"; | |||
} | } | |||
description | description | |||
"Relative reference to a termination point."; | "Relative reference to a termination point."; | |||
} | } | |||
uses te-types:label-set-info; | uses te-types:label-set-info; | |||
} | } | |||
uses connectivity-matrix-entry-path-attributes; | uses connectivity-matrix-entry-path-attributes; | |||
} // te-node-connectivity-matrix-attributes | } | |||
// te-node-connectivity-matrix-attributes | ||||
grouping te-node-info-attributes { | grouping te-node-info-attributes { | |||
description | description | |||
"Advertised TE information attributes."; | "Advertised TE information attributes."; | |||
leaf domain-id { | leaf domain-id { | |||
type uint32; | type uint32; | |||
description | description | |||
"Identifies the domain that this node belongs. | "Identifies the domain to which this node belongs. | |||
This attribute is used to support inter-domain links."; | This attribute is used to support inter-domain links."; | |||
reference | reference | |||
"RFC 5152: A Per-Domain Path Computation Method for | "RFC 5152: A Per-Domain Path Computation Method for | |||
Establishing Inter-Domain Traffic Engineering (TE) | Establishing Inter-Domain Traffic Engineering (TE) | |||
Label Switched Paths (LSPs). | Label Switched Paths (LSPs) | |||
RFC 5392: OSPF Extensions in Support of Inter-Autonomous | ||||
System (AS) MPLS and GMPLS Traffic Engineering. | ||||
RFC 5316: ISIS Extensions in Support of Inter-Autonomous | RFC 5316: ISIS Extensions in Support of Inter-Autonomous | |||
System (AS) MPLS and GMPLS Traffic Engineering."; | System (AS) MPLS and GMPLS Traffic Engineering | |||
RFC 5392: OSPF Extensions in Support of Inter-Autonomous | ||||
System (AS) MPLS and GMPLS Traffic Engineering"; | ||||
} | } | |||
leaf is-abstract { | leaf is-abstract { | |||
type empty; | type empty; | |||
description | description | |||
"Present if the node is abstract, not present if the node | "Present if the node is abstract; not present if the node | |||
is actual."; | is actual."; | |||
} | } | |||
leaf name { | leaf name { | |||
type string; | type string; | |||
description "Node name."; | description | |||
"Node name."; | ||||
} | } | |||
leaf-list signaling-address { | leaf-list signaling-address { | |||
type inet:ip-address; | type inet:ip-address; | |||
description "Node signaling address."; | description | |||
"The node's signaling address."; | ||||
} | } | |||
container underlay-topology { | container underlay-topology { | |||
if-feature te-topology-hierarchy; | if-feature "te-topology-hierarchy"; | |||
description | description | |||
"When an abstract node encapsulates a topology, | "When an abstract node encapsulates a topology, the | |||
the attributes in this container point to said topology."; | attributes in this container point to said topology."; | |||
uses nw:network-ref; | uses nw:network-ref; | |||
} | } | |||
} // te-node-info-attributes | } | |||
// te-node-info-attributes | ||||
grouping te-node-state-derived { | grouping te-node-state-derived { | |||
description "Node state attributes in a TE topology."; | description | |||
"Node state attributes in a TE topology."; | ||||
leaf oper-status { | leaf oper-status { | |||
type te-types:te-oper-status; | type te-types:te-oper-status; | |||
config false; | config false; | |||
description | description | |||
"The current operational state of the node."; | "The current operational state of the node."; | |||
} | } | |||
uses geolocation-container; | uses geolocation-container; | |||
leaf is-multi-access-dr { | leaf is-multi-access-dr { | |||
type empty; | type empty; | |||
config false; | config false; | |||
description | description | |||
"The presence of this attribute indicates that this TE node | "The presence of this attribute indicates that this TE node | |||
is a pseudonode elected as a designated router."; | is a pseudonode elected as a designated router."; | |||
reference | reference | |||
"RFC 3630: Traffic Engineering (TE) Extensions to OSPF | "RFC 1195: Use of OSI IS-IS for Routing in TCP/IP and Dual | |||
Version 2. | Environments | |||
RFC 1195: Use of OSI IS-IS for Routing in TCP/IP and Dual | RFC 3630: Traffic Engineering (TE) Extensions to OSPF | |||
Environments."; | Version 2"; | |||
} | } | |||
uses information-source-per-node-attributes; | uses information-source-per-node-attributes; | |||
list information-source-entry { | list information-source-entry { | |||
key "information-source information-source-instance"; | key "information-source information-source-instance"; | |||
config false; | config false; | |||
description | description | |||
"A list of information sources learned, including the one | "A list of information sources learned, including the source | |||
used."; | that is used."; | |||
uses information-source-per-node-attributes; | uses information-source-per-node-attributes; | |||
uses te-node-connectivity-matrices; | uses te-node-connectivity-matrices; | |||
uses te-node-info-attributes; | uses te-node-info-attributes; | |||
} | } | |||
} // te-node-state-derived | } | |||
// te-node-state-derived | ||||
grouping te-node-tunnel-termination-point-config { | grouping te-node-tunnel-termination-point-config { | |||
description | description | |||
"Termination capability of a tunnel termination point on a | "Termination capability of a TTP on a TE node."; | |||
TE node."; | ||||
uses te-node-tunnel-termination-point-config-attributes; | uses te-node-tunnel-termination-point-config-attributes; | |||
container local-link-connectivities { | container local-link-connectivities { | |||
description | description | |||
"Containing local link connectivity list for | "Contains an LLCL for a TTP on a TE node."; | |||
a tunnel termination point on a TE node."; | ||||
leaf number-of-entries { | leaf number-of-entries { | |||
type uint16; | type uint16; | |||
description | description | |||
"The number of local link connectivity list entries. | "The number of LLCL entries. | |||
If this number is specified in the configuration request, | If this number is specified in the configuration request, | |||
the number is requested number of entries, which may not | the number is the requested number of entries, which may | |||
all be listed in the list; | not all be listed in the list; | |||
if this number is reported in the state data, | if this number is reported in the state data, | |||
the number is the current number of operational entries."; | the number is the current number of operational entries."; | |||
} | } | |||
uses te-types:label-set-info; | uses te-types:label-set-info; | |||
uses connectivity-matrix-entry-path-attributes; | uses connectivity-matrix-entry-path-attributes; | |||
} // local-link-connectivities | } | |||
} // te-node-tunnel-termination-point-config | } | |||
// te-node-tunnel-termination-point-config | ||||
grouping te-node-tunnel-termination-point-config-attributes { | grouping te-node-tunnel-termination-point-config-attributes { | |||
description | description | |||
"Configuration attributes of a tunnel termination point on a | "Configuration attributes of a TTP on a TE node."; | |||
TE node."; | ||||
leaf admin-status { | leaf admin-status { | |||
type te-types:te-admin-status; | type te-types:te-admin-status; | |||
description | description | |||
"The administrative state of the tunnel termination point."; | "The administrative state of the TTP."; | |||
} | } | |||
leaf name { | leaf name { | |||
type string; | type string; | |||
description | description | |||
"A descriptive name for the tunnel termination point."; | "A descriptive name for the TTP."; | |||
} | } | |||
leaf switching-capability { | leaf switching-capability { | |||
type identityref { | type identityref { | |||
base te-types:switching-capabilities; | base te-types:switching-capabilities; | |||
} | } | |||
description | description | |||
"Switching Capability for this interface."; | "Switching capability for this interface."; | |||
} | } | |||
leaf encoding { | leaf encoding { | |||
type identityref { | type identityref { | |||
base te-types:lsp-encoding-types; | base te-types:lsp-encoding-types; | |||
} | } | |||
description | description | |||
"Encoding supported by this interface."; | "Encoding supported by this interface."; | |||
} | } | |||
leaf-list inter-layer-lock-id { | leaf-list inter-layer-lock-id { | |||
type uint32; | type uint32; | |||
description | description | |||
"Inter layer lock ID, used for path computation in a TE | "Inter-layer lock ID, used for path computation in a TE | |||
topology covering multiple layers or multiple regions."; | topology covering multiple layers or multiple regions."; | |||
reference | reference | |||
"RFC 5212: Requirements for GMPLS-Based Multi-Region and | "RFC 5212: Requirements for GMPLS-Based Multi-Region and | |||
Multi-Layer Networks (MRN/MLN). | Multi-Layer Networks (MRN/MLN) | |||
RFC 6001: Generalized MPLS (GMPLS) Protocol Extensions | RFC 6001: Generalized MPLS (GMPLS) Protocol Extensions | |||
for Multi-Layer and Multi-Region Networks (MLN/MRN)."; | for Multi-Layer and Multi-Region Networks (MLN/MRN)"; | |||
} | } | |||
leaf protection-type { | leaf protection-type { | |||
type identityref { | type identityref { | |||
base te-types:lsp-protection-type; | base te-types:lsp-protection-type; | |||
} | } | |||
description | description | |||
"The protection type that this tunnel termination point | "The protection type that this TTP is capable of."; | |||
is capable of."; | ||||
} | } | |||
container client-layer-adaptation { | container client-layer-adaptation { | |||
description | description | |||
"Containing capability information to support a client layer | "Contains capability information to support a client-layer | |||
adaption in multi-layer topology."; | adaptation in a multi-layer topology."; | |||
list switching-capability { | list switching-capability { | |||
key "switching-capability encoding"; | key "switching-capability encoding"; | |||
description | description | |||
"List of supported switching capabilities"; | "List of supported switching capabilities."; | |||
reference | reference | |||
"RFC 6001: Generalized MPLS (GMPLS) Protocol Extensions | "RFC 4202: Routing Extensions in Support of | |||
for Multi-Layer and Multi-Region Networks (MLN/MRN). | Generalized Multi-Protocol Label Switching (GMPLS) | |||
RFC 4202: Routing Extensions in Support of | RFC 6001: Generalized MPLS (GMPLS) Protocol Extensions | |||
Generalized Multi-Protocol Label Switching (GMPLS)."; | for Multi-Layer and Multi-Region Networks (MLN/MRN)"; | |||
leaf switching-capability { | leaf switching-capability { | |||
type identityref { | type identityref { | |||
base te-types:switching-capabilities; | base te-types:switching-capabilities; | |||
} | } | |||
description | description | |||
"Switching Capability for the client layer adaption."; | "Switching capability for the client-layer adaptation."; | |||
} | } | |||
leaf encoding { | leaf encoding { | |||
type identityref { | type identityref { | |||
base te-types:lsp-encoding-types; | base te-types:lsp-encoding-types; | |||
} | } | |||
description | description | |||
"Encoding supported by the client layer adaption."; | "Encoding supported by the client-layer adaptation."; | |||
} | } | |||
uses te-types:te-bandwidth; | uses te-types:te-bandwidth; | |||
} | } | |||
} | } | |||
} // te-node-tunnel-termination-point-config-attributes | } | |||
// te-node-tunnel-termination-point-config-attributes | ||||
grouping te-node-tunnel-termination-point-llc-list { | grouping te-node-tunnel-termination-point-llc-list { | |||
description | description | |||
"Local link connectivity list of a tunnel termination | "LLCL of a TTP on a TE node."; | |||
point on a TE node."; | ||||
list local-link-connectivity { | list local-link-connectivity { | |||
key "link-tp-ref"; | key "link-tp-ref"; | |||
description | description | |||
"The termination capabilities between | "The termination capabilities between the TTP and the LTP. | |||
tunnel-termination-point and link termination-point. | This capability information can be used to compute | |||
The capability information can be used to compute | ||||
the tunnel path. | the tunnel path. | |||
The Interface Adjustment Capability Descriptors (IACD) | The Interface Adjustment Capability Descriptors (IACDs) | |||
(defined in RFC 6001) on each link-tp can be derived from | (defined in RFC 6001) on each LTP can be derived from | |||
this local-link-connectivity list."; | this list."; | |||
reference | reference | |||
"RFC 6001: Generalized MPLS (GMPLS) Protocol Extensions | "RFC 6001: Generalized MPLS (GMPLS) Protocol Extensions | |||
for Multi-Layer and Multi-Region Networks (MLN/MRN)."; | for Multi-Layer and Multi-Region Networks (MLN/MRN)"; | |||
leaf link-tp-ref { | leaf link-tp-ref { | |||
type leafref { | type leafref { | |||
path "../../../../../nt:termination-point/nt:tp-id"; | path "../../../../../nt:termination-point/nt:tp-id"; | |||
} | } | |||
description | description | |||
"Link termination point."; | "LTP."; | |||
} | } | |||
uses te-types:label-set-info; | uses te-types:label-set-info; | |||
uses connectivity-matrix-entry-path-attributes; | uses connectivity-matrix-entry-path-attributes; | |||
} // local-link-connectivity | } | |||
} // te-node-tunnel-termination-point-config | } | |||
// te-node-tunnel-termination-point-llc-list | ||||
grouping te-path-element { | grouping te-path-element { | |||
description | description | |||
"A group of attributes defining an element in a TE path | "A group of attributes defining an element in a TE path, | |||
such as TE node, TE link, TE atomic resource or label."; | such as a TE node, TE link, TE atomic resource, or label."; | |||
uses te-types:explicit-route-hop; | uses te-types:explicit-route-hop; | |||
} // te-path-element | } | |||
// te-path-element | ||||
grouping te-termination-point-augment { | grouping te-termination-point-augment { | |||
description | description | |||
"Augmentation for TE termination point."; | "Augmentation for a TE termination point."; | |||
leaf te-tp-id { | leaf te-tp-id { | |||
type te-types:te-tp-id; | type te-types:te-tp-id; | |||
description | description | |||
"An identifier to uniquely identify a TE termination | "An identifier that uniquely identifies a TE termination | |||
point."; | point."; | |||
} | } | |||
container te { | container te { | |||
must "../te-tp-id"; | must '../te-tp-id'; | |||
presence "TE support."; | presence "TE support"; | |||
description | description | |||
"Indicates TE support."; | "Indicates TE support."; | |||
uses te-termination-point-config; | uses te-termination-point-config; | |||
leaf oper-status { | leaf oper-status { | |||
type te-types:te-oper-status; | type te-types:te-oper-status; | |||
config false; | config false; | |||
description | description | |||
"The current operational state of the link termination | "The current operational state of the LTP."; | |||
point."; | ||||
} | } | |||
uses geolocation-container; | uses geolocation-container; | |||
} // te | } | |||
} // te-termination-point-augment | } | |||
// te-termination-point-augment | ||||
grouping te-termination-point-config { | grouping te-termination-point-config { | |||
description | description | |||
"TE termination point configuration grouping."; | "TE termination point configuration grouping."; | |||
leaf admin-status { | leaf admin-status { | |||
type te-types:te-admin-status; | type te-types:te-admin-status; | |||
description | description | |||
"The administrative state of the link termination point."; | "The administrative state of the LTP."; | |||
} | } | |||
leaf name { | leaf name { | |||
type string; | type string; | |||
description | description | |||
"A descriptive name for the link termination point."; | "A descriptive name for the LTP."; | |||
} | } | |||
uses interface-switching-capability-list; | uses interface-switching-capability-list; | |||
leaf inter-domain-plug-id { | leaf inter-domain-plug-id { | |||
type binary; | type binary; | |||
description | description | |||
"A topology-wide unique number that identifies on the | "A network-wide unique number that identifies on the | |||
network a connectivity supporting a given inter-domain | network a connection that supports a given inter-domain | |||
TE link. This is more flexible alternative to specifying | TE link. This is a more flexible alternative to specifying | |||
remote-te-node-id and remote-te-link-tp-id on a TE link, | 'remote-te-node-id' and 'remote-te-link-tp-id' on a TE link | |||
when the provider does not know remote-te-node-id and | when the provider either does not know 'remote-te-node-id' | |||
remote-te-link-tp-id or need to give client the | and 'remote-te-link-tp-id' or needs to give the client the | |||
flexibility to mix-n-match multiple topologies."; | flexibility to mix and match multiple topologies."; | |||
} | } | |||
leaf-list inter-layer-lock-id { | leaf-list inter-layer-lock-id { | |||
type uint32; | type uint32; | |||
description | description | |||
"Inter layer lock ID, used for path computation in a TE | "Inter-layer lock ID, used for path computation in a TE | |||
topology covering multiple layers or multiple regions."; | topology covering multiple layers or multiple regions."; | |||
reference | reference | |||
"RFC 5212: Requirements for GMPLS-Based Multi-Region and | "RFC 5212: Requirements for GMPLS-Based Multi-Region and | |||
Multi-Layer Networks (MRN/MLN). | Multi-Layer Networks (MRN/MLN) | |||
RFC 6001: Generalized MPLS (GMPLS) Protocol Extensions | RFC 6001: Generalized MPLS (GMPLS) Protocol Extensions | |||
for Multi-Layer and Multi-Region Networks (MLN/MRN)."; | for Multi-Layer and Multi-Region Networks (MLN/MRN)"; | |||
} | } | |||
} // te-termination-point-config | } | |||
// te-termination-point-config | ||||
grouping te-topologies-augment { | grouping te-topologies-augment { | |||
description | description | |||
"Augmentation for TE topologies."; | "Augmentation for TE topologies."; | |||
container te { | container te { | |||
presence "TE support."; | presence "TE support"; | |||
description | description | |||
"Indicates TE support."; | "Indicates TE support."; | |||
container templates { | container templates { | |||
description | description | |||
"Configuration parameters for templates used for TE | "Configuration parameters for templates used for a TE | |||
topology."; | topology."; | |||
list node-template { | list node-template { | |||
if-feature template; | if-feature "template"; | |||
key "name"; | key "name"; | |||
leaf name { | leaf name { | |||
type te-types:te-template-name; | type te-types:te-template-name; | |||
description | description | |||
"The name to identify a TE node template."; | "The name to identify a TE node template."; | |||
} | } | |||
description | description | |||
"The list of TE node templates used to define sharable | "The list of TE node templates used to define sharable | |||
and reusable TE node attributes."; | and reusable TE node attributes."; | |||
uses template-attributes; | uses template-attributes; | |||
uses te-node-config-attributes-template; | uses te-node-config-attributes-template; | |||
} // node-template | } | |||
// node-template | ||||
list link-template { | list link-template { | |||
if-feature template; | if-feature "template"; | |||
key "name"; | key "name"; | |||
leaf name { | leaf name { | |||
type te-types:te-template-name; | type te-types:te-template-name; | |||
description | description | |||
"The name to identify a TE link template."; | "The name to identify a TE link template."; | |||
} | } | |||
description | description | |||
"The list of TE link templates used to define sharable | "The list of TE link templates used to define sharable | |||
and reusable TE link attributes."; | and reusable TE link attributes."; | |||
uses template-attributes; | uses template-attributes; | |||
uses te-link-config-attributes; | uses te-link-config-attributes; | |||
} // link-template | } | |||
} // templates | // link-template | |||
} // te | } | |||
} // te-topologies-augment | // templates | |||
} | ||||
// te | ||||
} | ||||
// te-topologies-augment | ||||
grouping te-topology-augment { | grouping te-topology-augment { | |||
description | description | |||
"Augmentation for TE topology."; | "Augmentation for a TE topology."; | |||
uses te-types:te-topology-identifier; | uses te-types:te-topology-identifier; | |||
container te { | container te { | |||
must "../te-topology-identifier/provider-id" | must '../te-topology-identifier/provider-id' | |||
+ " and ../te-topology-identifier/client-id" | + ' and ../te-topology-identifier/client-id' | |||
+ " and ../te-topology-identifier/topology-id"; | + ' and ../te-topology-identifier/topology-id'; | |||
presence "TE support."; | presence "TE support"; | |||
description | description | |||
"Indicates TE support."; | "Indicates TE support."; | |||
uses te-topology-config; | uses te-topology-config; | |||
uses geolocation-container; | uses geolocation-container; | |||
} // te | } | |||
} // te-topology-augment | } | |||
// te-topology-augment | ||||
grouping te-topology-config { | grouping te-topology-config { | |||
description | description | |||
"TE topology configuration grouping."; | "TE topology configuration grouping."; | |||
leaf name { | leaf name { | |||
type string; | type string; | |||
description | description | |||
"Name of the TE topology. This attribute is optional and can | "Name of the TE topology. This attribute is optional and can | |||
be specified by the operator to describe the TE topology, | be specified by the operator to describe the TE topology, | |||
which can be useful when network-id is not descriptive | which can be useful when 'network-id' (RFC 8345) is not | |||
and not modifiable because of being generated by the | descriptive and not modifiable because of being generated | |||
system."; | by the system."; | |||
reference | ||||
"RFC 8345: A YANG Data Model for Network Topologies"; | ||||
} | } | |||
leaf preference { | leaf preference { | |||
type uint8 { | type uint8 { | |||
range "1..255"; | range "1..255"; | |||
} | } | |||
description | description | |||
"Specifies a preference for this topology. A lower number | "Specifies a preference for this topology. A lower number | |||
indicates a higher preference."; | indicates a higher preference."; | |||
} | } | |||
leaf optimization-criterion { | leaf optimization-criterion { | |||
type identityref { | type identityref { | |||
base te-types:objective-function-type; | base te-types:objective-function-type; | |||
} | } | |||
description | description | |||
"Optimization criterion applied to this topology."; | "Optimization criterion applied to this topology."; | |||
reference | reference | |||
"RFC 3272: Overview and Principles of Internet Traffic | "RFC 3272: Overview and Principles of Internet Traffic | |||
Engineering."; | Engineering"; | |||
} | } | |||
list nsrlg { | list nsrlg { | |||
if-feature nsrlg; | if-feature "nsrlg"; | |||
key "id"; | key "id"; | |||
description | description | |||
"List of NSRLGs (Not Sharing Risk Link Groups)."; | "List of NSRLGs (Non-Shared Risk Link Groups)."; | |||
reference | reference | |||
"RFC 4872: RSVP-TE Extensions in Support of End-to-End | "RFC 4872: RSVP-TE Extensions in Support of End-to-End | |||
Generalized Multi-Protocol Label Switching (GMPLS) | Generalized Multi-Protocol Label Switching (GMPLS) | |||
Recovery"; | Recovery"; | |||
leaf id { | leaf id { | |||
type uint32; | type uint32; | |||
description | description | |||
"Identify the NSRLG entry."; | "Identifies the NSRLG entry."; | |||
} | } | |||
leaf disjointness { | leaf disjointness { | |||
type te-types:te-path-disjointness; | type te-types:te-path-disjointness; | |||
description | description | |||
"The type of resource disjointness."; | "The type of resource disjointness."; | |||
} | } | |||
} // nsrlg | } | |||
} // te-topology-config | // nsrlg | |||
} | ||||
// te-topology-config | ||||
grouping template-attributes { | grouping template-attributes { | |||
description | description | |||
"Common attributes for all templates."; | "Common attributes for all templates."; | |||
leaf priority { | leaf priority { | |||
type uint16; | type uint16; | |||
description | description | |||
"The preference value to resolve conflicts between different | "The preference value for resolving conflicts between | |||
templates. When two or more templates specify values for | different templates. When two or more templates specify | |||
one configuration attribute, the value from the template | values for one configuration attribute, the value from the | |||
with the highest priority is used. | template with the highest priority is used. | |||
A lower number indicates a higher priority. The highest | A lower number indicates a higher priority. The highest | |||
priority is 0."; | priority is 0."; | |||
} | } | |||
leaf reference-change-policy { | leaf reference-change-policy { | |||
type enumeration { | type enumeration { | |||
enum no-action { | enum no-action { | |||
description | description | |||
"When an attribute changes in this template, the | "When an attribute changes in this template, the | |||
configuration node referring to this template does | configuration node referring to this template does | |||
not take any action."; | not take any action."; | |||
} | } | |||
skipping to change at line 3789 ¶ | skipping to change at line 3757 ¶ | |||
} | } | |||
enum cascade { | enum cascade { | |||
description | description | |||
"When an attribute changes in this template, the | "When an attribute changes in this template, the | |||
configuration object referring to this template applies | configuration object referring to this template applies | |||
the new attribute value to the corresponding | the new attribute value to the corresponding | |||
configuration."; | configuration."; | |||
} | } | |||
} | } | |||
description | description | |||
"This attribute specifies the action taken to a configuration | "This attribute specifies the action taken for a | |||
node that has a reference to this template."; | configuration node that has a reference to this template."; | |||
} | } | |||
} // template-attributes | } | |||
// template-attributes | ||||
/* | /* | |||
* Data nodes | * Data nodes | |||
*/ | */ | |||
augment "/nw:networks/nw:network/nw:network-types" { | augment "/nw:networks/nw:network/nw:network-types" { | |||
description | description | |||
"Introduce new network type for TE topology."; | "Introduces a new network type for a TE topology."; | |||
container te-topology { | container te-topology { | |||
presence "Indicates TE topology."; | presence "Indicates a TE topology"; | |||
description | description | |||
"Its presence identifies the TE topology type."; | "Its presence identifies the TE topology type."; | |||
} | } | |||
} | } | |||
augment "/nw:networks" { | augment "/nw:networks" { | |||
description | description | |||
"Augmentation parameters for TE topologies."; | "Augmentation parameters for TE topologies."; | |||
uses te-topologies-augment; | uses te-topologies-augment; | |||
} | } | |||
augment "/nw:networks/nw:network" { | augment "/nw:networks/nw:network" { | |||
when "nw:network-types/tet:te-topology" { | when 'nw:network-types/tet:te-topology' { | |||
description | description | |||
"Augmentation parameters apply only for networks with | "Augmentation parameters apply only for networks with a | |||
TE topology type."; | TE topology type."; | |||
} | } | |||
description | description | |||
"Configuration parameters for TE topology."; | "Configuration parameters for a TE topology."; | |||
uses te-topology-augment; | uses te-topology-augment; | |||
} | } | |||
augment "/nw:networks/nw:network/nw:node" { | augment "/nw:networks/nw:network/nw:node" { | |||
when "../nw:network-types/tet:te-topology" { | when '../nw:network-types/tet:te-topology' { | |||
description | description | |||
"Augmentation parameters apply only for networks with | "Augmentation parameters apply only for networks with a | |||
TE topology type."; | TE topology type."; | |||
} | } | |||
description | description | |||
"Configuration parameters for TE at node level."; | "Configuration parameters for TE at the node level."; | |||
leaf te-node-id { | leaf te-node-id { | |||
type te-types:te-node-id; | type te-types:te-node-id; | |||
description | description | |||
"The identifier of a node in the TE topology. | "The identifier of a node in the TE topology. | |||
A node is specific to a topology to which it belongs."; | A node is specific to a topology to which it belongs."; | |||
} | } | |||
container te { | container te { | |||
must "../te-node-id" { | must '../te-node-id' { | |||
description | description | |||
"te-node-id is mandatory."; | "'te-node-id' is mandatory."; | |||
} | } | |||
must "count(../nw:supporting-node)<=1" { | must 'count(../nw:supporting-node)<=1' { | |||
description | description | |||
"For a node in a TE topology, there cannot be more | "For a node in a TE topology, there cannot be more | |||
than 1 supporting node. If multiple nodes are abstracted, | than one supporting node. If multiple nodes are | |||
the underlay-topology is used."; | abstracted, the 'underlay-topology' field is used."; | |||
} | } | |||
presence "TE support."; | presence "TE support"; | |||
description | description | |||
"Indicates TE support."; | "Indicates TE support."; | |||
uses te-node-augment; | uses te-node-augment; | |||
} // te | } | |||
} | } | |||
augment "/nw:networks/nw:network/nt:link" { | augment "/nw:networks/nw:network/nt:link" { | |||
when "../nw:network-types/tet:te-topology" { | when '../nw:network-types/tet:te-topology' { | |||
description | description | |||
"Augmentation parameters apply only for networks with | "Augmentation parameters apply only for networks with a | |||
TE topology type."; | TE topology type."; | |||
} | } | |||
description | description | |||
"Configuration parameters for TE at link level."; | "Configuration parameters for TE at the link level."; | |||
container te { | container te { | |||
must "count(../nt:supporting-link)<=1" { | must 'count(../nt:supporting-link)<=1' { | |||
description | description | |||
"For a link in a TE topology, there cannot be more | "For a link in a TE topology, there cannot be more | |||
than 1 supporting link. If one or more link paths are | than one supporting link. If one or more link paths are | |||
abstracted, the underlay is used."; | abstracted, the underlay is used."; | |||
} | } | |||
presence "TE support."; | presence "TE support"; | |||
description | description | |||
"Indicates TE support."; | "Indicates TE support."; | |||
uses te-link-augment; | uses te-link-augment; | |||
} // te | } | |||
} | } | |||
augment "/nw:networks/nw:network/nw:node/" | augment "/nw:networks/nw:network/nw:node/" | |||
+ "nt:termination-point" { | + "nt:termination-point" { | |||
when "../../nw:network-types/tet:te-topology" { | when '../../nw:network-types/tet:te-topology' { | |||
description | description | |||
"Augmentation parameters apply only for networks with | "Augmentation parameters apply only for networks with a | |||
TE topology type."; | TE topology type."; | |||
} | } | |||
description | description | |||
"Configuration parameters for TE at termination point level."; | "Configuration parameters for TE at the termination point | |||
level."; | ||||
uses te-termination-point-augment; | uses te-termination-point-augment; | |||
} | } | |||
augment | augment "/nw:networks/nw:network/nt:link/te/bundle-stack-level/" | |||
"/nw:networks/nw:network/nt:link/te/bundle-stack-level/" | + "bundle/bundled-links/bundled-link" { | |||
+ "bundle/bundled-links/bundled-link" { | when '../../../../nw:network-types/tet:te-topology' { | |||
when "../../../../nw:network-types/tet:te-topology" { | ||||
description | description | |||
"Augmentation parameters apply only for networks with | "Augmentation parameters apply only for networks with a | |||
TE topology type."; | TE topology type."; | |||
} | } | |||
description | description | |||
"Augment TE link bundled link."; | "Augmentation for a TE bundled link."; | |||
leaf src-tp-ref { | leaf src-tp-ref { | |||
type leafref { | type leafref { | |||
path "../../../../../nw:node[nw:node-id = " | path "../../../../../nw:node[nw:node-id = " | |||
+ "current()/../../../../nt:source/" | + "current()/../../../../nt:source/" | |||
+ "nt:source-node]/" | + "nt:source-node]/" | |||
+ "nt:termination-point/nt:tp-id"; | + "nt:termination-point/nt:tp-id"; | |||
require-instance true; | require-instance true; | |||
} | } | |||
description | description | |||
"Reference to another TE termination point on the | "Reference to another TE termination point on the | |||
same source node."; | same source node."; | |||
} | } | |||
leaf des-tp-ref { | leaf des-tp-ref { | |||
type leafref { | type leafref { | |||
path "../../../../../nw:node[nw:node-id = " | path "../../../../../nw:node[nw:node-id = " | |||
+ "current()/../../../../nt:destination/" | + "current()/../../../../nt:destination/" | |||
+ "nt:dest-node]/" | + "nt:dest-node]/" | |||
+ "nt:termination-point/nt:tp-id"; | + "nt:termination-point/nt:tp-id"; | |||
require-instance true; | require-instance true; | |||
} | } | |||
description | description | |||
"Reference to another TE termination point on the | "Reference to another TE termination point on the | |||
same destination node."; | same destination node."; | |||
} | } | |||
} | } | |||
augment | augment "/nw:networks/nw:network/nw:node/te/" | |||
"/nw:networks/nw:network/nw:node/te/" | + "information-source-entry/connectivity-matrices/" | |||
+ "information-source-entry/connectivity-matrices/" | + "connectivity-matrix" { | |||
+ "connectivity-matrix" { | when '../../../../../nw:network-types/tet:te-topology' { | |||
when "../../../../../nw:network-types/tet:te-topology" { | ||||
description | description | |||
"Augmentation parameters apply only for networks with | "Augmentation parameters apply only for networks with a | |||
TE topology type."; | TE topology type."; | |||
} | } | |||
description | description | |||
"Augment TE node connectivity-matrix."; | "Augmentation for the TE node connectivity matrix."; | |||
uses te-node-connectivity-matrix-attributes; | uses te-node-connectivity-matrix-attributes; | |||
} | } | |||
augment | augment "/nw:networks/nw:network/nw:node/te/te-node-attributes/" | |||
"/nw:networks/nw:network/nw:node/te/te-node-attributes/" | + "connectivity-matrices/connectivity-matrix" { | |||
+ "connectivity-matrices/connectivity-matrix" { | when '../../../../../nw:network-types/tet:te-topology' { | |||
when "../../../../../nw:network-types/tet:te-topology" { | ||||
description | description | |||
"Augmentation parameters apply only for networks with | "Augmentation parameters apply only for networks with a | |||
TE topology type."; | TE topology type."; | |||
} | } | |||
description | description | |||
"Augment TE node connectivity-matrix."; | "Augmentation for the TE node connectivity matrix."; | |||
uses te-node-connectivity-matrix-attributes; | uses te-node-connectivity-matrix-attributes; | |||
} | } | |||
augment | augment "/nw:networks/nw:network/nw:node/te/" | |||
"/nw:networks/nw:network/nw:node/te/" | + "tunnel-termination-point/local-link-connectivities" { | |||
+ "tunnel-termination-point/local-link-connectivities" { | when '../../../../nw:network-types/tet:te-topology' { | |||
when "../../../../nw:network-types/tet:te-topology" { | ||||
description | description | |||
"Augmentation parameters apply only for networks with | "Augmentation parameters apply only for networks with a | |||
TE topology type."; | TE topology type."; | |||
} | } | |||
description | description | |||
"Augment TE node tunnel termination point LLCs | "Augmentation for TE node TTP LLCs (Local Link | |||
(Local Link Connectivities)."; | Connectivities)."; | |||
uses te-node-tunnel-termination-point-llc-list; | uses te-node-tunnel-termination-point-llc-list; | |||
} | } | |||
} | }]]></sourcecode> | |||
<CODE ENDS> | ||||
]]></artwork> | ||||
</figure> | ||||
</section> | ||||
<section title="Security Considerations" anchor="sect-8"><t> | </section> | |||
<section anchor="sect-8" numbered="true" toc="default"> | ||||
<name>Security Considerations</name> | ||||
<t> | ||||
The YANG module specified in this document defines a schema for data | The YANG module specified in this document defines a schema for data | |||
that is designed to be accessed via network management protocols such | that is designed to be accessed via network management protocols such | |||
as NETCONF <xref target="RFC6241"/> or RESTCONF <xref target="RFC8040"/>. The lowest NETCONF layer | as NETCONF <xref target="RFC6241" format="default"/> or RESTCONF <xref target ="RFC8040" format="default"/>. The lowest NETCONF layer | |||
is the secure transport layer, and the mandatory-to-implement secure | is the secure transport layer, and the mandatory-to-implement secure | |||
transport is Secure Shell (SSH) <xref target="RFC6242"/>. The lowest RESTCONF layer | transport is Secure Shell (SSH) <xref target="RFC6242" format="default"/>. Th e lowest RESTCONF layer | |||
is HTTPS, and the mandatory-to-implement secure transport is TLS | is HTTPS, and the mandatory-to-implement secure transport is TLS | |||
<xref target="RFC8446"/>.</t> | <xref target="RFC8446" format="default"/>.</t> | |||
<t> | ||||
<t> | The Network Configuration Access Control Model (NACM) <xref target="RFC8341" | |||
The Network Configuration Access Control Model (NACM) <xref target="RFC8341"/ | format="default"/> | |||
> | ||||
provides the means to restrict access for particular NETCONF or | provides the means to restrict access for particular NETCONF or | |||
RESTCONF users to a preconfigured subset of all available NETCONF or | RESTCONF users to a preconfigured subset of all available NETCONF or | |||
RESTCONF protocol operations and content.</t> | RESTCONF protocol operations and content.</t> | |||
<t> | ||||
<t> | ||||
There are a number of data nodes defined in this YANG module that are | There are a number of data nodes defined in this YANG module that are | |||
writable/creatable/deletable (i.e., config true, which is the | writable/creatable/deletable (i.e., config true, which is the | |||
default). These data nodes may be considered sensitive or vulnerable | default). These data nodes may be considered sensitive or vulnerable | |||
in some network environments. Write operations (e.g., edit-config) to | in some network environments. Write operations (e.g., edit-config) to | |||
these data nodes without proper protection can have a negative effect | these data nodes without proper protection can have a negative effect | |||
on network operations. These are the subtrees and data nodes and | on network operations. These are the subtrees and data nodes and | |||
their sensitivity/vulnerability:</t> | their sensitivity/vulnerability:</t> | |||
<ul spacing="normal"> | ||||
<t><list style="symbols"> | <li> | |||
<t>/nw:networks/nw:network/nw:network-types/tet:te-topology | ||||
<t>/nw:networks/nw:network/nw:network-types/tet:te-topology | </t> | |||
<vspace /> | <t> | |||
This subtree specifies the TE topology type. Modifying the | This subtree specifies the TE topology type. Modifying the | |||
configurations can make TE topology type invalid. By such | configurations can render the TE topology type invalid. By making such | |||
modifications, a malicious attacker may disable the TE | modifications, a malicious attacker may disable the TE | |||
capabilities on the related networks and cause traffic disrupted | capabilities on the related networks and cause traffic to be disrupted | |||
or misrouted.</t> | or misrouted.</t> | |||
</li> | ||||
<t>/nw:networks/tet:te | <li> | |||
<vspace /> | <t>/nw:networks/tet:te | |||
</t> | ||||
<t> | ||||
This subtree specifies the TE node templates and TE link | This subtree specifies the TE node templates and TE link | |||
templates. Modifying the configurations in this subtree will change the | templates. Modifying the configurations in this subtree will change the | |||
related future TE configurations. By such modifications, a malicious | related future TE configurations. By making such modifications, a | |||
attacker may change the TE capabilities scheduled at a future time, to | malicious attacker may change TE capabilities scheduled at a | |||
cause traffic disrupted or misrouted.</t> | future time and cause traffic to be disrupted or misrouted.</t> | |||
</li> | ||||
<t>/nw:networks/nw:network | <li> | |||
<vspace /> | <t>/nw:networks/nw:network | |||
</t> | ||||
<t> | ||||
This subtree specifies the topology-wide configurations, including | This subtree specifies the topology-wide configurations, including | |||
the TE topology ID and topology-wide policies. Modifying the | the TE topology ID and topology-wide policies. Modifying the | |||
configurations in this subtree can add, remove, or modify TE | configurations in this subtree can add, remove, or modify TE | |||
topologies. By adding a TE topology, a malicious attacker may | topologies. By adding a TE topology, a malicious attacker may | |||
create an unauthorized traffic network. By removing or modifying a | create an unauthorized traffic network. By removing or modifying a | |||
TE topology, a malicious attacker may cause traffic disabled or | TE topology, a malicious attacker may cause traffic to be disabled or | |||
misrouted in the specified TE topology. Such traffic changes may | misrouted in the specified TE topology. Such traffic changes may | |||
also affect the traffic in the connected TE topologies.</t> | also affect the traffic in the connected TE topologies.</t> | |||
</li> | ||||
<t>/nw:networks/nw:network/nw:node | <li> | |||
<vspace /> | <t>/nw:networks/nw:network/nw:node | |||
</t> | ||||
<t> | ||||
This subtree specifies the configurations for TE nodes. Modifying | This subtree specifies the configurations for TE nodes. Modifying | |||
the configurations in this subtree can add, remove, or modify TE | the configurations in this subtree can add, remove, or modify TE | |||
nodes. By adding a TE node, a malicious attacker may create an | nodes. By adding a TE node, a malicious attacker may create an | |||
unauthorized traffic path. By removing or modifying a TE node, a | unauthorized traffic path. By removing or modifying a TE node, a | |||
malicious attacker may cause traffic disabled or misrouted in the | malicious attacker may cause traffic to be disabled or misrouted in the | |||
specified TE node. Such traffic changes may also affect the | specified TE node. Such traffic changes may also affect the | |||
traffic on the surrounding TE nodes and TE links in this TE | traffic on the surrounding TE nodes and TE links in this TE | |||
topology and the connected TE topologies.</t> | topology and the connected TE topologies.</t> | |||
</li> | ||||
<t>/nw:networks/nw:network/nt:link/tet:te | <li> | |||
<vspace /> | <t>/nw:networks/nw:network/nt:link/tet:te | |||
</t> | ||||
<t> | ||||
This subtree specifies the configurations for TE links. Modifying | This subtree specifies the configurations for TE links. Modifying | |||
the configurations in this subtree can add, remove, or modify TE | the configurations in this subtree can add, remove, or modify TE | |||
links. By adding a TE link, a malicious attacker may create an | links. By adding a TE link, a malicious attacker may create an | |||
unauthorized traffic path. By removing or modifying a TE link, a | unauthorized traffic path. By removing or modifying a TE link, a | |||
malicious attacker may cause traffic disabled or misrouted on the | malicious attacker may cause traffic to be disabled or misrouted on the | |||
specified TE link. Such traffic changes may also affect the | specified TE link. Such traffic changes may also affect the | |||
traffic on the surrounding TE nodes and TE links in this TE | traffic on the surrounding TE nodes and TE links in this TE | |||
topology and the connected TE topologies.</t> | topology and the connected TE topologies.</t> | |||
</li> | ||||
<t>/nw:networks/nw:network/nw:node/nt:termination-point | <li> | |||
<vspace /> | <t>/nw:networks/nw:network/nw:node/nt:termination-point | |||
This subtree specifies the configurations of TE link termination | </t> | |||
points. Modifying the configurations in this subtree can add, | <t> | |||
remove, or modify TE link termination points. By adding a TE link | This subtree specifies the configurations of TE LTPs. | |||
termination point, a malicious attacker may create an unauthorized | Modifying the configurations in this subtree can add, | |||
traffic path. By removing or modifying a TE link termination | remove, or modify TE LTPs. By adding a TE LTP, a malicious | |||
point, a malicious attacker may cause traffic disabled or | attacker may create an unauthorized traffic path. By removing | |||
misrouted on the specified TE link termination point. Such traffic | or modifying a TE LTP, a malicious attacker may cause traffic to be | |||
disabled or misrouted on the specified TE LTP. Such traffic | ||||
changes may also affect the traffic on the surrounding TE nodes | changes may also affect the traffic on the surrounding TE nodes | |||
and TE links in this TE topology and the connected TE topologies.</t> | and TE links in this TE topology and the connected TE topologies.</t> | |||
</li> | ||||
</list> | </ul> | |||
</t> | <t> | |||
<t> | ||||
Some of the readable data nodes in this YANG module may be considered | Some of the readable data nodes in this YANG module may be considered | |||
sensitive or vulnerable in some network environments. It is thus | sensitive or vulnerable in some network environments. It is thus | |||
important to control read access (e.g., via get, get-config, or | important to control read access (e.g., via get, get-config, or | |||
notification) to these data nodes. These are the subtrees and data | notification) to these data nodes. These are the subtrees and data | |||
nodes and their sensitivity/vulnerability:</t> | nodes and their sensitivity/vulnerability:</t> | |||
<ul spacing="normal"> | ||||
<t><list style="symbols"> | <li> | |||
<t>/nw:networks/nw:network/nw:network-types/tet:te-topology | ||||
<t>/nw:networks/nw:network/nw:network-types/tet:te-topology | </t> | |||
<vspace /> | <t> | |||
Unauthorized access to this subtree can disclose the TE topology | Unauthorized access to this subtree can disclose the TE topology | |||
type.</t> | type.</t> | |||
</li> | ||||
<t>/nw:networks/tet:te | <li> | |||
<vspace /> | <t>/nw:networks/tet:te | |||
</t> | ||||
<t> | ||||
Unauthorized access to this subtree can disclose the TE node | Unauthorized access to this subtree can disclose the TE node | |||
templates and TE link templates.</t> | templates and TE link templates.</t> | |||
</li> | ||||
<t>/nw:networks/nw:network | <li> | |||
<vspace /> | <t>/nw:networks/nw:network | |||
</t> | ||||
<t> | ||||
Unauthorized access to this subtree can disclose the topology-wide | Unauthorized access to this subtree can disclose the topology-wide | |||
configurations, including the TE topology ID, the topology-wide | configurations, including the TE topology ID, the topology-wide | |||
policies, and the topology geolocation.</t> | policies, and the topology geolocation.</t> | |||
</li> | ||||
<t>/nw:networks/nw:network/nw:node | <li> | |||
<vspace /> | <t>/nw:networks/nw:network/nw:node | |||
</t> | ||||
<t> | ||||
Unauthorized access to this subtree can disclose the operational | Unauthorized access to this subtree can disclose the operational | |||
state information of TE nodes.</t> | state information of TE nodes.</t> | |||
</li> | ||||
<t>/nw:networks/nw:network/nt:link/tet:te | <li> | |||
<vspace /> | <t>/nw:networks/nw:network/nt:link/tet:te | |||
</t> | ||||
<t> | ||||
Unauthorized access to this subtree can disclose the operational | Unauthorized access to this subtree can disclose the operational | |||
state information of TE links.</t> | state information of TE links.</t> | |||
</li> | ||||
<t>/nw:networks/nw:network/nw:node/nt:termination-point | <li> | |||
<vspace /> | <t>/nw:networks/nw:network/nw:node/nt:termination-point | |||
</t> | ||||
<t> | ||||
Unauthorized access to this subtree can disclose the operational | Unauthorized access to this subtree can disclose the operational | |||
state information of TE link termination points.</t> | state information of TE LTPs.</t> | |||
</li> | ||||
</list> | </ul> | |||
</t> | </section> | |||
<section anchor="sect-9" numbered="true" toc="default"> | ||||
</section> | <name>IANA Considerations</name> | |||
<t> | ||||
<section title="IANA Considerations" anchor="sect-9"><t> | IANA has registered the following URIs in the "ns" subregistry within the | |||
This document registers the following URIs in the IETF XML registry | "IETF XML Registry" <xref target="RFC3688" format="default"/>. | |||
<xref target="RFC3688"/>. Following the format in <xref target="RFC3688"/>, t | </t> | |||
he following | ||||
registration is requested to be made.</t> | ||||
<figure><artwork><![CDATA[ | ||||
URI: urn:ietf:params:xml:ns:yang:ietf-te-topology | ||||
Registrant Contact: The IESG. | ||||
XML: N/A, the requested URI is an XML namespace. | ||||
URI: urn:ietf:params:xml:ns:yang:ietf-te-topology-state | ||||
Registrant Contact: The IESG. | ||||
XML: N/A, the requested URI is an XML namespace. | ||||
]]></artwork> | ||||
</figure> | ||||
<t> | ||||
This document registers a YANG module in the YANG Module Names | ||||
registry <xref target="RFC7950"/>.</t> | ||||
<figure><artwork><![CDATA[ | <dl newline="false" spacing="compact"> | |||
name: ietf-te-topology | <dt>URI:</dt><dd>urn:ietf:params:xml:ns:yang:ietf-te-topology</dd> | |||
namespace: urn:ietf:params:xml:ns:yang:ietf-te-topology | <dt>Registrant Contact:</dt><dd>The IESG.</dd> | |||
prefix: tet | <dt>XML:</dt><dd>N/A; the requested URI is an XML namespace.</dd> | |||
reference: RFC XXXX | </dl> | |||
name: ietf-te-topology-state | <dl newline="false" spacing="compact"> | |||
namespace: urn:ietf:params:xml:ns:yang:ietf-te-topology-state | <dt>URI:</dt><dd>urn:ietf:params:xml:ns:yang:ietf-te-topology-state</dd> | |||
prefix: tet-s | <dt>Registrant Contact:</dt><dd>The IESG.</dd> | |||
reference: RFC XXXX | <dt>XML:</dt><dd>N/A; the requested URI is an XML namespace.</dd> | |||
]]></artwork> | </dl> | |||
</figure> | ||||
</section> | ||||
</middle> | <t> | |||
IANA has registered the following YANG modules in the "YANG Module Names" | ||||
subregistry <xref target="RFC6020" format="default"/> within the "YANG | ||||
Parameters" registry. | ||||
<back> | </t> | |||
<references title="Normative References"> | ||||
&RFC2119; | ||||
&RFC3688; | ||||
&RFC3945; | ||||
&RFC6241; | ||||
&RFC6242; | ||||
&RFC6991; | ||||
&RFC7926; | ||||
&RFC7950; | ||||
&RFC8040; | ||||
&RFC8174; | ||||
&RFC8341; | ||||
&RFC8342; | ||||
&RFC8345; | ||||
&RFC8446; | ||||
&I-D.ietf-teas-yang-te-types; | ||||
</references> | ||||
<references title="Informative References"> | ||||
<reference anchor="G.709"><front> | ||||
<title>Interfaces for the optical transport network</title> | ||||
<author> | ||||
<organization>ITU-T</organization> | ||||
</author> | ||||
<date month="June" year="2016"/> | <dl newline="false" spacing="compact"> | |||
</front> | <dt>Name:</dt><dd>ietf-te-topology</dd> | |||
<dt>Namespace:</dt><dd>urn:ietf:params:xml:ns:yang:ietf-te-topology</dd> | ||||
<dt>Prefix:</dt><dd>tet</dd> | ||||
<dt>Reference:</dt><dd>RFC 8795</dd> | ||||
</dl> | ||||
<seriesInfo name="ITU-T" value="Recommendation G.709"/> | <dl newline="false" spacing="compact"> | |||
</reference> | <dt>Name:</dt><dd>ietf-te-topology-state</dd> | |||
<reference anchor="G.805"><front> | <dt>Namespace:</dt><dd>urn:ietf:params:xml:ns:yang:ietf-te-topology-state</dd | |||
<title>Generic functional architecture of transport networks</title> | > | |||
<author> | <dt>Prefix:</dt><dd>tet-s</dd> | |||
<organization>ITU-T</organization> | <dt>Reference:</dt><dd>RFC 8795</dd> | |||
</author> | </dl> | |||
<date month="March" year="2000"/> | </section> | |||
</front> | </middle> | |||
<back> | ||||
<displayreference target="I-D.ietf-teas-te-topo-and-tunnel-modeling" to="TEAS-TO | ||||
PO"/> | ||||
<references> | ||||
<name>References</name> | ||||
<references> | ||||
<name>Normative References</name> | ||||
<xi:include href="https://xml2rfc.ietf.org/public/rfc/bibxml/reference.R | ||||
FC.2119.xml"/> | ||||
<xi:include href="https://xml2rfc.ietf.org/public/rfc/bibxml/reference.R | ||||
FC.3688.xml"/> | ||||
<xi:include href="https://xml2rfc.ietf.org/public/rfc/bibxml/reference.R | ||||
FC.3945.xml"/> | ||||
<xi:include href="https://xml2rfc.ietf.org/public/rfc/bibxml/reference.R | ||||
FC.6020.xml"/> | ||||
<xi:include href="https://xml2rfc.ietf.org/public/rfc/bibxml/reference.R | ||||
FC.6241.xml"/> | ||||
<xi:include href="https://xml2rfc.ietf.org/public/rfc/bibxml/reference.R | ||||
FC.6242.xml"/> | ||||
<xi:include href="https://xml2rfc.ietf.org/public/rfc/bibxml/reference.R | ||||
FC.6991.xml"/> | ||||
<xi:include href="https://xml2rfc.ietf.org/public/rfc/bibxml/reference.R | ||||
FC.7926.xml"/> | ||||
<xi:include href="https://xml2rfc.ietf.org/public/rfc/bibxml/reference.R | ||||
FC.7950.xml"/> | ||||
<xi:include href="https://xml2rfc.ietf.org/public/rfc/bibxml/reference.R | ||||
FC.8040.xml"/> | ||||
<xi:include href="https://xml2rfc.ietf.org/public/rfc/bibxml/reference.R | ||||
FC.8174.xml"/> | ||||
<xi:include href="https://xml2rfc.ietf.org/public/rfc/bibxml/reference.R | ||||
FC.8341.xml"/> | ||||
<xi:include href="https://xml2rfc.ietf.org/public/rfc/bibxml/reference.R | ||||
FC.8342.xml"/> | ||||
<xi:include href="https://xml2rfc.ietf.org/public/rfc/bibxml/reference.R | ||||
FC.8345.xml"/> | ||||
<xi:include href="https://xml2rfc.ietf.org/public/rfc/bibxml/reference.R | ||||
FC.8446.xml"/> | ||||
<seriesInfo name="ITU-T" value="Recommendation G.805"/> | <!-- draft-ietf-teas-yang-te-types (RFC 8776) (PUB 6/10/2020) --> | |||
</reference> | <xi:include href="https://xml2rfc.ietf.org/public/rfc/bibxml/reference.RFC.8776. | |||
<reference anchor="G.872"><front> | xml"/> | |||
<title>Architecture of optical transport networks</title> | </references> | |||
<author> | <references> | |||
<organization>ITU-T</organization> | <name>Informative References</name> | |||
</author> | <reference anchor="G.709" target="https://www.itu.int/rec/T-REC-G.709/"> | |||
<front> | ||||
<title>Interfaces for the optical transport network</title> | ||||
<seriesInfo name="ITU-T" value="Recommendation G.709"/> | ||||
<author> | ||||
<organization>ITU-T</organization> | ||||
</author> | ||||
<date month="June" year="2020"/> | ||||
</front> | ||||
</reference> | ||||
<reference anchor="G.805" target="https://www.itu.int/rec/T-REC-G.805/en | ||||
"> | ||||
<front> | ||||
<title>Generic functional architecture of transport networks</title> | ||||
<seriesInfo name="ITU-T" value="Recommendation G.805"/> | ||||
<author> | ||||
<organization>ITU-T</organization> | ||||
</author> | ||||
<date month="March" year="2000"/> | ||||
</front> | ||||
</reference> | ||||
<reference anchor="G.872" target="https://www.itu.int/rec/T-REC-G.872/en | ||||
"> | ||||
<front> | ||||
<title>Architecture of optical transport networks</title> | ||||
<seriesInfo name="ITU-T" value="Recommendation G.872"/> | ||||
<author> | ||||
<organization>ITU-T</organization> | ||||
</author> | ||||
<date month="December" year="2019"/> | ||||
</front> | ||||
</reference> | ||||
<reference anchor="G.8080" target="https://www.itu.int/rec/T-REC-G.8080/ | ||||
en"> | ||||
<front> | ||||
<title>Architecture for the automatically switched optical network</ | ||||
title> | ||||
<seriesInfo name="ITU-T" value="Recommendation G.8080"/> | ||||
<author> | ||||
<organization>ITU-T</organization> | ||||
</author> | ||||
<date month="February" year="2012"/> | ||||
</front> | ||||
</reference> | ||||
<xi:include href="https://xml2rfc.ietf.org/public/rfc/bibxml/reference.R | ||||
FC.1195.xml"/> | ||||
<xi:include href="https://xml2rfc.ietf.org/public/rfc/bibxml/reference.R | ||||
FC.2702.xml"/> | ||||
<xi:include href="https://xml2rfc.ietf.org/public/rfc/bibxml/reference.R | ||||
FC.3209.xml"/> | ||||
<xi:include href="https://xml2rfc.ietf.org/public/rfc/bibxml/reference.R | ||||
FC.3272.xml"/> | ||||
<xi:include href="https://xml2rfc.ietf.org/public/rfc/bibxml/reference.R | ||||
FC.3471.xml"/> | ||||
<xi:include href="https://xml2rfc.ietf.org/public/rfc/bibxml/reference.R | ||||
FC.3630.xml"/> | ||||
<xi:include href="https://xml2rfc.ietf.org/public/rfc/bibxml/reference.R | ||||
FC.3785.xml"/> | ||||
<xi:include href="https://xml2rfc.ietf.org/public/rfc/bibxml/reference.R | ||||
FC.4201.xml"/> | ||||
<xi:include href="https://xml2rfc.ietf.org/public/rfc/bibxml/reference.R | ||||
FC.4202.xml"/> | ||||
<xi:include href="https://xml2rfc.ietf.org/public/rfc/bibxml/reference.R | ||||
FC.4203.xml"/> | ||||
<xi:include href="https://xml2rfc.ietf.org/public/rfc/bibxml/reference.R | ||||
FC.4206.xml"/> | ||||
<xi:include href="https://xml2rfc.ietf.org/public/rfc/bibxml/reference.R | ||||
FC.4872.xml"/> | ||||
<xi:include href="https://xml2rfc.ietf.org/public/rfc/bibxml/reference.R | ||||
FC.5152.xml"/> | ||||
<xi:include href="https://xml2rfc.ietf.org/public/rfc/bibxml/reference.R | ||||
FC.5212.xml"/> | ||||
<xi:include href="https://xml2rfc.ietf.org/public/rfc/bibxml/reference.R | ||||
FC.5305.xml"/> | ||||
<xi:include href="https://xml2rfc.ietf.org/public/rfc/bibxml/reference.R | ||||
FC.5316.xml"/> | ||||
<xi:include href="https://xml2rfc.ietf.org/public/rfc/bibxml/reference.R | ||||
FC.5392.xml"/> | ||||
<xi:include href="https://xml2rfc.ietf.org/public/rfc/bibxml/reference.R | ||||
FC.6001.xml"/> | ||||
<xi:include href="https://xml2rfc.ietf.org/public/rfc/bibxml/reference.R | ||||
FC.7308.xml"/> | ||||
<xi:include href="https://xml2rfc.ietf.org/public/rfc/bibxml/reference.R | ||||
FC.7471.xml"/> | ||||
<xi:include href="https://xml2rfc.ietf.org/public/rfc/bibxml/reference.R | ||||
FC.7579.xml"/> | ||||
<xi:include href="https://xml2rfc.ietf.org/public/rfc/bibxml/reference.R | ||||
FC.7752.xml"/> | ||||
<xi:include href="https://xml2rfc.ietf.org/public/rfc/bibxml/reference.R | ||||
FC.8340.xml"/> | ||||
<xi:include href="https://xml2rfc.ietf.org/public/rfc/bibxml/reference.RFC.8639 | ||||
.xml"/> | ||||
<xi:include href="https://xml2rfc.ietf.org/public/rfc/bibxml/reference.RFC.8641. | ||||
xml"/> | ||||
<date month="January" year="2017"/> | <!-- draft-liu-netmod-yang-schedule (Expired) --> | |||
</front> | <!-- Long way; surname for "Gonzalez de Dios" in repository is wrong. --> | |||
<reference anchor="YANG-CFG-SCHED" target="https://tools.ietf.org/html/draft-liu | ||||
-netmod-yang-schedule-05"> | ||||
<front> | ||||
<title>A YANG Data Model for Configuration Scheduling</title> | ||||
<author initials='X' surname='Liu' fullname='Xufeng Liu'> | ||||
<organization /> | ||||
</author> | ||||
<author initials='I' surname='Bryskin' fullname='Igor Bryskin'> | ||||
<organization /> | ||||
</author> | ||||
<author initials='V' surname='Beeram' fullname='Vishnu Beeram'> | ||||
<organization /> | ||||
</author> | ||||
<author initials='T' surname='Saad' fullname='Tarek Saad'> | ||||
<organization /> | ||||
</author> | ||||
<author initials='H' surname='Shah' fullname='Himanshu Shah'> | ||||
<organization /> | ||||
</author> | ||||
<author initials='O' surname='Gonzalez de Dios' fullname='Oscar Gonzalez de Dios | ||||
'> | ||||
<organization /> | ||||
</author> | ||||
<date month='March' day='1' year='2018' /> | ||||
</front> | ||||
<seriesInfo name='Work in Progress, Internet-Draft,' value='draft-liu-netmod-yan | ||||
g-schedule-05' /> | ||||
</reference> | ||||
<seriesInfo name="ITU-T" value="Recommendation G.872"/> | <!-- draft-ietf-ccamp-wson-yang (I-D Exists) --> | |||
</reference> | <!-- Long way; surname for V. Lopez in repository file is different from | |||
<reference anchor="G.8080"><front> | how it's listed in the document itself. --> | |||
<title>Architecture for the automatically switched optical network</title | <reference anchor='YANG-WSON' target="https://tools.ietf.org/html/draft-ietf-cca | |||
> | mp-wson-yang-25"> | |||
<author> | <front> | |||
<organization>ITU-T</organization> | <title>A YANG Data Model for WSON (Wavelength Switched Optical Networks)</title> | |||
</author> | <author initials='H' surname='Zheng' fullname='Haomian Zheng'> | |||
<organization /> | ||||
</author> | ||||
<author initials='Y' surname='Lee' fullname='Young Lee'> | ||||
<organization /> | ||||
</author> | ||||
<author initials='A' surname='Guo' fullname='Aihua Guo'> | ||||
<organization /> | ||||
</author> | ||||
<author initials='V' surname='Lopez' fullname='Victor Lopez'> | ||||
<organization /> | ||||
</author> | ||||
<author initials='D' surname='King' fullname='Daniel King'> | ||||
<organization /> | ||||
</author> | ||||
<date month='May' day='19' year='2020' /> | ||||
</front> | ||||
<seriesInfo name='Work in Progress, Internet-Draft,' value='draft-ietf-ccamp-wso | ||||
n-yang-25' /> | ||||
</reference> | ||||
<date month="February" year="2012"/> | <!-- draft-ietf-ccamp-otn-topo-yang (I-D Exists) --> | |||
</front> | <!-- Long way; surname for "Gonzalez de Dios" in repository is wrong. --> | |||
<reference anchor='YANG-OTN' target="https://tools.ietf.org/html/draft-ietf-ccam | ||||
p-otn-topo-yang-10"> | ||||
<front> | ||||
<title>A YANG Data Model for Optical Transport Network Topology</title> | ||||
<author initials='H' surname='Zheng' fullname='Haomian Zheng'> | ||||
<organization /> | ||||
</author> | ||||
<author initials='I' surname='Busi' fullname='Italo Busi'> | ||||
<organization /> | ||||
</author> | ||||
<author initials='X' surname='Liu' fullname='Xufeng Liu'> | ||||
<organization /> | ||||
</author> | ||||
<author initials='S' surname='Belotti' fullname='Sergio Belotti'> | ||||
<organization /> | ||||
</author> | ||||
<author initials='O' surname='Gonzalez de Dios' fullname='Oscar Gonzalez de Dios | ||||
'> | ||||
<organization /> | ||||
</author> | ||||
<date month='March' day='9' year='2020' /> | ||||
</front> | ||||
<seriesInfo name='Work in Progress, Internet-Draft,' value='draft-ietf-ccamp-otn | ||||
-topo-yang-10' /> | ||||
</reference> | ||||
<seriesInfo name="ITU-T" value="Recommendation G.8080"/> | <!-- draft-ietf-teas-yang-l3-te-topo (I-D Exists) --> | |||
</reference> | <!-- Long way; surname for "Gonzalez de Dios" in repository is wrong. --> | |||
&RFC1195; | <reference anchor="YANG-L3" target="https://tools.ietf.org/html/draft-ietf-teas- | |||
&RFC2702; | yang-l3-te-topo-08"> | |||
&RFC3209; | <front> | |||
&RFC3272; | <title>YANG Data Model for Layer 3 TE Topologies</title> | |||
&RFC3471; | <author initials='X' surname='Liu' fullname='Xufeng Liu'> | |||
&RFC3630; | <organization /> | |||
&RFC3785; | </author> | |||
&RFC4201; | <author initials='I' surname='Bryskin' fullname='Igor Bryskin'> | |||
&RFC4202; | <organization /> | |||
&RFC4203; | </author> | |||
&RFC4206; | <author initials='V' surname='Beeram' fullname='Vishnu Beeram'> | |||
&RFC4872; | <organization /> | |||
&RFC5152; | </author> | |||
&RFC5212; | <author initials='T' surname='Saad' fullname='Tarek Saad'> | |||
&RFC5305; | <organization /> | |||
&RFC5316; | </author> | |||
&RFC5329; | <author initials='H' surname='Shah' fullname='Himanshu Shah'> | |||
&RFC5392; | <organization /> | |||
&RFC6001; | </author> | |||
&RFC7308; | <author initials='O' surname='Gonzalez de Dios' fullname='Oscar Gonzalez de Dios | |||
&RFC7471; | '> | |||
&RFC7579; | <organization /> | |||
&RFC7752; | </author> | |||
&RFC8340; | <date month='July' day='12' year='2020' /> | |||
&I-D.ietf-netconf-subscribed-notifications; | </front> | |||
&I-D.ietf-netconf-yang-push; | <seriesInfo name='Work in Progress, Internet-Draft,' value='draft-ietf-teas-yang | |||
&I-D.liu-netmod-yang-schedule; | -l3-te-topo-08' /> | |||
&I-D.ietf-ccamp-wson-yang; | </reference> | |||
&I-D.ietf-ccamp-otn-topo-yang; | ||||
&I-D.ietf-teas-yang-l3-te-topo; | ||||
&I-D.ietf-teas-te-topo-and-tunnel-modeling; | ||||
</references> | ||||
<section title="Complete Model Tree Structure" anchor="append-a"><figure> | <!-- draft-ietf-teas-te-topo-and-tunnel-modeling (I-D Exists) --> | |||
<artwork><![CDATA[ | <xi:include href="https://xml2rfc.tools.ietf.org/public/rfc/bibxml3/refe | |||
rence.I-D.draft-ietf-teas-te-topo-and-tunnel-modeling-06.xml"/> | ||||
</references> | ||||
</references> | ||||
<section anchor="append-a" numbered="true" toc="default"> | ||||
<name>Complete Model Tree Structure</name> | ||||
<sourcecode name="" type="yangtree"><![CDATA[ | ||||
module: ietf-te-topology | module: ietf-te-topology | |||
augment /nw:networks/nw:network/nw:network-types: | augment /nw:networks/nw:network/nw:network-types: | |||
+--rw te-topology! | +--rw te-topology! | |||
augment /nw:networks: | augment /nw:networks: | |||
+--rw te! | +--rw te! | |||
+--rw templates | +--rw templates | |||
+--rw node-template* [name] {template}? | +--rw node-template* [name] {template}? | |||
| +--rw name | | +--rw name | |||
| | te-types:te-template-name | | | te-types:te-template-name | |||
| +--rw priority? uint16 | | +--rw priority? uint16 | |||
skipping to change at line 6745 ¶ | skipping to change at line 6840 ¶ | |||
| +--rw (technology)? | | +--rw (technology)? | |||
| +--:(generic) | | +--:(generic) | |||
| +--rw generic? te-bandwidth | | +--rw generic? te-bandwidth | |||
+--rw inter-domain-plug-id? binary | +--rw inter-domain-plug-id? binary | |||
+--rw inter-layer-lock-id* uint32 | +--rw inter-layer-lock-id* uint32 | |||
+--ro oper-status? | +--ro oper-status? | |||
| te-types:te-oper-status | | te-types:te-oper-status | |||
+--ro geolocation | +--ro geolocation | |||
+--ro altitude? int64 | +--ro altitude? int64 | |||
+--ro latitude? geographic-coordinate-degree | +--ro latitude? geographic-coordinate-degree | |||
+--ro longitude? geographic-coordinate-degree | +--ro longitude? geographic-coordinate-degree]]></sourcecode> | |||
]]></artwork> | </section> | |||
</figure> | <section anchor="append-b" numbered="true" toc="default"> | |||
</section> | <name>Companion YANG Data Model for Non-NMDA-Compliant Implementations</na | |||
me> | ||||
<section title="Companion YANG Model for Non-NMDA Compliant Implementatio | <t> | |||
ns" anchor="append-b"><t> | The YANG module "ietf-te-topology" defined in <xref target="sect-7"/> is desi | |||
The YANG module ietf-te-topology defined in this document is designed | gned | |||
to be used in conjunction with implementations that support the | to be used in conjunction with implementations that support the | |||
Network Management Datastore Architecture (NMDA) defined in | Network Management Datastore Architecture (NMDA) defined in | |||
<xref target="RFC8342"/>. In order to allow implementations to use the model | <xref target="RFC8342" format="default"/>. In order to allow implementations | |||
even in | to use the model even in | |||
cases when NMDA is not supported, the following companion module | cases where NMDA is not supported, the following companion module, | |||
ietf-te-topology-state is defined as a state model, which mirrors the | "ietf-te-topology-state", is defined as a state model that mirrors the | |||
module ietf-te-topology defined earlier in this document. However, | module "ietf-te-topology". However, | |||
all data nodes in the companion module are non-configurable, to | all data nodes in this "ietf-te-topology-state" companion module are non-conf | |||
represent the applied configuration or the derived operational | igurable; | |||
states.</t> | they are provided to represent the applied configuration or the | |||
derived operational states.</t> | ||||
<t> | <t> | |||
The companion module, ietf-te-topology-state, is redundant and SHOULD | This companion module is redundant and <bcp14>SHOULD NOT</bcp14> be | |||
NOT be supported by implementations that support NMDA.</t> | supported by implementations that support NMDA; therefore, we define it | |||
below rather than in the main body of this document.</t> | ||||
<t> | <t> | |||
As the structure of the module ietf-te-topology-state mirrors that of the | As the structure of the module "ietf-te-topology-state" mirrors that of the | |||
module ietf-te-topology. The YANG tree of the module ietf-te-topology-state | module "ietf-te-topology", the YANG tree of the module "ietf&nbhy;te-topology | |||
-state" | ||||
is not depicted separately.</t> | is not depicted separately.</t> | |||
<section anchor="append-b1" numbered="true" toc="default"> | ||||
<name>TE Topology State YANG Module</name> | ||||
<t> | ||||
This module references <xref target="RFC6001" format="default"/>, <xref targe | ||||
t="RFC8345" format="default"/>, and | ||||
<xref target="RFC8776"/>.</t> | ||||
<section title="TE Topology State YANG Module" anchor="append-b1"><t> | <sourcecode name="ietf-te-topology-state@2020-06-29.yang" type="yang" ma | |||
This module references <xref target="RFC6001"/>, <xref target="RFC8345"/>, an | rkers="true"><![CDATA[ | |||
d | ||||
[I-D.ietf-teas-yang-te-types].</t> | ||||
<figure><artwork><![CDATA[ | ||||
<CODE BEGINS> file "ietf-te-topology-state@2019-02-07.yang" | ||||
module ietf-te-topology-state { | module ietf-te-topology-state { | |||
yang-version 1.1; | yang-version 1.1; | |||
namespace "urn:ietf:params:xml:ns:yang:ietf-te-topology-state"; | namespace "urn:ietf:params:xml:ns:yang:ietf-te-topology-state"; | |||
prefix tet-s; | ||||
prefix "tet-s"; | ||||
import ietf-te-types { | import ietf-te-types { | |||
prefix "te-types"; | prefix te-types; | |||
reference | reference | |||
"I-D.ietf-teas-yang-te-types: Traffic Engineering Common YANG | "RFC 8776: Common YANG Data Types for Traffic Engineering"; | |||
Types"; | ||||
} | } | |||
import ietf-te-topology { | import ietf-te-topology { | |||
prefix "tet"; | prefix tet; | |||
reference | ||||
"RFC 8795: YANG Data Model for Traffic Engineering (TE) | ||||
Topologies"; | ||||
} | } | |||
import ietf-network-state { | import ietf-network-state { | |||
prefix "nw-s"; | prefix nw-s; | |||
reference "RFC 8345: A YANG Data Model for Network Topologies"; | reference | |||
"RFC 8345: A YANG Data Model for Network Topologies"; | ||||
} | } | |||
import ietf-network-topology-state { | import ietf-network-topology-state { | |||
prefix "nt-s"; | prefix nt-s; | |||
reference "RFC 8345: A YANG Data Model for Network Topologies"; | reference | |||
"RFC 8345: A YANG Data Model for Network Topologies"; | ||||
} | } | |||
organization | organization | |||
"IETF Traffic Engineering Architecture and Signaling (TEAS) | "IETF Traffic Engineering Architecture and Signaling (TEAS) | |||
Working Group"; | Working Group"; | |||
contact | contact | |||
"WG Web: <http://tools.ietf.org/wg/teas/> | "WG Web: <https://datatracker.ietf.org/wg/teas/> | |||
WG List: <mailto:teas@ietf.org> | WG List: <mailto:teas@ietf.org> | |||
Editor: Xufeng Liu | Editor: Xufeng Liu | |||
<mailto:xufeng.liu.ietf@gmail.com> | <mailto:xufeng.liu.ietf@gmail.com> | |||
Editor: Igor Bryskin | Editor: Igor Bryskin | |||
<mailto:Igor.Bryskin@huawei.com> | <mailto:i_bryskin@yahoo.com> | |||
Editor: Vishnu Pavan Beeram | Editor: Vishnu Pavan Beeram | |||
<mailto:vbeeram@juniper.net> | <mailto:vbeeram@juniper.net> | |||
Editor: Tarek Saad | Editor: Tarek Saad | |||
<mailto:tsaad@juniper.net> | <mailto:tsaad@juniper.net> | |||
Editor: Himanshu Shah | Editor: Himanshu Shah | |||
<mailto:hshah@ciena.com> | <mailto:hshah@ciena.com> | |||
Editor: Oscar Gonzalez De Dios | Editor: Oscar Gonzalez de Dios | |||
<mailto:oscar.gonzalezdedios@telefonica.com>"; | <mailto:oscar.gonzalezdedios@telefonica.com>"; | |||
description | description | |||
"TE topology state model. | "This YANG module defines a TE topology state model. | |||
Copyright (c) 2019 IETF Trust and the persons identified as | Copyright (c) 2020 IETF Trust and the persons identified as | |||
authors of the code. All rights reserved. | authors of the code. All rights reserved. | |||
Redistribution and use in source and binary forms, with or | Redistribution and use in source and binary forms, with or | |||
without modification, is permitted pursuant to, and subject to | without modification, is permitted pursuant to, and subject to | |||
the license terms contained in, the Simplified BSD License set | the license terms contained in, the Simplified BSD License set | |||
forth in Section 4.c of the IETF Trust's Legal Provisions | forth in Section 4.c of the IETF Trust's Legal Provisions | |||
Relating to IETF Documents | Relating to IETF Documents | |||
(http://trustee.ietf.org/license-info). | (https://trustee.ietf.org/license-info). | |||
This version of this YANG module is part of RFC XXXX; see the | This version of this YANG module is part of RFC 8795; see the | |||
RFC itself for full legal notices."; | RFC itself for full legal notices."; | |||
revision "2019-02-07" { | revision 2020-06-29 { | |||
description "Initial revision"; | description | |||
reference "RFC XXXX: YANG Data Model for TE Topologies"; | "Initial revision."; | |||
// RFC Ed.: replace XXXX with actual RFC number and remove | reference | |||
// this note | "RFC 8795: YANG Data Model for Traffic Engineering (TE) | |||
Topologies"; | ||||
} | } | |||
/* | /* | |||
* Groupings | * Groupings | |||
*/ | */ | |||
grouping te-node-connectivity-matrix-attributes { | grouping te-node-connectivity-matrix-attributes { | |||
description | description | |||
"Termination point references of a connectivity matrix entry."; | "Termination point references of a connectivity matrix entry."; | |||
container from { | container from { | |||
description | description | |||
"Reference to source link termination point."; | "Reference to a source Link Termination Point (LTP)."; | |||
leaf tp-ref { | leaf tp-ref { | |||
type leafref { | type leafref { | |||
path "../../../../../../nt-s:termination-point/nt-s:tp-id"; | path "../../../../../../nt-s:termination-point/nt-s:tp-id"; | |||
} | } | |||
description | description | |||
"Relative reference to a termination point."; | "Relative reference to a termination point."; | |||
} | } | |||
uses te-types:label-set-info; | uses te-types:label-set-info; | |||
} | } | |||
container to { | container to { | |||
description | description | |||
"Reference to destination link termination point."; | "Reference to a destination LTP."; | |||
leaf tp-ref { | leaf tp-ref { | |||
type leafref { | type leafref { | |||
path "../../../../../../nt-s:termination-point/nt-s:tp-id"; | path "../../../../../../nt-s:termination-point/nt-s:tp-id"; | |||
} | } | |||
description | description | |||
"Relative reference to a termination point."; | "Relative reference to a termination point."; | |||
} | } | |||
uses te-types:label-set-info; | uses te-types:label-set-info; | |||
} | } | |||
uses tet:connectivity-matrix-entry-path-attributes; | uses tet:connectivity-matrix-entry-path-attributes; | |||
} // te-node-connectivity-matrix-attributes | } | |||
// te-node-connectivity-matrix-attributes | ||||
grouping te-node-tunnel-termination-point-llc-list { | grouping te-node-tunnel-termination-point-llc-list { | |||
description | description | |||
"Local link connectivity list of a tunnel termination | "Local Link Connectivity List (LLCL) of a Tunnel Termination | |||
point on a TE node."; | Point (TTP) on a TE node."; | |||
list local-link-connectivity { | list local-link-connectivity { | |||
key "link-tp-ref"; | key "link-tp-ref"; | |||
description | description | |||
"The termination capabilities between | "The termination capabilities between the TTP and the LTP. | |||
tunnel-termination-point and link termination-point. | This capability information can be used to compute | |||
The capability information can be used to compute | ||||
the tunnel path. | the tunnel path. | |||
The Interface Adjustment Capability Descriptors (IACD) | The Interface Adjustment Capability Descriptors (IACDs) | |||
(defined in RFC 6001) on each link-tp can be derived from | (defined in RFC 6001) on each LTP can be derived from | |||
this local-link-connectivity list."; | this list."; | |||
reference | reference | |||
"RFC 6001: Generalized MPLS (GMPLS) Protocol Extensions | "RFC 6001: Generalized MPLS (GMPLS) Protocol Extensions | |||
for Multi-Layer and Multi-Region Networks (MLN/MRN)."; | for Multi-Layer and Multi-Region Networks (MLN/MRN)"; | |||
leaf link-tp-ref { | leaf link-tp-ref { | |||
type leafref { | type leafref { | |||
path "../../../../../nt-s:termination-point/nt-s:tp-id"; | path "../../../../../nt-s:termination-point/nt-s:tp-id"; | |||
} | } | |||
description | description | |||
"Link termination point."; | "LTP."; | |||
} | } | |||
uses te-types:label-set-info; | uses te-types:label-set-info; | |||
uses tet:connectivity-matrix-entry-path-attributes; | uses tet:connectivity-matrix-entry-path-attributes; | |||
} // local-link-connectivity | } | |||
} // te-node-tunnel-termination-point-config | // local-link-connectivity | |||
} | ||||
// te-node-tunnel-termination-point-llc-list | ||||
/* | /* | |||
* Data nodes | * Data nodes | |||
*/ | */ | |||
augment "/nw-s:networks/nw-s:network/nw-s:network-types" { | augment "/nw-s:networks/nw-s:network/nw-s:network-types" { | |||
description | description | |||
"Introduce new network type for TE topology."; | "Introduces a new network type for a TE topology."; | |||
container te-topology { | container te-topology { | |||
presence "Indicates TE topology."; | presence "Indicates a TE topology"; | |||
description | description | |||
"Its presence identifies the TE topology type."; | "Its presence identifies the TE topology type."; | |||
} | } | |||
} | } | |||
augment "/nw-s:networks" { | augment "/nw-s:networks" { | |||
description | description | |||
"Augmentation parameters for TE topologies."; | "Augmentation parameters for TE topologies."; | |||
uses tet:te-topologies-augment; | uses tet:te-topologies-augment; | |||
} | } | |||
augment "/nw-s:networks/nw-s:network" { | augment "/nw-s:networks/nw-s:network" { | |||
when "nw-s:network-types/tet-s:te-topology" { | when 'nw-s:network-types/tet-s:te-topology' { | |||
description | description | |||
"Augmentation parameters apply only for networks with | "Augmentation parameters apply only for networks with a | |||
TE topology type."; | TE topology type."; | |||
} | } | |||
description | description | |||
"Configuration parameters for TE topology."; | "Configuration parameters for a TE topology."; | |||
uses tet:te-topology-augment; | uses tet:te-topology-augment; | |||
} | } | |||
augment "/nw-s:networks/nw-s:network/nw-s:node" { | augment "/nw-s:networks/nw-s:network/nw-s:node" { | |||
when "../nw-s:network-types/tet-s:te-topology" { | when '../nw-s:network-types/tet-s:te-topology' { | |||
description | description | |||
"Augmentation parameters apply only for networks with | "Augmentation parameters apply only for networks with a | |||
TE topology type."; | TE topology type."; | |||
} | } | |||
description | description | |||
"Configuration parameters for TE at node level."; | "Configuration parameters for TE at the node level."; | |||
leaf te-node-id { | leaf te-node-id { | |||
type te-types:te-node-id; | type te-types:te-node-id; | |||
description | description | |||
"The identifier of a node in the TE topology. | "The identifier of a node in the TE topology. | |||
A node is specific to a topology to which it belongs."; | A node is specific to a topology to which it belongs."; | |||
} | } | |||
container te { | container te { | |||
must "../te-node-id" { | must '../te-node-id' { | |||
description | description | |||
"te-node-id is mandatory."; | "'te-node-id' is mandatory."; | |||
} | } | |||
must "count(../nw-s:supporting-node)<=1" { | must 'count(../nw-s:supporting-node)<=1' { | |||
description | description | |||
"For a node in a TE topology, there cannot be more | "For a node in a TE topology, there cannot be more | |||
than 1 supporting node. If multiple nodes are abstracted, | than one supporting node. If multiple nodes are | |||
the underlay-topology is used."; | abstracted, the 'underlay-topology' field is used."; | |||
} | } | |||
presence "TE support."; | presence "TE support"; | |||
description | description | |||
"Indicates TE support."; | "Indicates TE support."; | |||
uses tet:te-node-augment; | uses tet:te-node-augment; | |||
} // te | } | |||
} | } | |||
augment "/nw-s:networks/nw-s:network/nt-s:link" { | augment "/nw-s:networks/nw-s:network/nt-s:link" { | |||
when "../nw-s:network-types/tet-s:te-topology" { | when '../nw-s:network-types/tet-s:te-topology' { | |||
description | description | |||
"Augmentation parameters apply only for networks with | "Augmentation parameters apply only for networks with a | |||
TE topology type."; | TE topology type."; | |||
} | } | |||
description | description | |||
"Configuration parameters for TE at link level."; | "Configuration parameters for TE at the link level."; | |||
container te { | container te { | |||
must "count(../nt-s:supporting-link)<=1" { | must 'count(../nt-s:supporting-link)<=1' { | |||
description | description | |||
"For a link in a TE topology, there cannot be more | "For a link in a TE topology, there cannot be more | |||
than 1 supporting link. If one or more link paths are | than one supporting link. If one or more link paths are | |||
abstracted, the underlay is used."; | abstracted, the underlay is used."; | |||
} | } | |||
presence "TE support."; | presence "TE support"; | |||
description | description | |||
"Indicates TE support."; | "Indicates TE support."; | |||
uses tet:te-link-augment; | uses tet:te-link-augment; | |||
} // te | } | |||
} | } | |||
augment "/nw-s:networks/nw-s:network/nw-s:node/" | augment "/nw-s:networks/nw-s:network/nw-s:node/" | |||
+ "nt-s:termination-point" { | + "nt-s:termination-point" { | |||
when "../../nw-s:network-types/tet-s:te-topology" { | when '../../nw-s:network-types/tet-s:te-topology' { | |||
description | description | |||
"Augmentation parameters apply only for networks with | "Augmentation parameters apply only for networks with a | |||
TE topology type."; | TE topology type."; | |||
} | } | |||
description | description | |||
"Configuration parameters for TE at termination point level."; | "Configuration parameters for TE at the termination point | |||
level."; | ||||
uses tet:te-termination-point-augment; | uses tet:te-termination-point-augment; | |||
} | } | |||
augment | augment "/nw-s:networks/nw-s:network/nt-s:link/te/" | |||
"/nw-s:networks/nw-s:network/nt-s:link/te/bundle-stack-level/" | + "bundle-stack-level/bundle/bundled-links/bundled-link" { | |||
+ "bundle/bundled-links/bundled-link" { | when '../../../../nw-s:network-types/tet-s:te-topology' { | |||
when "../../../../nw-s:network-types/tet-s:te-topology" { | ||||
description | description | |||
"Augmentation parameters apply only for networks with | "Augmentation parameters apply only for networks with a | |||
TE topology type."; | TE topology type."; | |||
} | } | |||
description | description | |||
"Augment TE link bundled link."; | "Augmentation for a TE bundled link."; | |||
leaf src-tp-ref { | leaf src-tp-ref { | |||
type leafref { | type leafref { | |||
path "../../../../../nw-s:node[nw-s:node-id = " | path "../../../../../nw-s:node[nw-s:node-id = " | |||
+ "current()/../../../../nt-s:source/" | + "current()/../../../../nt-s:source/" | |||
+ "nt-s:source-node]/" | + "nt-s:source-node]/" | |||
+ "nt-s:termination-point/nt-s:tp-id"; | + "nt-s:termination-point/nt-s:tp-id"; | |||
require-instance true; | require-instance true; | |||
} | } | |||
description | description | |||
"Reference to another TE termination point on the | "Reference to another TE termination point on the | |||
same source node."; | same source node."; | |||
} | } | |||
leaf des-tp-ref { | leaf des-tp-ref { | |||
type leafref { | type leafref { | |||
path "../../../../../nw-s:node[nw-s:node-id = " | path "../../../../../nw-s:node[nw-s:node-id = " | |||
+ "current()/../../../../nt-s:destination/" | + "current()/../../../../nt-s:destination/" | |||
+ "nt-s:dest-node]/" | + "nt-s:dest-node]/" | |||
+ "nt-s:termination-point/nt-s:tp-id"; | + "nt-s:termination-point/nt-s:tp-id"; | |||
require-instance true; | require-instance true; | |||
} | } | |||
description | description | |||
"Reference to another TE termination point on the | "Reference to another TE termination point on the | |||
same destination node."; | same destination node."; | |||
} | } | |||
} | } | |||
augment | augment "/nw-s:networks/nw-s:network/nw-s:node/te/" | |||
"/nw-s:networks/nw-s:network/nw-s:node/te/" | + "information-source-entry/connectivity-matrices/" | |||
+ "information-source-entry/connectivity-matrices/" | + "connectivity-matrix" { | |||
+ "connectivity-matrix" { | when '../../../../../nw-s:network-types/tet-s:te-topology' { | |||
when "../../../../../nw-s:network-types/tet-s:te-topology" { | ||||
description | description | |||
"Augmentation parameters apply only for networks with | "Augmentation parameters apply only for networks with a | |||
TE topology type."; | TE topology type."; | |||
} | } | |||
description | description | |||
"Augment TE node connectivity-matrix."; | "Augmentation for the TE node connectivity matrix."; | |||
uses te-node-connectivity-matrix-attributes; | uses te-node-connectivity-matrix-attributes; | |||
} | } | |||
augment | augment "/nw-s:networks/nw-s:network/nw-s:node/te/" | |||
"/nw-s:networks/nw-s:network/nw-s:node/te/te-node-attributes/" | + "te-node-attributes/connectivity-matrices/" | |||
+ "connectivity-matrices/connectivity-matrix" { | + "connectivity-matrix" { | |||
when "../../../../../nw-s:network-types/tet-s:te-topology" { | when '../../../../../nw-s:network-types/tet-s:te-topology' { | |||
description | description | |||
"Augmentation parameters apply only for networks with | "Augmentation parameters apply only for networks with a | |||
TE topology type."; | TE topology type."; | |||
} | } | |||
description | description | |||
"Augment TE node connectivity-matrix."; | "Augmentation for the TE node connectivity matrix."; | |||
uses te-node-connectivity-matrix-attributes; | uses te-node-connectivity-matrix-attributes; | |||
} | } | |||
augment | augment "/nw-s:networks/nw-s:network/nw-s:node/te/" | |||
"/nw-s:networks/nw-s:network/nw-s:node/te/" | + "tunnel-termination-point/local-link-connectivities" { | |||
+ "tunnel-termination-point/local-link-connectivities" { | when '../../../../nw-s:network-types/tet-s:te-topology' { | |||
when "../../../../nw-s:network-types/tet-s:te-topology" { | ||||
description | description | |||
"Augmentation parameters apply only for networks with | "Augmentation parameters apply only for networks with a | |||
TE topology type."; | TE topology type."; | |||
} | } | |||
description | description | |||
"Augment TE node tunnel termination point LLCs | "Augmentation for TE node TTP LLCs (Local Link | |||
(Local Link Connectivities)."; | Connectivities)."; | |||
uses te-node-tunnel-termination-point-llc-list; | uses te-node-tunnel-termination-point-llc-list; | |||
} | } | |||
} | }]]></sourcecode> | |||
<CODE ENDS> | </section> | |||
]]></artwork> | </section> | |||
</figure> | <section anchor="append-c" numbered="true" toc="default"> | |||
</section> | ||||
</section> | <name>Example: YANG Data Model for Technology-Specific Augmentations</name | |||
> | ||||
<t> | ||||
This appendix provides an example YANG module that defines a | ||||
technology-specific TE topology model for the example-topology model describe | ||||
d in | ||||
<xref target="sect-6" format="default"/>.</t> | ||||
<section title="Example: YANG Model for Technology Specific Augmentations | <t>This module references <xref target="RFC8345"/>.</t> | |||
" anchor="append-c"><t> | ||||
This section provides an example YANG module to define a technology | ||||
specific TE topology model for the example-topology described in | ||||
<xref target="sect-6"/>.</t> | ||||
<figure><artwork><![CDATA[ | <sourcecode name="" type="yang"><![CDATA[ | |||
module example-topology { | module example-topology { | |||
yang-version 1.1; | yang-version 1.1; | |||
namespace "https://example.com/example-topology"; | ||||
namespace "http://example.com/example-topology"; | prefix ex-topo; | |||
prefix "ex-topo"; | ||||
import ietf-network { | import ietf-network { | |||
prefix "nw"; | prefix nw; | |||
reference | ||||
"RFC 8345: A YANG Data Model for Network Topologies"; | ||||
} | } | |||
import ietf-network-topology { | import ietf-network-topology { | |||
prefix "nt"; | prefix nt; | |||
reference | ||||
"RFC 8345: A YANG Data Model for Network Topologies"; | ||||
} | } | |||
import ietf-te-topology { | import ietf-te-topology { | |||
prefix "tet"; | prefix tet; | |||
reference | ||||
"RFC 8795: YANG Data Model for Traffic Engineering (TE) | ||||
Topologies"; | ||||
} | } | |||
organization | organization | |||
"Example Organization"; | "Example Organization"; | |||
contact | contact | |||
"Editor: Example Author"; | "Editor: Example Author"; | |||
description | description | |||
"This module defines a topology data model for the example | "This module defines a topology data model for the example | |||
technology."; | technology."; | |||
revision 2018-06-15 { | revision 2020-06-29 { | |||
description | description | |||
"Initial revision."; | "Initial revision."; | |||
reference | reference | |||
"Example reference."; | "Example reference"; | |||
} | } | |||
/* | /* | |||
* Data nodes | * Data nodes | |||
*/ | */ | |||
augment "/nw:networks/nw:network/nw:network-types/" | augment "/nw:networks/nw:network/nw:network-types/" | |||
+ "tet:te-topology" { | + "tet:te-topology" { | |||
description | description | |||
"Augment network types to define example topology type."; | "Augmentation for network types to define an example topology | |||
type."; | ||||
container example-topology { | container example-topology { | |||
presence | presence "Introduces a new network type for an example | |||
"Introduce new network type for example topology."; | topology"; | |||
description | description | |||
"Its presence identifies the example topology type."; | "Its presence identifies the example topology type."; | |||
} | } | |||
} | } | |||
augment "/nw:networks/nw:network/tet:te" { | augment "/nw:networks/nw:network/tet:te" { | |||
when "../nw:network-types/tet:te-topology/" | when '../nw:network-types/tet:te-topology/' | |||
+ "ex-topo:example-topology" { | + 'ex-topo:example-topology' { | |||
description | description | |||
"Augmentation parameters apply only for networks with | "Augmentation parameters apply only for networks with an | |||
example topology type."; | example topology type."; | |||
} | } | |||
description "Augment network topology."; | description | |||
"Augmentation for the network topology."; | ||||
container attributes { | container attributes { | |||
description "Attributes for example technology."; | description | |||
"Attributes for the example technology."; | ||||
leaf attribute-1 { | leaf attribute-1 { | |||
type uint8; | type uint8; | |||
description "Attribute 1 for example technology."; | description | |||
"Attribute 1 for the example technology."; | ||||
} | } | |||
} | } | |||
} | } | |||
augment "/nw:networks/nw:network/nw:node/tet:te/" | augment "/nw:networks/nw:network/nw:node/tet:te/" | |||
+ "tet:te-node-attributes" { | + "tet:te-node-attributes" { | |||
when "../../nw:network-types/tet:te-topology/" | when '../../../nw:network-types/tet:te-topology/' | |||
+ "ex-topo:example-topology" { | + 'ex-topo:example-topology' { | |||
description | description | |||
"Augmentation parameters apply only for networks with | "Augmentation parameters apply only for networks with an | |||
example topology type."; | example topology type."; | |||
} | } | |||
description "Augment node attributes."; | description | |||
"Augmentation for node attributes."; | ||||
container attributes { | container attributes { | |||
description "Attributes for example technology."; | description | |||
"Attributes for the example technology."; | ||||
leaf attribute-2 { | leaf attribute-2 { | |||
type uint8; | type uint8; | |||
description "Attribute 2 for example technology."; | description | |||
"Attribute 2 for the example technology."; | ||||
} | } | |||
} | } | |||
} | } | |||
augment "/nw:networks/nw:network/nw:node/tet:te/" | augment "/nw:networks/nw:network/nw:node/tet:te/" | |||
+ "tet:te-node-attributes/tet:connectivity-matrices" { | + "tet:te-node-attributes/tet:connectivity-matrices" { | |||
when "../../../../nw:network-types/tet:te-topology/" | when '../../../../nw:network-types/tet:te-topology/' | |||
+ "ex-topo:example-topology" { | + 'ex-topo:example-topology' { | |||
description | description | |||
"Augmentation parameters apply only for networks with | "Augmentation parameters apply only for networks with an | |||
example topology type."; | example topology type."; | |||
} | } | |||
description "Augment node connectivity matrices."; | description | |||
"Augmentation for node connectivity matrices."; | ||||
container attributes { | container attributes { | |||
description "Attributes for example technology."; | description | |||
"Attributes for the example technology."; | ||||
leaf attribute-3 { | leaf attribute-3 { | |||
type uint8; | type uint8; | |||
description "Attribute 3 for example technology."; | description | |||
"Attribute 3 for the example technology."; | ||||
} | } | |||
} | } | |||
} | } | |||
augment "/nw:networks/nw:network/nw:node/tet:te/" | augment "/nw:networks/nw:network/nw:node/tet:te/" | |||
+ "tet:te-node-attributes/tet:connectivity-matrices/" | + "tet:te-node-attributes/tet:connectivity-matrices/" | |||
+ "tet:connectivity-matrix" { | + "tet:connectivity-matrix" { | |||
when "../../../../../nw:network-types/tet:te-topology/" | when '../../../../../nw:network-types/tet:te-topology/' | |||
+ "ex-topo:example-topology" { | + 'ex-topo:example-topology' { | |||
description | description | |||
"Augmentation parameters apply only for networks with | "Augmentation parameters apply only for networks with an | |||
example topology type."; | example topology type."; | |||
} | } | |||
description "Augment node connectivity matrix."; | description | |||
"Augmentation for the node connectivity matrix."; | ||||
container attributes { | container attributes { | |||
description "Attributes for example technology."; | description | |||
"Attributes for the example technology."; | ||||
leaf attribute-3 { | leaf attribute-3 { | |||
type uint8; | type uint8; | |||
description "Attribute 3 for example technology."; | description | |||
"Attribute 3 for the example technology."; | ||||
} | } | |||
} | } | |||
} | } | |||
augment "/nw:networks/nw:network/nw:node/tet:te/" | augment "/nw:networks/nw:network/nw:node/tet:te/" | |||
+ "tet:tunnel-termination-point" { | + "tet:tunnel-termination-point" { | |||
when "../../../nw:network-types/tet:te-topology/" | when '../../../nw:network-types/tet:te-topology/' | |||
+ "ex-topo:example-topology" { | + 'ex-topo:example-topology' { | |||
description | description | |||
"Augmentation parameters apply only for networks with | "Augmentation parameters apply only for networks with an | |||
example topology type."; | example topology type."; | |||
} | } | |||
description "Augment tunnel termination point."; | description | |||
"Augmentation for a TTP."; | ||||
container attributes { | container attributes { | |||
description "Attributes for example technology."; | description | |||
"Attributes for the example technology."; | ||||
leaf attribute-4 { | leaf attribute-4 { | |||
type uint8; | type uint8; | |||
description "Attribute 4 for example technology."; | description | |||
"Attribute 4 for the example technology."; | ||||
} | } | |||
} | } | |||
} | } | |||
augment "/nw:networks/nw:network/nw:node/nt:termination-point/" | augment "/nw:networks/nw:network/nw:node/nt:termination-point/" | |||
+ "tet:te" { | + "tet:te" { | |||
when "../../../nw:network-types/tet:te-topology/" | when '../../../nw:network-types/tet:te-topology/' | |||
+ "ex-topo:example-topology" { | + 'ex-topo:example-topology' { | |||
description | description | |||
"Augmentation parameters apply only for networks with | "Augmentation parameters apply only for networks with an | |||
example topology type."; | example topology type."; | |||
} | } | |||
description "Augment link termination point."; | description | |||
"Augmentation for an LTP."; | ||||
container attributes { | container attributes { | |||
description "Attributes for example technology."; | description | |||
"Attributes for the example technology."; | ||||
leaf attribute-5 { | leaf attribute-5 { | |||
type uint8; | type uint8; | |||
description "Attribute 5 for example technology."; | description | |||
"Attribute 5 for the example technology."; | ||||
} | } | |||
} | } | |||
} | } | |||
augment "/nw:networks/nw:network/nt:link/tet:te/" | augment "/nw:networks/nw:network/nt:link/tet:te/" | |||
+ "tet:te-link-attributes" { | + "tet:te-link-attributes" { | |||
when "../../../nw:network-types/tet:te-topology/" | when '../../../nw:network-types/tet:te-topology/' | |||
+ "ex-topo:example-topology" { | + 'ex-topo:example-topology' { | |||
description | description | |||
"Augmentation parameters apply only for networks with | "Augmentation parameters apply only for networks with an | |||
example topology type."; | example topology type."; | |||
} | } | |||
description "Augment link attributes."; | description | |||
"Augmentation for link attributes."; | ||||
container attributes { | container attributes { | |||
description "Attributes for example technology."; | description | |||
"Attributes for the example technology."; | ||||
leaf attribute-6 { | leaf attribute-6 { | |||
type uint8; | type uint8; | |||
description "Attribute 6 for example technology."; | description | |||
"Attribute 6 for the example technology."; | ||||
} | } | |||
} | } | |||
} | } | |||
/* | /* | |||
* Augment TE bandwidth. | * Augmentations for TE bandwidth. | |||
*/ | */ | |||
augment "/nw:networks/tet:te/tet:templates/" | augment "/nw:networks/tet:te/tet:templates/" | |||
+ "tet:link-template/tet:te-link-attributes/" | + "tet:link-template/tet:te-link-attributes/" | |||
+ "tet:interface-switching-capability/tet:max-lsp-bandwidth/" | + "tet:interface-switching-capability/tet:max-lsp-bandwidth/" | |||
+ "tet:te-bandwidth/tet:technology" { | + "tet:te-bandwidth/tet:technology" { | |||
case "example" { | case example { | |||
container example { | container example { | |||
description "Attributes for example technology."; | description | |||
"Attributes for the example technology."; | ||||
leaf bandwidth-1 { | leaf bandwidth-1 { | |||
type uint32; | type uint32; | |||
description "Bandwidth 1 for example technology."; | description | |||
"Bandwidth 1 for the example technology."; | ||||
} | } | |||
} | } | |||
} | } | |||
description "Augment TE bandwidth."; | description | |||
"Augmentation for TE bandwidth."; | ||||
} | } | |||
augment "/nw:networks/tet:te/tet:templates/" | augment "/nw:networks/tet:te/tet:templates/" | |||
+ "tet:link-template/tet:te-link-attributes/" | + "tet:link-template/tet:te-link-attributes/" | |||
+ "tet:max-link-bandwidth/" | + "tet:max-link-bandwidth/" | |||
+ "tet:te-bandwidth/tet:technology" { | + "tet:te-bandwidth/tet:technology" { | |||
case "example" { | case example { | |||
container example { | container example { | |||
description "Attributes for example technology."; | description | |||
"Attributes for the example technology."; | ||||
leaf bandwidth-1 { | leaf bandwidth-1 { | |||
type uint32; | type uint32; | |||
description "Bandwidth 1 for example technology."; | description | |||
"Bandwidth 1 for the example technology."; | ||||
} | } | |||
} | } | |||
} | } | |||
description "Augment TE bandwidth."; | description | |||
"Augmentation for TE bandwidth."; | ||||
} | } | |||
augment "/nw:networks/tet:te/tet:templates/" | augment "/nw:networks/tet:te/tet:templates/" | |||
+ "tet:link-template/tet:te-link-attributes/" | + "tet:link-template/tet:te-link-attributes/" | |||
+ "tet:max-resv-link-bandwidth/" | + "tet:max-resv-link-bandwidth/" | |||
+ "tet:te-bandwidth/tet:technology" { | + "tet:te-bandwidth/tet:technology" { | |||
case "example" { | case example { | |||
container example { | container example { | |||
description "Attributes for example technology."; | description | |||
"Attributes for the example technology."; | ||||
leaf bandwidth-1 { | leaf bandwidth-1 { | |||
type uint32; | type uint32; | |||
description "Bandwidth 1 for example technology."; | description | |||
"Bandwidth 1 for the example technology."; | ||||
} | } | |||
} | } | |||
} | } | |||
description "Augment TE bandwidth."; | description | |||
"Augmentation for TE bandwidth."; | ||||
} | } | |||
augment "/nw:networks/tet:te/tet:templates/" | augment "/nw:networks/tet:te/tet:templates/" | |||
+ "tet:link-template/tet:te-link-attributes/" | + "tet:link-template/tet:te-link-attributes/" | |||
+ "tet:unreserved-bandwidth/" | + "tet:unreserved-bandwidth/" | |||
+ "tet:te-bandwidth/tet:technology" { | + "tet:te-bandwidth/tet:technology" { | |||
case "example" { | case example { | |||
container example { | container example { | |||
description "Attributes for example technology."; | description | |||
"Attributes for the example technology."; | ||||
leaf bandwidth-1 { | leaf bandwidth-1 { | |||
type uint32; | type uint32; | |||
description "Bandwidth 1 for example technology."; | description | |||
"Bandwidth 1 for the example technology."; | ||||
} | } | |||
} | } | |||
} | } | |||
description "Augment TE bandwidth."; | description | |||
"Augmentation for TE bandwidth."; | ||||
} | } | |||
augment "/nw:networks/nw:network/nw:node/tet:te/" | augment "/nw:networks/nw:network/nw:node/tet:te/" | |||
+ "tet:te-node-attributes/tet:connectivity-matrices/" | + "tet:te-node-attributes/tet:connectivity-matrices/" | |||
+ "tet:path-constraints/tet:te-bandwidth/tet:technology" { | + "tet:path-constraints/tet:te-bandwidth/tet:technology" { | |||
when "../../../../../../../nw:network-types/tet:te-topology/" | when '../../../../../../nw:network-types/tet:te-topology/' | |||
+ "ex-topo:example-topology" { | + 'ex-topo:example-topology' { | |||
description | description | |||
"Augmentation parameters apply only for networks with | "Augmentation parameters apply only for networks with an | |||
example topology type."; | example topology type."; | |||
} | } | |||
case "example" { | case example { | |||
container example { | container example { | |||
description "Attributes for example technology."; | description | |||
"Attributes for the example technology."; | ||||
leaf bandwidth-1 { | leaf bandwidth-1 { | |||
type uint32; | type uint32; | |||
description "Bandwidth 1 for example technology."; | description | |||
"Bandwidth 1 for the example technology."; | ||||
} | } | |||
} | } | |||
} | } | |||
description "Augment TE bandwidth."; | description | |||
"Augmentation for TE bandwidth."; | ||||
} | } | |||
augment "/nw:networks/nw:network/nw:node/tet:te/" | augment "/nw:networks/nw:network/nw:node/tet:te/" | |||
+ "tet:te-node-attributes/tet:connectivity-matrices/" | + "tet:te-node-attributes/tet:connectivity-matrices/" | |||
+ "tet:connectivity-matrix/" | + "tet:connectivity-matrix/" | |||
+ "tet:path-constraints/tet:te-bandwidth/tet:technology" { | + "tet:path-constraints/tet:te-bandwidth/tet:technology" { | |||
when "../../../../../../../nw:network-types/tet:te-topology/" | when '../../../../../../../nw:network-types/tet:te-topology/' | |||
+ "ex-topo:example-topology" { | + 'ex-topo:example-topology' { | |||
description | description | |||
"Augmentation parameters apply only for networks with | "Augmentation parameters apply only for networks with an | |||
example topology type."; | example topology type."; | |||
} | } | |||
case "example" { | case example { | |||
container example { | container example { | |||
description "Attributes for example technology."; | description | |||
"Attributes for the example technology."; | ||||
leaf bandwidth-1 { | leaf bandwidth-1 { | |||
type uint32; | type uint32; | |||
description "Bandwidth 1 for example technology."; | description | |||
"Bandwidth 1 for the example technology."; | ||||
} | } | |||
} | } | |||
} | } | |||
description "Augment TE bandwidth."; | description | |||
"Augmentation for TE bandwidth."; | ||||
} | } | |||
augment "/nw:networks/nw:network/nw:node/tet:te/" | augment "/nw:networks/nw:network/nw:node/tet:te/" | |||
+ "tet:information-source-entry/tet:connectivity-matrices/" | + "tet:information-source-entry/tet:connectivity-matrices/" | |||
+ "tet:path-constraints/tet:te-bandwidth/tet:technology" { | + "tet:path-constraints/tet:te-bandwidth/tet:technology" { | |||
when "../../../../../../../nw:network-types/tet:te-topology/" | when '../../../../../../nw:network-types/tet:te-topology/' | |||
+ "ex-topo:example-topology" { | + 'ex-topo:example-topology' { | |||
description | description | |||
"Augmentation parameters apply only for networks with | "Augmentation parameters apply only for networks with an | |||
example topology type."; | example topology type."; | |||
} | } | |||
case "example" { | case example { | |||
container example { | container example { | |||
description "Attributes for example technology."; | description | |||
"Attributes for the example technology."; | ||||
leaf bandwidth-1 { | leaf bandwidth-1 { | |||
type uint32; | type uint32; | |||
description "Bandwidth 1 for example technology."; | description | |||
"Bandwidth 1 for the example technology."; | ||||
} | } | |||
} | } | |||
} | } | |||
description "Augment TE bandwidth."; | description | |||
"Augmentation for TE bandwidth."; | ||||
} | } | |||
augment "/nw:networks/nw:network/nw:node/tet:te/" | augment "/nw:networks/nw:network/nw:node/tet:te/" | |||
+ "tet:information-source-entry/tet:connectivity-matrices/" | + "tet:information-source-entry/tet:connectivity-matrices/" | |||
+ "tet:connectivity-matrix/" | + "tet:connectivity-matrix/" | |||
+ "tet:path-constraints/tet:te-bandwidth/tet:technology" { | + "tet:path-constraints/tet:te-bandwidth/tet:technology" { | |||
when "../../../../../../../nw:network-types/tet:te-topology/" | when '../../../../../../../nw:network-types/tet:te-topology/' | |||
+ "ex-topo:example-topology" { | + 'ex-topo:example-topology' { | |||
description | description | |||
"Augmentation parameters apply only for networks with | "Augmentation parameters apply only for networks with an | |||
example topology type."; | example topology type."; | |||
} | } | |||
case "example" { | case example { | |||
container example { | container example { | |||
description "Attributes for example technology."; | description | |||
"Attributes for the example technology."; | ||||
leaf bandwidth-1 { | leaf bandwidth-1 { | |||
type uint32; | type uint32; | |||
description "Bandwidth 1 for example technology."; | description | |||
"Bandwidth 1 for the example technology."; | ||||
} | } | |||
} | } | |||
} | } | |||
description "Augment TE bandwidth."; | description | |||
"Augmentation for TE bandwidth."; | ||||
} | } | |||
augment "/nw:networks/nw:network/nw:node/tet:te/" | augment "/nw:networks/nw:network/nw:node/tet:te/" | |||
+ "tet:tunnel-termination-point/tet:client-layer-adaptation/" | + "tet:tunnel-termination-point/" | |||
+ "tet:switching-capability/tet:te-bandwidth/tet:technology" { | + "tet:client-layer-adaptation/tet:switching-capability/" | |||
when "../../../../../../../nw:network-types/tet:te-topology/" | + "tet:te-bandwidth/tet:technology" { | |||
+ "ex-topo:example-topology" { | when '../../../../../../nw:network-types/tet:te-topology/' | |||
+ 'ex-topo:example-topology' { | ||||
description | description | |||
"Augmentation parameters apply only for networks with | "Augmentation parameters apply only for networks with an | |||
example topology type."; | example topology type."; | |||
} | } | |||
case "example" { | case example { | |||
container example { | container example { | |||
description "Attributes for example technology."; | description | |||
"Attributes for the example technology."; | ||||
leaf bandwidth-1 { | leaf bandwidth-1 { | |||
type uint32; | type uint32; | |||
description "Bandwidth 1 for example technology."; | description | |||
"Bandwidth 1 for the example technology."; | ||||
} | } | |||
} | } | |||
} | } | |||
description "Augment TE bandwidth."; | description | |||
"Augmentation for TE bandwidth."; | ||||
} | } | |||
augment "/nw:networks/nw:network/nw:node/tet:te/" | augment "/nw:networks/nw:network/nw:node/tet:te/" | |||
+ "tet:tunnel-termination-point/tet:local-link-connectivities/" | + "tet:tunnel-termination-point/" | |||
+ "tet:path-constraints/tet:te-bandwidth/tet:technology" { | + "tet:local-link-connectivities/tet:path-constraints/" | |||
when "../../../../../../../nw:network-types/tet:te-topology/" | + "tet:te-bandwidth/tet:technology" { | |||
+ "ex-topo:example-topology" { | when '../../../../../../nw:network-types/tet:te-topology/' | |||
+ 'ex-topo:example-topology' { | ||||
description | description | |||
"Augmentation parameters apply only for networks with | "Augmentation parameters apply only for networks with an | |||
example topology type."; | example topology type."; | |||
} | } | |||
case "example" { | case example { | |||
container example { | container example { | |||
description "Attributes for example technology."; | description | |||
"Attributes for the example technology."; | ||||
leaf bandwidth-1 { | leaf bandwidth-1 { | |||
type uint32; | type uint32; | |||
description "Bandwidth 1 for example technology."; | description | |||
"Bandwidth 1 for the example technology."; | ||||
} | } | |||
} | } | |||
} | } | |||
description "Augment TE bandwidth."; | description | |||
"Augmentation for TE bandwidth."; | ||||
} | } | |||
augment "/nw:networks/nw:network/nw:node/tet:te/" | augment "/nw:networks/nw:network/nw:node/tet:te/" | |||
+ "tet:tunnel-termination-point/tet:local-link-connectivities/" | + "tet:tunnel-termination-point/" | |||
+ "tet:local-link-connectivity/" | + "tet:local-link-connectivities/" | |||
+ "tet:path-constraints/tet:te-bandwidth/tet:technology" { | + "tet:local-link-connectivity/tet:path-constraints/" | |||
when "../../../../../../../../nw:network-types/tet:te-topology/" | + "tet:te-bandwidth/tet:technology" { | |||
+ "ex-topo:example-topology" { | when '../../../../../../../nw:network-types/tet:te-topology/' | |||
+ 'ex-topo:example-topology' { | ||||
description | description | |||
"Augmentation parameters apply only for networks with | "Augmentation parameters apply only for networks with an | |||
example topology type."; | example topology type."; | |||
} | } | |||
case "example" { | case example { | |||
container example { | container example { | |||
description "Attributes for example technology."; | description | |||
"Attributes for the example technology."; | ||||
leaf bandwidth-1 { | leaf bandwidth-1 { | |||
type uint32; | type uint32; | |||
description "Bandwidth 1 for example technology."; | description | |||
"Bandwidth 1 for the example technology."; | ||||
} | } | |||
} | } | |||
} | } | |||
description "Augment TE bandwidth."; | description | |||
"Augmentation for TE bandwidth."; | ||||
} | } | |||
augment "/nw:networks/nw:network/nt:link/tet:te/" | augment "/nw:networks/nw:network/nt:link/tet:te/" | |||
+ "tet:te-link-attributes/" | + "tet:te-link-attributes/" | |||
+ "tet:interface-switching-capability/tet:max-lsp-bandwidth/" | + "tet:interface-switching-capability/tet:max-lsp-bandwidth/" | |||
+ "tet:te-bandwidth/tet:technology" { | + "tet:te-bandwidth/tet:technology" { | |||
when "../../../../../../../../nw:network-types/tet:te-topology/" | when '../../../../../../nw:network-types/tet:te-topology/' | |||
+ "ex-topo:example-topology" { | + 'ex-topo:example-topology' { | |||
description | description | |||
"Augmentation parameters apply only for networks with | "Augmentation parameters apply only for networks with an | |||
example topology type."; | example topology type."; | |||
} | } | |||
case "example" { | case example { | |||
container example { | container example { | |||
description "Attributes for example technology."; | description | |||
"Attributes for the example technology."; | ||||
leaf bandwidth-1 { | leaf bandwidth-1 { | |||
type uint32; | type uint32; | |||
description "Bandwidth 1 for example technology."; | description | |||
"Bandwidth 1 for the example technology."; | ||||
} | } | |||
} | } | |||
} | } | |||
description "Augment TE bandwidth."; | description | |||
"Augmentation for TE bandwidth."; | ||||
} | } | |||
augment "/nw:networks/nw:network/nt:link/tet:te/" | augment "/nw:networks/nw:network/nt:link/tet:te/" | |||
+ "tet:te-link-attributes/" | + "tet:te-link-attributes/" | |||
+ "tet:max-link-bandwidth/" | + "tet:max-link-bandwidth/" | |||
+ "tet:te-bandwidth/tet:technology" { | + "tet:te-bandwidth/tet:technology" { | |||
when "../../../../../../nw:network-types/tet:te-topology/" | when '../../../../../nw:network-types/tet:te-topology/' | |||
+ "ex-topo:example-topology" { | + 'ex-topo:example-topology' { | |||
description | description | |||
"Augmentation parameters apply only for networks with | "Augmentation parameters apply only for networks with an | |||
example topology type."; | example topology type."; | |||
} | } | |||
case "example" { | case example { | |||
container example { | container example { | |||
description "Attributes for example technology."; | description | |||
"Attributes for the example technology."; | ||||
leaf bandwidth-1 { | leaf bandwidth-1 { | |||
type uint32; | type uint32; | |||
description "Bandwidth 1 for example technology."; | description | |||
"Bandwidth 1 for the example technology."; | ||||
} | } | |||
} | } | |||
} | } | |||
description "Augment TE bandwidth."; | description | |||
"Augmentation for TE bandwidth."; | ||||
} | } | |||
augment "/nw:networks/nw:network/nt:link/tet:te/" | augment "/nw:networks/nw:network/nt:link/tet:te/" | |||
+ "tet:te-link-attributes/" | + "tet:te-link-attributes/" | |||
+ "tet:max-resv-link-bandwidth/" | + "tet:max-resv-link-bandwidth/" | |||
+ "tet:te-bandwidth/tet:technology" { | + "tet:te-bandwidth/tet:technology" { | |||
when "../../../../../../nw:network-types/tet:te-topology/" | when '../../../../../nw:network-types/tet:te-topology/' | |||
+ "ex-topo:example-topology" { | + 'ex-topo:example-topology' { | |||
description | description | |||
"Augmentation parameters apply only for networks with | "Augmentation parameters apply only for networks with an | |||
example topology type."; | example topology type."; | |||
} | } | |||
case "example" { | case example { | |||
container example { | container example { | |||
description "Attributes for example technology."; | description | |||
"Attributes for the example technology."; | ||||
leaf bandwidth-1 { | leaf bandwidth-1 { | |||
type uint32; | type uint32; | |||
description "Bandwidth 1 for example technology."; | description | |||
"Bandwidth 1 for the example technology."; | ||||
} | } | |||
} | } | |||
} | } | |||
description "Augment TE bandwidth."; | description | |||
"Augmentation for TE bandwidth."; | ||||
} | } | |||
augment "/nw:networks/nw:network/nt:link/tet:te/" | augment "/nw:networks/nw:network/nt:link/tet:te/" | |||
+ "tet:information-source-entry/" | + "tet:information-source-entry/" | |||
+ "tet:interface-switching-capability/tet:max-lsp-bandwidth/" | + "tet:interface-switching-capability/tet:max-lsp-bandwidth/" | |||
+ "tet:te-bandwidth/tet:technology" { | + "tet:te-bandwidth/tet:technology" { | |||
when "../../../../../../../../nw:network-types/tet:te-topology/" | when '../../../../../../nw:network-types/tet:te-topology/' | |||
+ "ex-topo:example-topology" { | + 'ex-topo:example-topology' { | |||
description | description | |||
"Augmentation parameters apply only for networks with | "Augmentation parameters apply only for networks with an | |||
example topology type."; | example topology type."; | |||
} | } | |||
case "example" { | case example { | |||
container example { | container example { | |||
description "Attributes for example technology."; | description | |||
"Attributes for the example technology."; | ||||
leaf bandwidth-1 { | leaf bandwidth-1 { | |||
type uint32; | type uint32; | |||
description "Bandwidth 1 for example technology."; | description | |||
"Bandwidth 1 for the example technology."; | ||||
} | } | |||
} | } | |||
} | } | |||
description "Augment TE bandwidth."; | description | |||
"Augmentation for TE bandwidth."; | ||||
} | } | |||
augment "/nw:networks/nw:network/nt:link/tet:te/" | augment "/nw:networks/nw:network/nt:link/tet:te/" | |||
+ "tet:information-source-entry/" | + "tet:information-source-entry/" | |||
+ "tet:max-link-bandwidth/" | + "tet:max-link-bandwidth/" | |||
+ "tet:te-bandwidth/tet:technology" { | + "tet:te-bandwidth/tet:technology" { | |||
when "../../../../../../nw:network-types/tet:te-topology/" | when '../../../../../nw:network-types/tet:te-topology/' | |||
+ "ex-topo:example-topology" { | + 'ex-topo:example-topology' { | |||
description | description | |||
"Augmentation parameters apply only for networks with | "Augmentation parameters apply only for networks with an | |||
example topology type."; | example topology type."; | |||
} | } | |||
case "example" { | case example { | |||
container example { | container example { | |||
description "Attributes for example technology."; | description | |||
"Attributes for the example technology."; | ||||
leaf bandwidth-1 { | leaf bandwidth-1 { | |||
type uint32; | type uint32; | |||
description "Bandwidth 1 for example technology."; | description | |||
"Bandwidth 1 for the example technology."; | ||||
} | } | |||
} | } | |||
} | } | |||
description "Augment TE bandwidth."; | description | |||
"Augmentation for TE bandwidth."; | ||||
} | } | |||
augment "/nw:networks/nw:network/nt:link/tet:te/" | augment "/nw:networks/nw:network/nt:link/tet:te/" | |||
+ "tet:information-source-entry/" | + "tet:information-source-entry/" | |||
+ "tet:max-resv-link-bandwidth/" | + "tet:max-resv-link-bandwidth/" | |||
+ "tet:te-bandwidth/tet:technology" { | + "tet:te-bandwidth/tet:technology" { | |||
when "../../../../../../nw:network-types/tet:te-topology/" | when '../../../../../nw:network-types/tet:te-topology/' | |||
+ "ex-topo:example-topology" { | + 'ex-topo:example-topology' { | |||
description | description | |||
"Augmentation parameters apply only for networks with | "Augmentation parameters apply only for networks with an | |||
example topology type."; | example topology type."; | |||
} | } | |||
case "example" { | case example { | |||
container example { | container example { | |||
description "Attributes for example technology."; | description | |||
"Attributes for the example technology."; | ||||
leaf bandwidth-1 { | leaf bandwidth-1 { | |||
type uint32; | type uint32; | |||
description "Bandwidth 1 for example technology."; | description | |||
"Bandwidth 1 for the example technology."; | ||||
} | } | |||
} | } | |||
} | } | |||
description "Augment TE bandwidth."; | description | |||
"Augmentation for TE bandwidth."; | ||||
} | } | |||
augment "/nw:networks/nw:network/nt:link/tet:te/" | augment "/nw:networks/nw:network/nt:link/tet:te/" | |||
+ "tet:information-source-entry/" | + "tet:information-source-entry/" | |||
+ "tet:unreserved-bandwidth/" | + "tet:unreserved-bandwidth/" | |||
+ "tet:te-bandwidth/tet:technology" { | + "tet:te-bandwidth/tet:technology" { | |||
when "../../../../../../../nw:network-types/tet:te-topology/" | when '../../../../../nw:network-types/tet:te-topology/' | |||
+ "ex-topo:example-topology" { | + 'ex-topo:example-topology' { | |||
description | description | |||
"Augmentation parameters apply only for networks with | "Augmentation parameters apply only for networks with an | |||
example topology type."; | example topology type."; | |||
} | } | |||
case "example" { | case example { | |||
container example { | container example { | |||
description "Attributes for example technology."; | description | |||
"Attributes for the example technology."; | ||||
leaf bandwidth-1 { | leaf bandwidth-1 { | |||
type uint32; | type uint32; | |||
description "Bandwidth 1 for example technology."; | description | |||
"Bandwidth 1 for the example technology."; | ||||
} | } | |||
} | } | |||
} | } | |||
description "Augment TE bandwidth."; | description | |||
"Augmentation for TE bandwidth."; | ||||
} | } | |||
augment "/nw:networks/nw:network/nw:node/nt:termination-point/" | augment "/nw:networks/nw:network/nw:node/nt:termination-point/" | |||
+ "tet:te/" | + "tet:te/tet:interface-switching-capability/" | |||
+ "tet:interface-switching-capability/tet:max-lsp-bandwidth/" | + "tet:max-lsp-bandwidth/tet:te-bandwidth/tet:technology" { | |||
+ "tet:te-bandwidth/tet:technology" { | when '../../../../../../nw:network-types/tet:te-topology/' | |||
when "../../../../../../../../nw:network-types/tet:te-topology/" | + 'ex-topo:example-topology' { | |||
+ "ex-topo:example-topology" { | ||||
description | description | |||
"Augmentation parameters apply only for networks with | "Augmentation parameters apply only for networks with an | |||
example topology type."; | example topology type."; | |||
} | } | |||
case "example" { | case example { | |||
container example { | container example { | |||
description "Attributes for example technology."; | description | |||
"Attributes for the example technology."; | ||||
leaf bandwidth-1 { | leaf bandwidth-1 { | |||
type uint32; | type uint32; | |||
description "Bandwidth 1 for example technology."; | description | |||
"Bandwidth 1 for the example technology."; | ||||
} | } | |||
} | } | |||
} | } | |||
description "Augment TE bandwidth."; | description | |||
"Augmentation for TE bandwidth."; | ||||
} | } | |||
/* | /* | |||
* Augment TE label. | * Augmentations for the TE label. | |||
*/ | */ | |||
augment "/nw:networks/tet:te/tet:templates/" | augment "/nw:networks/tet:te/tet:templates/" | |||
+ "tet:link-template/tet:te-link-attributes/" | + "tet:link-template/tet:te-link-attributes/" | |||
+ "tet:underlay/tet:primary-path/tet:path-element/tet:type/" | + "tet:underlay/tet:primary-path/tet:path-element/tet:type/" | |||
+ "tet:label/tet:label-hop/tet:te-label/tet:technology" { | + "tet:label/tet:label-hop/tet:te-label/tet:technology" { | |||
case "example" { | case example { | |||
container example { | container example { | |||
description "Attributes for example technology."; | description | |||
"Attributes for the example technology."; | ||||
leaf label-1 { | leaf label-1 { | |||
type uint32; | type uint32; | |||
description "Label 1 for example technology."; | description | |||
"Label 1 for the example technology."; | ||||
} | } | |||
} | } | |||
} | } | |||
description "Augment TE label."; | description | |||
"Augmentation for the TE label."; | ||||
} | } | |||
augment "/nw:networks/tet:te/tet:templates/" | augment "/nw:networks/tet:te/tet:templates/" | |||
+ "tet:link-template/tet:te-link-attributes/" | + "tet:link-template/tet:te-link-attributes/" | |||
+ "tet:underlay/tet:backup-path/tet:path-element/tet:type/" | + "tet:underlay/tet:backup-path/tet:path-element/tet:type/" | |||
+ "tet:label/tet:label-hop/tet:te-label/tet:technology" { | + "tet:label/tet:label-hop/tet:te-label/tet:technology" { | |||
case "example" { | case example { | |||
container example { | container example { | |||
description "Attributes for example technology."; | description | |||
"Attributes for the example technology."; | ||||
leaf label-1 { | leaf label-1 { | |||
type uint32; | type uint32; | |||
description "Label 1 for example technology."; | description | |||
"Label 1 for the example technology."; | ||||
} | } | |||
} | } | |||
} | } | |||
description "Augment TE label."; | description | |||
"Augmentation for the TE label."; | ||||
} | } | |||
augment "/nw:networks/tet:te/tet:templates/" | augment "/nw:networks/tet:te/tet:templates/" | |||
+ "tet:link-template/tet:te-link-attributes/" | + "tet:link-template/tet:te-link-attributes/" | |||
+ "tet:label-restrictions/tet:label-restriction/tet:label-start/" | + "tet:label-restrictions/tet:label-restriction/" | |||
+ "tet:te-label/tet:technology" { | + "tet:label-start/tet:te-label/tet:technology" { | |||
case "example" { | case example { | |||
container example { | container example { | |||
description "Attributes for example technology."; | description | |||
"Attributes for the example technology."; | ||||
leaf label-1 { | leaf label-1 { | |||
type uint32; | type uint32; | |||
description "Label 1 for example technology."; | description | |||
"Label 1 for the example technology."; | ||||
} | } | |||
} | } | |||
} | } | |||
description "Augment TE label."; | description | |||
"Augmentation for the TE label."; | ||||
} | } | |||
augment "/nw:networks/tet:te/tet:templates/" | augment "/nw:networks/tet:te/tet:templates/" | |||
+ "tet:link-template/tet:te-link-attributes/" | + "tet:link-template/tet:te-link-attributes/" | |||
+ "tet:label-restrictions/tet:label-restriction/tet:label-end/" | + "tet:label-restrictions/tet:label-restriction/" | |||
+ "tet:te-label/tet:technology" { | + "tet:label-end/tet:te-label/tet:technology" { | |||
case "example" { | case example { | |||
container example { | container example { | |||
description "Attributes for example technology."; | description | |||
"Attributes for the example technology."; | ||||
leaf label-1 { | leaf label-1 { | |||
type uint32; | type uint32; | |||
description "Label 1 for example technology."; | description | |||
"Label 1 for the example technology."; | ||||
} | } | |||
} | } | |||
} | } | |||
description "Augment TE label."; | description | |||
"Augmentation for the TE label."; | ||||
} | } | |||
/* Under te-node-attributes/connectivity-matrices */ | /* Under te-node-attributes/connectivity-matrices */ | |||
augment "/nw:networks/nw:network/nw:node/tet:te/" | augment "/nw:networks/nw:network/nw:node/tet:te/" | |||
+ "tet:te-node-attributes/tet:connectivity-matrices/" | + "tet:te-node-attributes/tet:connectivity-matrices/" | |||
+ "tet:label-restrictions/tet:label-restriction/tet:label-start/" | + "tet:label-restrictions/tet:label-restriction/" | |||
+ "tet:te-label/tet:technology" { | + "tet:label-start/tet:te-label/tet:technology" { | |||
when "../../../../../../../../nw:network-types/tet:te-topology/" | when '../../../../../../../../nw:network-types/tet:te-topology/' | |||
+ "ex-topo:example-topology" { | + 'ex-topo:example-topology' { | |||
description | description | |||
"Augmentation parameters apply only for networks with | "Augmentation parameters apply only for networks with an | |||
example topology type."; | example topology type."; | |||
} | } | |||
case "example" { | case example { | |||
container example { | container example { | |||
description "Attributes for example technology."; | description | |||
"Attributes for the example technology."; | ||||
leaf label-1 { | leaf label-1 { | |||
type uint32; | type uint32; | |||
description "Label 1 for example technology."; | description | |||
"Label 1 for the example technology."; | ||||
} | } | |||
} | } | |||
} | } | |||
description "Augment TE label."; | description | |||
"Augmentation for the TE label."; | ||||
} | } | |||
augment "/nw:networks/nw:network/nw:node/tet:te/" | augment "/nw:networks/nw:network/nw:node/tet:te/" | |||
+ "tet:te-node-attributes/tet:connectivity-matrices/" | + "tet:te-node-attributes/tet:connectivity-matrices/" | |||
+ "tet:label-restrictions/tet:label-restriction/tet:label-end/" | + "tet:label-restrictions/tet:label-restriction/" | |||
+ "tet:te-label/tet:technology" { | + "tet:label-end/tet:te-label/tet:technology" { | |||
when "../../../../../../../../nw:network-types/tet:te-topology/" | when '../../../../../../../../nw:network-types/tet:te-topology/' | |||
+ "ex-topo:example-topology" { | + 'ex-topo:example-topology' { | |||
description | description | |||
"Augmentation parameters apply only for networks with | "Augmentation parameters apply only for networks with an | |||
example topology type."; | example topology type."; | |||
} | } | |||
case "example" { | case example { | |||
container example { | container example { | |||
description "Attributes for example technology."; | description | |||
"Attributes for the example technology."; | ||||
leaf label-1 { | leaf label-1 { | |||
type uint32; | type uint32; | |||
description "Label 1 for example technology."; | description | |||
"Label 1 for the example technology."; | ||||
} | } | |||
} | } | |||
} | } | |||
description "Augment TE label."; | description | |||
"Augmentation for the TE label."; | ||||
} | } | |||
augment "/nw:networks/nw:network/nw:node/tet:te/" | augment "/nw:networks/nw:network/nw:node/tet:te/" | |||
+ "tet:te-node-attributes/tet:connectivity-matrices/" | + "tet:te-node-attributes/tet:connectivity-matrices/" | |||
+ "tet:underlay/tet:primary-path/tet:path-element/tet:type/" | + "tet:underlay/tet:primary-path/tet:path-element/tet:type/" | |||
+ "tet:label/tet:label-hop/tet:te-label/tet:technology" { | + "tet:label/tet:label-hop/tet:te-label/tet:technology" { | |||
when "../../../../../../../../../../../../nw:network-types/" | when '../../../../../../../../../nw:network-types/' | |||
+ "tet:te-topology/ex-topo:example-topology" { | + 'tet:te-topology/ex-topo:example-topology' { | |||
description | description | |||
"Augmentation parameters apply only for networks with | "Augmentation parameters apply only for networks with an | |||
example topology type."; | example topology type."; | |||
} | } | |||
case "example" { | case example { | |||
container example { | container example { | |||
description "Attributes for example technology."; | description | |||
"Attributes for the example technology."; | ||||
leaf label-1 { | leaf label-1 { | |||
type uint32; | type uint32; | |||
description "Label 1 for example technology."; | description | |||
"Label 1 for the example technology."; | ||||
} | } | |||
} | } | |||
} | } | |||
description "Augment TE label."; | description | |||
"Augmentation for the TE label."; | ||||
} | } | |||
augment "/nw:networks/nw:network/nw:node/tet:te/" | augment "/nw:networks/nw:network/nw:node/tet:te/" | |||
+ "tet:te-node-attributes/tet:connectivity-matrices/" | + "tet:te-node-attributes/tet:connectivity-matrices/" | |||
+ "tet:underlay/tet:backup-path/tet:path-element/tet:type/" | + "tet:underlay/tet:backup-path/tet:path-element/tet:type/" | |||
+ "tet:label/tet:label-hop/tet:te-label/tet:technology" { | + "tet:label/tet:label-hop/tet:te-label/tet:technology" { | |||
when "../../../../../../../../../../../../nw:network-types/" | when '../../../../../../../../../nw:network-types/' | |||
+ "tet:te-topology/ex-topo:example-topology" { | + 'tet:te-topology/ex-topo:example-topology' { | |||
description | description | |||
"Augmentation parameters apply only for networks with | "Augmentation parameters apply only for networks with an | |||
example topology type."; | example topology type."; | |||
} | } | |||
case "example" { | case example { | |||
container example { | container example { | |||
description "Attributes for example technology."; | description | |||
"Attributes for the example technology."; | ||||
leaf label-1 { | leaf label-1 { | |||
type uint32; | type uint32; | |||
description "Label 1 for example technology."; | description | |||
"Label 1 for the example technology."; | ||||
} | } | |||
} | } | |||
} | } | |||
description "Augment TE label."; | description | |||
"Augmentation for the TE label."; | ||||
} | } | |||
augment "/nw:networks/nw:network/nw:node/tet:te/" | augment "/nw:networks/nw:network/nw:node/tet:te/" | |||
+ "tet:te-node-attributes/tet:connectivity-matrices/" | + "tet:te-node-attributes/tet:connectivity-matrices/" | |||
+ "tet:path-properties/tet:path-route-objects/" | + "tet:path-properties/tet:path-route-objects/" | |||
+ "tet:path-route-object/tet:type/" | + "tet:path-route-object/tet:type/" | |||
+ "tet:label/tet:label-hop/tet:te-label/tet:technology" { | + "tet:label/tet:label-hop/tet:te-label/tet:technology" { | |||
when "../../../../../../../../../../../../nw:network-types/" | when '../../../../../../../../../nw:network-types/' | |||
+ "tet:te-topology/ex-topo:example-topology" { | + 'tet:te-topology/ex-topo:example-topology' { | |||
description | description | |||
"Augmentation parameters apply only for networks with | "Augmentation parameters apply only for networks with an | |||
example topology type."; | example topology type."; | |||
} | } | |||
case "example" { | case example { | |||
container example { | container example { | |||
description "Attributes for example technology."; | description | |||
"Attributes for the example technology."; | ||||
leaf label-1 { | leaf label-1 { | |||
type uint32; | type uint32; | |||
description "Label 1 for example technology."; | description | |||
"Label 1 for the example technology."; | ||||
} | } | |||
} | } | |||
} | } | |||
description "Augment TE label."; | description | |||
"Augmentation for the TE label."; | ||||
} | } | |||
/* Under te-node-attributes/.../connectivity-matrix */ | /* Under te-node-attributes/.../connectivity-matrix */ | |||
augment "/nw:networks/nw:network/nw:node/tet:te/" | augment "/nw:networks/nw:network/nw:node/tet:te/" | |||
+ "tet:te-node-attributes/tet:connectivity-matrices/" | + "tet:te-node-attributes/tet:connectivity-matrices/" | |||
+ "tet:connectivity-matrix/tet:from/" | + "tet:connectivity-matrix/tet:from/tet:label-restrictions/" | |||
+ "tet:label-restrictions/tet:label-restriction/tet:label-start/" | + "tet:label-restriction/tet:label-start/" | |||
+ "tet:te-label/tet:technology" { | + "tet:te-label/tet:technology" { | |||
when "../../../../../../../../../../nw:network-types/" | when '../../../../../../../../../../nw:network-types/' | |||
+ "tet:te-topology/ex-topo:example-topology" { | + 'tet:te-topology/ex-topo:example-topology' { | |||
description | description | |||
"Augmentation parameters apply only for networks with | "Augmentation parameters apply only for networks with an | |||
example topology type."; | example topology type."; | |||
} | } | |||
case "example" { | case example { | |||
container example { | container example { | |||
description "Attributes for example technology."; | description | |||
"Attributes for the example technology."; | ||||
leaf label-1 { | leaf label-1 { | |||
type uint32; | type uint32; | |||
description "Label 1 for example technology."; | description | |||
"Label 1 for the example technology."; | ||||
} | } | |||
} | } | |||
} | } | |||
description "Augment TE label."; | description | |||
"Augmentation for the TE label."; | ||||
} | } | |||
augment "/nw:networks/nw:network/nw:node/tet:te/" | augment "/nw:networks/nw:network/nw:node/tet:te/" | |||
+ "tet:te-node-attributes/tet:connectivity-matrices/" | + "tet:te-node-attributes/tet:connectivity-matrices/" | |||
+ "tet:connectivity-matrix/tet:from/" | + "tet:connectivity-matrix/tet:from/" | |||
+ "tet:label-restrictions/tet:label-restriction/tet:label-end/" | + "tet:label-restrictions/tet:label-restriction/" | |||
+ "tet:te-label/tet:technology" { | + "tet:label-end/tet:te-label/tet:technology" { | |||
when "../../../../../../../../../../nw:network-types/" | when '../../../../../../../../../../nw:network-types/' | |||
+ "tet:te-topology/ex-topo:example-topology" { | + 'tet:te-topology/ex-topo:example-topology' { | |||
description | description | |||
"Augmentation parameters apply only for networks with | "Augmentation parameters apply only for networks with an | |||
example topology type."; | example topology type."; | |||
} | } | |||
case "example" { | case example { | |||
container example { | container example { | |||
description "Attributes for example technology."; | description | |||
"Attributes for the example technology."; | ||||
leaf label-1 { | leaf label-1 { | |||
type uint32; | type uint32; | |||
description "Label 1 for example technology."; | description | |||
"Label 1 for the example technology."; | ||||
} | } | |||
} | } | |||
} | } | |||
description "Augment TE label."; | description | |||
"Augmentation for the TE label."; | ||||
} | } | |||
augment "/nw:networks/nw:network/nw:node/tet:te/" | augment "/nw:networks/nw:network/nw:node/tet:te/" | |||
+ "tet:te-node-attributes/tet:connectivity-matrices/" | + "tet:te-node-attributes/tet:connectivity-matrices/" | |||
+ "tet:connectivity-matrix/tet:to/" | + "tet:connectivity-matrix/tet:to/tet:label-restrictions/" | |||
+ "tet:label-restrictions/tet:label-restriction/tet:label-start/" | + "tet:label-restriction/tet:label-start/" | |||
+ "tet:te-label/tet:technology" { | + "tet:te-label/tet:technology" { | |||
when "../../../../../../../../../../nw:network-types/" | when '../../../../../../../../../../nw:network-types/' | |||
+ "tet:te-topology/ex-topo:example-topology" { | + 'tet:te-topology/ex-topo:example-topology' { | |||
description | description | |||
"Augmentation parameters apply only for networks with | "Augmentation parameters apply only for networks with an | |||
example topology type."; | example topology type."; | |||
} | } | |||
case "example" { | case example { | |||
container example { | container example { | |||
description "Attributes for example technology."; | description | |||
"Attributes for the example technology."; | ||||
leaf label-1 { | leaf label-1 { | |||
type uint32; | type uint32; | |||
description "Label 1 for example technology."; | description | |||
"Label 1 for the example technology."; | ||||
} | } | |||
} | } | |||
} | } | |||
description "Augment TE label."; | description | |||
"Augmentation for the TE label."; | ||||
} | } | |||
augment "/nw:networks/nw:network/nw:node/tet:te/" | augment "/nw:networks/nw:network/nw:node/tet:te/" | |||
+ "tet:te-node-attributes/tet:connectivity-matrices/" | + "tet:te-node-attributes/tet:connectivity-matrices/" | |||
+ "tet:connectivity-matrix/tet:to/" | + "tet:connectivity-matrix/tet:to/" | |||
+ "tet:label-restrictions/tet:label-restriction/tet:label-end/" | + "tet:label-restrictions/tet:label-restriction/" | |||
+ "tet:te-label/tet:technology" { | + "tet:label-end/tet:te-label/tet:technology" { | |||
when "../../../../../../../../../../nw:network-types/" | when '../../../../../../../../../../nw:network-types/' | |||
+ "tet:te-topology/ex-topo:example-topology" { | + 'tet:te-topology/ex-topo:example-topology' { | |||
description | description | |||
"Augmentation parameters apply only for networks with | "Augmentation parameters apply only for networks with an | |||
example topology type."; | example topology type."; | |||
} | } | |||
case "example" { | case example { | |||
container example { | container example { | |||
description "Attributes for example technology."; | description | |||
"Attributes for the example technology."; | ||||
leaf label-1 { | leaf label-1 { | |||
type uint32; | type uint32; | |||
description "Label 1 for example technology."; | description | |||
"Label 1 for the example technology."; | ||||
} | } | |||
} | } | |||
} | } | |||
description "Augment TE label."; | description | |||
"Augmentation for the TE label."; | ||||
} | } | |||
augment "/nw:networks/nw:network/nw:node/tet:te/" | augment "/nw:networks/nw:network/nw:node/tet:te/" | |||
+ "tet:te-node-attributes/tet:connectivity-matrices/" | + "tet:te-node-attributes/tet:connectivity-matrices/" | |||
+ "tet:connectivity-matrix/" | + "tet:connectivity-matrix/" | |||
+ "tet:underlay/tet:primary-path/tet:path-element/tet:type/" | + "tet:underlay/tet:primary-path/tet:path-element/tet:type/" | |||
+ "tet:label/tet:label-hop/tet:te-label/tet:technology" { | + "tet:label/tet:label-hop/tet:te-label/tet:technology" { | |||
when "../../../../../../../../../../../../../nw:network-types/" | when '../../../../../../../../../../nw:network-types/' | |||
+ "tet:te-topology/ex-topo:example-topology" { | + 'tet:te-topology/ex-topo:example-topology' { | |||
description | description | |||
"Augmentation parameters apply only for networks with | "Augmentation parameters apply only for networks with an | |||
example topology type."; | example topology type."; | |||
} | } | |||
case "example" { | case example { | |||
container example { | container example { | |||
description "Attributes for example technology."; | description | |||
"Attributes for the example technology."; | ||||
leaf label-1 { | leaf label-1 { | |||
type uint32; | type uint32; | |||
description "Label 1 for example technology."; | description | |||
"Label 1 for the example technology."; | ||||
} | } | |||
} | } | |||
} | } | |||
description "Augment TE label."; | description | |||
"Augmentation for the TE label."; | ||||
} | } | |||
augment "/nw:networks/nw:network/nw:node/tet:te/" | augment "/nw:networks/nw:network/nw:node/tet:te/" | |||
+ "tet:te-node-attributes/tet:connectivity-matrices/" | + "tet:te-node-attributes/tet:connectivity-matrices/" | |||
+ "tet:connectivity-matrix/" | + "tet:connectivity-matrix/" | |||
+ "tet:underlay/tet:backup-path/tet:path-element/tet:type/" | + "tet:underlay/tet:backup-path/tet:path-element/tet:type/" | |||
+ "tet:label/tet:label-hop/tet:te-label/tet:technology" { | + "tet:label/tet:label-hop/tet:te-label/tet:technology" { | |||
when "../../../../../../../../../../../../nw:network-types/" | when '../../../../../../../../../../nw:network-types/' | |||
+ "tet:te-topology/ex-topo:example-topology" { | + 'tet:te-topology/ex-topo:example-topology' { | |||
description | description | |||
"Augmentation parameters apply only for networks with | "Augmentation parameters apply only for networks with an | |||
example topology type."; | example topology type."; | |||
} | } | |||
case "example" { | case example { | |||
container example { | container example { | |||
description "Attributes for example technology."; | description | |||
"Attributes for the example technology."; | ||||
leaf label-1 { | leaf label-1 { | |||
type uint32; | type uint32; | |||
description "Label 1 for example technology."; | description | |||
"Label 1 for the example technology."; | ||||
} | } | |||
} | } | |||
} | } | |||
description "Augment TE label."; | description | |||
"Augmentation for the TE label."; | ||||
} | } | |||
augment "/nw:networks/nw:network/nw:node/tet:te/" | augment "/nw:networks/nw:network/nw:node/tet:te/" | |||
+ "tet:te-node-attributes/tet:connectivity-matrices/" | + "tet:te-node-attributes/tet:connectivity-matrices/" | |||
+ "tet:connectivity-matrix/" | + "tet:connectivity-matrix/" | |||
+ "tet:path-properties/tet:path-route-objects/" | + "tet:path-properties/tet:path-route-objects/" | |||
+ "tet:path-route-object/tet:type/" | + "tet:path-route-object/tet:type/" | |||
+ "tet:label/tet:label-hop/tet:te-label/tet:technology" { | + "tet:label/tet:label-hop/tet:te-label/tet:technology" { | |||
when "../../../../../../../../../../../../../nw:network-types/" | when '../../../../../../../../../../nw:network-types/' | |||
+ "tet:te-topology/ex-topo:example-topology" { | + 'tet:te-topology/ex-topo:example-topology' { | |||
description | description | |||
"Augmentation parameters apply only for networks with | "Augmentation parameters apply only for networks with an | |||
example topology type."; | example topology type."; | |||
} | } | |||
case "example" { | case example { | |||
container example { | container example { | |||
description "Attributes for example technology."; | description | |||
"Attributes for the example technology."; | ||||
leaf label-1 { | leaf label-1 { | |||
type uint32; | type uint32; | |||
description "Label 1 for example technology."; | description | |||
"Label 1 for the example technology."; | ||||
} | } | |||
} | } | |||
} | } | |||
description "Augment TE label."; | description | |||
"Augmentation for the TE label."; | ||||
} | } | |||
/* Under information-source-entry/connectivity-matrices */ | /* Under information-source-entry/connectivity-matrices */ | |||
augment "/nw:networks/nw:network/nw:node/tet:te/" | augment "/nw:networks/nw:network/nw:node/tet:te/" | |||
+ "tet:information-source-entry/tet:connectivity-matrices/" | + "tet:information-source-entry/tet:connectivity-matrices/" | |||
+ "tet:label-restrictions/tet:label-restriction/tet:label-start/" | + "tet:label-restrictions/tet:label-restriction/" | |||
+ "tet:te-label/tet:technology" { | + "tet:label-start/tet:te-label/tet:technology" { | |||
when "../../../../../../../../nw:network-types/tet:te-topology/" | when '../../../../../../../../nw:network-types/tet:te-topology/' | |||
+ "ex-topo:example-topology" { | + 'ex-topo:example-topology' { | |||
description | description | |||
"Augmentation parameters apply only for networks with | "Augmentation parameters apply only for networks with an | |||
example topology type."; | example topology type."; | |||
} | } | |||
case "example" { | case example { | |||
container example { | container example { | |||
description "Attributes for example technology."; | description | |||
"Attributes for the example technology."; | ||||
leaf label-1 { | leaf label-1 { | |||
type uint32; | type uint32; | |||
description "Label 1 for example technology."; | description | |||
"Label 1 for the example technology."; | ||||
} | } | |||
} | } | |||
} | } | |||
description "Augment TE label."; | description | |||
"Augmentation for the TE label."; | ||||
} | } | |||
augment "/nw:networks/nw:network/nw:node/tet:te/" | augment "/nw:networks/nw:network/nw:node/tet:te/" | |||
+ "tet:information-source-entry/tet:connectivity-matrices/" | + "tet:information-source-entry/tet:connectivity-matrices/" | |||
+ "tet:label-restrictions/tet:label-restriction/tet:label-end/" | + "tet:label-restrictions/tet:label-restriction/" | |||
+ "tet:te-label/tet:technology" { | + "tet:label-end/tet:te-label/tet:technology" { | |||
when "../../../../../../../../nw:network-types/tet:te-topology/" | when '../../../../../../../../nw:network-types/tet:te-topology/' | |||
+ "ex-topo:example-topology" { | + 'ex-topo:example-topology' { | |||
description | description | |||
"Augmentation parameters apply only for networks with | "Augmentation parameters apply only for networks with an | |||
example topology type."; | example topology type."; | |||
} | } | |||
case "example" { | case example { | |||
container example { | container example { | |||
description "Attributes for example technology."; | description | |||
"Attributes for the example technology."; | ||||
leaf label-1 { | leaf label-1 { | |||
type uint32; | type uint32; | |||
description "Label 1 for example technology."; | description | |||
"Label 1 for the example technology."; | ||||
} | } | |||
} | } | |||
} | } | |||
description "Augment TE label."; | description | |||
"Augmentation for the TE label."; | ||||
} | } | |||
augment "/nw:networks/nw:network/nw:node/tet:te/" | augment "/nw:networks/nw:network/nw:node/tet:te/" | |||
+ "tet:information-source-entry/tet:connectivity-matrices/" | + "tet:information-source-entry/tet:connectivity-matrices/" | |||
+ "tet:underlay/tet:primary-path/tet:path-element/tet:type/" | + "tet:underlay/tet:primary-path/tet:path-element/tet:type/" | |||
+ "tet:label/tet:label-hop/tet:te-label/tet:technology" { | + "tet:label/tet:label-hop/tet:te-label/tet:technology" { | |||
when "../../../../../../../../../../../../nw:network-types/" | when '../../../../../../../../../nw:network-types/' | |||
+ "tet:te-topology/ex-topo:example-topology" { | + 'tet:te-topology/ex-topo:example-topology' { | |||
description | description | |||
"Augmentation parameters apply only for networks with | "Augmentation parameters apply only for networks with an | |||
example topology type."; | example topology type."; | |||
} | } | |||
case "example" { | case example { | |||
container example { | container example { | |||
description "Attributes for example technology."; | description | |||
"Attributes for the example technology."; | ||||
leaf label-1 { | leaf label-1 { | |||
type uint32; | type uint32; | |||
description "Label 1 for example technology."; | description | |||
"Label 1 for the example technology."; | ||||
} | } | |||
} | } | |||
} | } | |||
description "Augment TE label."; | description | |||
"Augmentation for the TE label."; | ||||
} | } | |||
augment "/nw:networks/nw:network/nw:node/tet:te/" | augment "/nw:networks/nw:network/nw:node/tet:te/" | |||
+ "tet:information-source-entry/tet:connectivity-matrices/" | + "tet:information-source-entry/tet:connectivity-matrices/" | |||
+ "tet:underlay/tet:backup-path/tet:path-element/tet:type/" | + "tet:underlay/tet:backup-path/tet:path-element/tet:type/" | |||
+ "tet:label/tet:label-hop/tet:te-label/tet:technology" { | + "tet:label/tet:label-hop/tet:te-label/tet:technology" { | |||
when "../../../../../../../../../../../../nw:network-types/" | when '../../../../../../../../../nw:network-types/' | |||
+ "tet:te-topology/ex-topo:example-topology" { | + 'tet:te-topology/ex-topo:example-topology' { | |||
description | description | |||
"Augmentation parameters apply only for networks with | "Augmentation parameters apply only for networks with an | |||
example topology type."; | example topology type."; | |||
} | } | |||
case "example" { | case example { | |||
container example { | container example { | |||
description "Attributes for example technology."; | description | |||
"Attributes for the example technology."; | ||||
leaf label-1 { | leaf label-1 { | |||
type uint32; | type uint32; | |||
description "Label 1 for example technology."; | description | |||
"Label 1 for the example technology."; | ||||
} | } | |||
} | } | |||
} | } | |||
description "Augment TE label."; | description | |||
"Augmentation for the TE label."; | ||||
} | } | |||
augment "/nw:networks/nw:network/nw:node/tet:te/" | augment "/nw:networks/nw:network/nw:node/tet:te/" | |||
+ "tet:information-source-entry/tet:connectivity-matrices/" | + "tet:information-source-entry/tet:connectivity-matrices/" | |||
+ "tet:path-properties/tet:path-route-objects/" | + "tet:path-properties/tet:path-route-objects/" | |||
+ "tet:path-route-object/tet:type/" | + "tet:path-route-object/tet:type/" | |||
+ "tet:label/tet:label-hop/tet:te-label/tet:technology" { | + "tet:label/tet:label-hop/tet:te-label/tet:technology" { | |||
when "../../../../../../../../../../../../nw:network-types/" | when '../../../../../../../../../nw:network-types/' | |||
+ "tet:te-topology/ex-topo:example-topology" { | + 'tet:te-topology/ex-topo:example-topology' { | |||
description | description | |||
"Augmentation parameters apply only for networks with | "Augmentation parameters apply only for networks with an | |||
example topology type."; | example topology type."; | |||
} | } | |||
case "example" { | case example { | |||
container example { | container example { | |||
description "Attributes for example technology."; | description | |||
"Attributes for the example technology."; | ||||
leaf label-1 { | leaf label-1 { | |||
type uint32; | type uint32; | |||
description "Label 1 for example technology."; | description | |||
"Label 1 for the example technology."; | ||||
} | } | |||
} | } | |||
} | } | |||
description "Augment TE label."; | description | |||
"Augmentation for the TE label."; | ||||
} | } | |||
/* Under information-source-entry/.../connectivity-matrix */ | /* Under information-source-entry/.../connectivity-matrix */ | |||
augment "/nw:networks/nw:network/nw:node/tet:te/" | augment "/nw:networks/nw:network/nw:node/tet:te/" | |||
+ "tet:information-source-entry/tet:connectivity-matrices/" | + "tet:information-source-entry/tet:connectivity-matrices/" | |||
+ "tet:connectivity-matrix/tet:from/" | + "tet:connectivity-matrix/tet:from/" | |||
+ "tet:label-restrictions/tet:label-restriction/tet:label-start/" | + "tet:label-restrictions/tet:label-restriction/" | |||
+ "tet:te-label/tet:technology" { | + "tet:label-start/tet:te-label/tet:technology" { | |||
when "../../../../../../../../../../nw:network-types/" | when '../../../../../../../../../../nw:network-types/' | |||
+ "tet:te-topology/ex-topo:example-topology" { | + 'tet:te-topology/ex-topo:example-topology' { | |||
description | description | |||
"Augmentation parameters apply only for networks with | "Augmentation parameters apply only for networks with an | |||
example topology type."; | example topology type."; | |||
} | } | |||
case "example" { | case example { | |||
container example { | container example { | |||
description "Attributes for example technology."; | description | |||
"Attributes for the example technology."; | ||||
leaf label-1 { | leaf label-1 { | |||
type uint32; | type uint32; | |||
description "Label 1 for example technology."; | description | |||
"Label 1 for the example technology."; | ||||
} | } | |||
} | } | |||
} | } | |||
description "Augment TE label."; | description | |||
"Augmentation for the TE label."; | ||||
} | } | |||
augment "/nw:networks/nw:network/nw:node/tet:te/" | augment "/nw:networks/nw:network/nw:node/tet:te/" | |||
+ "tet:information-source-entry/tet:connectivity-matrices/" | + "tet:information-source-entry/tet:connectivity-matrices/" | |||
+ "tet:connectivity-matrix/tet:from/" | + "tet:connectivity-matrix/tet:from/" | |||
+ "tet:label-restrictions/tet:label-restriction/tet:label-end/" | + "tet:label-restrictions/tet:label-restriction/" | |||
+ "tet:te-label/tet:technology" { | + "tet:label-end/tet:te-label/tet:technology" { | |||
when "../../../../../../../../../../nw:network-types/" | when '../../../../../../../../../../nw:network-types/' | |||
+ "tet:te-topology/ex-topo:example-topology" { | + 'tet:te-topology/ex-topo:example-topology' { | |||
description | description | |||
"Augmentation parameters apply only for networks with | "Augmentation parameters apply only for networks with an | |||
example topology type."; | example topology type."; | |||
} | } | |||
case "example" { | case example { | |||
container example { | container example { | |||
description "Attributes for example technology."; | description | |||
"Attributes for the example technology."; | ||||
leaf label-1 { | leaf label-1 { | |||
type uint32; | type uint32; | |||
description "Label 1 for example technology."; | description | |||
"Label 1 for the example technology."; | ||||
} | } | |||
} | } | |||
} | } | |||
description "Augment TE label."; | description | |||
"Augmentation for the TE label."; | ||||
} | } | |||
augment "/nw:networks/nw:network/nw:node/tet:te/" | augment "/nw:networks/nw:network/nw:node/tet:te/" | |||
+ "tet:information-source-entry/tet:connectivity-matrices/" | + "tet:information-source-entry/tet:connectivity-matrices/" | |||
+ "tet:connectivity-matrix/tet:to/" | + "tet:connectivity-matrix/tet:to/" | |||
+ "tet:label-restrictions/tet:label-restriction/tet:label-start/" | + "tet:label-restrictions/tet:label-restriction/" | |||
+ "tet:te-label/tet:technology" { | + "tet:label-start/tet:te-label/tet:technology" { | |||
when "../../../../../../../../../../nw:network-types/" | when '../../../../../../../../../../nw:network-types/' | |||
+ "tet:te-topology/ex-topo:example-topology" { | + 'tet:te-topology/ex-topo:example-topology' { | |||
description | description | |||
"Augmentation parameters apply only for networks with | "Augmentation parameters apply only for networks with an | |||
example topology type."; | example topology type."; | |||
} | } | |||
case "example" { | case example { | |||
container example { | container example { | |||
description "Attributes for example technology."; | description | |||
"Attributes for the example technology."; | ||||
leaf label-1 { | leaf label-1 { | |||
type uint32; | type uint32; | |||
description "Label 1 for example technology."; | description | |||
"Label 1 for the example technology."; | ||||
} | } | |||
} | } | |||
} | } | |||
description "Augment TE label."; | description | |||
"Augmentation for the TE label."; | ||||
} | } | |||
augment "/nw:networks/nw:network/nw:node/tet:te/" | augment "/nw:networks/nw:network/nw:node/tet:te/" | |||
+ "tet:information-source-entry/tet:connectivity-matrices/" | + "tet:information-source-entry/tet:connectivity-matrices/" | |||
+ "tet:connectivity-matrix/tet:to/" | + "tet:connectivity-matrix/tet:to/" | |||
+ "tet:label-restrictions/tet:label-restriction/tet:label-end/" | + "tet:label-restrictions/tet:label-restriction/" | |||
+ "tet:te-label/tet:technology" { | + "tet:label-end/tet:te-label/tet:technology" { | |||
when "../../../../../../../../../../nw:network-types/" | when '../../../../../../../../../../nw:network-types/' | |||
+ "tet:te-topology/ex-topo:example-topology" { | + 'tet:te-topology/ex-topo:example-topology' { | |||
description | description | |||
"Augmentation parameters apply only for networks with | "Augmentation parameters apply only for networks with an | |||
example topology type."; | example topology type."; | |||
} | } | |||
case "example" { | case example { | |||
container example { | container example { | |||
description "Attributes for example technology."; | description | |||
"Attributes for the example technology."; | ||||
leaf label-1 { | leaf label-1 { | |||
type uint32; | type uint32; | |||
description "Label 1 for example technology."; | description | |||
"Label 1 for the example technology."; | ||||
} | } | |||
} | } | |||
} | } | |||
description "Augment TE label."; | description | |||
"Augmentation for the TE label."; | ||||
} | } | |||
augment "/nw:networks/nw:network/nw:node/tet:te/" | augment "/nw:networks/nw:network/nw:node/tet:te/" | |||
+ "tet:information-source-entry/tet:connectivity-matrices/" | + "tet:information-source-entry/tet:connectivity-matrices/" | |||
+ "tet:connectivity-matrix/" | + "tet:connectivity-matrix/" | |||
+ "tet:underlay/tet:primary-path/tet:path-element/tet:type/" | + "tet:underlay/tet:primary-path/tet:path-element/tet:type/" | |||
+ "tet:label/tet:label-hop/tet:te-label/tet:technology" { | + "tet:label/tet:label-hop/tet:te-label/tet:technology" { | |||
when "../../../../../../../../../../../../../nw:network-types/" | when '../../../../../../../../../../nw:network-types/' | |||
+ "tet:te-topology/ex-topo:example-topology" { | + 'tet:te-topology/ex-topo:example-topology' { | |||
description | description | |||
"Augmentation parameters apply only for networks with | "Augmentation parameters apply only for networks with an | |||
example topology type."; | example topology type."; | |||
} | } | |||
case "example" { | case example { | |||
container example { | container example { | |||
description "Attributes for example technology."; | description | |||
"Attributes for the example technology."; | ||||
leaf label-1 { | leaf label-1 { | |||
type uint32; | type uint32; | |||
description "Label 1 for example technology."; | description | |||
"Label 1 for the example technology."; | ||||
} | } | |||
} | } | |||
} | } | |||
description "Augment TE label."; | description | |||
"Augmentation for the TE label."; | ||||
} | } | |||
augment "/nw:networks/nw:network/nw:node/tet:te/" | augment "/nw:networks/nw:network/nw:node/tet:te/" | |||
+ "tet:information-source-entry/tet:connectivity-matrices/" | + "tet:information-source-entry/tet:connectivity-matrices/" | |||
+ "tet:connectivity-matrix/" | + "tet:connectivity-matrix/" | |||
+ "tet:underlay/tet:backup-path/tet:path-element/tet:type/" | + "tet:underlay/tet:backup-path/tet:path-element/tet:type/" | |||
+ "tet:label/tet:label-hop/tet:te-label/tet:technology" { | + "tet:label/tet:label-hop/tet:te-label/tet:technology" { | |||
when "../../../../../../../../../../../../nw:network-types/" | when '../../../../../../../../../../nw:network-types/' | |||
+ "tet:te-topology/ex-topo:example-topology" { | + 'tet:te-topology/ex-topo:example-topology' { | |||
description | description | |||
"Augmentation parameters apply only for networks with | "Augmentation parameters apply only for networks with an | |||
example topology type."; | example topology type."; | |||
} | } | |||
case "example" { | case example { | |||
container example { | container example { | |||
description "Attributes for example technology."; | description | |||
"Attributes for the example technology."; | ||||
leaf label-1 { | leaf label-1 { | |||
type uint32; | type uint32; | |||
description "Label 1 for example technology."; | description | |||
"Label 1 for the example technology."; | ||||
} | } | |||
} | } | |||
} | } | |||
description "Augment TE label."; | description | |||
"Augmentation for the TE label."; | ||||
} | } | |||
augment "/nw:networks/nw:network/nw:node/tet:te/" | augment "/nw:networks/nw:network/nw:node/tet:te/" | |||
+ "tet:information-source-entry/tet:connectivity-matrices/" | + "tet:information-source-entry/tet:connectivity-matrices/" | |||
+ "tet:connectivity-matrix/" | + "tet:connectivity-matrix/" | |||
+ "tet:path-properties/tet:path-route-objects/" | + "tet:path-properties/tet:path-route-objects/" | |||
+ "tet:path-route-object/tet:type/" | + "tet:path-route-object/tet:type/" | |||
+ "tet:label/tet:label-hop/tet:te-label/tet:technology" { | + "tet:label/tet:label-hop/tet:te-label/tet:technology" { | |||
when "../../../../../../../../../../../../../nw:network-types/" | when '../../../../../../../../../../nw:network-types/' | |||
+ "tet:te-topology/ex-topo:example-topology" { | + 'tet:te-topology/ex-topo:example-topology' { | |||
description | description | |||
"Augmentation parameters apply only for networks with | "Augmentation parameters apply only for networks with an | |||
example topology type."; | example topology type."; | |||
} | } | |||
case "example" { | case example { | |||
container example { | container example { | |||
description "Attributes for example technology."; | description | |||
"Attributes for the example technology."; | ||||
leaf label-1 { | leaf label-1 { | |||
type uint32; | type uint32; | |||
description "Label 1 for example technology."; | description | |||
"Label 1 for the example technology."; | ||||
} | } | |||
} | } | |||
} | } | |||
description "Augment TE label."; | description | |||
"Augmentation for the TE label."; | ||||
} | } | |||
/* Under tunnel-termination-point/local-link-connectivities */ | /* Under tunnel-termination-point/local-link-connectivities */ | |||
augment "/nw:networks/nw:network/nw:node/tet:te/" | augment "/nw:networks/nw:network/nw:node/tet:te/" | |||
+ "tet:tunnel-termination-point/tet:local-link-connectivities/" | + "tet:tunnel-termination-point/" | |||
+ "tet:label-restrictions/tet:label-restriction/tet:label-start/" | + "tet:local-link-connectivities/tet:label-restrictions/" | |||
+ "tet:te-label/tet:technology" { | + "tet:label-restriction/tet:label-start/tet:te-label/" | |||
when "../../../../../../../../nw:network-types/tet:te-topology/" | + "tet:technology" { | |||
+ "ex-topo:example-topology" { | when '../../../../../../../../nw:network-types/tet:te-topology/' | |||
+ 'ex-topo:example-topology' { | ||||
description | description | |||
"Augmentation parameters apply only for networks with | "Augmentation parameters apply only for networks with an | |||
example topology type."; | example topology type."; | |||
} | } | |||
case "example" { | case example { | |||
container example { | container example { | |||
description "Attributes for example technology."; | description | |||
"Attributes for the example technology."; | ||||
leaf label-1 { | leaf label-1 { | |||
type uint32; | type uint32; | |||
description "Label 1 for example technology."; | description | |||
"Label 1 for the example technology."; | ||||
} | } | |||
} | } | |||
} | } | |||
description "Augment TE label."; | description | |||
"Augmentation for the TE label."; | ||||
} | } | |||
augment "/nw:networks/nw:network/nw:node/tet:te/" | augment "/nw:networks/nw:network/nw:node/tet:te/" | |||
+ "tet:tunnel-termination-point/tet:local-link-connectivities/" | + "tet:tunnel-termination-point/" | |||
+ "tet:label-restrictions/tet:label-restriction/tet:label-end/" | + "tet:local-link-connectivities/tet:label-restrictions/" | |||
+ "tet:te-label/tet:technology" { | + "tet:label-restriction/tet:label-end/" | |||
when "../../../../../../../../nw:network-types/tet:te-topology/" | + "tet:te-label/tet:technology" { | |||
+ "ex-topo:example-topology" { | when '../../../../../../../../nw:network-types/tet:te-topology/' | |||
+ 'ex-topo:example-topology' { | ||||
description | description | |||
"Augmentation parameters apply only for networks with | "Augmentation parameters apply only for networks with an | |||
example topology type."; | example topology type."; | |||
} | } | |||
case "example" { | case example { | |||
container example { | container example { | |||
description "Attributes for example technology."; | description | |||
"Attributes for the example technology."; | ||||
leaf label-1 { | leaf label-1 { | |||
type uint32; | type uint32; | |||
description "Label 1 for example technology."; | description | |||
"Label 1 for the example technology."; | ||||
} | } | |||
} | } | |||
} | } | |||
description "Augment TE label."; | description | |||
"Augmentation for the TE label."; | ||||
} | } | |||
augment "/nw:networks/nw:network/nw:node/tet:te/" | augment "/nw:networks/nw:network/nw:node/tet:te/" | |||
+ "tet:tunnel-termination-point/tet:local-link-connectivities/" | + "tet:tunnel-termination-point/" | |||
+ "tet:underlay/tet:primary-path/tet:path-element/tet:type/" | + "tet:local-link-connectivities/tet:underlay/" | |||
+ "tet:label/tet:label-hop/tet:te-label/tet:technology" { | + "tet:primary-path/tet:path-element/tet:type/" | |||
when "../../../../../../../../../../../../nw:network-types/" | + "tet:label/tet:label-hop/tet:te-label/tet:technology" { | |||
+ "tet:te-topology/ex-topo:example-topology" { | when '../../../../../../../../../nw:network-types/' | |||
+ 'tet:te-topology/ex-topo:example-topology' { | ||||
description | description | |||
"Augmentation parameters apply only for networks with | "Augmentation parameters apply only for networks with an | |||
example topology type."; | example topology type."; | |||
} | } | |||
case "example" { | case example { | |||
container example { | container example { | |||
description "Attributes for example technology."; | description | |||
"Attributes for the example technology."; | ||||
leaf label-1 { | leaf label-1 { | |||
type uint32; | type uint32; | |||
description "Label 1 for example technology."; | description | |||
"Label 1 for the example technology."; | ||||
} | } | |||
} | } | |||
} | } | |||
description "Augment TE label."; | description | |||
"Augmentation for the TE label."; | ||||
} | } | |||
augment "/nw:networks/nw:network/nw:node/tet:te/" | augment "/nw:networks/nw:network/nw:node/tet:te/" | |||
+ "tet:tunnel-termination-point/tet:local-link-connectivities/" | + "tet:tunnel-termination-point/" | |||
+ "tet:underlay/tet:backup-path/tet:path-element/tet:type/" | + "tet:local-link-connectivities/tet:underlay/" | |||
+ "tet:label/tet:label-hop/tet:te-label/tet:technology" { | + "tet:backup-path/tet:path-element/tet:type/" | |||
when "../../../../../../../../../../../../nw:network-types/" | + "tet:label/tet:label-hop/tet:te-label/tet:technology" { | |||
+ "tet:te-topology/ex-topo:example-topology" { | when '../../../../../../../../../nw:network-types/' | |||
+ 'tet:te-topology/ex-topo:example-topology' { | ||||
description | description | |||
"Augmentation parameters apply only for networks with | "Augmentation parameters apply only for networks with an | |||
example topology type."; | example topology type."; | |||
} | } | |||
case "example" { | case example { | |||
container example { | container example { | |||
description "Attributes for example technology."; | description | |||
"Attributes for the example technology."; | ||||
leaf label-1 { | leaf label-1 { | |||
type uint32; | type uint32; | |||
description "Label 1 for example technology."; | description | |||
"Label 1 for the example technology."; | ||||
} | } | |||
} | } | |||
} | } | |||
description "Augment TE label."; | description | |||
"Augmentation for the TE label."; | ||||
} | } | |||
augment "/nw:networks/nw:network/nw:node/tet:te/" | augment "/nw:networks/nw:network/nw:node/tet:te/" | |||
+ "tet:tunnel-termination-point/tet:local-link-connectivities/" | + "tet:tunnel-termination-point/" | |||
+ "tet:path-properties/tet:path-route-objects/" | + "tet:local-link-connectivities/tet:path-properties/" | |||
+ "tet:path-route-object/tet:type/" | + "tet:path-route-objects/tet:path-route-object/tet:type/" | |||
+ "tet:label/tet:label-hop/tet:te-label/tet:technology" { | + "tet:label/tet:label-hop/tet:te-label/tet:technology" { | |||
when "../../../../../../../../../../../../nw:network-types/" | when '../../../../../../../../../nw:network-types/' | |||
+ "tet:te-topology/ex-topo:example-topology" { | + 'tet:te-topology/ex-topo:example-topology' { | |||
description | description | |||
"Augmentation parameters apply only for networks with | "Augmentation parameters apply only for networks with an | |||
example topology type."; | example topology type."; | |||
} | } | |||
case "example" { | case example { | |||
container example { | container example { | |||
description "Attributes for example technology."; | description | |||
"Attributes for the example technology."; | ||||
leaf label-1 { | leaf label-1 { | |||
type uint32; | type uint32; | |||
description "Label 1 for example technology."; | description | |||
"Label 1 for the example technology."; | ||||
} | } | |||
} | } | |||
} | } | |||
description "Augment TE label."; | description | |||
"Augmentation for the TE label."; | ||||
} | } | |||
/* Under tunnel-termination-point/.../local-link-connectivity */ | /* Under tunnel-termination-point/.../local-link-connectivity */ | |||
augment "/nw:networks/nw:network/nw:node/tet:te/" | augment "/nw:networks/nw:network/nw:node/tet:te/" | |||
+ "tet:tunnel-termination-point/tet:local-link-connectivities/" | + "tet:tunnel-termination-point/" | |||
+ "tet:local-link-connectivity/" | + "tet:local-link-connectivities/" | |||
+ "tet:label-restrictions/tet:label-restriction/tet:label-start/" | + "tet:local-link-connectivity/tet:label-restrictions/" | |||
+ "tet:te-label/tet:technology" { | + "tet:label-restriction/tet:label-start/" | |||
when "../../../../../../../../../nw:network-types/" | + "tet:te-label/tet:technology" { | |||
+ "tet:te-topology/ex-topo:example-topology" { | when '../../../../../../../../../nw:network-types/' | |||
+ 'tet:te-topology/ex-topo:example-topology' { | ||||
description | description | |||
"Augmentation parameters apply only for networks with | "Augmentation parameters apply only for networks with an | |||
example topology type."; | example topology type."; | |||
} | } | |||
case "example" { | case example { | |||
container example { | container example { | |||
description "Attributes for example technology."; | description | |||
"Attributes for the example technology."; | ||||
leaf label-1 { | leaf label-1 { | |||
type uint32; | type uint32; | |||
description "Label 1 for example technology."; | description | |||
"Label 1 for the example technology."; | ||||
} | } | |||
} | } | |||
} | } | |||
description "Augment TE label."; | description | |||
"Augmentation for the TE label."; | ||||
} | } | |||
augment "/nw:networks/nw:network/nw:node/tet:te/" | augment "/nw:networks/nw:network/nw:node/tet:te/" | |||
+ "tet:tunnel-termination-point/tet:local-link-connectivities/" | + "tet:tunnel-termination-point/" | |||
+ "tet:local-link-connectivity/" | + "tet:local-link-connectivities/" | |||
+ "tet:label-restrictions/tet:label-restriction/tet:label-end/" | + "tet:local-link-connectivity/tet:label-restrictions/" | |||
+ "tet:te-label/tet:technology" { | + "tet:label-restriction/tet:label-end/" | |||
when "../../../../../../../../../nw:network-types/" | + "tet:te-label/tet:technology" { | |||
+ "tet:te-topology/ex-topo:example-topology" { | when '../../../../../../../../../nw:network-types/' | |||
+ 'tet:te-topology/ex-topo:example-topology' { | ||||
description | description | |||
"Augmentation parameters apply only for networks with | "Augmentation parameters apply only for networks with an | |||
example topology type."; | example topology type."; | |||
} | } | |||
case "example" { | case example { | |||
container example { | container example { | |||
description "Attributes for example technology."; | description | |||
"Attributes for the example technology."; | ||||
leaf label-1 { | leaf label-1 { | |||
type uint32; | type uint32; | |||
description "Label 1 for example technology."; | description | |||
"Label 1 for the example technology."; | ||||
} | } | |||
} | } | |||
} | } | |||
description "Augment TE label."; | description | |||
"Augmentation for the TE label."; | ||||
} | } | |||
augment "/nw:networks/nw:network/nw:node/tet:te/" | augment "/nw:networks/nw:network/nw:node/tet:te/" | |||
+ "tet:tunnel-termination-point/tet:local-link-connectivities/" | + "tet:tunnel-termination-point/" | |||
+ "tet:local-link-connectivity/" | + "tet:local-link-connectivities/" | |||
+ "tet:underlay/tet:primary-path/tet:path-element/tet:type/" | + "tet:local-link-connectivity/tet:underlay/" | |||
+ "tet:label/tet:label-hop/tet:te-label/tet:technology" { | + "tet:primary-path/tet:path-element/tet:type/" | |||
when "../../../../../../../../../../../../../nw:network-types/" | + "tet:label/tet:label-hop/tet:te-label/tet:technology" { | |||
+ "tet:te-topology/ex-topo:example-topology" { | when '../../../../../../../../../../nw:network-types/' | |||
+ 'tet:te-topology/ex-topo:example-topology' { | ||||
description | description | |||
"Augmentation parameters apply only for networks with | "Augmentation parameters apply only for networks with an | |||
example topology type."; | example topology type."; | |||
} | } | |||
case "example" { | case example { | |||
container example { | container example { | |||
description "Attributes for example technology."; | description | |||
"Attributes for the example technology."; | ||||
leaf label-1 { | leaf label-1 { | |||
type uint32; | type uint32; | |||
description "Label 1 for example technology."; | description | |||
"Label 1 for the example technology."; | ||||
} | } | |||
} | } | |||
} | } | |||
description "Augment TE label."; | description | |||
"Augmentation for the TE label."; | ||||
} | } | |||
augment "/nw:networks/nw:network/nw:node/tet:te/" | augment "/nw:networks/nw:network/nw:node/tet:te/" | |||
+ "tet:tunnel-termination-point/tet:local-link-connectivities/" | + "tet:tunnel-termination-point/" | |||
+ "tet:local-link-connectivity/" | + "tet:local-link-connectivities/" | |||
+ "tet:underlay/tet:backup-path/tet:path-element/tet:type/" | + "tet:local-link-connectivity/tet:underlay/" | |||
+ "tet:label/tet:label-hop/tet:te-label/tet:technology" { | + "tet:backup-path/tet:path-element/tet:type/" | |||
when "../../../../../../../../../../../../nw:network-types/" | + "tet:label/tet:label-hop/tet:te-label/tet:technology" { | |||
+ "tet:te-topology/ex-topo:example-topology" { | when '../../../../../../../../../../nw:network-types/' | |||
+ 'tet:te-topology/ex-topo:example-topology' { | ||||
description | description | |||
"Augmentation parameters apply only for networks with | "Augmentation parameters apply only for networks with an | |||
example topology type."; | example topology type."; | |||
} | } | |||
case "example" { | case example { | |||
container example { | container example { | |||
description "Attributes for example technology."; | description | |||
"Attributes for the example technology."; | ||||
leaf label-1 { | leaf label-1 { | |||
type uint32; | type uint32; | |||
description "Label 1 for example technology."; | description | |||
"Label 1 for the example technology."; | ||||
} | } | |||
} | } | |||
} | } | |||
description "Augment TE label."; | description | |||
"Augmentation for the TE label."; | ||||
} | } | |||
augment "/nw:networks/nw:network/nw:node/tet:te/" | augment "/nw:networks/nw:network/nw:node/tet:te/" | |||
+ "tet:tunnel-termination-point/tet:local-link-connectivities/" | + "tet:tunnel-termination-point/" | |||
+ "tet:local-link-connectivity/" | + "tet:local-link-connectivities/" | |||
+ "tet:path-properties/tet:path-route-objects/" | + "tet:local-link-connectivity/tet:path-properties/" | |||
+ "tet:path-route-object/tet:type/" | + "tet:path-route-objects/tet:path-route-object/tet:type/" | |||
+ "tet:label/tet:label-hop/tet:te-label/tet:technology" { | + "tet:label/tet:label-hop/tet:te-label/tet:technology" { | |||
when "../../../../../../../../../../../../../nw:network-types/" | when '../../../../../../../../../../nw:network-types/' | |||
+ "tet:te-topology/ex-topo:example-topology" { | + 'tet:te-topology/ex-topo:example-topology' { | |||
description | description | |||
"Augmentation parameters apply only for networks with | "Augmentation parameters apply only for networks with an | |||
example topology type."; | example topology type."; | |||
} | } | |||
case "example" { | case example { | |||
container example { | container example { | |||
description "Attributes for example technology."; | description | |||
"Attributes for the example technology."; | ||||
leaf label-1 { | leaf label-1 { | |||
type uint32; | type uint32; | |||
description "Label 1 for example technology."; | description | |||
"Label 1 for the example technology."; | ||||
} | } | |||
} | } | |||
} | } | |||
description "Augment TE label."; | description | |||
"Augmentation for the TE label."; | ||||
} | } | |||
/* Under te-link-attributes */ | /* Under te-link-attributes */ | |||
augment "/nw:networks/nw:network/nt:link/tet:te/" | augment "/nw:networks/nw:network/nt:link/tet:te/" | |||
+ "tet:te-link-attributes/" | + "tet:te-link-attributes/" | |||
+ "tet:label-restrictions/tet:label-restriction/tet:label-start/" | + "tet:label-restrictions/tet:label-restriction/" | |||
+ "tet:te-label/tet:technology" { | + "tet:label-start/tet:te-label/tet:technology" { | |||
when "../../../../../../../nw:network-types/" | when '../../../../../../../nw:network-types/' | |||
+ "tet:te-topology/ex-topo:example-topology" { | + 'tet:te-topology/ex-topo:example-topology' { | |||
description | description | |||
"Augmentation parameters apply only for networks with | "Augmentation parameters apply only for networks with an | |||
example topology type."; | example topology type."; | |||
} | } | |||
case "example" { | case example { | |||
container example { | container example { | |||
description "Attributes for example technology."; | description | |||
"Attributes for the example technology."; | ||||
leaf label-1 { | leaf label-1 { | |||
type uint32; | type uint32; | |||
description "Label 1 for example technology."; | description | |||
"Label 1 for the example technology."; | ||||
} | } | |||
} | } | |||
} | } | |||
description "Augment TE label."; | description | |||
"Augmentation for the TE label."; | ||||
} | } | |||
augment "/nw:networks/nw:network/nt:link/tet:te/" | augment "/nw:networks/nw:network/nt:link/tet:te/" | |||
+ "tet:te-link-attributes/" | + "tet:te-link-attributes/tet:label-restrictions/" | |||
+ "tet:label-restrictions/tet:label-restriction/tet:label-end/" | + "tet:label-restriction/tet:label-end/" | |||
+ "tet:te-label/tet:technology" { | + "tet:te-label/tet:technology" { | |||
when "../../../../../../../nw:network-types/" | when '../../../../../../../nw:network-types/' | |||
+ "tet:te-topology/ex-topo:example-topology" { | + 'tet:te-topology/ex-topo:example-topology' { | |||
description | description | |||
"Augmentation parameters apply only for networks with | "Augmentation parameters apply only for networks with an | |||
example topology type."; | example topology type."; | |||
} | } | |||
case "example" { | case example { | |||
container example { | container example { | |||
description "Attributes for example technology."; | description | |||
"Attributes for the example technology."; | ||||
leaf label-1 { | leaf label-1 { | |||
type uint32; | type uint32; | |||
description "Label 1 for example technology."; | description | |||
"Label 1 for the example technology."; | ||||
} | } | |||
} | } | |||
} | } | |||
description "Augment TE label."; | description | |||
"Augmentation for the TE label."; | ||||
} | } | |||
augment "/nw:networks/nw:network/nt:link/tet:te/" | augment "/nw:networks/nw:network/nt:link/tet:te/" | |||
+ "tet:te-link-attributes/" | + "tet:te-link-attributes/tet:underlay/" | |||
+ "tet:underlay/tet:primary-path/tet:path-element/tet:type/" | + "tet:primary-path/tet:path-element/tet:type/" | |||
+ "tet:label/tet:label-hop/tet:te-label/tet:technology" { | + "tet:label/tet:label-hop/tet:te-label/tet:technology" { | |||
when "../../../../../../../../../../../nw:network-types/" | when '../../../../../../../../nw:network-types/' | |||
+ "tet:te-topology/ex-topo:example-topology" { | + 'tet:te-topology/ex-topo:example-topology' { | |||
description | description | |||
"Augmentation parameters apply only for networks with | "Augmentation parameters apply only for networks with an | |||
example topology type."; | example topology type."; | |||
} | } | |||
case "example" { | case example { | |||
container example { | container example { | |||
description "Attributes for example technology."; | description | |||
"Attributes for the example technology."; | ||||
leaf label-1 { | leaf label-1 { | |||
type uint32; | type uint32; | |||
description "Label 1 for example technology."; | description | |||
"Label 1 for the example technology."; | ||||
} | } | |||
} | } | |||
} | } | |||
description "Augment TE label."; | description | |||
"Augmentation for the TE label."; | ||||
} | } | |||
augment "/nw:networks/nw:network/nt:link/tet:te/" | augment "/nw:networks/nw:network/nt:link/tet:te/" | |||
+ "tet:te-link-attributes/" | + "tet:te-link-attributes/tet:underlay/" | |||
+ "tet:underlay/tet:backup-path/tet:path-element/tet:type/" | + "tet:backup-path/tet:path-element/tet:type/" | |||
+ "tet:label/tet:label-hop/tet:te-label/tet:technology" { | + "tet:label/tet:label-hop/tet:te-label/tet:technology" { | |||
when "../../../../../../../../../../nw:network-types/" | when '../../../../../../../../nw:network-types/' | |||
+ "tet:te-topology/ex-topo:example-topology" { | + 'tet:te-topology/ex-topo:example-topology' { | |||
description | description | |||
"Augmentation parameters apply only for networks with | "Augmentation parameters apply only for networks with an | |||
example topology type."; | example topology type."; | |||
} | } | |||
case "example" { | case example { | |||
container example { | container example { | |||
description "Attributes for example technology."; | description | |||
"Attributes for the example technology."; | ||||
leaf label-1 { | leaf label-1 { | |||
type uint32; | type uint32; | |||
description "Label 1 for example technology."; | description | |||
"Label 1 for the example technology."; | ||||
} | } | |||
} | } | |||
} | } | |||
description "Augment TE label."; | description | |||
"Augmentation for the TE label."; | ||||
} | } | |||
/* Under te-link information-source-entry */ | ||||
/* Under TE link information-source-entry */ | ||||
augment "/nw:networks/nw:network/nt:link/tet:te/" | augment "/nw:networks/nw:network/nt:link/tet:te/" | |||
+ "tet:information-source-entry/" | + "tet:information-source-entry/tet:label-restrictions/" | |||
+ "tet:label-restrictions/tet:label-restriction/tet:label-start/" | + "tet:label-restriction/tet:label-start/" | |||
+ "tet:te-label/tet:technology" { | + "tet:te-label/tet:technology" { | |||
when "../../../../../../../nw:network-types/" | when '../../../../../../../nw:network-types/' | |||
+ "tet:te-topology/ex-topo:example-topology" { | + 'tet:te-topology/ex-topo:example-topology' { | |||
description | description | |||
"Augmentation parameters apply only for networks with | "Augmentation parameters apply only for networks with an | |||
example topology type."; | example topology type."; | |||
} | } | |||
case "example" { | case example { | |||
container example { | container example { | |||
description "Attributes for example technology."; | description | |||
"Attributes for the example technology."; | ||||
leaf label-1 { | leaf label-1 { | |||
type uint32; | type uint32; | |||
description "Label 1 for example technology."; | description | |||
"Label 1 for the example technology."; | ||||
} | } | |||
} | } | |||
} | } | |||
description "Augment TE label."; | description | |||
"Augmentation for the TE label."; | ||||
} | } | |||
augment "/nw:networks/nw:network/nt:link/tet:te/" | augment "/nw:networks/nw:network/nt:link/tet:te/" | |||
+ "tet:information-source-entry/" | + "tet:information-source-entry/tet:label-restrictions/" | |||
+ "tet:label-restrictions/tet:label-restriction/tet:label-end/" | + "tet:label-restriction/tet:label-end/" | |||
+ "tet:te-label/tet:technology" { | + "tet:te-label/tet:technology" { | |||
when "../../../../../../../nw:network-types/" | when '../../../../../../../nw:network-types/' | |||
+ "tet:te-topology/ex-topo:example-topology" { | + 'tet:te-topology/ex-topo:example-topology' { | |||
description | description | |||
"Augmentation parameters apply only for networks with | "Augmentation parameters apply only for networks with an | |||
example topology type."; | example topology type."; | |||
} | } | |||
case "example" { | case example { | |||
container example { | container example { | |||
description "Attributes for example technology."; | description | |||
"Attributes for the example technology."; | ||||
leaf label-1 { | leaf label-1 { | |||
type uint32; | type uint32; | |||
description "Label 1 for example technology."; | description | |||
"Label 1 for the example technology."; | ||||
} | } | |||
} | } | |||
} | } | |||
description "Augment TE label."; | description | |||
"Augmentation for the TE label."; | ||||
} | } | |||
} | }]]></sourcecode> | |||
]]></artwork> | </section> | |||
</figure> | <section anchor="sect-a" numbered="false" toc="default"> | |||
</section> | <name>Acknowledgments</name> | |||
<t> | ||||
<section title="Acknowledgments" anchor="sect-a" numbered="no"><t> | The authors would like to thank <contact fullname="Lou Berger"/>, <contact fu | |||
The authors would like to thank Lou Berger, Sue Hares, Mazen Khaddam, | llname="Sue Hares"/>, <contact fullname="Mazen Khaddam"/>, | |||
Cyril Margaria and Zafar Ali for participating in design discussions | <contact fullname="Cyril Margaria"/>, and <contact fullname="Zafar Ali"/> for | |||
participating in design discussions | ||||
and providing valuable insights.</t> | and providing valuable insights.</t> | |||
</section> | ||||
<section numbered="false" anchor="contributors" toc="default"> | ||||
<name>Contributors</name> | ||||
<contact fullname="Sergio Belotti"> | ||||
<organization>Nokia</organization> | ||||
<address> | ||||
<email>sergio.belotti@nokia.com</email> | ||||
</address> | ||||
</contact> | ||||
</section> | <contact fullname="Dieter Beller"> | |||
<organization>Nokia</organization> | ||||
<section title="Contributors" numbered="no" anchor="contributors"><figure | <address> | |||
><artwork><![CDATA[ | <email>Dieter.Beller@nokia.com</email> | |||
Sergio Belotti | </address> | |||
Nokia | </contact> | |||
Email: sergio.belotti@nokia.com | ||||
Dieter Beller | ||||
Nokia | ||||
Email: Dieter.Beller@nokia.com | ||||
Carlo Perocchio | ||||
Ericsson | ||||
Email: carlo.perocchio@ericsson.com | ||||
Italo Busi | ||||
Huawei Technologies | ||||
Email: Italo.Busi@huawei.com | ||||
]]></artwork> | ||||
</figure> | ||||
</section> | ||||
</back> | <contact fullname="Carlo Perocchio"> | |||
<organization>Ericsson</organization> | ||||
<address> | ||||
<email>carlo.perocchio@ericsson.com</email> | ||||
</address> | ||||
</contact> | ||||
</rfc> | <contact fullname="Italo Busi"> | |||
<organization>Huawei Technologies</organization> | ||||
<address> | ||||
<email>Italo.Busi@huawei.com</email> | ||||
</address> | ||||
</contact> | ||||
</section> | ||||
</back> | ||||
</rfc> | ||||
End of changes. 1041 change blocks. | ||||
2813 lines changed or deleted | 3180 lines changed or added | |||
This html diff was produced by rfcdiff 1.45. The latest version is available from http://tools.ietf.org/tools/rfcdiff/ |