<?xml version='1.0' encoding='utf-8'?>
<rfc xmlns:xi="http://www.w3.org/2001/XInclude" version="3" category="info" consensus="true" docName="draft-ietf-babel-information-model-14" indexInclude="true" ipr="trust200902" number="9046" prepTime="2021-06-30T16:59:34" scripts="Common,Latin" sortRefs="true" submissionType="IETF" symRefs="true" tocDepth="4" tocInclude="true" xml:lang="en">
  <link href="https://datatracker.ietf.org/doc/draft-ietf-babel-information-model-14" rel="prev"/>
  <link href="https://dx.doi.org/10.17487/rfc9046" rel="alternate"/>
  <link href="urn:issn:2070-1721" rel="alternate"/>
  <front>
    <title>Babel Information Model</title>
    <seriesInfo name="RFC" value="9046" stream="IETF"/>
    <author initials="B." surname="Stark" fullname="Barbara Stark">
      <organization showOnFrontPage="true">AT&amp;T</organization>
      <address>
        <postal>
          <street/>
          <city/>
          <region>TX</region>
          <code/>
          <country>United States of America</country>
        </postal>
        <phone/>
        <email>barbara.stark@att.com</email>
      </address>
    </author>
    <author initials="M." surname="Jethanandani" fullname="Mahesh Jethanandani">
      <organization showOnFrontPage="true">Kloud Services</organization>
      <address>
        <postal>
          <street/>
          <city/>
          <region>CA</region>
          <code/>
          <country>United States of America</country>
        </postal>
        <phone/>
        <email>mjethanandani@gmail.com</email>
      </address>
    </author>
    <date month="06" year="2021"/>
    <area>Routing</area>
    <workgroup>Babel routing protocol</workgroup>
    <keyword>Babel</keyword>
    <abstract pn="section-abstract">
      <t indent="0" pn="section-abstract-1">The Babel information model provides structured data elements
for a Babel implementation reporting its current state and may
allow limited configuration of some such data elements.
This information model can be used as a basis for creating data
models under various data modeling regimes. This information
model only includes parameters and parameter values useful for
managing Babel over IPv6.</t>
    </abstract>
    <boilerplate>
      <section anchor="status-of-memo" numbered="false" removeInRFC="false" toc="exclude" pn="section-boilerplate.1">
        <name slugifiedName="name-status-of-this-memo">Status of This Memo</name>
        <t indent="0" pn="section-boilerplate.1-1">
            This document is not an Internet Standards Track specification; it is
            published for informational purposes.  
        </t>
        <t indent="0" pn="section-boilerplate.1-2">
            This document is a product of the Internet Engineering Task Force
            (IETF).  It represents the consensus of the IETF community.  It has
            received public review and has been approved for publication by the
            Internet Engineering Steering Group (IESG).  Not all documents
            approved by the IESG are candidates for any level of Internet
            Standard; see Section 2 of RFC 7841. 
        </t>
        <t indent="0" pn="section-boilerplate.1-3">
            Information about the current status of this document, any
            errata, and how to provide feedback on it may be obtained at
            <eref target="https://www.rfc-editor.org/info/rfc9046" brackets="none"/>.
        </t>
      </section>
      <section anchor="copyright" numbered="false" removeInRFC="false" toc="exclude" pn="section-boilerplate.2">
        <name slugifiedName="name-copyright-notice">Copyright Notice</name>
        <t indent="0" pn="section-boilerplate.2-1">
            Copyright (c) 2021 IETF Trust and the persons identified as the
            document authors. All rights reserved.
        </t>
        <t indent="0" pn="section-boilerplate.2-2">
            This document is subject to BCP 78 and the IETF Trust's Legal
            Provisions Relating to IETF Documents
            (<eref target="https://trustee.ietf.org/license-info" brackets="none"/>) in effect on the date of
            publication of this document. Please review these documents
            carefully, as they describe your rights and restrictions with
            respect to this document. Code Components extracted from this
            document must include Simplified BSD License text as described in
            Section 4.e of the Trust Legal Provisions and are provided without
            warranty as described in the Simplified BSD License.
        </t>
      </section>
    </boilerplate>
    <toc>
      <section anchor="toc" numbered="false" removeInRFC="false" toc="exclude" pn="section-toc.1">
        <name slugifiedName="name-table-of-contents">Table of Contents</name>
        <ul bare="true" empty="true" indent="2" spacing="compact" pn="section-toc.1-1">
          <li pn="section-toc.1-1.1">
            <t indent="0" keepWithNext="true" pn="section-toc.1-1.1.1"><xref derivedContent="1" format="counter" sectionFormat="of" target="section-1"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-introduction">Introduction</xref></t>
            <ul bare="true" empty="true" indent="2" spacing="compact" pn="section-toc.1-1.1.2">
              <li pn="section-toc.1-1.1.2.1">
                <t indent="0" keepWithNext="true" pn="section-toc.1-1.1.2.1.1"><xref derivedContent="1.1" format="counter" sectionFormat="of" target="section-1.1"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-requirements-language">Requirements Language</xref></t>
              </li>
              <li pn="section-toc.1-1.1.2.2">
                <t indent="0" keepWithNext="true" pn="section-toc.1-1.1.2.2.1"><xref derivedContent="1.2" format="counter" sectionFormat="of" target="section-1.2"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-notation">Notation</xref></t>
              </li>
            </ul>
          </li>
          <li pn="section-toc.1-1.2">
            <t indent="0" pn="section-toc.1-1.2.1"><xref derivedContent="2" format="counter" sectionFormat="of" target="section-2"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-overview">Overview</xref></t>
          </li>
          <li pn="section-toc.1-1.3">
            <t indent="0" pn="section-toc.1-1.3.1"><xref derivedContent="3" format="counter" sectionFormat="of" target="section-3"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-the-information-model">The Information Model</xref></t>
            <ul bare="true" empty="true" indent="2" spacing="compact" pn="section-toc.1-1.3.2">
              <li pn="section-toc.1-1.3.2.1">
                <t indent="0" pn="section-toc.1-1.3.2.1.1"><xref derivedContent="3.1" format="counter" sectionFormat="of" target="section-3.1"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-definition-of-babel-informa">Definition of babel-information-obj</xref></t>
              </li>
              <li pn="section-toc.1-1.3.2.2">
                <t indent="0" pn="section-toc.1-1.3.2.2.1"><xref derivedContent="3.2" format="counter" sectionFormat="of" target="section-3.2"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-definition-of-babel-constan">Definition of babel-constants-obj</xref></t>
              </li>
              <li pn="section-toc.1-1.3.2.3">
                <t indent="0" pn="section-toc.1-1.3.2.3.1"><xref derivedContent="3.3" format="counter" sectionFormat="of" target="section-3.3"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-definition-of-babel-interfa">Definition of babel-interface-obj</xref></t>
              </li>
              <li pn="section-toc.1-1.3.2.4">
                <t indent="0" pn="section-toc.1-1.3.2.4.1"><xref derivedContent="3.4" format="counter" sectionFormat="of" target="section-3.4"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-definition-of-babel-if-stat">Definition of babel-if-stats-obj</xref></t>
              </li>
              <li pn="section-toc.1-1.3.2.5">
                <t indent="0" pn="section-toc.1-1.3.2.5.1"><xref derivedContent="3.5" format="counter" sectionFormat="of" target="section-3.5"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-definition-of-babel-neighbo">Definition of babel-neighbor-obj</xref></t>
              </li>
              <li pn="section-toc.1-1.3.2.6">
                <t indent="0" pn="section-toc.1-1.3.2.6.1"><xref derivedContent="3.6" format="counter" sectionFormat="of" target="section-3.6"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-definition-of-babel-route-o">Definition of babel-route-obj</xref></t>
              </li>
              <li pn="section-toc.1-1.3.2.7">
                <t indent="0" pn="section-toc.1-1.3.2.7.1"><xref derivedContent="3.7" format="counter" sectionFormat="of" target="section-3.7"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-definition-of-babel-mac-key">Definition of babel-mac-key-set-obj</xref></t>
              </li>
              <li pn="section-toc.1-1.3.2.8">
                <t indent="0" pn="section-toc.1-1.3.2.8.1"><xref derivedContent="3.8" format="counter" sectionFormat="of" target="section-3.8"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-definition-of-babel-mac-key-">Definition of babel-mac-key-obj</xref></t>
              </li>
              <li pn="section-toc.1-1.3.2.9">
                <t indent="0" pn="section-toc.1-1.3.2.9.1"><xref derivedContent="3.9" format="counter" sectionFormat="of" target="section-3.9"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-definition-of-babel-dtls-ce">Definition of babel-dtls-cert-set-obj</xref></t>
              </li>
              <li pn="section-toc.1-1.3.2.10">
                <t indent="0" pn="section-toc.1-1.3.2.10.1"><xref derivedContent="3.10" format="counter" sectionFormat="of" target="section-3.10"/>. <xref derivedContent="" format="title" sectionFormat="of" target="name-definition-of-babel-dtls-cer">Definition of babel-dtls-cert-obj</xref></t>
              </li>
            </ul>
          </li>
          <li pn="section-toc.1-1.4">
            <t indent="0" pn="section-toc.1-1.4.1"><xref derivedContent="4" format="counter" sectionFormat="of" target="section-4"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-extending-the-information-m">Extending the Information Model</xref></t>
          </li>
          <li pn="section-toc.1-1.5">
            <t indent="0" pn="section-toc.1-1.5.1"><xref derivedContent="5" format="counter" sectionFormat="of" target="section-5"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-security-considerations">Security Considerations</xref></t>
          </li>
          <li pn="section-toc.1-1.6">
            <t indent="0" pn="section-toc.1-1.6.1"><xref derivedContent="6" format="counter" sectionFormat="of" target="section-6"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-iana-considerations">IANA Considerations</xref></t>
          </li>
          <li pn="section-toc.1-1.7">
            <t indent="0" pn="section-toc.1-1.7.1"><xref derivedContent="7" format="counter" sectionFormat="of" target="section-7"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-references">References</xref></t>
            <ul bare="true" empty="true" indent="2" spacing="compact" pn="section-toc.1-1.7.2">
              <li pn="section-toc.1-1.7.2.1">
                <t indent="0" pn="section-toc.1-1.7.2.1.1"><xref derivedContent="7.1" format="counter" sectionFormat="of" target="section-7.1"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-normative-references">Normative References</xref></t>
              </li>
              <li pn="section-toc.1-1.7.2.2">
                <t indent="0" pn="section-toc.1-1.7.2.2.1"><xref derivedContent="7.2" format="counter" sectionFormat="of" target="section-7.2"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-informative-references">Informative References</xref></t>
              </li>
            </ul>
          </li>
          <li pn="section-toc.1-1.8">
            <t indent="0" pn="section-toc.1-1.8.1"><xref derivedContent="" format="none" sectionFormat="of" target="section-appendix.a"/><xref derivedContent="" format="title" sectionFormat="of" target="name-acknowledgements">Acknowledgements</xref></t>
          </li>
          <li pn="section-toc.1-1.9">
            <t indent="0" pn="section-toc.1-1.9.1"><xref derivedContent="" format="none" sectionFormat="of" target="section-appendix.b"/><xref derivedContent="" format="title" sectionFormat="of" target="name-authors-addresses">Authors' Addresses</xref></t>
          </li>
        </ul>
      </section>
    </toc>
  </front>
  <middle>
    <section anchor="introduction" numbered="true" toc="include" removeInRFC="false" pn="section-1">
      <name slugifiedName="name-introduction">Introduction</name>
      <t indent="0" pn="section-1-1">Babel is a loop-avoiding, distance-vector routing protocol defined in
