rfc9719xml2.original.xml | rfc9719.xml | |||
---|---|---|---|---|
<?xml version="1.0" encoding="iso-8859-1" ?> | <?xml version='1.0' encoding='UTF-8'?> | |||
<!--<!DOCTYPE rfc SYSTEM "rfc4748.dtd"> --> | ||||
<!DOCTYPE rfc SYSTEM 'rfc2629.dtd' [ | ||||
<!ENTITY rfc2119 PUBLIC '' 'http://xml.resource.org/public/rfc/bi | ||||
bxml/reference.RFC.2119.xml'> | ||||
<!ENTITY rfc2629 PUBLIC '' 'http://xml.resource.org/public/rfc/bibxml/refere | ||||
nce.RFC.2629.xml'> | ||||
<!ENTITY rfc3688 PUBLIC '' 'http://xml.resource.org/public/rfc/bibxml/refere | ||||
nce.RFC.3688.xml'> | ||||
<!ENTITY rfc5881 PUBLIC '' 'http://xml.resource.org/public/rfc/bibxml/refere | ||||
nce.RFC.5881.xml'> | ||||
<!ENTITY rfc6020 PUBLIC '' 'http://xml.resource.org/public/rfc/bibxml/refere | ||||
nce.RFC.6020.xml'> | ||||
<!ENTITY rfc6241 PUBLIC '' 'http://xml.resource.org/public/rfc/bibxml/refere | ||||
nce.RFC.6241.xml'> | ||||
<!ENTITY rfc6242 PUBLIC '' 'http://xml.resource.org/public/rfc/bibxml/refere | ||||
nce.RFC.6242.xml'> | ||||
<!ENTITY rfc6991 PUBLIC '' 'http://xml.resource.org/public/rfc/bibxml/ref | ||||
erence.RFC.6991.xml'> | ||||
<!ENTITY rfc7950 PUBLIC '' 'http://xml.resource.org/public/rfc/bibxml/ref | ||||
erence.RFC.7950.xml'> | ||||
<!ENTITY rfc8040 PUBLIC '' 'http://xml.resource.org/public/rfc/bibxml/refere | ||||
nce.RFC.8040.xml'> | ||||
<!ENTITY rfc8174 PUBLIC '' 'http://xml.resource.org/public/rfc/bibxml/refere | ||||
nce.RFC.8174.xml'> | ||||
<!ENTITY rfc8177 PUBLIC '' 'http://xml.resource.org/public/rfc/bibxml/refere | ||||
nce.RFC.8177.xml'> | ||||
<!ENTITY rfc8294 PUBLIC '' 'http://xml.resource.org/public/rfc/bibxml/refere | ||||
nce.RFC.8294.xml'> | ||||
<!ENTITY rfc8340 PUBLIC '' 'http://xml.resource.org/public/rfc/bibxml/refere | ||||
nce.RFC.8340.xml'> | ||||
<!ENTITY rfc8341 PUBLIC '' 'http://xml.resource.org/public/rfc/bibxml/refere | ||||
nce.RFC.8341.xml'> | ||||
<!ENTITY rfc8342 PUBLIC '' 'http://xml.resource.org/public/rfc/bibxml/refere | ||||
nce.RFC.8342.xml'> | ||||
<!ENTITY rfc8343 PUBLIC '' 'http://xml.resource.org/public/rfc/bibxml/refere | ||||
nce.RFC.8343.xml'> | ||||
<!ENTITY rfc8349 PUBLIC '' 'http://xml.resource.org/public/rfc/bibxml/refere | ||||
nce.RFC.8349.xml'> | ||||
<!ENTITY rfc8407 PUBLIC '' 'http://xml.resource.org/public/rfc/bibxml/refere | ||||
nce.RFC.8407.xml'> | ||||
<!ENTITY rfc8446 PUBLIC '' 'http://xml.resource.org/public/rfc/bibxml/refere | ||||
nce.RFC.8446.xml'> | ||||
<!ENTITY rfc8505 PUBLIC '' 'http://xml.resource.org/public/rfc/bibxml/refere | ||||
nce.RFC.8505.xml'> | ||||
<!ENTITY rfc8639 PUBLIC '' 'http://xml.resource.org/public/rfc/bibxml/refere | ||||
nce.RFC.8639.xml'> | ||||
<!ENTITY rfc8641 PUBLIC '' 'http://xml.resource.org/public/rfc/bibxml/refere | ||||
nce.RFC.8641.xml'> | ||||
<!ENTITY I-D.ietf-rift-rift PUBLIC '' 'http://xml.resource.org/public/rfc/bi | ||||
bxml3/reference.I-D.ietf-rift-rift.xml'> | ||||
]> | ||||
<?xml-stylesheet type='text/xsl' href='rfc2629.xslt' ?> | <!DOCTYPE rfc [ | |||
<!ENTITY nbsp " "> | ||||
<!ENTITY zwsp "​"> | ||||
<!ENTITY nbhy "‑"> | ||||
<!ENTITY wj "⁠"> | ||||
]> | ||||
<?rfc toc="yes"?> | <rfc xmlns:xi="http://www.w3.org/2001/XInclude" category="std" docName="draft-ie | |||
<?rfc symrefs="yes"?> | tf-rift-yang-17" number="9719" consensus="true" ipr="trust200902" obsoletes="" u | |||
<?rfc sortrefs="yes"?> | pdates="" submissionType="IETF" xml:lang="en" tocInclude="true" symRefs="true" s | |||
<?rfc disable-output-escaping="yes"?> | ortRefs="true" version="3"> | |||
<rfc category="std" docName="draft-ietf-rift-yang-17" | ||||
ipr="trust200902"> | ||||
<!-- ***** FRONT MATTER ***** --> | ||||
<front> | <front> | |||
<title abbrev="RIFT YANG Model">YANG Data Model for Routing in Fat Trees (RI | <title abbrev="RIFT YANG Data Model">YANG Data Model for Routing in Fat Tree | |||
FT)</title> | s (RIFT)</title> | |||
<seriesInfo name="RFC" value="9719"/> | ||||
<author fullname="Zheng Zhang" initials="Z" surname="Zhang"> | <author fullname="Zheng (Sandy) Zhang" initials="Z" surname="Zhang"> | |||
<organization>ZTE Corporation</organization> | <organization>ZTE Corporation</organization> | |||
<address> | <address> | |||
<postal> | ||||
<street></street> | ||||
<city></city> | ||||
<region></region> | ||||
<code></code> | ||||
<country></country> | ||||
</postal> | ||||
<email>zhang.zheng@zte.com.cn</email> | <email>zhang.zheng@zte.com.cn</email> | |||
</address> | </address> | |||
</author> | </author> | |||
<author fullname="Yuehua Wei" initials="Y" surname="Wei"> | ||||
<author fullname="Yuehua Wei" initials="Y" surname="Wei"> | ||||
<organization>ZTE Corporation</organization> | <organization>ZTE Corporation</organization> | |||
<address> | <address> | |||
<postal> | ||||
<street></street> | ||||
<city></city> | ||||
<region></region> | ||||
<code></code> | ||||
<country></country> | ||||
</postal> | ||||
<email>wei.yuehua@zte.com.cn</email> | <email>wei.yuehua@zte.com.cn</email> | |||
</address> | </address> | |||
</author> | </author> | |||
<author fullname="Shaowen Ma" initials="S" surname="Ma"> | ||||
<author fullname="Shaowen Ma" initials="S" surname="Ma"> | ||||
<organization>Google</organization> | <organization>Google</organization> | |||
<address> | <address> | |||
<postal> | ||||
<street></street> | ||||
<city></city> | ||||
<region></region> | ||||
<code></code> | ||||
<country></country> | ||||
</postal> | ||||
<email>mashaowen@gmail.com</email> | <email>mashaowen@gmail.com</email> | |||
</address> | </address> | |||
</author> | </author> | |||
<author fullname="Xufeng Liu" initials="X" surname="Liu"> | ||||
<author fullname="Xufeng Liu" initials="X" surname="Liu"> | ||||
<organization>Alef Edge</organization> | <organization>Alef Edge</organization> | |||
<address> | <address> | |||
<postal> | ||||
<street></street> | ||||
<city></city> | ||||
<region></region> | ||||
<code></code> | ||||
<country></country> | ||||
</postal> | ||||
<email>xufeng.liu.ietf@gmail.com</email> | <email>xufeng.liu.ietf@gmail.com</email> | |||
</address> | </address> | |||
</author> | </author> | |||
<author fullname="Bruno Rijsman" initials="B" surname="Rijsman"> | ||||
<author fullname="Bruno Rijsman" initials="B" surname="Rijsman"> | ||||
<organization>Individual</organization> | <organization>Individual</organization> | |||
<address> | <address> | |||
<postal> | ||||
<street></street> | ||||
<city></city> | ||||
<region></region> | ||||
<code></code> | ||||
<country></country> | ||||
</postal> | ||||
<email>brunorijsman@gmail.com</email> | <email>brunorijsman@gmail.com</email> | |||
</address> | </address> | |||
</author> | </author> | |||
<date year="2025" month="January"/> | ||||
<date year="2024"/> | <area>RTG</area> | |||
<area>Routing</area> | <workgroup>rift</workgroup> | |||
<workgroup>RIFT WG</workgroup> | <keyword>RIFT</keyword> | |||
<keyword>RIFT, YANG</keyword> | <keyword>YANG</keyword> | |||
<abstract> | <abstract> | |||
<t> | <t> | |||
This document defines a YANG data model for the configuration and | This document defines a YANG data model for the configuration and | |||
management of Routing in Fat Trees (RIFT) Protocol. The model is based on | management of the Routing in Fat Trees (RIFT) Protocol. The model is base | |||
YANG 1.1 as defined in | d on YANG 1.1, which is defined in | |||
RFC7950 and conforms to the Network Management Datastore Architecture | RFC 7950 and conforms to the Network Management Datastore Architecture | |||
(NMDA) as described in RFC8342. | (NMDA) as described in RFC 8342. | |||
</t> | </t> | |||
</abstract> | </abstract> | |||
</front> | </front> | |||
<!-- ***** MIDDLE MATTER ***** --> | ||||
<middle> | <middle> | |||
<section title="Introduction"> | <section numbered="true" toc="default"> | |||
<t>RFC Ed.: Please replace all occurrences of 'I-D.ietf-rift-rift' with th | <name>Introduction</name> | |||
e | <t><xref target="RFC9692" format="default"/> introduces the protocol defin | |||
actual RFC number of draft-ietf-rift-rift (and remove this note).</t> | ition of RIFT. | |||
This document defines one NMDA-compatible <xref target="RFC8342" format | ||||
<t><xref target="I-D.ietf-rift-rift"/> introduces the protocol definiti | ="default"/> YANG 1.1 | |||
on of RIFT. | <xref target="RFC7950" format="default"/> data model for the management of | |||
This document defines one NMDA compatible <xref target="RFC8342"/> YANG | the RIFT protocol. | |||
1.1 | This model imports and augments the ietf-routing YANG data model | |||
<xref target="RFC7950"/> model for the management of RIFT protocol. | defined in <xref target="RFC8349" format="default"/>.</t> | |||
This model imports and augments ietf-routing YANG model | <section numbered="true" toc="default"> | |||
defined in <xref target="RFC8349"/>.</t> | <name>Terminology</name> | |||
<t>The following terminology and abbreviations are used in this document | ||||
<section title="Terminology"> | and the defined model.</t> | |||
<t>The following terminologies and abbreviations are used in this document | <t>The content is copied from <xref target="RFC9692" format="default"/> | |||
and the defined model:</t> | for reading convenience.</t> | |||
<t>The content is copied from <xref target="I-D.ietf-rift-rift"/> for r | <dl newline="true"> | |||
eading convenience.</t> | <dt>Clos / Fat Tree:</dt><dd> This document uses the terms "Clos" and | |||
"Fat Tree" interchangeably where it always refers to a folded | ||||
<t>Clos/Fat Tree: It refers to a folded spine-and-leaf topology with | spine-and-leaf topology with possibly multiple Points of Delivery | |||
possibly multiple Points of Delivery (PoDs) and one or multiple | (PoDs) and one or multiple Top of Fabric (ToF) planes.</dd> | |||
Top of Fabric (ToF) planes. </t> | <dt>RIFT:</dt><dd>Routing in Fat Trees <xref target="RFC9692" format="de | |||
fault"/>.</dd> | ||||
<t>RIFT: Routing in Fat Trees <xref target="I-D.ietf-rift-rift"/>.</t> | <dt>LIE:</dt><dd>This is an acronym for a "Link Information Element" | |||
exchanged on all the system's links running RIFT to form <em>ThreeWay</e | ||||
<t>LIE: "Link Information Element" are exchanged on | m> | |||
all the system's links running RIFT to form ThreeWay adjacencies | adjacencies and carry information used to perform RIFT Zero Touch | |||
and carry information used to perform Zero Touch Provisioning | Provisioning (ZTP) of levels.</dd> | |||
(ZTP) of levels.</t> | <dt>Point of Delivery (PoD):</dt><dd>A self-contained vertical slice or | |||
subset of a Clos or Fat Tree | ||||
<t>PoD: "Point of Delivery" means a self-contained vertical slice or sub | network normally containing only level 0 and level 1 nodes. A | |||
set of a Clos or Fat Tree | ||||
network containing normally only level 0 and level 1 nodes. A | ||||
node in a PoD communicates with nodes in other PoDs via the ToF | node in a PoD communicates with nodes in other PoDs via the ToF | |||
nodes. PoDs are numbered to distinguish them and PoD value 0 is | nodes. PoDs are numbered to distinguish them, and PoD value 0 is | |||
used to denote "undefined" or "any" PoD.</t> | used to denote "undefined" or "any" PoD.</dd> | |||
<dt>ThreeWay Adjacency:</dt><dd> RIFT tries to form a unique | ||||
<t>ThreeWay Adjacency: A unique adjacency between two nodes over a | adjacency between two nodes over a point-to-point interface and | |||
point-to-point interface and exchange local configuration and | exchange local configuration and necessary RIFT ZTP information. An | |||
necessary RIFT ZTP information. An adjacency is only advertised | adjacency is only advertised in Node TIEs and used for computations | |||
in Node TIEs and used for computations after it achieved | after it achieved <em>ThreeWay</em> state, i.e., both routers | |||
ThreeWay state, i.e. both routers reflected each other in LIEs | reflected each other in LIEs, including relevant security | |||
including relevant security information. Nevertheless, LIEs | information. Nevertheless, LIEs before <em>ThreeWay</em> state is | |||
before ThreeWay state is reached may carry RIFT ZTP related | reached may carry RIFT ZTP related information already.</dd> | |||
information already.</t> | <dt>TIEs:</dt><dd>This is an acronym for a "Topology Information | |||
Element". TIEs are exchanged between RIFT nodes to describe parts of | ||||
<t>TIE: "Topology Information Element" are | a network such as links and address prefixes. A TIE has always a | |||
exchanged between RIFT nodes to describe parts of a network such | direction and a type. North TIEs (sometimes abbreviated as N-TIEs) are | |||
as links and address prefixes. A TIE has always a direction and a | used when dealing with TIEs in the northbound representation, and | |||
type. North TIEs (sometimes abbreviated as N-TIEs) are used when | South TIEs (sometimes abbreviated as S-TIEs) for the southbound | |||
dealing with TIEs in the northbound representation and South-TIEs | equivalent. TIEs have different types, such as node and prefix | |||
(sometimes abbreviated as S-TIEs) for the southbound equivalent. | TIEs.</dd> | |||
TIEs have different types such as node and prefix TIEs.</t> | <dt>Top of Fabric (ToF):</dt><dd>The set of nodes that provide | |||
inter-PoD communication and have no northbound adjacencies, i.e., are | ||||
<t>ToF: "Top of Fabric" is | at the "very top" of the fabric. ToF nodes do not belong to any PoD | |||
the set of nodes that provide inter-PoD communication and have no | and are assigned the default PoD value to indicate the equivalent of | |||
northbound adjacencies, i.e. are at the "very top" of the fabric. | "any" PoD.</dd> | |||
ToF nodes do not belong to any PoD and are assigned | </dl> | |||
default PoD value to indicate the equivalent of "any" PoD.</t> | </section> | |||
<section numbered="true" toc="default"> | ||||
</section> | <name>Conventions Used in This Document</name> | |||
<t> | ||||
<section title="Conventions Used in This Document"> | The key words "<bcp14>MUST</bcp14>", "<bcp14>MUST NOT</bcp14>", "<bcp14>REQU | |||
<t>The key words "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL NOT", | IRED</bcp14>", "<bcp14>SHALL</bcp14>", "<bcp14>SHALL | |||
"SHOULD", "SHOULD NOT", "RECOMMENDED", "NOT RECOMMENDED", "MAY", and | NOT</bcp14>", "<bcp14>SHOULD</bcp14>", "<bcp14>SHOULD NOT</bcp14>", "<bcp14> | |||
"OPTIONAL" in this document are to be interpreted as described in | RECOMMENDED</bcp14>", "<bcp14>NOT RECOMMENDED</bcp14>", | |||
BCP 14 <xref target="RFC2119"/> <xref target="RFC8174"/> | "<bcp14>MAY</bcp14>", and "<bcp14>OPTIONAL</bcp14>" in this document are to | |||
when, and only when, they appear in all capitals, as shown here.</t> | be interpreted as | |||
</section> | described in BCP 14 <xref target="RFC2119"/> <xref target="RFC8174"/> | |||
when, and only when, they appear in all capitals, as shown here. | ||||
<section title="Tree Diagrams"> | </t> | |||
<t>Tree diagrams used in this document follow the notation defined in <xre | </section> | |||
f target="RFC8340"/>.</t> | <section numbered="true" toc="default"> | |||
</section> | <name>Tree Diagrams</name> | |||
<t>Tree diagrams used in this document follow the notation defined in <x | ||||
<section title="Prefixes in Data Node Names"> | ref target="RFC8340" format="default"/>.</t> | |||
<t>In this document, names of data nodes, actions, and other data mod | </section> | |||
el | <section numbered="true" toc="default"> | |||
<name>Prefixes in Data Node Names</name> | ||||
<t>In this document, names of data nodes, actions, and other data model | ||||
objects are often used without a prefix, as long as it is clear from | objects are often used without a prefix, as long as it is clear from | |||
the context in which YANG module each name is defined. Otherwise, | the context in which YANG module each name is defined. Otherwise, | |||
names are prefixed using the standard prefix associated with the | names are prefixed using the standard prefix associated with the | |||
corresponding YANG module, as shown in Table 1.</t> | corresponding YANG module as shown in <xref target="TABLE_1"/>.</t> | |||
<table anchor="TABLE_1" align="center"> | ||||
<texttable anchor="TABLE_1" title=""> | <thead> | |||
<tr> | ||||
<ttcol align="left">Prefix</ttcol> | <th align="left">Prefix</th> | |||
<ttcol align="left">YANG module</ttcol> | <th align="left">YANG Module</th> | |||
<ttcol align="left">Reference</ttcol> | <th align="left">Reference</th> | |||
</tr> | ||||
<c>yang</c> | </thead> | |||
<c>ietf-yang-types</c> | <tbody> | |||
<c><xref target="RFC6991"/></c> | <tr> | |||
<td align="left">yang</td> | ||||
<c>inet</c> | <td align="left">ietf-yang-types</td> | |||
<c>ietf-inet-types</c> | <td align="left"> | |||
<c><xref target="RFC6991"/></c> | <xref target="RFC6991" format="default"/></td> | |||
</tr> | ||||
<c>rt</c> | <tr> | |||
<c>ietf-routing</c> | <td align="left">inet</td> | |||
<c><xref target="RFC8349"/></c> | <td align="left">ietf-inet-types</td> | |||
<td align="left"> | ||||
<c>if</c> | <xref target="RFC6991" format="default"/></td> | |||
<c>ietf-interfaces</c> | </tr> | |||
<c><xref target="RFC8343"/></c> | <tr> | |||
<td align="left">rt</td> | ||||
<c>rt-types</c> | <td align="left">ietf-routing</td> | |||
<c>ietf-routing-types</c> | <td align="left"> | |||
<c><xref target="RFC8294"/></c> | <xref target="RFC8349" format="default"/></td> | |||
</tr> | ||||
<c>iana-rt-types</c> | <tr> | |||
<c>iana-routing-types</c> | <td align="left">if</td> | |||
<c><xref target="RFC8294"/></c> | <td align="left">ietf-interfaces</td> | |||
<td align="left"> | ||||
<c>key-chain</c> | <xref target="RFC8343" format="default"/></td> | |||
<c>ietf-key-chain</c> | </tr> | |||
<c><xref target="RFC8177"/></c> | <tr> | |||
</texttable> | <td align="left">rt-types</td> | |||
<td align="left">ietf-routing-types</td> | ||||
<td align="left"> | ||||
<xref target="RFC8294" format="default"/></td> | ||||
</tr> | ||||
<tr> | ||||
<td align="left">iana-rt-types</td> | ||||
<td align="left">iana-routing-types</td> | ||||
<td align="left"> | ||||
<xref target="RFC8294" format="default"/></td> | ||||
</tr> | ||||
<tr> | ||||
<td align="left">key-chain</td> | ||||
<td align="left">ietf-key-chain</td> | ||||
<td align="left"> | ||||
<xref target="RFC8177" format="default"/></td> | ||||
</tr> | ||||
</tbody> | ||||
</table> | ||||
</section> | ||||
</section> | </section> | |||
<section numbered="true" toc="default"> | ||||
</section> | <name>Design of the Data Model</name> | |||
<section numbered="true" toc="default"> | ||||
<section title="Design of the Data Model"> | <name>Scope of Model</name> | |||
<section title="Scope of Model"> | <t>This model can be used to configure and manage the | |||
<t>This model can be used to configure and manage the | ||||
RIFT protocol. The operational state data and statistics | RIFT protocol. The operational state data and statistics | |||
can be retrieved by this model. The subscription and push | can be retrieved by this model. The subscription and push | |||
mechanism defined in <xref target="RFC8639"/> | mechanism defined in <xref target="RFC8639" format="default"/> | |||
and <xref target="RFC8641"/> can be implemented by | and <xref target="RFC8641" format="default"/> can be implemented by | |||
the user to subscribe to notifications on the data nodes in this | the user to subscribe to notifications on the data nodes in this | |||
model.</t> | model.</t> | |||
<t>The model contains all the basic configuration parameters to | ||||
<t>The model contains all the basic configuration parameters to operate | operate the protocol. Depending on the implementation choices, some | |||
the protocol. Depending on the implementation choices, | systems may not allow some of the advanced parameters to be | |||
some systems may not allow some of the advanced parameters to be | configurable. The occasionally implemented parameters are modeled as | |||
configurable. The occasionally implemented parameters are modeled as | optional features in this model. This model can be extended, and it | |||
optional features in this model. | has been structured in a way that such extensions can be conveniently | |||
This model can be extended, and it has been structured in a way that | made.</t> | |||
such extensions can be conveniently made.</t> | <t>The RIFT YANG module augments the /routing/control-plane-protocols/ | |||
control-plane-protocol path defined in the ietf-routing module. This | ||||
<t>The RIFT YANG module augments the /routing/control-plane-protocols/ | model augments the routing module to add RIFT as a control-plane | |||
control-plane-protocol path defined in the ietf-routing module. | protocol. It then offers the ability to create a list of instances, | |||
This model augments the routing module to add RIFT as a control plane protoco | which it does by declaring 'list rift'. Multiple instances of the | |||
l. | protocol are supported by the module by giving each instance a unique | |||
It then offers the ability to create a list of instances, which it does by de | name.</t> | |||
claring 'list rift'. | </section> | |||
Multiple instances of the protocol are supported by the module by giving each | <section numbered="true" toc="default"> | |||
instance a unique name.</t> | <name>Specification</name> | |||
</section> | <t> | |||
<section title="Specification"> | ||||
<t> | ||||
This model imports and augments ietf-routing YANG model | This model imports and augments ietf-routing YANG model | |||
defined in <xref target="RFC8349"/>. | defined in <xref target="RFC8349" format="default"/>. | |||
The container "rift" is the top level container in this data model. | The container "rift" is the top-level container in this data model. | |||
The container is expected to enable RIFT protocol functionality. | The container is expected to enable RIFT protocol functionality. | |||
</t> | </t> | |||
<t>The YANG data model defined in this document conforms to the Network | ||||
<t>The YANG data model defined in this document conforms to the Network | Management Datastore Architecture (NMDA) <xref target="RFC8342" format="defau | |||
Management Datastore Architecture (NMDA) <xref target="RFC8342"/>. | lt"/>. | |||
The operational state data is combined with the associated configuration | The operational state data is combined with the associated configuration | |||
data in the same hierarchy <xref target="RFC8407"/>.</t> | data in the same hierarchy <xref target="RFC8407" format="default"/>.</t> | |||
</section> | ||||
</section> | <section numbered="true" toc="default"> | |||
<name>Overview</name> | ||||
<section title="Overview"> | <t>The RIFT YANG module defined in this document has all the common | |||
<t>The RIFT YANG module defined in this document has all the common | ||||
building blocks for the RIFT protocol.</t> | building blocks for the RIFT protocol.</t> | |||
<t>At a high level, the RIFT YANG model is organized into five elements: | ||||
<t>The RIFT YANG module augments the /routing/control-plane-protocols/ | </t> | |||
control-plane-protocol path defined in the ietf-routing module. | <dl spacing="normal" newline="false"> | |||
This model augments the routing module to add RIFT as a control plane protoco | <dt>base protocol configuration --</dt> <dd>Configuration | |||
l. | affecting RIFT protocol-related operations.</dd> | |||
It then offers the ability to create a list of instances, which it does by de | <dt>interface configuration --</dt> <dd>Configuration affecting | |||
claring 'list rift'. | the interface operations.</dd> | |||
Multiple instances of the protocol are supported by the module by giving each | <dt>neighbor status --</dt> <dd>Information of neighbors.</dd> | |||
instance a unique name.</t> | <dt>database --</dt> <dd>Information of TIEs.</dd> | |||
<dt>statistics --</dt> <dd>Statistics of SPF, interface, and neighbo | ||||
<t>At a high level, RIFT YANG model is organized into five elements:</t> | r.</dd> | |||
<t> | </dl> | |||
<list style="symbols"> | <sourcecode type="yangtree"> | |||
<t>base protocol configuration -- configuration affecting RIFT | ||||
protocol-related operations.</t> | ||||
<t>interface configuration -- configuration affecting the interface oper | ||||
ations.</t> | ||||
<t>neigbor status -- information of neighbors.</t> | ||||
<t>database -- information of TIEs.</t> | ||||
<t>statistics-- statistics of SPF, interface and neighbor.</t> | ||||
</list> | ||||
</t> | ||||
<figure align="center"> | ||||
<artwork align="center"><![CDATA[ | ||||
module: ietf-rift | module: ietf-rift | |||
augment /rt:routing/rt:control-plane-protocols | augment /rt:routing/rt:control-plane-protocols | |||
/rt:control-plane-protocol: | /rt:control-plane-protocol: | |||
+--rw rift* [name] | +--rw rift* [name] | |||
+--rw name string | +--rw name string | |||
+--rw global | +--rw global | |||
| +--ro node-level? level | | +--ro node-level? level | |||
| +--rw system-id system-id | | +--rw system-id system-id | |||
| +--rw fabric-id? uint16 | | +--rw fabric-id? uint16 | |||
| +--rw pod? uint32 | | +--rw pod? uint32 | |||
skipping to change at line 482 ¶ | skipping to change at line 390 ¶ | |||
| | +--ro bfd-state? enumeration | | | +--ro bfd-state? enumeration | |||
| | +--ro outer-security-key-id? uint8 | | | +--ro outer-security-key-id? uint8 | |||
| | +--ro local-nonce? uint16 | | | +--ro local-nonce? uint16 | |||
| | +--ro remote-nonce? uint16 | | | +--ro remote-nonce? uint16 | |||
| | +---x clear-neighbor | | | +---x clear-neighbor | |||
| +---x clear-all-neighbors | | +---x clear-all-neighbors | |||
+--ro statistics | +--ro statistics | |||
| +--ro global | | +--ro global | |||
| | +--ro total-num-routes-north? | | | +--ro total-num-routes-north? | |||
| | | yang:zero-based-counter32 | | | | yang:zero-based-counter32 | |||
| | +--ro total-num-routes-sourth? | | | +--ro total-num-routes-south? | |||
| | yang:zero-based-counter32 | | | yang:zero-based-counter32 | |||
| +--ro spf-statistics* [spf-direction-type] | | +--ro spf-statistics* [spf-direction-type] | |||
| | +--ro spf-direction-type enumeration | | | +--ro spf-direction-type enumeration | |||
| | +--ro start-time? yang:date-and-time | | | +--ro start-time? yang:date-and-time | |||
| | +--ro end-time? yang:date-and-time | | | +--ro end-time? yang:date-and-time | |||
| | +--ro triggering-tie | | | +--ro triggering-tie | |||
| | | +--ro tie-direction-type? enumeration | | | | +--ro tie-direction-type? enumeration | |||
| | | +--ro originator? system-id | | | | +--ro originator? system-id | |||
| | | +--ro tie-type? enumeration | | | | +--ro tie-type? enumeration | |||
| | | +--ro tie-number? uint32 | | | | +--ro tie-number? uint32 | |||
skipping to change at line 729 ¶ | skipping to change at line 637 ¶ | |||
| +--ro remaining-lifetime? uint32 | | +--ro remaining-lifetime? uint32 | |||
+--ro neighbor-error | +--ro neighbor-error | |||
+--ro rift* [name] | +--ro rift* [name] | |||
+--ro name string | +--ro name string | |||
+--ro interfaces* [name] | +--ro interfaces* [name] | |||
+--ro link-id? uint32 | +--ro link-id? uint32 | |||
+--ro name if:interface-ref | +--ro name if:interface-ref | |||
+--ro neighbors* [system-id] | +--ro neighbors* [system-id] | |||
+--ro system-id system-id | +--ro system-id system-id | |||
+--ro node-level? level | +--ro node-level? level | |||
]]></artwork> | </sourcecode> | |||
<postamble></postamble> | <t keepWithPrevious="true"/> | |||
</figure> | </section> | |||
</section> | <section numbered="true" toc="default"> | |||
<name>RIFT Configuration</name> | ||||
<section title="RIFT configuration"> | <t> | |||
<t> | ||||
The RIFT configuration includes node global configuration and interface c onfiguration. | The RIFT configuration includes node global configuration and interface c onfiguration. | |||
Some features can be used to enhance protocol, such as BFD <xref target="R | Some features can be used to enhance protocols, such as BFD <xref target=" | |||
FC5881"/>, | RFC5881" format="default"/> with | |||
flooding-reducing section 6.3.9 <xref target="I-D.ietf-rift-rift"/>.</t | flooding reduction (<xref target="RFC9692" sectionFormat="of" section=" | |||
> | 6.3.9"/>).</t> | |||
</section> | </section> | |||
<section numbered="true" toc="default"> | ||||
<section title="RIFT States"> | <name>RIFT States</name> | |||
<t>The state data nodes include node, interface, neighbor and database infor | <t>The state data nodes include node, interface, neighbor, and database | |||
mation.</t> | information.</t> | |||
<t>YANG actions are defined to clear the connection of one specific neigh | <t>YANG actions are defined to clear the connection of one specific neig | |||
bor on an interface, | hbor on an interface, | |||
clear the connections of all neighbors on an interface, or clear some or all statistics.</t> | clear the connections of all neighbors on an interface, or clear some or all statistics.</t> | |||
</section> | ||||
<section numbered="true" toc="default"> | ||||
<name>Notifications</name> | ||||
<t>Unexpected TIE and neighbor layer errors should be notified.</t> | ||||
</section> | ||||
</section> | </section> | |||
<section numbered="true" toc="default"> | ||||
<name>RIFT YANG Module</name> | ||||
<t>This module references <xref target="RFC9692" format="default"/>, | ||||
<xref target="RFC5881" format="default"/>, <xref target="RFC6991" format="de | ||||
fault"/>, | ||||
<xref target="RFC8177" format="default"/>, <xref target="RFC8294" forma | ||||
t="default"/>, <xref target="RFC8343" format="default"/>, | ||||
<xref target="RFC8349" format="default"/>, <xref target="RFC8505" format="de | ||||
fault"/>, and | ||||
<xref target="IEEE8021AS" format="default"/>.</t> | ||||
<section title="Notifications"> | <!--[rfced] In the YANG module, please clarify "system id using pattern" | |||
<t>Unexpected TIE and neighbor's layer error should be notified.</t> | in the description of system-id. (In text as "System ID" to match | |||
</section> | RFC-to-be 9692.) | |||
</section> | Original: | |||
description | ||||
"This type defines RIFT system id using pattern, | ||||
the system id looks like: 0021.2FFF.FEB5.6E10"; | ||||
<section title="RIFT YANG model"> | Perhaps: | |||
<t>This module references <xref target="I-D.ietf-rift-rift"/>, | description | |||
<xref target="RFC5881"/>, <xref target="RFC6991"/>, | "This type defines the pattern for RIFT System IDs. | |||
<xref target="RFC8177"/>, <xref target="RFC8294"/>, <xref target="RFC83 | An example of a System ID is 0021.2FFF.FEB5.6E10."; | |||
43"/>, | --> | |||
<xref target="RFC8349"/>, <xref target="RFC8505"/>, | ||||
<xref target="IEEE8021AS"/>.</t> | ||||
<figure align="center"> | <!--[rfced] Please note that the YANG module has been updated per | |||
<artwork align="center"><![CDATA[ | the formatting option of pyang. Please let us know any concerns. | |||
<CODE BEGINS> file "ietf-rift@2024-08-16.yang" | --> | |||
<sourcecode name="ietf-rift@2025-01-15.yang" type="yang" markers="true"><! | ||||
[CDATA[ | ||||
module ietf-rift { | module ietf-rift { | |||
yang-version 1.1; | yang-version 1.1; | |||
namespace "urn:ietf:params:xml:ns:yang:ietf-rift"; | namespace "urn:ietf:params:xml:ns:yang:ietf-rift"; | |||
prefix rift; | prefix rift; | |||
import ietf-inet-types { | import ietf-inet-types { | |||
prefix "inet"; | prefix inet; | |||
reference | reference | |||
"RFC 6991: Common YANG Data Types"; | "RFC 6991: Common YANG Data Types"; | |||
} | } | |||
import ietf-yang-types { | import ietf-yang-types { | |||
prefix "yang"; | prefix yang; | |||
reference | reference | |||
"RFC 6991: Common YANG Data Types"; | "RFC 6991: Common YANG Data Types"; | |||
} | } | |||
import ietf-routing { | import ietf-routing { | |||
prefix "rt"; | prefix rt; | |||
reference | reference | |||
"RFC 8349: A YANG Data Model for Routing Management | "RFC 8349: A YANG Data Model for Routing Management | |||
(NMDA Version)"; | (NMDA Version)"; | |||
} | } | |||
import ietf-interfaces { | import ietf-interfaces { | |||
prefix "if"; | prefix if; | |||
reference | reference | |||
"RFC 8343: A YANG Data Model for Interface Management"; | "RFC 8343: A YANG Data Model for Interface Management"; | |||
} | } | |||
import ietf-routing-types { | import ietf-routing-types { | |||
prefix "rt-types"; | prefix rt-types; | |||
reference | reference | |||
"RFC 8294: Common YANG Data Types for the Routing Area"; | "RFC 8294: Common YANG Data Types for the Routing Area"; | |||
} | } | |||
import iana-routing-types { | import iana-routing-types { | |||
prefix "iana-rt-types"; | prefix iana-rt-types; | |||
reference | reference | |||
"RFC 8294: Common YANG Data Types for the Routing Area"; | "RFC 8294: Common YANG Data Types for the Routing Area"; | |||
} | } | |||
import ietf-key-chain { | import ietf-key-chain { | |||
prefix "key-chain"; | prefix key-chain; | |||
reference | reference | |||
"RFC 8177: YANG Data Model for Key Chains"; | "RFC 8177: YANG Data Model for Key Chains"; | |||
} | } | |||
organization | organization | |||
"IETF RIFT (Routing In Fat Trees) Working Group"; | "IETF RIFT (Routing In Fat Trees) Working Group"; | |||
contact | contact | |||
"WG Web: <https://datatracker.ietf.org/wg/rift/> | "WG Web: <https://datatracker.ietf.org/wg/rift/> | |||
WG List: <mailto:rift@ietf.org> | WG List: <mailto:rift@ietf.org> | |||
Editor: Zheng Zhang | Author: Zheng (Sandy) Zhang | |||
<mailto:zhang.zheng@zte.com.cn> | <mailto:zhang.zheng@zte.com.cn> | |||
Editor: Yuehua Wei | Author: Yuehua Wei | |||
<mailto:wei.yuehua@zte.com.cn> | <mailto:wei.yuehua@zte.com.cn> | |||
Editor: Shaowen Ma | Author: Shaowen Ma | |||
<mailto:mashaowen@gmail.com> | <mailto:mashaowen@gmail.com> | |||
Editor: Xufeng Liu | Author: Xufeng Liu | |||
<mailto:xufeng.liu.ietf@gmail.com> | <mailto:xufeng.liu.ietf@gmail.com> | |||
Editor: Bruno Rijsman | Author: Bruno Rijsman | |||
<mailto:brunorijsman@gmail.com>"; | <mailto:brunorijsman@gmail.com>"; | |||
// RFC Ed.: replace XXXX with actual RFC number and remove | ||||
// this note | ||||
description | description | |||
"This YANG module defines the generic configuration and | "This YANG module defines the generic configuration and | |||
operational state for the RIFT protocol common to all | operational state for the RIFT protocol common to all | |||
vendor implementations. It is intended that the module | vendor implementations. It is intended that the module | |||
will be extended by vendors to define vendor-specific | will be extended by vendors to define vendor-specific | |||
RIFT configuration parameters and policies -- | RIFT configuration parameters and policies -- | |||
for example, route maps or route policies. | for example, route maps or route policies. | |||
Copyright (c) 2024 IETF Trust and the persons identified as | Copyright (c) 2025 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 Revised BSD License set | the license terms contained in, the Revised 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 | |||
(https://trustee.ietf.org/license-info). | (https://trustee.ietf.org/license-info). | |||
This version of this YANG module is part of RFC XXXX | This version of this YANG module is part of RFC 9719 | |||
(https://www.rfc-editor.org/info/rfcXXXX); see the RFC itself | (https://www.rfc-editor.org/info/rfc9719); see the RFC itself | |||
for full legal notices. | for full legal notices. | |||
The key words 'MUST', 'MUST NOT', 'REQUIRED', 'SHALL', 'SHALL | The key words 'MUST', 'MUST NOT', 'REQUIRED', 'SHALL', 'SHALL | |||
NOT', 'SHOULD', 'SHOULD NOT', 'RECOMMENDED', 'NOT RECOMMENDED', | NOT', 'SHOULD', 'SHOULD NOT', 'RECOMMENDED', 'NOT RECOMMENDED', | |||
'MAY', and 'OPTIONAL' in this document are to be interpreted as | 'MAY', and 'OPTIONAL' in this document are to be interpreted as | |||
described in BCP 14 (RFC 2119) (RFC 8174) when, and only when, | described in BCP 14 (RFC 2119) (RFC 8174) when, and only when, | |||
they appear in all capitals, as shown here."; | they appear in all capitals, as shown here."; | |||
revision 2024-08-16 { | revision 2025-01-15 { | |||
description | description | |||
"Initial revision."; | "Initial revision."; | |||
reference | reference | |||
"RFCXXXX: YANG Data Model for Routing in Fat Trees | "RFC 9719: YANG Data Model for Routing in Fat Trees | |||
(RIFT)."; | (RIFT)."; | |||
} | } | |||
/* | /* | |||
* Features | * Features | |||
*/ | */ | |||
feature nonce-delta-adjust { | feature nonce-delta-adjust { | |||
description | description | |||
"Support weak nonce delta adjusting which is used in | "Support weak nonce delta adjusting that is used in | |||
security."; | security."; | |||
reference | reference | |||
"I-D.ietf-rift-rift: RIFT: Routing in Fat Trees. | "RFC 9692: RIFT: Routing in Fat Trees. | |||
Section 6.9."; | Section 6.9."; | |||
} | } | |||
feature label-switching { | feature label-switching { | |||
description | description | |||
"Support label switching for instance distinguishing."; | "Support label switching for instance distinguishing."; | |||
reference | reference | |||
"I-D.ietf-rift-rift: RIFT: Routing in Fat Trees. | "RFC 9692: RIFT: Routing in Fat Trees. | |||
Section 6.8.8"; | Section 6.8.8"; | |||
} | } | |||
feature tie-security { | feature tie-security { | |||
description | description | |||
"Support security function for the TIE exchange."; | "Support security function for the TIE exchange."; | |||
reference | reference | |||
"I-D.ietf-rift-rift: RIFT: Routing in Fat Trees. | "RFC 9692: RIFT: Routing in Fat Trees. | |||
Section 6.9.3."; | Section 6.9.3."; | |||
} | } | |||
feature link-security { | feature link-security { | |||
description | description | |||
"Support security function of link."; | "Support security function of link."; | |||
reference | reference | |||
"I-D.ietf-rift-rift: RIFT: Routing in Fat Trees. | "RFC 9692: RIFT: Routing in Fat Trees. | |||
Section 6.9."; | Section 6.9."; | |||
} | } | |||
typedef system-id { | typedef system-id { | |||
type string { | type string { | |||
pattern | pattern | |||
'[0-9A-Fa-f]{4}\.[0-9A-Fa-f]{4}\.[0-9A-Fa-f]{4}\.[0-9A-Fa-f]{4}'; | '[0-9A-Fa-f]{4}\.[0-9A-Fa-f]{4}\.[0-9A-Fa-f]{4}\.[0-9A-Fa-f]{4}'; | |||
} | } | |||
description | description | |||
"This type defines RIFT system id using pattern, | "This type defines the pattern for RIFT System IDs. | |||
the system id looks like: 0021.2FFF.FEB5.6E10"; | An example of a System ID is 0021.2FFF.FEB5.6E10."; | |||
} | } | |||
typedef level { | typedef level { | |||
type uint8 { | type uint8 { | |||
range "0 .. 24"; | range "0 .. 24"; | |||
} | } | |||
default "0"; | default "0"; | |||
description | description | |||
"The value of node level. | "The value of node level. | |||
Clos and Fat Tree networks are topologically partially | Clos and Fat Tree networks are topologically partially | |||
ordered graphs and 'level' denotes the set of nodes at | ordered graphs and 'level' denotes the set of nodes at | |||
the same height in such a network. | the same height in such a network. | |||
Nodes at the top level (i.e., ToF) are at the level with | Nodes at the top level (i.e., ToF) are at the level with | |||
the highest value and count down to the nodes | the highest value and count down to the nodes | |||
at the bottom level (i.e., leaf) with the lowest value. | at the bottom level (i.e., leaf) with the lowest value. | |||
In RIFT, Level 0 always indicates that a node is a leaf, | In RIFT, level 0 always indicates that a node is a leaf, | |||
but does not have to be level 0. | but does not have to be level 0. | |||
Level values can be configured manually or automatically | Level values can be configured manually or automatically | |||
derived."; | derived."; | |||
reference | reference | |||
"I-D.ietf-rift-rift: RIFT: Routing in Fat Trees. | "RFC 9692: RIFT: Routing in Fat Trees. | |||
Section 6.7."; | Section 6.7."; | |||
} | } | |||
typedef ieee802-1as-timestamp { | typedef ieee802-1as-timestamp { | |||
type uint64; | type uint64; | |||
units "seconds"; | units "seconds"; | |||
description | description | |||
"Timestamp per IEEE802.1AS. It is advertised with prefix | "Timestamp per IEEE802.1AS. It is advertised with prefix | |||
to achieve mobility."; | to achieve mobility."; | |||
reference | reference | |||
"I-D.ietf-rift-rift: RIFT: Routing in Fat Trees. Section 6.8.4. | "RFC 9692: RIFT: Routing in Fat Trees. Section 6.8.4. | |||
IEEE8021AS: Timing and Synchronization for Time-Sensitive | IEEE8021AS: Timing and Synchronization for Time-Sensitive | |||
Applications in Bridged Local Area Networks"; | Applications in Bridged Local Area Networks"; | |||
} | } | |||
/* | /* | |||
* Identity | * Identity | |||
*/ | */ | |||
identity rift { | identity rift { | |||
base rt:routing-protocol; | base rt:routing-protocol; | |||
description | description | |||
"Identity for the RIFT routing protocol."; | "Identity for the RIFT routing protocol."; | |||
reference | reference | |||
"I-D.ietf-rift-rift: RIFT: Routing in Fat Trees"; | "RFC 9692: RIFT: Routing in Fat Trees"; | |||
} | } | |||
/* | /* | |||
* Groupings | * Groupings | |||
*/ | */ | |||
grouping address-families { | grouping address-families { | |||
leaf-list address-families { | leaf-list address-families { | |||
type iana-rt-types:address-family; | type iana-rt-types:address-family; | |||
description | description | |||
"Indication which address families are up on the | "Indication which address families are up on the | |||
interface."; | interface."; | |||
} | } | |||
description | description | |||
"Containing address families on the interface."; | "Containing address families on the interface."; | |||
} | } | |||
grouping hierarchy-indications { | grouping hierarchy-indications { | |||
leaf hierarchy-indications { | leaf hierarchy-indications { | |||
type enumeration { | type enumeration { | |||
enum "leaf-only" { | enum leaf-only { | |||
description | description | |||
"The node will never leave the | "The node will never leave the | |||
'bottom of the hierarchy'. | 'bottom of the hierarchy'. | |||
When this value is set, the 'configured-level' | When this value is set, the 'configured-level' | |||
is the minimum level value."; | is the minimum level value."; | |||
} | } | |||
enum "leaf-only-and-leaf-2-leaf-procedures" { | enum leaf-only-and-leaf-2-leaf-procedures { | |||
description | description | |||
"This means leaf to leaf. | "This means leaf to leaf. | |||
When this value is set, the 'configured-level' | When this value is set, the 'configured-level' | |||
is the minimum level value."; | is the minimum level value."; | |||
} | } | |||
enum "top-of-fabric" { | enum top-of-fabric { | |||
description | description | |||
"The node is 'top of fabric'. | "The node is 'top of fabric'. | |||
When this value is set, the 'configured-level' | When this value is set, the 'configured-level' | |||
is the maximum level value."; | is the maximum level value."; | |||
} | } | |||
} | } | |||
description | description | |||
"The hierarchy indications of this node."; | "The hierarchy indications of this node."; | |||
} | } | |||
description | description | |||
"Flags indicating node configuration in case of ZTP"; | "Flags indicating node configuration in case of ZTP."; | |||
} | } | |||
grouping node-capability { | grouping node-capability { | |||
leaf proto-minor-ver { | leaf proto-minor-ver { | |||
type uint16; | type uint16; | |||
description | description | |||
"Represents the minor protocol encoding schema | "Represents the minor protocol encoding schema | |||
version of this node."; | version of this node."; | |||
} | } | |||
leaf flood-reduction { | leaf flood-reduction { | |||
skipping to change at line 1037 ¶ | skipping to change at line 947 ¶ | |||
"The hierarchy-indications of the node."; | "The hierarchy-indications of the node."; | |||
uses hierarchy-indications; | uses hierarchy-indications; | |||
} | } | |||
description | description | |||
"The supported capabilities of this node."; | "The supported capabilities of this node."; | |||
} | } | |||
grouping tie-type { | grouping tie-type { | |||
leaf tie-type { | leaf tie-type { | |||
type enumeration { | type enumeration { | |||
enum "illegal" { | enum illegal { | |||
description | description | |||
"The illegal TIE."; | "The illegal TIE."; | |||
} | } | |||
enum "min-tie-type" { | enum min-tie-type { | |||
description | description | |||
"The minimum TIE."; | "The minimum TIE."; | |||
} | } | |||
enum "node" { | enum node { | |||
description | description | |||
"The node TIE."; | "The node TIE."; | |||
} | } | |||
enum "prefix" { | enum prefix { | |||
description | description | |||
"The prefix TIE."; | "The prefix TIE."; | |||
} | } | |||
enum "positive-disaggregation-prefix" { | enum positive-disaggregation-prefix { | |||
description | description | |||
"The positive disaggregation prefix TIE."; | "The positive disaggregation prefix TIE."; | |||
} | } | |||
enum "negative-disaggregation-prefix" { | enum negative-disaggregation-prefix { | |||
description | description | |||
"The negative disaggregation prefix TIE."; | "The negative disaggregation prefix TIE."; | |||
} | } | |||
enum "pgp-prefix" { | enum pgp-prefix { | |||
description | description | |||
"The policy guide prefix TIE."; | "The policy guide prefix TIE."; | |||
} | } | |||
enum "key-value" { | enum key-value { | |||
description | description | |||
"The key value TIE."; | "The key value TIE."; | |||
} | } | |||
enum "external-prefix" { | enum external-prefix { | |||
description | description | |||
"The external prefix TIE."; | "The external prefix TIE."; | |||
} | } | |||
enum "positive-external-disaggregation-prefix" { | enum positive-external-disaggregation-prefix { | |||
description | description | |||
"The positive external disaggregation prefix TIE."; | "The positive external disaggregation prefix TIE."; | |||
} | } | |||
enum "max-tie-type" { | enum max-tie-type { | |||
description | description | |||
"The maximum TIE."; | "The maximum TIE."; | |||
} | } | |||
} | } | |||
description | description | |||
"The types of TIE."; | "The types of TIE."; | |||
} | } | |||
description | description | |||
"The types of TIE"; | "The types of TIE."; | |||
} | } | |||
grouping prefix-attribute { | grouping prefix-attribute { | |||
leaf metric { | leaf metric { | |||
type uint32; | type uint32; | |||
description | description | |||
"The metric of this prefix."; | "The metric of this prefix."; | |||
} | } | |||
leaf-list tags { | leaf-list tags { | |||
type uint64; | type uint64; | |||
description | description | |||
"The tags of this prefix."; | "The tags of this prefix."; | |||
} | } | |||
skipping to change at line 1122 ¶ | skipping to change at line 1031 ¶ | |||
description | description | |||
"As per RFC 8505, a sequence number called a | "As per RFC 8505, a sequence number called a | |||
Transaction ID (TID) with a prefix can be | Transaction ID (TID) with a prefix can be | |||
advertised."; | advertised."; | |||
reference | reference | |||
"RFC 8505: Registration Extensions for IPv6 over | "RFC 8505: Registration Extensions for IPv6 over | |||
Low-Power Wireless Personal Area Network (6LoWPAN) | Low-Power Wireless Personal Area Network (6LoWPAN) | |||
Neighbor Discovery"; | Neighbor Discovery"; | |||
} | } | |||
description | description | |||
"The prefix sequence attribute which can be advertised | "The prefix sequence attribute that can be advertised | |||
for mobility."; | for mobility."; | |||
reference | reference | |||
"I-D.ietf-rift-rift: RIFT: Routing in Fat Trees. | "RFC 9692: RIFT: Routing in Fat Trees. | |||
Section 6.8.4."; | Section 6.8.4."; | |||
} | } | |||
description | description | |||
"The monotonic clock for mobile addresses."; | "The monotonic clock for mobile addresses."; | |||
} | } | |||
leaf loopback { | leaf loopback { | |||
type boolean; | type boolean; | |||
description | description | |||
"If the value is set to 'true', it | "If the value is set to 'true', it | |||
indicates if the interface is a node loopback. | indicates if the interface is a node loopback. | |||
The node's loopback address can be injected into | The node's loopback address can be injected into | |||
North and South Prefix TIEs for node reachability."; | Prefix North and Prefix South TIEs for node reachability."; | |||
reference | reference | |||
"I-D.ietf-rift-rift: RIFT: Routing in Fat Trees. | "RFC 9692: RIFT: Routing in Fat Trees. | |||
Section 6.4."; | Section 6.4."; | |||
} | } | |||
leaf directly-attached { | leaf directly-attached { | |||
type boolean; | type boolean; | |||
description | description | |||
"If the value is set to 'true', it indicates that the | "If the value is set to 'true', it indicates that the | |||
prefix is directly attached, i.e. should be routed to | prefix is directly attached, i.e., should be routed to | |||
even if the node is in overload."; | even if the node is in overload."; | |||
} | } | |||
leaf from-link { | leaf from-link { | |||
type uint32; | type uint32; | |||
description | description | |||
"In case of locally originated prefixes, | "In case of locally originated prefixes, | |||
i.e. interface addresses this can describe which | i.e., interface addresses this can describe which | |||
link the address belongs to."; | link the address belongs to."; | |||
} | } | |||
leaf label { | leaf label { | |||
type uint32; | type uint32; | |||
description | description | |||
"Per prefix significant label."; | "Per prefix significant label."; | |||
reference | reference | |||
"I-D.ietf-rift-rift: RIFT: Routing in Fat Trees"; | "RFC 9692: RIFT: Routing in Fat Trees"; | |||
} | } | |||
description | description | |||
"The attributes of the prefix."; | "The attributes of the prefix."; | |||
} | } | |||
grouping security { | grouping security { | |||
leaf security-type { | leaf security-type { | |||
type enumeration { | type enumeration { | |||
enum public { | enum public { | |||
description | description | |||
"When using PKI (Public Key Infrastructure), | "When using Public Key Infrastructure (PKI), | |||
the public and shared key can be used to verify | the public and shared key can be used to verify | |||
the original packet exchanged with the neighbor."; | the original packet exchanged with the neighbor."; | |||
} | } | |||
enum private { | enum private { | |||
description | description | |||
"When using PKI (Public Key Infrastructure), | "When using Public Key Infrastructure (PKI), | |||
the private key can be used by the Security | the private key can be used by the Security | |||
fingerprint originating node to create the signature."; | fingerprint originating node to create the signature."; | |||
} | } | |||
} | } | |||
description | description | |||
"The security type."; | "The security type."; | |||
reference | reference | |||
"I-D.ietf-rift-rift: RIFT: Routing in Fat Trees. | "RFC 9692: RIFT: Routing in Fat Trees. | |||
Section 6.9."; | Section 6.9."; | |||
} | } | |||
leaf shared { | leaf shared { | |||
type boolean; | type boolean; | |||
description | description | |||
"When using PKI (Public Key Infrastructure), | "When using Public Key Infrastructure (PKI), | |||
if the key is shared."; | if the key is shared."; | |||
reference | reference | |||
"I-D.ietf-rift-rift: RIFT: Routing in Fat Trees. | "RFC 9692: RIFT: Routing in Fat Trees. | |||
Section 6.9."; | Section 6.9."; | |||
} | } | |||
choice auth-key-chain { | choice auth-key-chain { | |||
description | description | |||
"Key chain or explicit key parameter specification"; | "Key chain or explicit key parameter specification."; | |||
case auth-key-chain { | case auth-key-chain { | |||
leaf key-chain { | leaf key-chain { | |||
type key-chain:key-chain-ref; | type key-chain:key-chain-ref; | |||
description | description | |||
"key-chain name."; | "key-chain name."; | |||
reference | reference | |||
"RFC 8177: YANG Data Model for Key Chains"; | "RFC 8177: YANG Data Model for Key Chains"; | |||
} | } | |||
} | } | |||
case auth-key-explicit { | case auth-key-explicit { | |||
skipping to change at line 1244 ¶ | skipping to change at line 1152 ¶ | |||
leaf node-level { | leaf node-level { | |||
type level; | type level; | |||
config false; | config false; | |||
description | description | |||
"The level of this node."; | "The level of this node."; | |||
} | } | |||
leaf system-id { | leaf system-id { | |||
type system-id; | type system-id; | |||
mandatory true; | mandatory true; | |||
description | description | |||
"Each node is identified via a system-id which is 64 | "Each node is identified via a system-id that is 64 | |||
bits wide."; | bits wide."; | |||
} | } | |||
leaf fabric-id { | leaf fabric-id { | |||
type uint16; | type uint16; | |||
description | description | |||
"The optional id of the fabric."; | "The optional id of the fabric."; | |||
} | } | |||
leaf pod { | leaf pod { | |||
type uint32 { | type uint32 { | |||
range "1..max"; | range "1..max"; | |||
skipping to change at line 1314 ¶ | skipping to change at line 1222 ¶ | |||
type inet:ipv6-address-no-zone; | type inet:ipv6-address-no-zone; | |||
description | description | |||
"IPv6 address to be used."; | "IPv6 address to be used."; | |||
} | } | |||
description | description | |||
"IPv4 and/or IPv6 address to be used."; | "IPv4 and/or IPv6 address to be used."; | |||
} | } | |||
grouping lie-elements { | grouping lie-elements { | |||
leaf label { | leaf label { | |||
if-feature label-switching; | if-feature "label-switching"; | |||
type uint32; | type uint32; | |||
description | description | |||
"A locally significant, downstream assigned by | "A locally significant, downstream assigned by | |||
the neighbor, interface specific label which may | the neighbor, interface-specific label that may | |||
be advertised in its LIEs."; | be advertised in its LIEs."; | |||
reference | reference | |||
"I-D.ietf-rift-rift: RIFT: Routing in Fat Trees. | "RFC 9692: RIFT: Routing in Fat Trees. | |||
Section 6.8.8."; | Section 6.8.8."; | |||
} | } | |||
leaf you-are-flood-repeater { | leaf you-are-flood-repeater { | |||
type boolean; | type boolean; | |||
description | description | |||
"If the neighbor on this link is flooding repeater. | "If the neighbor on this link is flooding repeater. | |||
When this value is set to 'true', the value can be | When this value is set to 'true', the value can be | |||
carried in exchanged packet."; | carried in exchanged packet."; | |||
reference | reference | |||
"I-D.ietf-rift-rift: RIFT: Routing in Fat Trees. | "RFC 9692: RIFT: Routing in Fat Trees. | |||
Section 6.3.9."; | Section 6.3.9."; | |||
} | } | |||
leaf not-a-ztp-offer { | leaf not-a-ztp-offer { | |||
type boolean; | type boolean; | |||
description | description | |||
"When this value is set to 'true', the flag can be | "When this value is set to 'true', the flag can be | |||
carried in the LIE packet. When the value received | carried in the LIE packet. When the value received | |||
in the LIE from neighbor, it indicates the level on | in the LIE from neighbor, it indicates the level on | |||
the LIE MUST NOT be used to derive a ZTP level by | the LIE MUST NOT be used to derive a ZTP level by | |||
the receiving node."; | the receiving node."; | |||
reference | reference | |||
"I-D.ietf-rift-rift: RIFT: Routing in Fat Trees. | "RFC 9692: RIFT: Routing in Fat Trees. | |||
Section 6.7."; | Section 6.7."; | |||
} | } | |||
leaf you-are-sending-too-quickly { | leaf you-are-sending-too-quickly { | |||
type boolean; | type boolean; | |||
description | description | |||
"Can be optionally set to indicate to neighbor that | "Can be optionally set to indicate to neighbor that | |||
packet losses are seen on reception based on packet | packet losses are seen on reception based on packet | |||
numbers or the rate is too high. The receiver SHOULD | numbers or the rate is too high. The receiver SHOULD | |||
temporarily slow down flooding rates. When this value | temporarily slow down flooding rates. When this value | |||
is set to 'true', the flag can be carried in packet."; | is set to 'true', the flag can be carried in packet."; | |||
skipping to change at line 1391 ¶ | skipping to change at line 1299 ¶ | |||
description | description | |||
"A pair of local and remote link-id to identify a link | "A pair of local and remote link-id to identify a link | |||
between two nodes."; | between two nodes."; | |||
} // link-id-pair | } // link-id-pair | |||
grouping neighbor-node { | grouping neighbor-node { | |||
list link-id-pair { | list link-id-pair { | |||
key "remote-id"; | key "remote-id"; | |||
uses link-id-pair; | uses link-id-pair; | |||
description | description | |||
"The Multiple parallel links to this neighbor."; | "The multiple parallel links to this neighbor."; | |||
} | } | |||
leaf cost { | leaf cost { | |||
type uint32; | type uint32; | |||
description | description | |||
"The cost value advertised by the neighbor."; | "The cost value advertised by the neighbor."; | |||
} | } | |||
leaf bandwidth { | leaf bandwidth { | |||
type uint32; | type uint32; | |||
units "bits"; | units "bits"; | |||
description | description | |||
"Total bandwith to the neighbor, this will be | "Total bandwidth to the neighbor, this will be | |||
normally sum of the bandwidths of all the | normally sum of the bandwidths of all the | |||
parallel links."; | parallel links."; | |||
} | } | |||
container received-link-capabilities { | container received-link-capabilities { | |||
uses link-capabilities; | uses link-capabilities; | |||
description | description | |||
"The link capabilities advertised by the neighbor."; | "The link capabilities advertised by the neighbor."; | |||
} | } | |||
description | description | |||
"The neighbor information indicated in node TIE."; | "The neighbor information indicated in node TIE."; | |||
skipping to change at line 1473 ¶ | skipping to change at line 1381 ¶ | |||
the neighbors."; | the neighbors."; | |||
} | } | |||
leaf removed-from-consideration { | leaf removed-from-consideration { | |||
type boolean; | type boolean; | |||
description | description | |||
"If the value is set to 'true', it means that | "If the value is set to 'true', it means that | |||
the level value is not considered to be used."; | the level value is not considered to be used."; | |||
} | } | |||
leaf removal-reason { | leaf removal-reason { | |||
when "../removed-from-consideration='true'" { | when "../removed-from-consideration='true'" { | |||
description | description | |||
"The level value is not considered to be used."; | "The level value is not considered to be used."; | |||
} | } | |||
type string; | type string; | |||
description | description | |||
"The reason why this value is not considered to | "The reason why this value is not considered to | |||
be used."; | be used."; | |||
} | } | |||
description | description | |||
"The level offered to the interface from the neighbor. | "The level offered to the interface from the neighbor. | |||
And if the level value is considered to be used."; | And if the level value is considered to be used."; | |||
} | } | |||
container received-source-addr { | container received-source-addr { | |||
skipping to change at line 1530 ¶ | skipping to change at line 1438 ¶ | |||
} | } | |||
} | } | |||
description | description | |||
"The link is protected by established BFD session or not."; | "The link is protected by established BFD session or not."; | |||
} | } | |||
leaf outer-security-key-id { | leaf outer-security-key-id { | |||
type uint8; | type uint8; | |||
description | description | |||
"The received security key id from the neighbor."; | "The received security key id from the neighbor."; | |||
reference | reference | |||
"I-D.ietf-rift-rift: RIFT: Routing in Fat Trees. | "RFC 9692: RIFT: Routing in Fat Trees. | |||
Section 6.9.3."; | Section 6.9.3."; | |||
} | } | |||
description | description | |||
"The neighbor information."; | "The neighbor information."; | |||
} // neighbor | } // neighbor | |||
grouping link-direction-type { | grouping link-direction-type { | |||
leaf link-direction-type { | leaf link-direction-type { | |||
type enumeration { | type enumeration { | |||
enum illegal { | enum illegal { | |||
skipping to change at line 1603 ¶ | skipping to change at line 1511 ¶ | |||
description | description | |||
"The direction type of TIE."; | "The direction type of TIE."; | |||
} // tie-direction-type | } // tie-direction-type | |||
grouping spf-direction-type { | grouping spf-direction-type { | |||
leaf spf-direction-type { | leaf spf-direction-type { | |||
type enumeration { | type enumeration { | |||
enum n-spf { | enum n-spf { | |||
description | description | |||
"A reachability calculation that is progressing | "A reachability calculation that is progressing | |||
northbound, as example SPF that is using South | northbound, as example SPF that is using South | |||
Node TIEs only. Normally it progresses a single | Node TIEs only. Normally it progresses a single | |||
hop only and installs default routes."; | hop only and installs default routes."; | |||
} | } | |||
enum s-spf { | enum s-spf { | |||
description | description | |||
"A reachability calculation that is progressing | "A reachability calculation that is progressing | |||
southbound, as example SPF that is using North | southbound, as example SPF that is using North | |||
Node TIEs only."; | Node TIEs only."; | |||
} | } | |||
} | } | |||
config false; | config false; | |||
description | description | |||
skipping to change at line 1629 ¶ | skipping to change at line 1537 ¶ | |||
"The direction type of SPF calculation."; | "The direction type of SPF calculation."; | |||
} // spf-direction-type | } // spf-direction-type | |||
grouping tie-header { | grouping tie-header { | |||
uses tie-direction-type; | uses tie-direction-type; | |||
leaf originator { | leaf originator { | |||
type system-id; | type system-id; | |||
description | description | |||
"The originator's system-id of this TIE."; | "The originator's system-id of this TIE."; | |||
} | } | |||
uses tie-type; | uses tie-type; | |||
leaf tie-number { | leaf tie-number { | |||
type uint32; | type uint32; | |||
description | description | |||
"The number of this TIE"; | "The number of this TIE."; | |||
} | } | |||
leaf seq { | leaf seq { | |||
type uint64; | type uint64; | |||
description | description | |||
"The sequence number of a TIE."; | "The sequence number of a TIE."; | |||
reference | reference | |||
"I-D.ietf-rift-rift: RIFT: Routing in Fat Trees. | "RFC 9692: RIFT: Routing in Fat Trees. | |||
Section 6.3.1."; | Section 6.3.1."; | |||
} | } | |||
leaf size { | leaf size { | |||
type uint32; | type uint32; | |||
description | description | |||
"The size of this TIE."; | "The size of this TIE."; | |||
} | } | |||
leaf origination-time { | leaf origination-time { | |||
type ieee802-1as-timestamp; | type ieee802-1as-timestamp; | |||
description | description | |||
"Absolute timestamp when the TIE was generated. | "Absolute timestamp when the TIE was generated. | |||
This can be used on fabrics with synchronized | This can be used on fabrics with synchronized | |||
clock to prevent lifetime modification attacks."; | clock to prevent lifetime modification attacks."; | |||
} | } | |||
leaf origination-lifetime { | leaf origination-lifetime { | |||
type uint32; | type uint32; | |||
units seconds; | units "seconds"; | |||
description | description | |||
"Original lifetime when the TIE was generated. | "Original lifetime when the TIE was generated. | |||
This can be used on fabrics with synchronized clock | This can be used on fabrics with synchronized clock | |||
to prevent lifetime modification attacks."; | to prevent lifetime modification attacks."; | |||
} | } | |||
leaf remaining-lifetime { | leaf remaining-lifetime { | |||
type uint32; | type uint32; | |||
units seconds; | units "seconds"; | |||
description | description | |||
"The remaining lifetime of the TIE."; | "The remaining lifetime of the TIE."; | |||
} | } | |||
description | description | |||
"TIEs are exchanged between RIFT nodes to describe parts | "TIEs are exchanged between RIFT nodes to describe parts | |||
of a network such as links and address prefixes. | of a network such as links and address prefixes. | |||
This is the TIE header information."; | This is the TIE header information."; | |||
} // tie-header | } // tie-header | |||
/* | /* | |||
* Data nodes | * Data nodes | |||
*/ | */ | |||
augment "/rt:routing/rt:control-plane-protocols" | augment "/rt:routing/rt:control-plane-protocols" | |||
+ "/rt:control-plane-protocol" { | + "/rt:control-plane-protocol" { | |||
when "derived-from-or-self(rt:type, 'rift:rift')" { | when "derived-from-or-self(rt:type, 'rift:rift')" { | |||
description | description | |||
"This augment is only valid when routing protocol | "This augment is only valid when routing protocol | |||
instance type is 'RIFT'."; | instance type is 'RIFT'."; | |||
} | } | |||
description | description | |||
"RIFT ( Routing in Fat Trees ) YANG model."; | "RIFT ( Routing in Fat Trees ) YANG model."; | |||
list rift { | list rift { | |||
key "name"; | key "name"; | |||
leaf name { | leaf name { | |||
type string; | type string; | |||
description | description | |||
"The RIFT instance's name."; | "The RIFT instance's name."; | |||
} | } | |||
container global { | container global { | |||
description | description | |||
"The global configuration and status of | "The global configuration and status of | |||
this RIFT protocol instance."; | this RIFT protocol instance."; | |||
uses base-node-info; | uses base-node-info; | |||
leaf fabric-prefix { | leaf fabric-prefix { | |||
type inet:ip-prefix; | type inet:ip-prefix; | |||
description | description | |||
"The configured fabric prefix."; | "The configured fabric prefix."; | |||
} | } | |||
skipping to change at line 1769 ¶ | skipping to change at line 1671 ¶ | |||
description | description | |||
"Represents protocol encoding schema major version."; | "Represents protocol encoding schema major version."; | |||
} | } | |||
leaf proto-minor-ver { | leaf proto-minor-ver { | |||
type uint16; | type uint16; | |||
config false; | config false; | |||
mandatory true; | mandatory true; | |||
description | description | |||
"Represents protocol encoding schema minor version."; | "Represents protocol encoding schema minor version."; | |||
} | } | |||
container node-capabilities { | container node-capabilities { | |||
uses hierarchy-indications; | uses hierarchy-indications; | |||
leaf flood-reduction { | leaf flood-reduction { | |||
type boolean; | type boolean; | |||
description | description | |||
"If the node supports flood reduction function. | "If the node supports flood reduction function. | |||
If this value is set to 'true', it means that | If this value is set to 'true', it means that | |||
the flood reduction function is enabled."; | the flood reduction function is enabled."; | |||
reference | reference | |||
"I-D.ietf-rift-rift: RIFT: Routing in Fat Trees. | "RFC 9692: RIFT: Routing in Fat Trees. | |||
Section 6.3.8."; | Section 6.3.8."; | |||
} | } | |||
description | description | |||
"The node's capabilities."; | "The node's capabilities."; | |||
} | } | |||
leaf maximum-nonce-delta { | leaf maximum-nonce-delta { | |||
if-feature nonce-delta-adjust; | if-feature "nonce-delta-adjust"; | |||
type uint8 { | type uint8 { | |||
range "1..5"; | range "1..5"; | |||
} | } | |||
description | description | |||
"The configurable valid nonce delta value used for | "The configurable valid nonce delta value used for | |||
security. It is used as vulnerability window. | security. It is used as vulnerability window. | |||
If the nonces in received packet exceeds the range | If the nonces in received packet exceeds the range | |||
indicated by this value, the packet MUST be | indicated by this value, the packet MUST be | |||
discarded."; | discarded."; | |||
reference | reference | |||
"I-D.ietf-rift-rift: RIFT: Routing in Fat Trees. | "RFC 9692: RIFT: Routing in Fat Trees. | |||
Section 6.9.4."; | Section 6.9.4."; | |||
} | } | |||
leaf nonce-increasing-interval { | leaf nonce-increasing-interval { | |||
type uint16; | type uint16; | |||
units seconds; | units "seconds"; | |||
description | description | |||
"The configurable nonce increasing interval."; | "The configurable nonce increasing interval."; | |||
} | } | |||
leaf adjusted-lifetime { | leaf adjusted-lifetime { | |||
type rt-types:timer-value-seconds16; | type rt-types:timer-value-seconds16; | |||
units seconds; | units "seconds"; | |||
description | description | |||
"The adjusted lifetime may affect the TIE stability. | "The adjusted lifetime may affect the TIE stability. | |||
Be careful to change this parameter. | Be careful to change this parameter. | |||
This SHOULD be prohibited less than 2*purge-lifetime."; | This SHOULD be prohibited less than 2*purge-lifetime."; | |||
} | } | |||
container rx-lie-multicast-addr { | container rx-lie-multicast-addr { | |||
leaf ipv4 { | leaf ipv4 { | |||
type inet:ipv4-address; | type inet:ipv4-address; | |||
default "224.0.0.121"; | default "224.0.0.121"; | |||
description | description | |||
skipping to change at line 1872 ¶ | skipping to change at line 1771 ¶ | |||
receiving and sending."; | receiving and sending."; | |||
} | } | |||
leaf lie-tx-port { | leaf lie-tx-port { | |||
type inet:port-number; | type inet:port-number; | |||
default "914"; | default "914"; | |||
description | description | |||
"The UDP port of LIE packet sending. The default port | "The UDP port of LIE packet sending. The default port | |||
number is 914. The value can be set to other value | number is 914. The value can be set to other value | |||
associated with different RIFT instance."; | associated with different RIFT instance."; | |||
} | } | |||
container global-link-capabilities { | container global-link-capabilities { | |||
uses link-capabilities; | uses link-capabilities; | |||
description | description | |||
"The node default link capabilities. It can be | "The node default link capabilities. It can be | |||
overwritten by the configuration underneath interface | overwritten by the configuration underneath interface | |||
and neighbor."; | and neighbor."; | |||
} | } | |||
leaf tide-generation-interval { | leaf tide-generation-interval { | |||
type rt-types:timer-value-seconds16; | type rt-types:timer-value-seconds16; | |||
units seconds; | units "seconds"; | |||
description | description | |||
"The TIDE generation interval."; | "The TIDE generation interval."; | |||
} | } | |||
list tie-security { | list tie-security { | |||
if-feature tie-security; | if-feature "tie-security"; | |||
key "security-type"; | key "security-type"; | |||
uses security; | uses security; | |||
description | description | |||
"The security function used for the TIE exchange."; | "The security function used for the TIE exchange."; | |||
reference | reference | |||
"I-D.ietf-rift-rift: RIFT: Routing in Fat Trees. | "RFC 9692: RIFT: Routing in Fat Trees. | |||
Section 6.9.3."; | Section 6.9.3."; | |||
} | } | |||
leaf inner-security-key-id { | leaf inner-security-key-id { | |||
type uint8; | type uint8; | |||
description | description | |||
"The inner security key id for received packet | "The inner security key id for received packet | |||
checking."; | checking."; | |||
reference | reference | |||
"I-D.ietf-rift-rift: RIFT: Routing in Fat Trees. | "RFC 9692: RIFT: Routing in Fat Trees. | |||
Section 6.9.3."; | Section 6.9.3."; | |||
} | } | |||
leaf algorithm-type { | leaf algorithm-type { | |||
type enumeration { | type enumeration { | |||
enum spf { | enum spf { | |||
description | description | |||
"The algorithm is SPF."; | "The algorithm is SPF."; | |||
} | } | |||
enum all-path { | enum all-path { | |||
description | description | |||
"The algorithm is all-path."; | "The algorithm is all-path."; | |||
skipping to change at line 1930 ¶ | skipping to change at line 1825 ¶ | |||
"The possible algorithm types."; | "The possible algorithm types."; | |||
} | } | |||
container hal { | container hal { | |||
config false; | config false; | |||
leaf hal-value { | leaf hal-value { | |||
type level; | type level; | |||
description | description | |||
"The highest defined level value seen from all | "The highest defined level value seen from all | |||
valid level offers received."; | valid level offers received."; | |||
} | } | |||
leaf-list system-ids{ | leaf-list system-ids { | |||
type system-id; | type system-id; | |||
description | description | |||
"The node's system-id of the offered level comes | "The node's system-id of the offered level comes | |||
from."; | from."; | |||
} | } | |||
description | description | |||
"The highest defined level and the offered nodes set."; | "The highest defined level and the offered nodes set."; | |||
} | } | |||
leaf-list miscabled-links { | leaf-list miscabled-links { | |||
type uint32; | type uint32; | |||
config false; | config false; | |||
description | description | |||
"List of miscabled links."; | "List of miscabled links."; | |||
} | } | |||
leaf hop-limit { | leaf hop-limit { | |||
type uint8 { | type uint8 { | |||
range "1 | 255"; | range "1 | 255"; | |||
} | } | |||
default "1"; | default "1"; | |||
description | description | |||
"The IPv4 TTL or IPv6 HL used for LIE and TIE | "The IPv4 TTL or IPv6 HL used for LIE and TIE | |||
sending/receiving."; | sending/receiving."; | |||
} | } | |||
leaf maximum-clock-delta { | leaf maximum-clock-delta { | |||
type ieee802-1as-timestamp; | type ieee802-1as-timestamp; | |||
description | description | |||
"The maximum drift for the timestamp comparing."; | "The maximum drift for the timestamp comparing."; | |||
reference | reference | |||
"I-D.ietf-rift-rift: RIFT: Routing in Fat Trees. | "RFC 9692: RIFT: Routing in Fat Trees. | |||
Section 6.8.4."; | Section 6.8.4."; | |||
} | } | |||
} | } | |||
list interfaces { | list interfaces { | |||
key "name"; | key "name"; | |||
leaf link-id { | leaf link-id { | |||
type uint32; | type uint32; | |||
config false; | config false; | |||
description | description | |||
"The local id of this interface."; | "The local id of this interface."; | |||
} | } | |||
leaf name { | leaf name { | |||
type if:interface-ref; | type if:interface-ref; | |||
skipping to change at line 1996 ¶ | skipping to change at line 1887 ¶ | |||
type inet:port-number; | type inet:port-number; | |||
default "915"; | default "915"; | |||
description | description | |||
"The UDP port which is used to receive flooded | "The UDP port which is used to receive flooded | |||
TIEs. The default port number is 915. The value | TIEs. The default port number is 915. The value | |||
can be set to other value associated with different | can be set to other value associated with different | |||
RIFT instance."; | RIFT instance."; | |||
} | } | |||
leaf holdtime { | leaf holdtime { | |||
type rt-types:timer-value-seconds16; | type rt-types:timer-value-seconds16; | |||
units seconds; | units "seconds"; | |||
default "3"; | default "3"; | |||
description | description | |||
"The holding time of LIE."; | "The holding time of LIE."; | |||
} | } | |||
uses address-families; | uses address-families; | |||
container advertised-source-addr { | container advertised-source-addr { | |||
uses addresses; | uses addresses; | |||
description | description | |||
"The address used in the advertised LIE and TIE | "The address used in the advertised LIE and TIE | |||
packets."; | packets."; | |||
} | } | |||
uses link-direction-type; | uses link-direction-type; | |||
leaf broadcast-capable { | leaf broadcast-capable { | |||
type boolean; | type boolean; | |||
description | description | |||
"If LIE can be received by broadcast address."; | "If LIE can be received by broadcast address."; | |||
reference | reference | |||
"I-D.ietf-rift-rift: RIFT: Routing in Fat Trees. | "RFC 9692: RIFT: Routing in Fat Trees. | |||
Section 6.2."; | Section 6.2."; | |||
} | } | |||
leaf allow-horizontal-link { | leaf allow-horizontal-link { | |||
type boolean; | type boolean; | |||
description | description | |||
"If horizontal link adjacency is allowed."; | "If horizontal link adjacency is allowed."; | |||
} | } | |||
container security { | container security { | |||
if-feature link-security; | if-feature "link-security"; | |||
uses security; | uses security; | |||
description | description | |||
"The security function used for this interface."; | "The security function used for this interface."; | |||
reference | reference | |||
"I-D.ietf-rift-rift: RIFT: Routing in Fat Trees. | "RFC 9692: RIFT: Routing in Fat Trees. | |||
Section 6.9.3."; | Section 6.9.3."; | |||
} | } | |||
leaf security-checking { | leaf security-checking { | |||
type enumeration { | type enumeration { | |||
enum "no-checking" { | enum no-checking { | |||
description | description | |||
"The security envelope does not be checked."; | "The security envelope does not be checked."; | |||
} | } | |||
enum "permissive" { | enum permissive { | |||
description | description | |||
"The security envelope checking is permissive."; | "The security envelope checking is permissive."; | |||
} | } | |||
enum "loose" { | enum loose { | |||
description | description | |||
"The security envelope checking is loose."; | "The security envelope checking is loose."; | |||
} | } | |||
enum "strict" { | enum strict { | |||
description | description | |||
"The security envelope checking is strict."; | "The security envelope checking is strict."; | |||
} | } | |||
} | } | |||
description | description | |||
"The possible security checking types. | "The possible security checking types. | |||
Only one type can be set at the same time."; | Only one type can be set at the same time."; | |||
} | } | |||
leaf was-the-last-lie-accepted { | leaf was-the-last-lie-accepted { | |||
type boolean; | type boolean; | |||
config false; | config false; | |||
description | description | |||
"If the value is set to 'true', it means that | "If the value is set to 'true', it means that | |||
the most recently received LIE was accepted. | the most recently received LIE was accepted. | |||
If the LIE was rejected, the neighbor error | If the LIE was rejected, the neighbor error | |||
notifications should be used to find the reason."; | notifications should be used to find the reason."; | |||
} | } | |||
leaf last-lie-reject-reason { | leaf last-lie-reject-reason { | |||
skipping to change at line 2090 ¶ | skipping to change at line 1974 ¶ | |||
"The attributes advertised in the LIEs from | "The attributes advertised in the LIEs from | |||
this interface."; | this interface."; | |||
} | } | |||
container link-capabilities { | container link-capabilities { | |||
uses link-capabilities; | uses link-capabilities; | |||
description | description | |||
"The interface's link capabilities."; | "The interface's link capabilities."; | |||
} | } | |||
leaf state { | leaf state { | |||
type enumeration { | type enumeration { | |||
enum "one-way" { | enum one-way { | |||
description | description | |||
"The initial state."; | "The initial state."; | |||
} | } | |||
enum "two-way" { | enum two-way { | |||
description | description | |||
"Valid LIE received but not a ThreeWay LIE."; | "Valid LIE received but not a ThreeWay LIE."; | |||
} | } | |||
enum "three-way" { | enum three-way { | |||
description | description | |||
"Valid ThreeWay LIE received."; | "Valid ThreeWay LIE received."; | |||
} | } | |||
enum "multiple-neighbors-wait" { | enum multiple-neighbors-wait { | |||
description | description | |||
"More than two neighbors found in the same link."; | "More than two neighbors found in the same link."; | |||
} | } | |||
} | } | |||
config false; | config false; | |||
mandatory true; | mandatory true; | |||
description | description | |||
"The states of LIE finite state machine."; | "The states of LIE finite state machine."; | |||
reference | reference | |||
"I-D.ietf-rift-rift: RIFT: Routing in Fat Trees. | "RFC 9692: RIFT: Routing in Fat Trees. | |||
Section 6.2.1."; | Section 6.2.1."; | |||
} | } | |||
list neighbors { | list neighbors { | |||
key "system-id"; | key "system-id"; | |||
config false; | config false; | |||
uses base-node-info; | uses base-node-info; | |||
uses neighbor; | uses neighbor; | |||
leaf local-nonce { | leaf local-nonce { | |||
type uint16; | type uint16; | |||
description | description | |||
"The exchanged local nonce with this neighbor."; | "The exchanged local nonce with this neighbor."; | |||
} | } | |||
leaf remote-nonce { | leaf remote-nonce { | |||
type uint16; | type uint16; | |||
description | description | |||
"The exchanged remote nonce to this neighbor."; | "The exchanged remote nonce to this neighbor."; | |||
} | } | |||
skipping to change at line 2132 ¶ | skipping to change at line 2014 ¶ | |||
leaf local-nonce { | leaf local-nonce { | |||
type uint16; | type uint16; | |||
description | description | |||
"The exchanged local nonce with this neighbor."; | "The exchanged local nonce with this neighbor."; | |||
} | } | |||
leaf remote-nonce { | leaf remote-nonce { | |||
type uint16; | type uint16; | |||
description | description | |||
"The exchanged remote nonce to this neighbor."; | "The exchanged remote nonce to this neighbor."; | |||
} | } | |||
action clear-neighbor { | action clear-neighbor { | |||
description | description | |||
"Clears the connection to the neighbor."; | "Clears the connection to the neighbor."; | |||
} | } | |||
description | description | |||
"The neighbor's information."; | "The neighbor's information."; | |||
} | } | |||
action clear-all-neighbors { | action clear-all-neighbors { | |||
description | description | |||
"Clears all the connections to the neighbors | "Clears all the connections to the neighbors | |||
on this interface."; | on this interface."; | |||
} | } | |||
description | description | |||
"The interface information on this node."; | "The interface information on this node."; | |||
} // list interface | } // list interface | |||
container statistics { | container statistics { | |||
config false; | config false; | |||
container global { | container global { | |||
leaf total-num-routes-north { | leaf total-num-routes-north { | |||
type yang:zero-based-counter32; | type yang:zero-based-counter32; | |||
config false; | config false; | |||
description | description | |||
"The total number of north routes."; | "The total number of north routes."; | |||
} | } | |||
leaf total-num-routes-sourth { | leaf total-num-routes-south { | |||
type yang:zero-based-counter32; | type yang:zero-based-counter32; | |||
config false; | config false; | |||
description | description | |||
"The total number of sourth routes."; | "The total number of south routes."; | |||
} | } | |||
description | description | |||
"The global routes number."; | "The global routes number."; | |||
} | } | |||
list spf-statistics { | list spf-statistics { | |||
key "spf-direction-type"; | key "spf-direction-type"; | |||
uses spf-direction-type; | uses spf-direction-type; | |||
leaf start-time { | leaf start-time { | |||
type yang:date-and-time; | type yang:date-and-time; | |||
description | description | |||
"The last SPF calculation start time."; | "The last SPF calculation start time."; | |||
} | } | |||
leaf end-time { | leaf end-time { | |||
type yang:date-and-time; | type yang:date-and-time; | |||
description | description | |||
"The last SPF calculation end time."; | "The last SPF calculation end time."; | |||
} | } | |||
skipping to change at line 2191 ¶ | skipping to change at line 2065 ¶ | |||
leaf end-time { | leaf end-time { | |||
type yang:date-and-time; | type yang:date-and-time; | |||
description | description | |||
"The last SPF calculation end time."; | "The last SPF calculation end time."; | |||
} | } | |||
container triggering-tie { | container triggering-tie { | |||
uses tie-header; | uses tie-header; | |||
description | description | |||
"The TIE that triggered the SPF."; | "The TIE that triggered the SPF."; | |||
} | } | |||
action clear-spf-statistics { | action clear-spf-statistics { | |||
description | description | |||
"Clears the statistics of this type of | "Clears the statistics of this type of | |||
SPF calculation."; | SPF calculation."; | |||
} | } | |||
description | description | |||
"The statistics of SPF calculation."; | "The statistics of SPF calculation."; | |||
} | } | |||
list interfaces { | list interfaces { | |||
key "name"; | key "name"; | |||
leaf name { | leaf name { | |||
type if:interface-ref; | type if:interface-ref; | |||
description | description | |||
"The interface's name."; | "The interface's name."; | |||
} | } | |||
container intf-states-statistics { | container intf-states-statistics { | |||
leaf intf-states-startup-time { | leaf intf-states-startup-time { | |||
type uint64; | type uint64; | |||
description | description | |||
"The states and statistics record startup time | "The states and statistics record startup time | |||
of the interface."; | of the interface."; | |||
} | } | |||
leaf num-of-nbrs-3way { | leaf num-of-nbrs-3way { | |||
type yang:zero-based-counter32; | type yang:zero-based-counter32; | |||
description | description | |||
"The number of neighbors which state is in 3-way."; | "The number of neighbors which state is in | |||
ThreeWay."; | ||||
} | } | |||
leaf num-of-nbrs-down { | leaf num-of-nbrs-down { | |||
type yang:zero-based-counter32; | type yang:zero-based-counter32; | |||
description | description | |||
"The number of neighbors which state | "The number of neighbors which state | |||
changed to down."; | changed to down."; | |||
} | } | |||
list nbrs-down-reasons { | list nbrs-down-reasons { | |||
key "system-id"; | key "system-id"; | |||
leaf system-id { | leaf system-id { | |||
type system-id; | type system-id; | |||
description | description | |||
"The system-id of neighbor."; | "The system-id of neighbor."; | |||
} | } | |||
leaf last-down-reason { | leaf last-down-reason { | |||
type string; | type string; | |||
skipping to change at line 2272 ¶ | skipping to change at line 2143 ¶ | |||
config false; | config false; | |||
description | description | |||
"The last time of up."; | "The last time of up."; | |||
} | } | |||
leaf last-down { | leaf last-down { | |||
type yang:date-and-time; | type yang:date-and-time; | |||
config false; | config false; | |||
description | description | |||
"The last time of down."; | "The last time of down."; | |||
} | } | |||
container intf-lie-states { | container intf-lie-states { | |||
leaf last-lie-sent-time { | leaf last-lie-sent-time { | |||
type uint64; | type uint64; | |||
description | description | |||
"The time of the last LIE sent."; | "The time of the last LIE sent."; | |||
} | } | |||
leaf last-lie-received-time { | leaf last-lie-received-time { | |||
type uint64; | type uint64; | |||
description | description | |||
"The time of the last LIE received."; | "The time of the last LIE received."; | |||
} | } | |||
leaf num-lie-received { | leaf num-lie-received { | |||
type yang:zero-based-counter32; | type yang:zero-based-counter32; | |||
description | description | |||
"The number of received LIEs."; | "The number of received LIEs."; | |||
} | } | |||
leaf num-lie-transmitted { | leaf num-lie-transmitted { | |||
type yang:zero-based-counter32; | type yang:zero-based-counter32; | |||
description | description | |||
"The number of transmitted LIEs."; | "The number of transmitted LIEs."; | |||
} | } | |||
leaf num-lie-drop-invalid-envelope { | leaf num-lie-drop-invalid-envelope { | |||
type yang:zero-based-counter32; | type yang:zero-based-counter32; | |||
description | description | |||
"The number of dropped LIEs due to | "The number of dropped LIEs due to | |||
skipping to change at line 2584 ¶ | skipping to change at line 2443 ¶ | |||
config false; | config false; | |||
description | description | |||
"ToFs in the same plane. Only carried by ToF. | "ToFs in the same plane. Only carried by ToF. | |||
Multiple Node TIEs can carry disjoint sets of | Multiple Node TIEs can carry disjoint sets of | |||
ToFs which MUST be joined to form a single | ToFs which MUST be joined to form a single | |||
set."; | set."; | |||
} | } | |||
leaf fabric-id { | leaf fabric-id { | |||
type uint32; | type uint32; | |||
config false; | config false; | |||
description | description | |||
"The optional ID of the Fabric configured."; | "The optional ID of the Fabric configured."; | |||
} | } | |||
description | description | |||
"The node element information in this TIE."; | "The node element information in this TIE."; | |||
} // node | } // node | |||
container prefixes { | container prefixes { | |||
description | description | |||
"The prefix element information in this TIE."; | "The prefix element information in this TIE."; | |||
list prefixes { | list prefixes { | |||
key "prefix"; | key "prefix"; | |||
leaf prefix { | leaf prefix { | |||
type inet:ip-prefix; | type inet:ip-prefix; | |||
description | description | |||
"The prefix information."; | "The prefix information."; | |||
} | } | |||
skipping to change at line 2629 ¶ | skipping to change at line 2486 ¶ | |||
description | description | |||
"The information used to distinguish a Key/Value | "The information used to distinguish a Key/Value | |||
pair. When the type of kv is set to 'node', | pair. When the type of kv is set to 'node', | |||
node-element is making sense. When the type of | node-element is making sense. When the type of | |||
kv is set to other values except 'node', | kv is set to other values except 'node', | |||
prefix-info is making sense."; | prefix-info is making sense."; | |||
} // kv-store | } // kv-store | |||
} // ties | } // ties | |||
description | description | |||
"The TIEs information in database."; | "The TIEs information in database."; | |||
}// container database | } // container database | |||
description | description | |||
"RIFT configuration and state data."; | "RIFT configuration and state data."; | |||
}//rift | } //rift | |||
}//augment | } //augment | |||
/* | /* | |||
* Notifications | * Notifications | |||
*/ | */ | |||
notification error-set { | notification error-set { | |||
description | description | |||
"The errors notification of RIFT."; | "The errors notification of RIFT."; | |||
container tie-level-error { | container tie-level-error { | |||
description | description | |||
"The TIE errors notification of RIFT."; | "The TIE errors notification of RIFT."; | |||
list rift { | list rift { | |||
key "name"; | key "name"; | |||
leaf name { | leaf name { | |||
type string; | type string; | |||
description | description | |||
"The RIFT instance's name."; | "The RIFT instance's name."; | |||
} | } | |||
list ties { | list ties { | |||
key "originator"; | key "originator"; | |||
uses tie-header; | uses tie-header; | |||
skipping to change at line 2709 ¶ | skipping to change at line 2566 ¶ | |||
} | } | |||
description | description | |||
"The interfaces with wrong level neighbor."; | "The interfaces with wrong level neighbor."; | |||
} | } | |||
description | description | |||
"The RIFT instance."; | "The RIFT instance."; | |||
} | } | |||
} | } | |||
} | } | |||
} | } | |||
<CODE ENDS> | ]]></sourcecode> | |||
]]></artwork> | <t keepWithPrevious="true"/> | |||
<postamble></postamble> | ||||
</figure> | ||||
</section> | </section> | |||
<section numbered="true" toc="default"> | ||||
<name>Security Considerations</name> | ||||
<!-- DNE begins --> | ||||
<t>The YANG module specified in this document defines a schema for data | ||||
that is designed to be accessed via network management protocols such 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 transport | ||||
is Secure Shell (SSH) <xref target="RFC6242" format="default"/>. The | ||||
lowest RESTCONF layer is HTTPS, and the mandatory-to-implement secure | ||||
transport is TLS <xref target="RFC8446" format="default"/>.</t> | ||||
<section title="Security Considerations"> | <t>The Network Configuration Access Control Model <xref target="RFC8341" | |||
<t>The YANG module specified in this document defines a schema for data | format="default"/> provides the means to restrict access for particular | |||
that is designed to be accessed via network management protocols such | NETCONF or RESTCONF users to a preconfigured subset of all available | |||
as NETCONF <xref target="RFC6241"/> or RESTCONF <xref target="RFC8040"/>. | NETCONF or RESTCONF protocol operations and content.</t> | |||
The lowest NETCONF layer is the secure transport layer, and the | ||||
mandatory-to-implement secure transport is Secure Shell (SSH) <xref target="R | ||||
FC6242"/>. | ||||
The lowest RESTCONF layer is HTTPS, and the mandatory-to-implement secure | ||||
transport is TLS <xref target="RFC8446"/>.</t> | ||||
<t>The Network Configuration Access Control Model <xref target="RFC8341"/> pr | ||||
ovides the means to | ||||
restrict access for particular NETCONF or RESTCONF users to a | ||||
preconfigured subset of all available NETCONF or RESTCONF protocol | ||||
operations and content.</t> | ||||
<t>There are a number of data nodes defined in this YANG module that are | ||||
writable/creatable/deletable (i.e., config true, which is the | ||||
default). These data nodes may be considered sensitive or vulnerable | ||||
in some network environments. Write operations (e.g., edit-config) | ||||
to these data nodes without proper protection can have a negative | ||||
effect on network operations. Writable data node represent | ||||
configuration of each instance, node, interface, etc. | ||||
These correspond to the following schema node:</t> | ||||
<t> | ||||
<list style="symbols"> | ||||
<t>/rift</t> | ||||
</list> | ||||
</t> | ||||
<t>Modifying the configuration may cause all the RIFT neighborship to be reb | <t>There are a number of data nodes defined in this YANG module that are | |||
uilt. | writable/creatable/deletable (i.e., config true, which is the default). These | |||
For example, the configuration changing of configured-level or system-id w | data nodes may be considered sensitive or vulnerable in some network | |||
ill lead to all the neighbor connections of this node rebuilt. | environments. Write operations (e.g., edit-config) to these data nodes | |||
The incorrect modification of authentication, except for the neighbor conn | without proper protection can have a negative effect on network operations. | |||
ection broken, will | These are the subtrees and data nodes and their sensitivity/vulnerability:</t | |||
lead to the permanent connection broken. The modification of interface wil | > | |||
l lead to the neighbor state changing. | <!-- DNE ends --> | |||
In general, unauthorized modification of most RIFT configurations will pos | ||||
e their own | ||||
set of security risks and the "Security Considerations" in the | ||||
respective reference RFCs should be consulted.</t> | ||||
<t>Some of the readable data nodes in this YANG module may be considered | <ul spacing="normal"> | |||
<li> | ||||
<t>/rift</t> | ||||
</li> | ||||
</ul> | ||||
<t>Modifying the configuration may cause all the RIFT neighborships to | ||||
be rebuilt. For example, changing the configuration of configured-level | ||||
or system-id will lead to all the neighbor connections of this node | ||||
being rebuilt. The incorrect modification of authentication, except for | ||||
the broken neighbor connection, will break the connection permanently. | ||||
The modification of interface will cause the neighbor state to change. | ||||
In general, unauthorized modification of most RIFT configurations will | ||||
pose their own set of security risks and the "Security Considerations" | ||||
in the respective RFCs referenced should be consulted.</t> | ||||
<t>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> | <li> | |||
<list style="symbols"> | <t>/rift</t> | |||
<t>/rift</t> | </li> | |||
<t>/rift/global/tie-security</t> | <li> | |||
<t>/rift/interface</t> | <t>/rift/global/tie-security</t> | |||
<t>/rift/interface/neighbor</t> | </li> | |||
<t>/rift/database</t> | <li> | |||
</list> | <t>/rift/interface</t> | |||
</t> | </li> | |||
<li> | ||||
<t>The exposure of the database will expose the detailed topology | <t>/rift/interface/neighbor</t> | |||
</li> | ||||
<li> | ||||
<t>/rift/database</t> | ||||
</li> | ||||
</ul> | ||||
<t>The exposure of the database will expose the detailed topology | ||||
of the network. Network operators may consider their topologies | of the network. Network operators may consider their topologies | |||
to be sensitive confidential data.</t> | to be sensitive confidential data.</t> | |||
<t>For RIFT authentication, configuration is supported via the | ||||
<t>For RIFT authentication, configuration is supported via the | specification of key chains <xref target="RFC8177" format="default"/> or the | |||
specification of key-chains <xref target="RFC8177"/> or the direct | direct | |||
specification of key and authentication algorithm. | specification of key and authentication algorithm. | |||
Hence, authentication configuration inherits the security | Hence, authentication configuration inherits the security | |||
considerations of <xref target="RFC8177"/>. This includes the | considerations of <xref target="RFC8177" format="default"/>. This includes t he | |||
considerations with respect to the | considerations with respect to the | |||
local storage and handling of authentication keys.</t> | local storage and handling of authentication keys.</t> | |||
<t>The actual authentication key data (whether locally specified | ||||
<t>The actual authentication key data (whether locally specified | ||||
or part of a key chain) is sensitive and needs to be kept secret | or part of a key chain) is sensitive and needs to be kept secret | |||
from unauthorized parties; compromise of the key data would allow | from unauthorized parties. Compromise of the key data would allow | |||
an attacker to forge RIFT packet that would be accepted as | an attacker to forge RIFT packets that would be accepted as | |||
authentic, potentially compromising the entire domain.</t> | authentic, potentially compromising the entire domain.</t> | |||
<t>Some of the RPC operations in this YANG module may be considered | ||||
<t>Some of the RPC operations 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 access to these operations. Specifically, | important to control access to these operations. | |||
the following operations have particular sensitivities/ | These are the operations and their sensitivity/vulnerability:</t> | |||
vulnerabilities:</t> | <ul spacing="normal"> | |||
<li> | ||||
<t> | <t>/rift/interface/clear-all-neighbors</t> | |||
<list style="symbols"> | </li> | |||
<t>/rift/interface/clear-all-neighbors</t> | <li> | |||
<t>/rift/interface/neighbor/clear-neighbor</t> | <t>/rift/interface/neighbor/clear-neighbor</t> | |||
<t>/rift/statistics/spf-statistics/clear-spf-statistics</t> | </li> | |||
<t>/rift/statistics/interface/clear-intf-statistics</t> | <li> | |||
<t>/rift/statistics/interface/neighbors/clear-nbr-statistics</t> | <t>/rift/statistics/spf-statistics/clear-spf-statistics</t> | |||
</list> | </li> | |||
</t> | <li> | |||
<t>/rift/statistics/interface/clear-intf-statistics</t> | ||||
<t>Unauthorized access to either of the above action operations can | </li> | |||
<li> | ||||
<t>/rift/statistics/interface/neighbors/clear-nbr-statistics</t> | ||||
</li> | ||||
</ul> | ||||
<t>Unauthorized access to either of the above action operations can | ||||
lead to the neighbor connection rebuilding or clearing of | lead to the neighbor connection rebuilding or clearing of | |||
statistics on this device.</t> | statistics on this device.</t> | |||
</section> | ||||
</section> | <section numbered="true" toc="default"> | |||
<name>IANA Considerations</name> | ||||
<section title="IANA Considerations"> | <t>Per this document, IANA has registered a URI in the IETF XML registry | |||
<t>RFC Ed.: Please replace all occurrences of 'XXXX' with the | <xref target="RFC3688" format="default"/>. | |||
actual RFC number (and remove this note).</t> | Following the format in <xref target="RFC3688" format="default"/>, the follow | |||
ing | ||||
<t>This document registers a URI in the IETF XML registry | registration has been made:</t> | |||
<xref target="RFC3688"/>. | <dl newline="false" spacing="compact"> | |||
Following the format in <xref target="RFC3688"/>, the following | <dt>URI:</dt> <dd>urn:ietf:params:xml:ns:yang:ietf-rift</dd> | |||
registration is requested to be made:</t> | <dt>Registrant Contact:</dt> <dd>The IESG</dd> | |||
<dt>XML:</dt> <dd>N/A; the requested URI is an XML namespace.</dd> | ||||
<t>URI: urn:ietf:params:xml:ns:yang:ietf-rift</t> | </dl> | |||
<t>Registrant Contact: The IESG</t> | <t>One new YANG module name has been registered in the YANG | |||
<t>XML: N/A, the requested URI is an XML namespace.</t> | Module Names registry <xref target="RFC6020" format="default"/> as follows:</ | |||
t> | ||||
<t>This document also requests one new YANG module name in the YANG | <dl newline="false" spacing="compact"> | |||
Module Names registry <xref target="RFC6020"/> with the following | <dt>Name:</dt> <dd>ietf-rift</dd> | |||
suggestion:</t> | <dt>Namespace:</dt> <dd>urn:ietf:params:xml:ns:yang:ietf-rift</dd> | |||
<dt>Prefix:</dt> <dd>rift</dd> | ||||
<t>name: ietf-rift</t> | <dt>Reference:</dt> <dd>RFC 9719</dd> | |||
<t>namespace: urn:ietf:params:xml:ns:yang:ietf-rift</t> | </dl> | |||
<t>prefix: rift</t> | </section> | |||
<t>reference: RFC XXXX</t> | ||||
</section> | ||||
<section title="Acknowledgement"> | ||||
<t>The authors would like to thank Tony Przygienda, Jordan Head, | ||||
Benchong Xu (xu.benchong@zte.com.cn), Tom Petch for their review, | ||||
valuable comments and suggestions.</t> | ||||
</section> | ||||
</middle> | </middle> | |||
<!-- *****BACK MATTER ***** --> | ||||
<back> | <back> | |||
<references> | ||||
<name>References</name> | ||||
<references> | ||||
<name>Normative References</name> | ||||
<xi:include href="https://bib.ietf.org/public/rfc/bibxml/reference.RFC.2 | ||||
119.xml"/> | ||||
<xi:include href="https://bib.ietf.org/public/rfc/bibxml/reference.RFC.5 | ||||
881.xml"/> | ||||
<xi:include href="https://bib.ietf.org/public/rfc/bibxml/reference.RFC.6 | ||||
020.xml"/> | ||||
<xi:include href="https://bib.ietf.org/public/rfc/bibxml/reference.RFC.6 | ||||
241.xml"/> | ||||
<xi:include href="https://bib.ietf.org/public/rfc/bibxml/reference.RFC.6 | ||||
242.xml"/> | ||||
<xi:include href="https://bib.ietf.org/public/rfc/bibxml/reference.RFC.6 | ||||
991.xml"/> | ||||
<xi:include href="https://bib.ietf.org/public/rfc/bibxml/reference.RFC.7 | ||||
950.xml"/> | ||||
<xi:include href="https://bib.ietf.org/public/rfc/bibxml/reference.RFC.8 | ||||
040.xml"/> | ||||
<xi:include href="https://bib.ietf.org/public/rfc/bibxml/reference.RFC.8 | ||||
174.xml"/> | ||||
<xi:include href="https://bib.ietf.org/public/rfc/bibxml/reference.RFC.8 | ||||
177.xml"/> | ||||
<xi:include href="https://bib.ietf.org/public/rfc/bibxml/reference.RFC.8 | ||||
294.xml"/> | ||||
<xi:include href="https://bib.ietf.org/public/rfc/bibxml/reference.RFC.8 | ||||
340.xml"/> | ||||
<xi:include href="https://bib.ietf.org/public/rfc/bibxml/reference.RFC.8 | ||||
341.xml"/> | ||||
<xi:include href="https://bib.ietf.org/public/rfc/bibxml/reference.RFC.8 | ||||
342.xml"/> | ||||
<xi:include href="https://bib.ietf.org/public/rfc/bibxml/reference.RFC.8 | ||||
343.xml"/> | ||||
<xi:include href="https://bib.ietf.org/public/rfc/bibxml/reference.RFC.8 | ||||
349.xml"/> | ||||
<xi:include href="https://bib.ietf.org/public/rfc/bibxml/reference.RFC.8 | ||||
446.xml"/> | ||||
<xi:include href="https://bib.ietf.org/public/rfc/bibxml/reference.RFC.8 | ||||
505.xml"/> | ||||
<references title='Normative References'> | <!-- Note to RE: Companion document RFC 9692 in AUTH48 as of 12/09/24 - update t | |||
&rfc2119; | o use xi:include before publication --> | |||
&rfc5881; | <reference anchor="RFC9692" target="https://www.rfc-editor.org/info/rfc9692"> | |||
&rfc6020; | <front> | |||
&rfc6241; | <title>RIFT: Routing in Fat Trees</title> | |||
&rfc6242; | <author fullname="Tony Przygienda" initials="T." surname="Przygienda" role="edit | |||
&rfc6991; | or"> | |||
&rfc7950; | <organization>Juniper Networks</organization> | |||
&rfc8040; | </author> | |||
&rfc8174; | <author fullname="Jordan Head" initials="J." surname="Head" role="editor"> | |||
&rfc8177; | <organization>Juniper Networks</organization> | |||
&rfc8294; | </author> | |||
&rfc8340; | <author fullname="Alankar Sharma" initials="A." surname="Sharma"> | |||
&rfc8341; | <organization>Hudson River Trading</organization> | |||
&rfc8342; | </author> | |||
&rfc8343; | <author fullname="Pascal Thubert" initials="P." surname="Thubert"> | |||
&rfc8349; | <organization>Individual</organization> | |||
&rfc8446; | </author> | |||
&rfc8505; | <author fullname="Bruno Rijsman" initials="B." surname="Rijsman"> | |||
&I-D.ietf-rift-rift; | <organization>Individual</organization> | |||
</references> | </author> | |||
<author fullname="Dmitry Afanasiev" initials="D." surname="Afanasiev"> | ||||
<organization>Yandex</organization> | ||||
</author> | ||||
<date month="January" year="2025"/> | ||||
</front> | ||||
<seriesInfo name="RFC" value="9692"/> | ||||
<seriesInfo name="DOI" value="10.17487/RFC9692"/> | ||||
<references title='Informative References'> | </reference> | |||
&rfc3688; | </references> | |||
&rfc8407; | <references> | |||
&rfc8639; | <name>Informative References</name> | |||
&rfc8641; | <xi:include href="https://bib.ietf.org/public/rfc/bibxml/reference.RFC.3 | |||
<reference anchor="IEEE8021AS" target="https://ieeexplore.ieee.org/docu | 688.xml"/> | |||
ment/5741898/"> | <xi:include href="https://bib.ietf.org/public/rfc/bibxml/reference.RFC.8 | |||
<front> | 407.xml"/> | |||
<title>IEEE Standard for Local and Metropolitan Area | <xi:include href="https://bib.ietf.org/public/rfc/bibxml/reference.RFC.8 | |||
639.xml"/> | ||||
<xi:include href="https://bib.ietf.org/public/rfc/bibxml/reference.RFC.8 | ||||
641.xml"/> | ||||
<reference anchor="IEEE8021AS" target="https://ieeexplore.ieee.org/docum | ||||
ent/5741898/"> | ||||
<front> | ||||
<title>IEEE Standard for Local and Metropolitan Area | ||||
Networks - Timing and Synchronization for Time-Sensitive | Networks - Timing and Synchronization for Time-Sensitive | |||
Applications in Bridged Local Area Networks</title> | Applications in Bridged Local Area Networks</title> | |||
<author/> | <author> | |||
<date/> | <organization>IEEE</organization> | |||
</front> | </author> | |||
</reference> | <date month="March" year="2011"/> | |||
</front> | ||||
<seriesInfo name="IEEE Std" value="802.1AS-2011"/> | ||||
<seriesInfo name=" DOI" value="10.1109/IEEESTD.2011.5741898"/> | ||||
</reference> | ||||
</references> | ||||
</references> | </references> | |||
<!-- [rfced] Please review the "Inclusive Language" portion of the online | ||||
Style Guide | ||||
<https://www.rfc-editor.org/styleguide/part2/#inclusive_language> and let | ||||
us know if any changes are needed. Updates of this nature typically | ||||
result in more precise language, which is helpful for readers. Note that | ||||
our script did not flag any words in particular, but this should still be | ||||
reviewed as a best practice. --> | ||||
<section numbered="false" toc="default"> | ||||
<name>Acknowledgments</name> | ||||
<t>The authors would like to thank <contact fullname="Tony | ||||
Przygienda"/>, <contact fullname="Jordan Head"/>, <contact | ||||
fullname="Benchong Xu"/> (<eref target="mailto:xu.benchong@zte.com.cn"/>), | ||||
and | ||||
<contact fullname="Tom Petch"/> for their review, valuable comments, and | ||||
suggestions.</t> | ||||
</section> | ||||
</back> | </back> | |||
</rfc> | </rfc> | |||
End of changes. 215 change blocks. | ||||
696 lines changed or deleted | 619 lines changed or added | |||
This html diff was produced by rfcdiff 1.48. |