<xref target="RFC8966" format="default" sectionFormat="of" derivedContent="RFC8966"/>. <xref target="RFC8967" format="default" sectionFormat="of" derivedContent="RFC8967"/> defines a security
mechanism that allows Babel packets to be cryptographically
authenticated, and <xref target="RFC8968" format="default" sectionFormat="of" derivedContent="RFC8968"/> defines a security mechanism
that allows Babel packets to be both authenticated and encrypted.
This document describes an information model for Babel (including implementations
using one or both of these security mechanisms) that can be used to create management
protocol data models (such as a NETCONF <xref target="RFC6241" format="default" sectionFormat="of" derivedContent="RFC6241"/> YANG <xref target="RFC7950" format="default" sectionFormat="of" derivedContent="RFC7950"/> data model).</t>
      <t indent="0" pn="section-1-2">Due to the simplicity of the Babel protocol, most of the information model
is focused on reporting the Babel protocol operational state, and very little of
that is considered mandatory to implement for an implementation claiming
compliance with this information model. Some parameters may be configurable.
However, it is up to the Babel implementation whether to allow any of these
to be configured within its implementation. Where the implementation does
not allow configuration of these parameters, it <bcp14>MAY</bcp14> still choose to expose
them as read-only.</t>
      <t indent="0" pn="section-1-3">The information model is presented using a hierarchical structure. This does
not preclude a data model based on this information model from using a referential
or other structure.</t>
      <t indent="0" pn="section-1-4">This information model only includes parameters and parameter values
useful for managing Babel over IPv6. This model has no parameters
or values specific to operating Babel over IPv4, even though
<xref target="RFC8966" format="default" sectionFormat="of" derivedContent="RFC8966"/> does define a multicast group for
sending and listening to multicast announcements on IPv4.
There is less likelihood of breakage due to inconsistent
configuration and increased implementation simplicity if
Babel is operated always and only over IPv6. Running Babel
over IPv6 requires IPv6 at the link layer and does not need
advertised prefixes, router advertisements, or DHCPv6 to be
present in the network. Link-local IPv6 is widely supported
among devices where Babel is expected to be used. Note that
Babel over IPv6 can be used for configuration of both IPv4
and IPv6 routes.</t>
      <section anchor="requirements-language" numbered="true" toc="include" removeInRFC="false" pn="section-1.1">
        <name slugifiedName="name-requirements-language">Requirements Language</name>
        <t indent="0" pn="section-1.1-1">
    The key words "<bcp14>MUST</bcp14>", "<bcp14>MUST NOT</bcp14>", "<bcp14>REQUIRED</bcp14>", "<bcp14>SHALL</bcp14>", "<bcp14>SHALL NOT</bcp14>", "<bcp14>SHOULD</bcp14>", "<bcp14>SHOULD NOT</bcp14>", "<bcp14>RECOMMENDED</bcp14>", "<bcp14>NOT RECOMMENDED</bcp14>",
    "<bcp14>MAY</bcp14>", and "<bcp14>OPTIONAL</bcp14>" in this document are to be interpreted as
    described in BCP 14 <xref target="RFC2119" format="default" sectionFormat="of" derivedContent="RFC2119"/> <xref target="RFC8174" format="default" sectionFormat="of" derivedContent="RFC8174"/> 
    when, and only when, they appear in all capitals, as shown here.
        </t>
      </section>
      <section anchor="notation" numbered="true" toc="include" removeInRFC="false" pn="section-1.2">
        <name slugifiedName="name-notation">Notation</name>
        <t indent="0" pn="section-1.2-1">This document uses a programming-language-like notation to define the properties
of the objects of the information model. An optional property is enclosed
by square brackets, [ ], and a list property is indicated by two numbers
in angle brackets, &lt;m..n&gt;, where m indicates the minimal number
of list elements,
and n indicates the maximum number of list elements.  The symbol "*" for n
means there are no defined limits on the number of list elements. Each parameter
and object includes an indication of "ro" or "rw". "ro" means the parameter
or object is read-only. "rw" means it is read-write. For an object, read-write
means instances of the object can be created or deleted.
If an implementation is allowed to choose
to implement a "rw" parameter as read-only, this is noted in the parameter
	description.</t>
        <t indent="0" pn="section-1.2-2">The object definitions use base types that are defined as follows:</t>
        <dl indent="14" newline="false" spacing="normal" pn="section-1.2-3">
          <dt pn="section-1.2-3.1">
binary:  </dt>
          <dd pn="section-1.2-3.2">
            <t indent="0" pn="section-1.2-3.2.1">A binary string (sequence of octets).</t>
          </dd>
          <dt pn="section-1.2-3.3">
boolean:  </dt>
          <dd pn="section-1.2-3.4">
            <t indent="0" pn="section-1.2-3.4.1">A type representing a Boolean (true or false) value.</t>
          </dd>
          <dt pn="section-1.2-3.5">
datetime:  </dt>
          <dd pn="section-1.2-3.6">
            <t indent="0" pn="section-1.2-3.6.1">A type representing a date and time using the Gregorian calendar. The datetime
format <bcp14>MUST</bcp14> conform to <xref target="RFC3339" sectionFormat="comma" section="5.6" format="default" derivedLink="https://rfc-editor.org/rfc/rfc3339#section-5.6" derivedContent="RFC3339"/>.</t>
          </dd>
          <dt pn="section-1.2-3.7">
ip-address:  </dt>
          <dd pn="section-1.2-3.8">
            <t indent="0" pn="section-1.2-3.8.1">A type representing an IP address. This type supports both IPv4 and IPv6
addresses.</t>
          </dd>
          <dt pn="section-1.2-3.9">
operation:  </dt>
          <dd pn="section-1.2-3.10">
            <t indent="0" pn="section-1.2-3.10.1">A type representing a remote procedure call or other action that can be used
to manipulate data elements or system behaviors.</t>
          </dd>
          <dt pn="section-1.2-3.11">
reference:  </dt>
          <dd pn="section-1.2-3.12">
            <t indent="0" pn="section-1.2-3.12.1">A type representing a reference to another information or data model element
or to some other device resource.</t>
          </dd>
          <dt pn="section-1.2-3.13">
string:  </dt>
          <dd pn="section-1.2-3.14">
            <t indent="0" pn="section-1.2-3.14.1">A type representing a human-readable string consisting of a (possibly restricted)
subset of Unicode and ISO/IEC 10646 <xref target="ISO.10646" format="default" sectionFormat="of" derivedContent="ISO.10646"/> characters.</t>
          </dd>
          <dt pn="section-1.2-3.15">
uint:  </dt>
          <dd pn="section-1.2-3.16">
            <t indent="0" pn="section-1.2-3.16.1">A type representing an unsigned integer number. This information
model does not define a precision.</t>
          </dd>
        </dl>
      </section>
    </section>
    <section anchor="overview" numbered="true" toc="include" removeInRFC="false" pn="section-2">
      <name slugifiedName="name-overview">Overview</name>
      <t indent="0" pn="section-2-1">The information model is hierarchically structured as follows:</t>
      <sourcecode name="" type="" markers="false" pn="section-2-2">
+-- babel-information
   +-- babel-implementation-version
   +-- babel-enable
   +-- router-id
   +-- self-seqno
   +-- babel-metric-comp-algorithms
   +-- babel-security-supported
   +-- babel-mac-algorithms
   +-- babel-dtls-cert-types
   +-- babel-stats-enable
   +-- babel-stats-reset
   +-- babel-constants
   |  +-- babel-udp-port
   |  +-- babel-mcast-group
   +-- babel-interfaces
   |  +-- babel-interface-reference
   |  +-- babel-interface-enable
   |  +-- babel-interface-metric-algorithm
   |  +-- babel-interface-split-horizon
   |  +-- babel-mcast-hello-seqno
   |  +-- babel-mcast-hello-interval
   |  +-- babel-update-interval
   |  +-- babel-mac-enable
   |  +-- babel-if-mac-key-sets
   |  +-- babel-mac-verify
   |  +-- babel-dtls-enable
   |  +-- babel-if-dtls-cert-sets
   |  +-- babel-dtls-cached-info
   |  +-- babel-dtls-cert-prefer
   |  +-- babel-packet-log-enable
   |  +-- babel-packet-log
   |  +-- babel-if-stats
   |  |  +-- babel-sent-mcast-hello
   |  |  +-- babel-sent-mcast-update
   |  |  +-- babel-sent-ucast-hello
   |  |  +-- babel-sent-ucast-update
   |  |  +-- babel-sent-IHU
   |  |  +-- babel-received-packets
   |  +-- babel-neighbors
   |     +-- babel-neighbor-address
   |     +-- babel-hello-mcast-history
   |     +-- babel-hello-ucast-history
   |     +-- babel-txcost
   |     +-- babel-exp-mcast-hello-seqno
   |     +-- babel-exp-ucast-hello-seqno
   |     +-- babel-ucast-hello-seqno
   |     +-- babel-ucast-hello-interval
   |     +-- babel-rxcost
   |     +-- babel-cost
   +-- babel-routes
   |  +-- babel-route-prefix
   |  +-- babel-route-prefix-length
   |  +-- babel-route-router-id
   |  +-- babel-route-neighbor
   |  +-- babel-route-received-metric
   |  +-- babel-route-calculated-metric
   |  +-- babel-route-seqno
   |  +-- babel-route-next-hop
   |  +-- babel-route-feasible
   |  +-- babel-route-selected
   +-- babel-mac-key-sets
   |  +-- babel-mac-default-apply
   |  +-- babel-mac-keys
   |     +-- babel-mac-key-name
   |     +-- babel-mac-key-use-send
   |     +-- babel-mac-key-use-verify
   |     +-- babel-mac-key-value
   |     +-- babel-mac-key-algorithm
   |     +-- babel-mac-key-test
   +-- babel-dtls-cert-sets
      +-- babel-dtls-default-apply
      +-- babel-dtls-certs
         +-- babel-cert-name
         +-- babel-cert-value
         +-- babel-cert-type
         +-- babel-cert-private-key
</sourcecode>
      <t indent="0" pn="section-2-3">Most parameters are read-only. The following is a descriptive list of the parameters that are not required to be read-only:</t>
      <ul spacing="normal" bare="false" empty="false" indent="3" pn="section-2-4">
        <li pn="section-2-4.1">enable/disable Babel</li>
        <li pn="section-2-4.2">create/delete Babel Message Authentication Code (MAC) Key sets</li>
        <li pn="section-2-4.3">create/delete Babel Certificate sets</li>
        <li pn="section-2-4.4">enable/disable statistics collection</li>
        <li pn="section-2-4.5">Constant: UDP port</li>
        <li pn="section-2-4.6">Constant: IPv6 multicast group</li>
        <li pn="section-2-4.7">Interface: enable/disable Babel on this interface</li>
        <li pn="section-2-4.8">Interface: metric algorithm</li>
        <li pn="section-2-4.9">Interface: split horizon</li>
        <li pn="section-2-4.10">Interface: sets of MAC keys</li>
        <li pn="section-2-4.11">Interface: verify received MAC packets</li>
        <li pn="section-2-4.12">Interface: set of certificates for use with DTLS</li>
        <li pn="section-2-4.13">Interface: use cached info extensions</li>
        <li pn="section-2-4.14">Interface: preferred order of certificate types</li>
        <li pn="section-2-4.15">Interface: enable/disable packet log</li>
        <li pn="section-2-4.16">MAC-keys: create/delete entries</li>
        <li pn="section-2-4.17">MAC-keys: key used for sent packets</li>
        <li pn="section-2-4.18">MAC-keys: key used to verify packets</li>
        <li pn="section-2-4.19">DTLS-certs: create/delete entries</li>
      </ul>
      <t indent="0" pn="section-2-5">The following parameters are required to return no value when read:</t>
      <ul spacing="normal" bare="false" empty="false" indent="3" pn="section-2-6">
        <li pn="section-2-6.1">MAC key values</li>
        <li pn="section-2-6.2">DTLS private keys</li>
      </ul>
      <t indent="0" pn="section-2-7">Note that this overview is intended simply to be informative and is not normative.
If there is any discrepancy between this overview and the detailed information
model definitions in subsequent sections, the error is in this overview.</t>
    </section>
    <section anchor="the-information-model" numbered="true" toc="include" removeInRFC="false" pn="section-3">
      <name slugifiedName="name-the-information-model">The Information Model</name>
      <section anchor="definition-of-babel-information-obj" numbered="true" toc="include" removeInRFC="false" pn="section-3.1">
        <name slugifiedName="name-definition-of-babel-informa">Definition of babel-information-obj</name>
        <sourcecode name="" type="" markers="false" pn="section-3.1-1">
object {
     string                    ro babel-implementation-version;
     boolean                   rw babel-enable;
     binary                    ro babel-self-router-id;
    [uint                      ro babel-self-seqno;]
     string                    ro babel-metric-comp-algorithms&lt;1..*&gt;;
     string                    ro babel-security-supported&lt;0..*&gt;;
    [string                    ro babel-mac-algorithms&lt;1..*&gt;;]
    [string                    ro babel-dtls-cert-types&lt;1..*&gt;;]
    [boolean                   rw babel-stats-enable;]
    [operation                    babel-stats-reset;]
     babel-constants-obj       ro babel-constants;
     babel-interface-obj       ro babel-interfaces&lt;0..*&gt;;
     babel-route-obj           ro babel-routes&lt;0..*&gt;;
    [babel-mac-key-set-obj     rw babel-mac-key-sets&lt;0..*&gt;;]
    [babel-dtls-cert-set-obj   rw babel-dtls-cert-sets&lt;0..*&gt;;]
} babel-information-obj;
</sourcecode>
        <dl indent="3" newline="false" spacing="normal" pn="section-3.1-2">
          <dt pn="section-3.1-2.1">
babel-implementation-version:  </dt>
          <dd pn="section-3.1-2.2">
            <t indent="0" pn="section-3.1-2.2.1">The name and version of this implementation of the Babel protocol.</t>
          </dd>
          <dt pn="section-3.1-2.3">
babel-enable:  </dt>
          <dd pn="section-3.1-2.4">
            <t indent="0" pn="section-3.1-2.4.1">When written, it configures whether the protocol should be enabled
(true) or disabled (false).
A read from the running or intended datastore indicates the
configured administrative value of whether the protocol is enabled
(true) or not (false). A read from the operational datastore indicates whether
the protocol is actually running (true) or not (i.e., it indicates the
operational state of the protocol).
A data model that does not replicate parameters for running and operational
datastores can implement this as two separate parameters.
An implementation <bcp14>MAY</bcp14> choose
to expose this parameter as read-only ("ro").</t>
          </dd>
          <dt pn="section-3.1-2.5">
babel-self-router-id:  </dt>
          <dd pn="section-3.1-2.6">
            <t indent="0" pn="section-3.1-2.6.1">The router-id used by this instance of the Babel protocol
to identify itself. <xref target="RFC8966" format="default" sectionFormat="of" derivedContent="RFC8966"/>
describes this as an arbitrary string of 8 octets.</t>
          </dd>
          <dt pn="section-3.1-2.7">
babel-self-seqno:  </dt>
          <dd pn="section-3.1-2.8">
            <t indent="0" pn="section-3.1-2.8.1">The current sequence number included in route updates for routes
originated by this node. This is a 16-bit unsigned integer.</t>
          </dd>
          <dt pn="section-3.1-2.9">
babel-metric-comp-algorithms:  </dt>
          <dd pn="section-3.1-2.10">
            <t indent="0" pn="section-3.1-2.10.1">List of supported cost computation algorithms. Possible
values include "2-out-of-3", as described in <xref target="RFC8966" sectionFormat="comma" section="A.2.1" format="default" derivedLink="https://rfc-editor.org/rfc/rfc8966#appendix-A.2.1" derivedContent="RFC8966"/>, and "ETX", as described in <xref target="RFC8966" sectionFormat="comma" section="A.2.2" format="default" derivedLink="https://rfc-editor.org/rfc/rfc8966#appendix-A.2.2" derivedContent="RFC8966"/>. </t>
          </dd>
          <dt pn="section-3.1-2.11">
babel-security-supported:  </dt>
          <dd pn="section-3.1-2.12">
            <t indent="0" pn="section-3.1-2.12.1">List of supported security mechanisms. Possible values include
"MAC" to indicate support of <xref target="RFC8967" format="default" sectionFormat="of" derivedContent="RFC8967"/> and "DTLS"
to indicate support of <xref target="RFC8968" format="default" sectionFormat="of" derivedContent="RFC8968"/>.</t>
          </dd>
          <dt pn="section-3.1-2.13">
babel-mac-algorithms:  </dt>
          <dd pn="section-3.1-2.14">
            <t indent="0" pn="section-3.1-2.14.1">List of supported MAC computation algorithms. Possible values
include "HMAC-SHA256" and "BLAKE2s-128" to indicate support for
algorithms indicated in <xref target="RFC8967" format="default" sectionFormat="of" derivedContent="RFC8967"/>.</t>
          </dd>
          <dt pn="section-3.1-2.15">
babel-dtls-cert-types:  </dt>
          <dd pn="section-3.1-2.16">
            <t indent="0" pn="section-3.1-2.16.1">List of supported certificate types. Possible values include
"X.509" and "RawPublicKey" to indicate support for types
indicated in <xref target="RFC8968" format="default" sectionFormat="of" derivedContent="RFC8968"/>.</t>
          </dd>
          <dt pn="section-3.1-2.17">
babel-stats-enable:  </dt>
          <dd pn="section-3.1-2.18">
            <t indent="0" pn="section-3.1-2.18.1">Indicates whether statistics collection is enabled
(true) or disabled (false) on all interfaces. When
enabled, existing statistics values are not cleared
and will be incremented as new packets are counted.</t>
          </dd>
          <dt pn="section-3.1-2.19">
babel-stats-reset:  </dt>
          <dd pn="section-3.1-2.20">
            <t indent="0" pn="section-3.1-2.20.1">An operation that resets all babel-if-stats
parameters to zero. This
operation has no input or output parameters.</t>
          </dd>
          <dt pn="section-3.1-2.21">
babel-constants:  </dt>
          <dd pn="section-3.1-2.22">
            <t indent="0" pn="section-3.1-2.22.1">A babel-constants-obj object.</t>
          </dd>
          <dt pn="section-3.1-2.23">
babel-interfaces:  </dt>
          <dd pn="section-3.1-2.24">
            <t indent="0" pn="section-3.1-2.24.1">A set of babel-interface-obj objects.</t>
          </dd>
          <dt pn="section-3.1-2.25">
babel-routes:  </dt>
          <dd pn="section-3.1-2.26">
            <t indent="0" pn="section-3.1-2.26.1">A set of babel-route-obj objects. Contains the routes known to this
node.</t>
          </dd>
          <dt pn="section-3.1-2.27">
babel-mac-key-sets:  </dt>
          <dd pn="section-3.1-2.28">
            <t indent="0" pn="section-3.1-2.28.1">A set of babel-mac-key-set-obj objects. If this
object is implemented, it
provides access to parameters related to the MAC security mechanism.
An implementation <bcp14>MAY</bcp14> choose
to expose this object as read-only ("ro").</t>
          </dd>
          <dt pn="section-3.1-2.29">
babel-dtls-cert-sets:  </dt>
          <dd pn="section-3.1-2.30">
            <t indent="0" pn="section-3.1-2.30.1">A set of babel-dtls-cert-set-obj objects. If this
object is implemented, it
provides access to parameters related to the DTLS security mechanism.
An implementation <bcp14>MAY</bcp14> choose
to expose this object as read-only ("ro").</t>
          </dd>
        </dl>
      </section>
      <section anchor="definition-of-babel-constants-obj" numbered="true" toc="include" removeInRFC="false" pn="section-3.2">
        <name slugifiedName="name-definition-of-babel-constan">Definition of babel-constants-obj</name>
        <sourcecode name="" type="" markers="false" pn="section-3.2-1">
object {
     uint         rw babel-udp-port;
    [ip-address   rw babel-mcast-group;]
} babel-constants-obj;
</sourcecode>
        <dl indent="3" newline="false" spacing="normal" pn="section-3.2-2">
          <dt pn="section-3.2-2.1">
babel-udp-port:  </dt>
          <dd pn="section-3.2-2.2">
            <t indent="0" pn="section-3.2-2.2.1">UDP port for sending and listening for Babel packets. Default
is 6696. An implementation <bcp14>MAY</bcp14> choose
to expose this parameter as read-only ("ro").
This is a 16-bit unsigned integer.</t>
          </dd>
          <dt pn="section-3.2-2.3">
babel-mcast-group:  </dt>
          <dd pn="section-3.2-2.4">
            <t indent="0" pn="section-3.2-2.4.1">Multicast group for sending and listening to multicast
announcements on IPv6. Default is ff02::1:6.
An implementation <bcp14>MAY</bcp14> choose
to expose this parameter as read-only ("ro").</t>
          </dd>
        </dl>
      </section>
      <section anchor="definition-of-babel-interface-obj" numbered="true" toc="include" removeInRFC="false" pn="section-3.3">
        <name slugifiedName="name-definition-of-babel-interfa">Definition of babel-interface-obj</name>
        <sourcecode name="" type="" markers="false" pn="section-3.3-1">
object {
     reference            ro babel-interface-reference;
    [boolean              rw babel-interface-enable;]
     string               rw babel-interface-metric-algorithm;
    [boolean              rw babel-interface-split-horizon;]
    [uint                 ro babel-mcast-hello-seqno;]
    [uint                 ro babel-mcast-hello-interval;]
    [uint                 ro babel-update-interval;]
    [boolean              rw babel-mac-enable;]
    [reference            rw babel-if-mac-key-sets&lt;0..*&gt;;]
    [boolean              rw babel-mac-verify;]
    [boolean              rw babel-dtls-enable;]
    [reference            rw babel-if-dtls-cert-sets&lt;0..*&gt;;]
    [boolean              rw babel-dtls-cached-info;]
    [string               rw babel-dtls-cert-prefer&lt;0..*&gt;;]
    [boolean              rw babel-packet-log-enable;]
    [reference            ro babel-packet-log;]
    [babel-if-stats-obj   ro babel-if-stats;]
     babel-neighbor-obj   ro babel-neighbors&lt;0..*&gt;;
} babel-interface-obj;
</sourcecode>
        <dl indent="3" newline="false" spacing="normal" pn="section-3.3-2">
          <dt pn="section-3.3-2.1">
babel-interface-reference:  </dt>
          <dd pn="section-3.3-2.2">
            <t indent="0" pn="section-3.3-2.2.1">Reference to an interface object that can be used to send and
receive IPv6 packets, as defined by
the data model (e.g., YANG <xref target="RFC7950" format="default" sectionFormat="of" derivedContent="RFC7950"/> and Broadband Forum (BBF) <xref target="TR-181" format="default" sectionFormat="of" derivedContent="TR-181"/>).
Referencing syntax will be specific to the data model. If there is
no set of interface objects available, this should be a string that indicates
the interface name used by the underlying operating system.</t>
          </dd>
          <dt pn="section-3.3-2.3">
babel-interface-enable:  </dt>
          <dd pn="section-3.3-2.4">
            <t indent="0" pn="section-3.3-2.4.1">When written, it configures whether the protocol should be enabled
(true) or disabled (false) on this interface.
A read from the running or intended datastore indicates the
configured administrative value of whether the protocol is enabled
(true) or not (false). A read from the operational datastore indicates whether
the protocol is actually running (true) or not (i.e., it indicates the
operational state of the protocol).
A data model that does not replicate parameters for running and operational
datastores can implement this as two separate parameters.
An implementation <bcp14>MAY</bcp14> choose
to expose this parameter as read-only ("ro").</t>
          </dd>
          <dt pn="section-3.3-2.5">
	  babel-interface-metric-algorithm:  </dt>
          <dd pn="section-3.3-2.6">
            <t indent="0" pn="section-3.3-2.6.1">Indicates the metric computation algorithm used on this interface.
The value <bcp14>MUST</bcp14> be one of those listed in the babel-metric-comp-algorithms parameter.
An implementation <bcp14>MAY</bcp14> choose
to expose this parameter as read-only ("ro").</t>
          </dd>
          <dt pn="section-3.3-2.7">
babel-interface-split-horizon:  </dt>
          <dd pn="section-3.3-2.8">
            <t indent="0" pn="section-3.3-2.8.1">Indicates whether or not the split-horizon optimization is used
when calculating metrics on this interface. A value of "true"
indicates split-horizon optimization is used.
Split-horizon optimization is described in
<xref target="RFC8966" sectionFormat="comma" section="3.7.4" format="default" derivedLink="https://rfc-editor.org/rfc/rfc8966#section-3.7.4" derivedContent="RFC8966"/>.
An implementation <bcp14>MAY</bcp14> choose
to expose this parameter as read-only ("ro").</t>
          </dd>
          <dt pn="section-3.3-2.9">
babel-mcast-hello-seqno:  </dt>
          <dd pn="section-3.3-2.10">
            <t indent="0" pn="section-3.3-2.10.1">The current sequence number in use for multicast
Hellos sent on this interface.
This is a 16-bit unsigned integer.</t>
          </dd>
          <dt pn="section-3.3-2.11">
babel-mcast-hello-interval:  </dt>
          <dd pn="section-3.3-2.12">
            <t indent="0" pn="section-3.3-2.12.1">The current interval in use for multicast Hellos
sent on this interface. Units are centiseconds.
This is a 16-bit unsigned integer.</t>
          </dd>
          <dt pn="section-3.3-2.13">
babel-update-interval:  </dt>
          <dd pn="section-3.3-2.14">
            <t indent="0" pn="section-3.3-2.14.1">The current interval in use for all updates (multicast
and unicast) sent on this interface. Units are centiseconds.
This is a 16-bit unsigned integer.</t>
          </dd>
          <dt pn="section-3.3-2.15">
babel-mac-enable:  </dt>
          <dd pn="section-3.3-2.16">
            <t indent="0" pn="section-3.3-2.16.1">Indicates whether the MAC security mechanism is enabled
(true) or disabled (false).
An implementation <bcp14>MAY</bcp14> choose
to expose this parameter as read-only ("ro").</t>
          </dd>
          <dt pn="section-3.3-2.17">
babel-if-mac-key-sets:  </dt>
          <dd pn="section-3.3-2.18">
            <t indent="0" pn="section-3.3-2.18.1">List of references to the babel-mac-key-sets entries that apply to this
interface. When an interface instance is created, all babel-mac-key-sets
instances with babel-mac-default-apply "true" will be included
in this list.
An implementation <bcp14>MAY</bcp14> choose
to expose this parameter as read-only ("ro").</t>
          </dd>
          <dt pn="section-3.3-2.19">
babel-mac-verify:</dt>
          <dd pn="section-3.3-2.20">
            <t indent="0" pn="section-3.3-2.20.1">A Boolean flag indicating whether MACs in incoming Babel packets
are required to be present and are verified. If this parameter is "true",
incoming packets are required to have a valid MAC.
An implementation <bcp14>MAY</bcp14> choose
to expose this parameter as read-only ("ro").</t>
          </dd>
          <dt pn="section-3.3-2.21">
babel-dtls-enable:  </dt>
          <dd pn="section-3.3-2.22">
            <t indent="0" pn="section-3.3-2.22.1">Indicates whether the DTLS security mechanism is enabled
(true) or disabled (false).
An implementation <bcp14>MAY</bcp14> choose
to expose this parameter as read-only ("ro").</t>
          </dd>
          <dt pn="section-3.3-2.23">
babel-if-dtls-cert-sets:  </dt>
          <dd pn="section-3.3-2.24">
            <t indent="0" pn="section-3.3-2.24.1">List of references to the babel-dtls-cert-sets entries that apply to this
interface. When an interface instance is created, all babel-dtls-cert-sets
instances with babel-dtls-default-apply "true" will be included
in this list.
An implementation <bcp14>MAY</bcp14> choose
to expose this parameter as read-only ("ro").</t>
          </dd>
          <dt pn="section-3.3-2.25">
babel-dtls-cached-info:  </dt>
          <dd pn="section-3.3-2.26">
            <t indent="0" pn="section-3.3-2.26.1">Indicates whether the cached_info extension
(see <xref target="RFC8968" sectionFormat="comma" section="A" format="default" derivedLink="https://rfc-editor.org/rfc/rfc8968#appendix-A" derivedContent="RFC8968"/>) is included in ClientHello
and ServerHello packets. The extension is included if the value
is "true".
An implementation <bcp14>MAY</bcp14> choose
to expose this parameter as read-only ("ro").</t>
          </dd>
          <dt pn="section-3.3-2.27">
babel-dtls-cert-prefer:  </dt>
          <dd pn="section-3.3-2.28">
            <t indent="0" pn="section-3.3-2.28.1">List of supported certificate types, in order of preference.
The values <bcp14>MUST</bcp14> be among those
listed in the babel-dtls-cert-types parameter.
This list is used to populate the server_certificate_type
extension (see <xref target="RFC8968" sectionFormat="comma" section="A" format="default" derivedLink="https://rfc-editor.org/rfc/rfc8968#appendix-A" derivedContent="RFC8968"/>)
in a ClientHello. Values that are present in
at least one instance in the babel-dtls-certs object of a
referenced babel-dtls instance and that have
a non-empty babel-cert-private-key will be used to populate
the client_certificate_type extension in a ClientHello.</t>
          </dd>
          <dt pn="section-3.3-2.29">
babel-packet-log-enable:  </dt>
          <dd pn="section-3.3-2.30">
            <t indent="0" pn="section-3.3-2.30.1">Indicates whether packet logging is enabled
(true) or disabled (false) on this interface.</t>
          </dd>
          <dt pn="section-3.3-2.31">
babel-packet-log:  </dt>
          <dd pn="section-3.3-2.32">
            <t indent="0" pn="section-3.3-2.32.1">A reference or URL link to a file that contains a timestamped log
of packets received and sent on babel-udp-port on this interface.
The <xref target="libpcap" format="default" sectionFormat="of" derivedContent="libpcap"/> file format with a .pcap file extension <bcp14>SHOULD</bcp14> be supported for
packet log files. Logging is
enabled/disabled by babel-packet-log-enable.
Implementations will need to carefully manage and limit
memory used by packet logs.</t>
          </dd>
          <dt pn="section-3.3-2.33">
babel-if-stats:  </dt>
          <dd pn="section-3.3-2.34">
            <t indent="0" pn="section-3.3-2.34.1">Statistics collection object for this interface.</t>
          </dd>
          <dt pn="section-3.3-2.35">
babel-neighbors:  </dt>
          <dd pn="section-3.3-2.36">
            <t indent="0" pn="section-3.3-2.36.1">A set of babel-neighbor-obj objects.</t>
          </dd>
        </dl>
      </section>
      <section anchor="definition-of-babel-if-stats-obj" numbered="true" toc="include" removeInRFC="false" pn="section-3.4">
        <name slugifiedName="name-definition-of-babel-if-stat">Definition of babel-if-stats-obj</name>
        <sourcecode name="" type="" markers="false" pn="section-3.4-1">
object {
     uint   ro babel-sent-mcast-hello;
     uint   ro babel-sent-mcast-update;
     uint   ro babel-sent-ucast-hello;
     uint   ro babel-sent-ucast-update;
     uint   ro babel-sent-IHU;
     uint   ro babel-received-packets;
} babel-if-stats-obj;
</sourcecode>
        <dl indent="3" newline="false" spacing="normal" pn="section-3.4-2">
          <dt pn="section-3.4-2.1">
babel-sent-mcast-hello:  </dt>
          <dd pn="section-3.4-2.2">
            <t indent="0" pn="section-3.4-2.2.1">A count of the number of multicast Hello packets sent on this interface.</t>
          </dd>
          <dt pn="section-3.4-2.3">
babel-sent-mcast-update:  </dt>
          <dd pn="section-3.4-2.4">
            <t indent="0" pn="section-3.4-2.4.1">A count of the number of multicast update packets sent on this interface.</t>
          </dd>
          <dt pn="section-3.4-2.5">
babel-sent-ucast-hello:  </dt>
          <dd pn="section-3.4-2.6">
            <t indent="0" pn="section-3.4-2.6.1">A count of the number of unicast Hello packets sent on this interface.</t>
          </dd>
          <dt pn="section-3.4-2.7">
babel-sent-ucast-update:  </dt>
          <dd pn="section-3.4-2.8">
            <t indent="0" pn="section-3.4-2.8.1">A count of the number of unicast update packets sent on this interface.</t>
          </dd>
          <dt pn="section-3.4-2.9">
babel-sent-IHU:  </dt>
          <dd pn="section-3.4-2.10">
            <t indent="0" pn="section-3.4-2.10.1">A count of the number of "I Heard You" (IHU) packets sent on this interface.</t>
          </dd>
          <dt pn="section-3.4-2.11">
babel-received-packets:  </dt>
          <dd pn="section-3.4-2.12">
            <t indent="0" pn="section-3.4-2.12.1">A count of the number of Babel packets received on this interface.</t>
          </dd>
        </dl>
      </section>
      <section anchor="definition-of-babel-neighbor-obj" numbered="true" toc="include" removeInRFC="false" pn="section-3.5">
        <name slugifiedName="name-definition-of-babel-neighbo">Definition of babel-neighbor-obj</name>
        <sourcecode name="" type="" markers="false" pn="section-3.5-1">
object {
     ip-address   ro babel-neighbor-address;
    [binary       ro babel-hello-mcast-history;]
    [binary       ro babel-hello-ucast-history;]
     uint         ro babel-txcost;
     uint         ro babel-exp-mcast-hello-seqno;
     uint         ro babel-exp-ucast-hello-seqno;
    [uint         ro babel-ucast-hello-seqno;]
    [uint         ro babel-ucast-hello-interval;]
    [uint         ro babel-rxcost;]
    [uint         ro babel-cost;]
} babel-neighbor-obj;
</sourcecode>
        <dl indent="3" newline="false" spacing="normal" pn="section-3.5-2">
          <dt pn="section-3.5-2.1">
babel-neighbor-address:  </dt>
          <dd pn="section-3.5-2.2">
            <t indent="0" pn="section-3.5-2.2.1">IPv4 or IPv6 address the neighbor sends packets from.</t>
          </dd>
          <dt pn="section-3.5-2.3">
babel-hello-mcast-history:  </dt>
          <dd pn="section-3.5-2.4">
            <t indent="0" pn="section-3.5-2.4.1">The multicast Hello history of whether or not
the multicast Hello packets prior to babel-exp-mcast-hello-seqno
were received.
A binary sequence where the most recently received Hello
is expressed as a "1" placed in the leftmost bit, with prior bits shifted
right (and "0" bits placed between prior Hello bits and most recent Hello
for any not-received Hellos). This value should be displayed using
hex digits ([0-9a-fA-F]). See <xref target="RFC8966" sectionFormat="comma" section="A.1" format="default" derivedLink="https://rfc-editor.org/rfc/rfc8966#appendix-A.1" derivedContent="RFC8966"/>.</t>
          </dd>
          <dt pn="section-3.5-2.5">
babel-hello-ucast-history:  </dt>
          <dd pn="section-3.5-2.6">
            <t indent="0" pn="section-3.5-2.6.1">The unicast Hello history of whether or not the
unicast Hello packets prior to babel-exp-ucast-hello-seqno were received.
A binary sequence where the most recently received Hello
is expressed as a "1" placed in the leftmost bit, with prior bits shifted
right (and "0" bits placed between prior Hello bits and the most recent Hello
for any not-received Hellos). This value should be displayed using
hex digits ([0-9a-fA-F]). See <xref target="RFC8966" sectionFormat="comma" section="A.1" format="default" derivedLink="https://rfc-editor.org/rfc/rfc8966#appendix-A.1" derivedContent="RFC8966"/>.</t>
          </dd>
          <dt pn="section-3.5-2.7">
babel-txcost:  </dt>
          <dd pn="section-3.5-2.8">
            <t indent="0" pn="section-3.5-2.8.1">Transmission cost value from the last IHU packet received from
this neighbor, or the maximum value to indicate the IHU hold timer
for this neighbor has expired. See <xref target="RFC8966" sectionFormat="comma" section="3.4.2" format="default" derivedLink="https://rfc-editor.org/rfc/rfc8966#section-3.4.2" derivedContent="RFC8966"/>.
This is a 16-bit unsigned integer.</t>
          </dd>
          <dt pn="section-3.5-2.9">
babel-exp-mcast-hello-seqno:  </dt>
          <dd pn="section-3.5-2.10">
            <t indent="0" pn="section-3.5-2.10.1">Expected multicast Hello sequence number of
next Hello to be received from this neighbor. If multicast Hello packets
are not expected or processing of multicast packets is not enabled, this
<bcp14>MUST</bcp14> be NULL.
This is a 16-bit unsigned integer; if the data model uses
zero (0) to represent NULL values for unsigned integers,
the data model <bcp14>MAY</bcp14> use a different data type that allows
differentiation between zero (0) and NULL.</t>
          </dd>
          <dt pn="section-3.5-2.11">
babel-exp-ucast-hello-seqno:  </dt>
          <dd pn="section-3.5-2.12">
            <t indent="0" pn="section-3.5-2.12.1">Expected unicast Hello sequence number of next
Hello to be received from this neighbor. If unicast Hello packets are not
expected or processing of unicast packets is not enabled, this <bcp14>MUST</bcp14> be
NULL.
This is a 16-bit unsigned integer; if the data model uses
zero (0) to represent NULL values for unsigned integers,
the data model <bcp14>MAY</bcp14> use a different data type that allows
differentiation between zero (0) and NULL.</t>
          </dd>
          <dt pn="section-3.5-2.13">
babel-ucast-hello-seqno:  </dt>
          <dd pn="section-3.5-2.14">
            <t indent="0" pn="section-3.5-2.14.1">The current sequence number in use for unicast Hellos
sent to this neighbor. If unicast Hellos are not being sent,
this <bcp14>MUST</bcp14> be NULL.
This is a 16-bit unsigned integer; if the data model uses
zero (0) to represent NULL values for unsigned integers,
the data model <bcp14>MAY</bcp14> use a different data type that allows
differentiation between zero (0) and NULL.</t>
          </dd>
          <dt pn="section-3.5-2.15">
babel-ucast-hello-interval:  </dt>
          <dd pn="section-3.5-2.16">
            <t indent="0" pn="section-3.5-2.16.1">The current interval in use for unicast Hellos
sent to this neighbor. Units are centiseconds.
This is a 16-bit unsigned integer.</t>
          </dd>
          <dt pn="section-3.5-2.17">
babel-rxcost:  </dt>
          <dd pn="section-3.5-2.18">
            <t indent="0" pn="section-3.5-2.18.1">Reception cost calculated for this neighbor. This value is
usually derived from the Hello history, which may be combined with other
data, such as statistics maintained by the link layer. The rxcost is sent
to a neighbor in each IHU. See <xref target="RFC8966" sectionFormat="comma" section="3.4.3" format="default" derivedLink="https://rfc-editor.org/rfc/rfc8966#section-3.4.3" derivedContent="RFC8966"/>.
This is a 16-bit unsigned integer.</t>
          </dd>
          <dt pn="section-3.5-2.19">
babel-cost:  </dt>
          <dd pn="section-3.5-2.20">
            <t indent="0" pn="section-3.5-2.20.1">The link cost, as computed from the values
maintained in the neighbor table: the statistics kept in the
neighbor table about the reception of Hellos and the txcost
computed from received IHU packets.
This is a 16-bit unsigned integer.</t>
          </dd>
        </dl>
      </section>
      <section anchor="definition-of-babel-route-obj" numbered="true" toc="include" removeInRFC="false" pn="section-3.6">
        <name slugifiedName="name-definition-of-babel-route-o">Definition of babel-route-obj</name>
        <sourcecode name="" type="" markers="false" pn="section-3.6-1">
object {
     ip-address   ro babel-route-prefix;
     uint         ro babel-route-prefix-length;
     binary       ro babel-route-router-id;
     reference    ro babel-route-neighbor;
     uint         ro babel-route-received-metric;
     uint         ro babel-route-calculated-metric;
     uint         ro babel-route-seqno;
     ip-address   ro babel-route-next-hop;
     boolean      ro babel-route-feasible;
     boolean      ro babel-route-selected;
} babel-route-obj;
</sourcecode>
        <dl indent="3" newline="false" spacing="normal" pn="section-3.6-2">
          <dt pn="section-3.6-2.1">
babel-route-prefix:  </dt>
          <dd pn="section-3.6-2.2">
            <t indent="0" pn="section-3.6-2.2.1">Prefix (expressed in IP address format) for which this
route is advertised.</t>
          </dd>
          <dt pn="section-3.6-2.3">
babel-route-prefix-length:  </dt>
          <dd pn="section-3.6-2.4">
            <t indent="0" pn="section-3.6-2.4.1">Length of the prefix for which this route is advertised.</t>
          </dd>
          <dt pn="section-3.6-2.5">
babel-route-router-id:  </dt>
          <dd pn="section-3.6-2.6">
            <t indent="0" pn="section-3.6-2.6.1">The router-id of the router that originated this route.</t>
          </dd>
          <dt pn="section-3.6-2.7">
babel-route-neighbor:  </dt>
          <dd pn="section-3.6-2.8">
            <t indent="0" pn="section-3.6-2.8.1">Reference to the babel-neighbors entry for the neighbor
that advertised this route.</t>
          </dd>
          <dt pn="section-3.6-2.9">
babel-route-received-metric:  </dt>
          <dd pn="section-3.6-2.10">
            <t indent="0" pn="section-3.6-2.10.1">The metric with which this route was advertised
by the neighbor, or the maximum value to indicate the route was
recently retracted and is temporarily unreachable (see <xref target="RFC8966" sectionFormat="of" section="3.5.4" format="default" derivedLink="https://rfc-editor.org/rfc/rfc8966#section-3.5.4" derivedContent="RFC8966"/>). This metric will be
NULL if the route was not received from a neighbor
but was generated through other means. At least one of the following 
<bcp14>MUST</bcp14> be non-NULL: babel-route-calculated-metric
or babel-route-received-metric.
Having both be non-NULL is expected for a route that is received and
subsequently advertised.
This is a 16-bit unsigned integer; if the data model uses
zero (0) to represent NULL values for unsigned integers,
the data model <bcp14>MAY</bcp14> use a different data type that allows
differentiation between zero (0) and NULL.</t>
          </dd>
          <dt pn="section-3.6-2.11">
babel-route-calculated-metric:  </dt>
          <dd pn="section-3.6-2.12">
            <t indent="0" pn="section-3.6-2.12.1">A calculated metric for this route. How the
metric is calculated is implementation specific. The maximum value
indicates the route was recently retracted and is temporarily unreachable
(see <xref target="RFC8966" sectionFormat="of" section="3.5.4" format="default" derivedLink="https://rfc-editor.org/rfc/rfc8966#section-3.5.4" derivedContent="RFC8966"/>).
At least one of the following <bcp14>MUST</bcp14> be non-NULL: babel-route-calculated-metric or babel-route-received-metric.
Having both be non-NULL is expected for a route that is received and
subsequently advertised.
This is a 16-bit unsigned integer; if the data model uses
zero (0) to represent NULL values for unsigned integers,
the data model <bcp14>MAY</bcp14> use a different data type that allows
differentiation between zero (0) and NULL.</t>
          </dd>
          <dt pn="section-3.6-2.13">
babel-route-seqno:  </dt>
          <dd pn="section-3.6-2.14">
            <t indent="0" pn="section-3.6-2.14.1">The sequence number with which this route was advertised.
This is a 16-bit unsigned integer.</t>
          </dd>
          <dt pn="section-3.6-2.15">
babel-route-next-hop:  </dt>
          <dd pn="section-3.6-2.16">
            <t indent="0" pn="section-3.6-2.16.1">The next-hop address of this route. This will be empty
if this route has no next-hop address.</t>
          </dd>
          <dt pn="section-3.6-2.17">
babel-route-feasible:  </dt>
          <dd pn="section-3.6-2.18">
            <t indent="0" pn="section-3.6-2.18.1">A Boolean flag indicating whether this route is feasible,
as defined in <xref target="RFC8966" sectionFormat="of" section="3.5.1" format="default" derivedLink="https://rfc-editor.org/rfc/rfc8966#section-3.5.1" derivedContent="RFC8966"/>).</t>
          </dd>
          <dt pn="section-3.6-2.19">
babel-route-selected:  </dt>
          <dd pn="section-3.6-2.20">
            <t indent="0" pn="section-3.6-2.20.1">A Boolean flag indicating whether this route is selected
(i.e., whether it is currently being used for forwarding and
is being advertised).</t>
          </dd>
        </dl>
      </section>
      <section anchor="definition-of-babel-mac-key-set-obj" numbered="true" toc="include" removeInRFC="false" pn="section-3.7">
        <name slugifiedName="name-definition-of-babel-mac-key">Definition of babel-mac-key-set-obj</name>
        <sourcecode name="" type="" markers="false" pn="section-3.7-1">
object {
     boolean             rw babel-mac-default-apply;
     babel-mac-key-obj   rw babel-mac-keys&lt;0..*&gt;;
} babel-mac-key-set-obj;
</sourcecode>
        <dl indent="3" newline="false" spacing="normal" pn="section-3.7-2">
          <dt pn="section-3.7-2.1">
babel-mac-default-apply:  </dt>
          <dd pn="section-3.7-2.2">
            <t indent="0" pn="section-3.7-2.2.1">A Boolean flag indicating whether this object instance is
applied to all new babel-interfaces instances by default.
If "true", this instance is applied to
new babel-interfaces instances at the time they are created by including
it in the babel-if-mac-key-sets list.
If "false", this instance is not applied to new babel-interfaces
instances when they are created.
An implementation <bcp14>MAY</bcp14> choose
to expose this parameter as read-only ("ro").</t>
          </dd>
          <dt pn="section-3.7-2.3">
babel-mac-keys:  </dt>
          <dd pn="section-3.7-2.4">
            <t indent="0" pn="section-3.7-2.4.1">A set of babel-mac-key-obj objects.</t>
          </dd>
        </dl>
      </section>
      <section anchor="definition-of-babel-mac-key-obj" numbered="true" toc="include" removeInRFC="false" pn="section-3.8">
        <name slugifiedName="name-definition-of-babel-mac-key-">Definition of babel-mac-key-obj</name>
        <sourcecode name="" type="" markers="false" pn="section-3.8-1">
object {
     string      rw babel-mac-key-name;
     boolean     rw babel-mac-key-use-send;
     boolean     rw babel-mac-key-use-verify;
     binary      -- babel-mac-key-value;
     string      rw babel-mac-key-algorithm;
    [operation      babel-mac-key-test;]
} babel-mac-key-obj;
</sourcecode>
        <dl indent="3" newline="false" spacing="normal" pn="section-3.8-2">
          <dt pn="section-3.8-2.1">
babel-mac-key-name:  </dt>
          <dd pn="section-3.8-2.2">
            <t indent="0" pn="section-3.8-2.2.1">A unique name for this MAC key that can be used to identify
the key in this object instance since the key value is not
allowed to be read. This value <bcp14>MUST NOT</bcp14> be empty and can only be provided when this
instance is created (i.e., it is not subsequently writable).
The value <bcp14>MAY</bcp14> be auto-generated if not explicitly supplied when the instance is created.</t>
          </dd>
          <dt pn="section-3.8-2.3">
babel-mac-key-use-send:  </dt>
          <dd pn="section-3.8-2.4">
            <t indent="0" pn="section-3.8-2.4.1">Indicates whether this key value is used to compute a MAC
and include that MAC in the sent Babel
packet. A MAC for sent packets is computed using this key if the value
is "true". If the value is "false", this key is not used to
compute a MAC to include in sent Babel packets.
An implementation <bcp14>MAY</bcp14> choose
to expose this parameter as read-only ("ro").</t>
          </dd>
          <dt pn="section-3.8-2.5">
babel-mac-key-use-verify:  </dt>
          <dd pn="section-3.8-2.6">
            <t indent="0" pn="section-3.8-2.6.1">Indicates whether this key value is used to verify
incoming Babel packets. This key is used to verify
incoming packets if the value is "true". If the value
is "false", no MAC is computed from this key for
comparison with the MAC in an incoming packet.
An implementation <bcp14>MAY</bcp14> choose
to expose this parameter as read-only ("ro").</t>
          </dd>
          <dt pn="section-3.8-2.7">
babel-mac-key-value:  </dt>
          <dd pn="section-3.8-2.8">
            <t indent="0" pn="section-3.8-2.8.1">The value of the MAC key. An implementation <bcp14>MUST NOT</bcp14> allow
this parameter to be read. This can be done by always providing
an empty string when read, through permissions, or by other means.
This value <bcp14>MUST</bcp14> be provided when this
instance is created and is not subsequently writable.
This value is of a length suitable for the associated
babel-mac-key-algorithm.
If the algorithm is based on the Hashed Message Authentication Code (HMAC) construction <xref target="RFC2104" format="default" sectionFormat="of" derivedContent="RFC2104"/>,
the length <bcp14>MUST</bcp14> be between 0 and an upper limit that is at least
the size of the output length (where the "HMAC-SHA256" output length
is 32 octets as described in <xref target="RFC4868" format="default" sectionFormat="of" derivedContent="RFC4868"/>). Longer lengths <bcp14>MAY</bcp14> be
supported but are not necessary if the management system has the
ability to generate a suitably random value (e.g., by randomly
generating a value or by using a key derivation technique as
recommended in the security considerations in <xref target="RFC8967" sectionFormat="of" section="7" format="default" derivedLink="https://rfc-editor.org/rfc/rfc8967#section-7" derivedContent="RFC8967"/>). If the
algorithm is "BLAKE2s-128", the length <bcp14>MUST</bcp14> be between 0 and 32
bytes inclusive as specified by <xref target="RFC7693" format="default" sectionFormat="of" derivedContent="RFC7693"/>.</t>
          </dd>
          <dt pn="section-3.8-2.9">
babel-mac-key-algorithm  </dt>
          <dd pn="section-3.8-2.10">
            <t indent="0" pn="section-3.8-2.10.1">The name of the MAC algorithm used with this key.
The value <bcp14>MUST</bcp14> be the same as one of the enumerations
listed in the babel-mac-algorithms parameter.
An implementation <bcp14>MAY</bcp14> choose
to expose this parameter as read-only ("ro").</t>
          </dd>
          <dt pn="section-3.8-2.11">
babel-mac-key-test:  </dt>
          <dd pn="section-3.8-2.12">
            <t indent="0" pn="section-3.8-2.12.1">An operation that allows the MAC key and MAC algorithm to
	    be tested to see if they produce an expected outcome. Input
to this operation is a binary string and a calculated MAC
(also in the format of a binary string) for the binary string.
The implementation is
expected to create a MAC over the binary string using the
babel-mac-key-value and the babel-mac-key-algorithm. The
output of this operation is a Boolean indication that the
calculated MAC matched the input MAC (true) or
the MACs did not match (false).</t>
          </dd>
        </dl>
      </section>
      <section anchor="definition-of-babel-dtls-cert-set-obj" numbered="true" toc="include" removeInRFC="false" pn="section-3.9">
        <name slugifiedName="name-definition-of-babel-dtls-ce">Definition of babel-dtls-cert-set-obj</name>
        <sourcecode name="" type="" markers="false" pn="section-3.9-1">
object {
     boolean               rw babel-dtls-default-apply;
     babel-dtls-cert-obj   rw babel-dtls-certs&lt;0..*&gt;;
} babel-dtls-cert-set-obj;
</sourcecode>
        <dl indent="3" newline="false" spacing="normal" pn="section-3.9-2">
          <dt pn="section-3.9-2.1">
babel-dtls-default-apply:  </dt>
          <dd pn="section-3.9-2.2">
            <t indent="0" pn="section-3.9-2.2.1">A Boolean flag indicating whether this object instance is
applied to all new babel-interfaces instances by default.
If "true", this instance is applied to
new babel-interfaces instances at the time they are created by including
it in the babel-interface-dtls-certs list.
If "false", this instance is not applied to new babel-interfaces
instances when they are created.
An implementation <bcp14>MAY</bcp14> choose
to expose this parameter as read-only ("ro").</t>
          </dd>
          <dt pn="section-3.9-2.3">
babel-dtls-certs:  </dt>
          <dd pn="section-3.9-2.4">
            <t indent="0" pn="section-3.9-2.4.1">A set of babel-dtls-cert-obj objects. This contains both certificates
for this implementation to present for authentication and those to accept
from others. Certificates with a non-empty babel-cert-private-key can
be presented by this implementation for authentication.</t>
          </dd>
        </dl>
      </section>
      <section anchor="definition-of-babel-dtls-cert-obj" numbered="true" toc="include" removeInRFC="false" pn="section-3.10">
        <name slugifiedName="name-definition-of-babel-dtls-cer">Definition of babel-dtls-cert-obj</name>
        <sourcecode name="" type="" markers="false" pn="section-3.10-1">
object {
     string      rw babel-cert-name;
     string      rw babel-cert-value;
     string      rw babel-cert-type;
     binary      -- babel-cert-private-key;
} babel-dtls-cert-obj;
</sourcecode>
        <dl indent="3" newline="false" spacing="normal" pn="section-3.10-2">
          <dt pn="section-3.10-2.1">
babel-cert-name:  </dt>
          <dd pn="section-3.10-2.2">
            <t indent="0" pn="section-3.10-2.2.1">A unique name for this certificate that can be used to identify
the certificate in this object instance since the value is too long
to be useful for identification. This value <bcp14>MUST NOT</bcp14> be empty and can
only be provided when this instance is created (i.e., it is not
subsequently writable). The value <bcp14>MAY</bcp14> be auto-generated if not
explicitly supplied when the instance is created.</t>
          </dd>
          <dt pn="section-3.10-2.3">
babel-cert-value:  </dt>
          <dd pn="section-3.10-2.4">
            <t indent="0" pn="section-3.10-2.4.1">The certificate in Privacy-Enhanced Mail (PEM) format <xref target="RFC7468" format="default" sectionFormat="of" derivedContent="RFC7468"/>.
This value <bcp14>MUST</bcp14> be provided when this
instance is created and is not subsequently writable.</t>
          </dd>
          <dt pn="section-3.10-2.5">
babel-cert-type:  </dt>
          <dd pn="section-3.10-2.6">
            <t indent="0" pn="section-3.10-2.6.1">The name of the certificate type of this object
instance. The value <bcp14>MUST</bcp14> be the same as one of the enumerations
listed in the babel-dtls-cert-types parameter.
This value can only be provided when this
instance is created and is not subsequently writable.</t>
          </dd>
          <dt pn="section-3.10-2.7">
babel-cert-private-key:  </dt>
          <dd pn="section-3.10-2.8">
            <t indent="0" pn="section-3.10-2.8.1">The value of the private key. If this is non-empty, this
certificate can be used by this implementation
to provide a certificate during DTLS handshaking.
An implementation <bcp14>MUST NOT</bcp14> allow
this parameter to be read. This can be done by always providing
an empty string when read, through permissions, or by other means.
This value can only be provided when this
instance is created and is not subsequently writable.</t>
          </dd>
        </dl>
      </section>
    </section>
    <section anchor="extending-the-information-model" numbered="true" toc="include" removeInRFC="false" pn="section-4">
      <name slugifiedName="name-extending-the-information-m">Extending the Information Model</name>
      <t indent="0" pn="section-4-1">Implementations <bcp14>MAY</bcp14> extend this information model with other parameters or
objects. For example, an implementation <bcp14>MAY</bcp14> choose to expose Babel route
filtering rules by adding a route filtering object with parameters appropriate
to how route filtering is done in that implementation. The precise means
used to extend the information model would be specific to the data model
the implementation uses to expose this information.</t>
    </section>
    <section anchor="security-considerations" numbered="true" toc="include" removeInRFC="false" pn="section-5">
      <name slugifiedName="name-security-considerations">Security Considerations</name>
      <t indent="0" pn="section-5-1">This document defines a set of information model objects and parameters that
may be exposed and visible from other devices. Some of these information model objects and parameters may be configured. Securing access to and ensuring the integrity of this data
is in scope of and the responsibility of any data model derived from this
information model. Specifically, any YANG <xref target="RFC7950" format="default" sectionFormat="of" derivedContent="RFC7950"/> data model is expected
to define security exposure of the various parameters, and a <xref target="TR-181" format="default" sectionFormat="of" derivedContent="TR-181"/> data model
will be secured by the mechanisms defined for the management protocol used to
transport it.</t>
      <t indent="0" pn="section-5-2">Misconfiguration (whether unintentional or malicious) can prevent reachability
or cause poor network performance (increased latency, jitter, etc.).
Misconfiguration of security credentials can cause a denial-of-service condition
for the Babel routing protocol.
The information in this model discloses network topology, which can be used
to mount subsequent attacks on traffic traversing the network.</t>
      <t indent="0" pn="section-5-3">This information model defines objects that can allow credentials (for this
device, for trusted devices, and for trusted certificate authorities) to
be added and deleted. Public keys may be exposed through
this model. This model requires that private keys and MAC
keys never be exposed. Certificates used by <xref target="RFC8968" format="default" sectionFormat="of" derivedContent="RFC8968"/>
implementations use separate parameters to model the public
parts (including the public key) and the private key.</t>
      <t indent="0" pn="section-5-4">MAC keys are allowed to be as short as zero length. This is
useful for testing. It is <bcp14>RECOMMENDED</bcp14> that network operators follow current best practices for key length and generation of
keys related to the MAC algorithm associated with the key.
Short (and zero-length) keys are highly susceptible to brute-force attacks
and therefore <bcp14>SHOULD NOT</bcp14> be used.
See the security considerations as described in <xref target="RFC8967" sectionFormat="of" section="7" format="default" derivedLink="https://rfc-editor.org/rfc/rfc8967#section-7" derivedContent="RFC8967"/> 
for additional considerations related to MAC keys; note that there are some specific key value recommendations in the fifth paragraph.
It says that if it is necessary to derive keys from a human-readable
passphrase, "only the derived keys should be communicated to the routers"
and "the original passphrase itself should be kept on the host used to
perform the key generation" (which would be the management system in the
case of a remote management protocol). It also recommends that keys "should
have a length of 32 octets (both for HMAC-SHA256 and BLAKE2s), and be
chosen randomly".</t>
      <t indent="0" pn="section-5-5">This information model uses key sets and certification sets to provide
      a means of grouping keys and certificates. This makes it easy to use
a different set per interface, use the same set for one or more interfaces, have
a default set in case a new interface is instantiated, and
change keys and certificates as needed.</t>
    </section>
    <section anchor="iana-considerations" numbered="true" toc="include" removeInRFC="false" pn="section-6">
      <name slugifiedName="name-iana-considerations">IANA Considerations</name>
      <t indent="0" pn="section-6-1">This document has no IANA actions.</t>
    </section>
  </middle>
  <back>
    <references pn="section-7">
      <name slugifiedName="name-references">References</name>
      <references pn="section-7.1">
        <name slugifiedName="name-normative-references">Normative References</name>
        <reference anchor="ISO.10646" quoteTitle="true" derivedAnchor="ISO.10646">
          <front>
            <title>Information technology - Universal Coded Character Set (UCS)</title>
            <author>
              <organization showOnFrontPage="true">International Organization for Standardization</organization>
            </author>
            <date year="2014"/>
          </front>
          <seriesInfo name="ISO Standard" value="10646:2014"/>
        </reference>
        <reference anchor="libpcap" target="https://gitlab.com/wireshark/wireshark/-/wikis/Development/LibpcapFileFormat" quoteTitle="true" derivedAnchor="libpcap">
          <front>
            <title>Libpcap File Format</title>
            <author>
              <organization showOnFrontPage="true">GitLab</organization>
            </author>
            <date year="2020" month="November"/>
          </front>
          <refcontent>Wireshark Foundation</refcontent>
        </reference>
        <reference anchor="RFC2104" target="https://www.rfc-editor.org/info/rfc2104" quoteTitle="true" derivedAnchor="RFC2104">
          <front>
            <title>HMAC: Keyed-Hashing for Message Authentication</title>
            <author initials="H." surname="Krawczyk" fullname="H. Krawczyk">
              <organization showOnFrontPage="true"/>
            </author>
            <author initials="M." surname="Bellare" fullname="M. Bellare">
              <organization showOnFrontPage="true"/>
            </author>
            <author initials="R." surname="Canetti" fullname="R. Canetti">
              <organization showOnFrontPage="true"/>
            </author>
            <date year="1997" month="February"/>
            <abstract>
              <t indent="0">This document describes HMAC, a mechanism for message authentication using cryptographic hash functions. HMAC can be used with any iterative cryptographic hash function, e.g., MD5, SHA-1, in combination with a secret shared key.  The cryptographic strength of HMAC depends on the properties of the underlying hash function.  This memo provides information for the Internet community.  This memo does not specify an Internet standard of any kind</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="2104"/>
          <seriesInfo name="DOI" value="10.17487/RFC2104"/>
        </reference>
        <reference anchor="RFC2119" target="https://www.rfc-editor.org/info/rfc2119" quoteTitle="true" derivedAnchor="RFC2119">
          <front>
            <title>Key words for use in RFCs to Indicate Requirement Levels</title>
            <author initials="S." surname="Bradner" fullname="S. Bradner">
              <organization showOnFrontPage="true"/>
            </author>
            <date year="1997" month="March"/>
            <abstract>
              <t indent="0">In many standards track documents several words are used to signify the requirements in the specification.  These words are often capitalized. This document defines these words as they should be interpreted in IETF documents.  This document specifies an Internet Best Current Practices for the Internet Community, and requests discussion and suggestions for improvements.</t>
            </abstract>
          </front>
          <seriesInfo name="BCP" value="14"/>
          <seriesInfo name="RFC" value="2119"/>
          <seriesInfo name="DOI" value="10.17487/RFC2119"/>
        </reference>
        <reference anchor="RFC3339" target="https://www.rfc-editor.org/info/rfc3339" quoteTitle="true" derivedAnchor="RFC3339">
          <front>
            <title>Date and Time on the Internet: Timestamps</title>
            <author initials="G." surname="Klyne" fullname="G. Klyne">
              <organization showOnFrontPage="true"/>
            </author>
            <author initials="C." surname="Newman" fullname="C. Newman">
              <organization showOnFrontPage="true"/>
            </author>
            <date year="2002" month="July"/>
            <abstract>
              <t indent="0">This document defines a date and time format for use in Internet protocols that is a profile of the ISO 8601 standard for representation of dates and times using the Gregorian calendar.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="3339"/>
          <seriesInfo name="DOI" value="10.17487/RFC3339"/>
        </reference>
        <reference anchor="RFC4868" target="https://www.rfc-editor.org/info/rfc4868" quoteTitle="true" derivedAnchor="RFC4868">
          <front>
            <title>Using HMAC-SHA-256, HMAC-SHA-384, and HMAC-SHA-512 with IPsec</title>
            <author initials="S." surname="Kelly" fullname="S. Kelly">
              <organization showOnFrontPage="true"/>
            </author>
            <author initials="S." surname="Frankel" fullname="S. Frankel">
              <organization showOnFrontPage="true"/>
            </author>
            <date year="2007" month="May"/>
            <abstract>
              <t indent="0">This specification describes the use of Hashed Message Authentication Mode (HMAC) in conjunction with the SHA-256, SHA-384, and SHA-512 algorithms in IPsec.  These algorithms may be used as the basis for data origin authentication and integrity verification mechanisms for the Authentication Header (AH), Encapsulating Security Payload (ESP), Internet Key Exchange Protocol (IKE), and IKEv2 protocols, and also as Pseudo-Random Functions (PRFs) for IKE and IKEv2.  Truncated output lengths are specified for the authentication-related variants, with the corresponding algorithms designated as HMAC-SHA-256-128, HMAC-SHA-384-192, and HMAC-SHA-512-256.  The PRF variants are not truncated, and are called PRF-HMAC-SHA-256, PRF-HMAC-SHA-384, and PRF-HMAC-SHA-512.  [STANDARDS-TRACK]</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="4868"/>
          <seriesInfo name="DOI" value="10.17487/RFC4868"/>
        </reference>
        <reference anchor="RFC7468" target="https://www.rfc-editor.org/info/rfc7468" quoteTitle="true" derivedAnchor="RFC7468">
          <front>
            <title>Textual Encodings of PKIX, PKCS, and CMS Structures</title>
            <author initials="S." surname="Josefsson" fullname="S. Josefsson">
              <organization showOnFrontPage="true"/>
            </author>
            <author initials="S." surname="Leonard" fullname="S. Leonard">
              <organization showOnFrontPage="true"/>
            </author>
            <date year="2015" month="April"/>
            <abstract>
              <t indent="0">This document describes and discusses the textual encodings of the Public-Key Infrastructure X.509 (PKIX), Public-Key Cryptography Standards (PKCS), and Cryptographic Message Syntax (CMS).  The textual encodings are well-known, are implemented by several applications and libraries, and are widely deployed.  This document articulates the de facto rules by which existing implementations operate and defines them so that future implementations can interoperate.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="7468"/>
          <seriesInfo name="DOI" value="10.17487/RFC7468"/>
        </reference>
        <reference anchor="RFC7693" target="https://www.rfc-editor.org/info/rfc7693" quoteTitle="true" derivedAnchor="RFC7693">
          <front>
            <title>The BLAKE2 Cryptographic Hash and Message Authentication Code (MAC)</title>
            <author initials="M-J." surname="Saarinen" fullname="M-J. Saarinen" role="editor">
              <organization showOnFrontPage="true"/>
            </author>
            <author initials="J-P." surname="Aumasson" fullname="J-P. Aumasson">
              <organization showOnFrontPage="true"/>
            </author>
            <date year="2015" month="November"/>
            <abstract>
              <t indent="0">This document describes the cryptographic hash function BLAKE2 and makes the algorithm specification and C source code conveniently available to the Internet community.  BLAKE2 comes in two main flavors: BLAKE2b is optimized for 64-bit platforms and BLAKE2s for smaller architectures.  BLAKE2 can be directly keyed, making it functionally equivalent to a Message Authentication Code (MAC).</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="7693"/>
          <seriesInfo name="DOI" value="10.17487/RFC7693"/>
        </reference>
        <reference anchor="RFC8174" target="https://www.rfc-editor.org/info/rfc8174" quoteTitle="true" derivedAnchor="RFC8174">
          <front>
            <title>Ambiguity of Uppercase vs Lowercase in RFC 2119 Key Words</title>
            <author initials="B." surname="Leiba" fullname="B. Leiba">
              <organization showOnFrontPage="true"/>
            </author>
            <date year="2017" month="May"/>
            <abstract>
              <t indent="0">RFC 2119 specifies common key words that may be used in protocol  specifications.  This document aims to reduce the ambiguity by clarifying that only UPPERCASE usage of the key words have the  defined special meanings.</t>
            </abstract>
          </front>
          <seriesInfo name="BCP" value="14"/>
          <seriesInfo name="RFC" value="8174"/>
          <seriesInfo name="DOI" value="10.17487/RFC8174"/>
        </reference>
        <reference anchor="RFC8966" target="https://www.rfc-editor.org/info/rfc8966" quoteTitle="true" derivedAnchor="RFC8966">
          <front>
            <title>The Babel Routing Protocol</title>
            <author initials="J." surname="Chroboczek" fullname="J. Chroboczek">
              <organization showOnFrontPage="true"/>
            </author>
            <author initials="D." surname="Schinazi" fullname="D. Schinazi">
              <organization showOnFrontPage="true"/>
            </author>
            <date year="2021" month="January"/>
            <abstract>
              <t indent="0">Babel is a loop-avoiding, distance-vector routing protocol that is robust and efficient both in ordinary wired networks and in wireless mesh networks.  This document describes the Babel routing protocol and obsoletes RFC 6126 and RFC 7557.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="8966"/>
          <seriesInfo name="DOI" value="10.17487/RFC8966"/>
        </reference>
        <reference anchor="RFC8967" target="https://www.rfc-editor.org/info/rfc8967" quoteTitle="true" derivedAnchor="RFC8967">
          <front>
            <title>MAC Authentication for the Babel Routing Protocol</title>
            <author initials="C." surname="Dô" fullname="C. Dô">
              <organization showOnFrontPage="true"/>
            </author>
            <author initials="W." surname="Kolodziejak" fullname="W. Kolodziejak">
              <organization showOnFrontPage="true"/>
            </author>
            <author initials="J." surname="Chroboczek" fullname="J. Chroboczek">
              <organization showOnFrontPage="true"/>
            </author>
            <date year="2021" month="January"/>
            <abstract>
              <t indent="0">This document describes a cryptographic authentication mechanism for the Babel routing protocol that has provisions for replay avoidance.  This document obsoletes RFC 7298.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="8967"/>
          <seriesInfo name="DOI" value="10.17487/RFC8967"/>
        </reference>
        <reference anchor="RFC8968" target="https://www.rfc-editor.org/info/rfc8968" quoteTitle="true" derivedAnchor="RFC8968">
          <front>
            <title>Babel Routing Protocol over Datagram Transport Layer Security</title>
            <author initials="A." surname="Décimo" fullname="A. Décimo">
              <organization showOnFrontPage="true"/>
            </author>
            <author initials="D." surname="Schinazi" fullname="D. Schinazi">
              <organization showOnFrontPage="true"/>
            </author>
            <author initials="J." surname="Chroboczek" fullname="J. Chroboczek">
              <organization showOnFrontPage="true"/>
            </author>
            <date year="2021" month="January"/>
            <abstract>
              <t indent="0">The Babel Routing Protocol does not contain any means to authenticate neighbours or provide integrity or confidentiality for messages sent between them.  This document specifies a mechanism to ensure these properties using Datagram Transport Layer Security (DTLS).</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="8968"/>
          <seriesInfo name="DOI" value="10.17487/RFC8968"/>
        </reference>
      </references>
      <references pn="section-7.2">
        <name slugifiedName="name-informative-references">Informative References</name>
        <reference anchor="RFC6241" target="https://www.rfc-editor.org/info/rfc6241" quoteTitle="true" derivedAnchor="RFC6241">
          <front>
            <title>Network Configuration Protocol (NETCONF)</title>
            <author initials="R." surname="Enns" fullname="R. Enns" role="editor">
              <organization showOnFrontPage="true"/>
            </author>
            <author initials="M." surname="Bjorklund" fullname="M. Bjorklund" role="editor">
              <organization showOnFrontPage="true"/>
            </author>
            <author initials="J." surname="Schoenwaelder" fullname="J. Schoenwaelder" role="editor">
              <organization showOnFrontPage="true"/>
            </author>
            <author initials="A." surname="Bierman" fullname="A. Bierman" role="editor">
              <organization showOnFrontPage="true"/>
            </author>
            <date year="2011" month="June"/>
            <abstract>
              <t indent="0">The Network Configuration Protocol (NETCONF) defined in this document provides mechanisms to install, manipulate, and delete the configuration of network devices.  It uses an Extensible Markup Language (XML)-based data encoding for the configuration data as well as the protocol messages.  The NETCONF protocol operations are realized as remote procedure calls (RPCs).  This document obsoletes RFC 4741.  [STANDARDS-TRACK]</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="6241"/>
          <seriesInfo name="DOI" value="10.17487/RFC6241"/>
        </reference>
        <reference anchor="RFC7950" target="https://www.rfc-editor.org/info/rfc7950" quoteTitle="true" derivedAnchor="RFC7950">
          <front>
            <title>The YANG 1.1 Data Modeling Language</title>
            <author initials="M." surname="Bjorklund" fullname="M. Bjorklund" role="editor">
              <organization showOnFrontPage="true"/>
            </author>
            <date year="2016" month="August"/>
            <abstract>
              <t indent="0">YANG is a data modeling language used to model configuration data, state data, Remote Procedure Calls, and notifications for network management protocols.  This document describes the syntax and semantics of version 1.1 of the YANG language.  YANG version 1.1 is a maintenance release of the YANG language, addressing ambiguities and defects in the original specification.  There are a small number of backward incompatibilities from YANG version 1.  This document also specifies the YANG mappings to the Network Configuration Protocol (NETCONF).</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="7950"/>
          <seriesInfo name="DOI" value="10.17487/RFC7950"/>
        </reference>
        <reference anchor="RFC8193" target="https://www.rfc-editor.org/info/rfc8193" quoteTitle="true" derivedAnchor="RFC8193">
          <front>
            <title>Information Model for Large-Scale Measurement Platforms (LMAPs)</title>
            <author initials="T." surname="Burbridge" fullname="T. Burbridge">
              <organization showOnFrontPage="true"/>
            </author>
            <author initials="P." surname="Eardley" fullname="P. Eardley">
              <organization showOnFrontPage="true"/>
            </author>
            <author initials="M." surname="Bagnulo" fullname="M. Bagnulo">
              <organization showOnFrontPage="true"/>
            </author>
            <author initials="J." surname="Schoenwaelder" fullname="J. Schoenwaelder">
              <organization showOnFrontPage="true"/>
            </author>
            <date year="2017" month="August"/>
            <abstract>
              <t indent="0">This Information Model applies to the Measurement Agent within an LMAP framework.  As such, it outlines the information that is configured or preconfigured on the Measurement Agent or exists in communications with a Controller or Collector within an LMAP framework.  The purpose of such an Information Model is to provide a protocol- and device-independent view of the Measurement Agent that can be implemented via one or more Control and Report Protocols.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="8193"/>
          <seriesInfo name="DOI" value="10.17487/RFC8193"/>
        </reference>
        <reference anchor="TR-181" target="http://cwmp-data-models.broadband-forum.org/" quoteTitle="true" derivedAnchor="TR-181">
          <front>
            <title>Device Data Model</title>
            <author>
              <organization showOnFrontPage="true">Broadband Forum</organization>
            </author>
            <date month="November" year="2020"/>
          </front>
          <refcontent>Issue: 2 Amendment 14</refcontent>
        </reference>
      </references>
    </references>
    <section anchor="Acknowledgements" numbered="false" toc="include" removeInRFC="false" pn="section-appendix.a">
      <name slugifiedName="name-acknowledgements">Acknowledgements</name>
      <t indent="0" pn="section-appendix.a-1"><contact fullname="Juliusz Chroboczek"/>, <contact fullname="Toke Høiland-Jørgensen"/>, <contact fullname="David Schinazi"/>,
<contact fullname="Antonin Décimo"/>, <contact fullname="Roman Danyliw"/>, <contact fullname="Benjamin Kaduk"/>, <contact fullname="Valery Smyslov"/>, <contact fullname="Alvaro Retana"/>, <contact fullname="Donald Eastlake"/>, <contact fullname="Martin Vigoureux"/>,
<contact fullname="Acee Lindem"/>, and <contact fullname="Carsten Bormann"/> have been very helpful in
refining this information model.</t>
      <t indent="0" pn="section-appendix.a-2">The language in the <xref target="notation" format="none" sectionFormat="of" derivedContent="">"Notation"</xref> section was mostly taken from <xref target="RFC8193" format="default" sectionFormat="of" derivedContent="RFC8193"/>.</t>
    </section>
    <section anchor="authors-addresses" numbered="false" removeInRFC="false" toc="include" pn="section-appendix.b">
      <name slugifiedName="name-authors-addresses">Authors' Addresses</name>
      <author initials="B." surname="Stark" fullname="Barbara Stark">
        <organization showOnFrontPage="true">AT&amp;T</organization>
        <address>
          <postal>
            <street/>
            <city/>
            <region>TX</region>
            <code/>
            <country>United States of America</country>
          </postal>
          <phone/>
          <email>barbara.stark@att.com</email>
        </address>
      </author>
      <author initials="M." surname="Jethanandani" fullname="Mahesh Jethanandani">
        <organization showOnFrontPage="true">Kloud Services</organization>
        <address>
          <postal>
            <street/>
            <city/>
            <region>CA</region>
            <code/>
            <country>United States of America</country>
          </postal>
          <phone/>
          <email>mjethanandani@gmail.com</email>
        </address>
      </author>
    </section>
  </back>
</rfc>
