<?xml version='1.0' encoding='utf-8'?>
<!DOCTYPE rfc [
  <!ENTITY nbsp    "&#160;">
  <!ENTITY zwsp   "&#8203;">
  <!ENTITY nbhy   "&#8209;">
  <!ENTITY wj     "&#8288;">
]>
<?xml-stylesheet type="text/xsl" href="rfc2629.xslt" ?>
<!-- generated by https://github.com/cabo/kramdown-rfc version 1.7.4 (Ruby 2.7.0) -->
<rfc xmlns:xi="http://www.w3.org/2001/XInclude" ipr="trust200902" docName="draft-ietf-ivy-network-inventory-yang-00" category="std" consensus="true" submissionType="IETF" tocInclude="true" sortRefs="true" symRefs="true" version="3">
  <!-- xml2rfc v2v3 conversion 3.18.2 -->
  <front>
    <title abbrev="Network Inventory YANG">A YANG Data Model for Network Inventory</title>
    <seriesInfo name="Internet-Draft" value="draft-ietf-ivy-network-inventory-yang-00"/>
    <author initials="C." surname="Yu" fullname="Chaode Yu">
      <organization>Huawei Technologies</organization>
      <address>
        <email>yuchaode@huawei.com</email>
      </address>
    </author>
    <author initials="S." surname="Belotti" fullname="Sergio Belotti">
      <organization>Nokia</organization>
      <address>
        <email>sergio.belotti@nokia.com</email>
      </address>
    </author>
    <author initials="J.-F." surname="Bouquier" fullname="Jean-Francois Bouquier">
      <organization>Vodafone</organization>
      <address>
        <email>jeff.bouquier@vodafone.com</email>
      </address>
    </author>
    <author initials="F." surname="Peruzzini" fullname="Fabio Peruzzini">
      <organization>TIM</organization>
      <address>
        <email>fabio.peruzzini@telecomitalia.it</email>
      </address>
    </author>
    <author initials="P." surname="Bedard" fullname="Phil Bedard">
      <organization>Cisco</organization>
      <address>
        <email>phbedard@cisco.com</email>
      </address>
    </author>
    <date year="2023" month="December" day="06"/>
    <keyword>next generation</keyword>
    <keyword>unicorn</keyword>
    <keyword>sparkling distributed ledger</keyword>
    <abstract>
      <?line 98?>

<t>This document defines a base YANG data model for network inventory
that is application- and technology-agnostic.  This data model can be
augmented with application-specific and technology-specific details
in other, more specific network inventory data models.</t>
    </abstract>
    <note removeInRFC="true">
      <name>About This Document</name>
      <t>
        The latest revision of this draft can be found at <eref target="https://ietf-ivy-wg.github.io/network-inventory-yang/draft-ietf-ivy-network-inventory-yang.html"/>.
        Status information for this document may be found at <eref target="https://datatracker.ietf.org/doc/draft-ietf-ivy-network-inventory-yang/"/>.
      </t>
      <t>Source for this draft and an issue tracker can be found at
        <eref target="https://github.com/ietf-ivy-wg/network-inventory-yang"/>.</t>
    </note>
  </front>
  <middle>
    <?line 105?>

<section anchor="introduction">
      <name>Introduction</name>
      <t>The purpose of this document is to define a base network inventory
YANG data model that is application- and technology-agnostic.  The
base data model can be augmented to describe application-specific or
technology-specific information.</t>
      <t>Network Inventory management is a key component in
operators' OSS architectures.</t>
      <t>Network Inventory is a fundamental functionality in network
management and was specified many years ago.  Given the emergence of
data models and their deployment in operator's management and control
systems, the traditional function of inventory management is also
requested to be defined as a data model.</t>
      <t>Network Inventory management and monitoring is a critical
part for ensuring the network stays healthy, well-planned, and
functioning in the operator's network.  Network Inventory
management allows the operator to keep track of which physical
devices are deployed in the network including relevant software and
hardware versions.</t>
      <t>The Network Inventory management also helps the operator to
know when to acquire new assets and what is needed, or to
decommission old or faulty ones, which can help to improve network
performance and capacity planning.</t>
      <t>In <xref target="I-D.ietf-teas-actn-poi-applicability"/> a gap was identified
regarding the lack of a YANG data model that could be used at ACTN
MPI interface level to report whole/partial network hardware
inventory information available at domain controller level towards
north-bound systems (e.g., MDSC or OSS layer).</t>
      <t><xref target="RFC8345"/> initial goal was to make possible the augmentation of the
YANG data model with Network Inventory data model but this
was never developed and the scope was kept limited to network
topology data only.</t>
      <t>It is key for operators to drive the industry towards the use of a
standard YANG data model for Network Inventory data instead
of using vendors proprietary APIs (e.g., REST API).</t>
      <t>In the ACTN architecture, this would bring also clear benefits at
MDSC level for packet over optical integration scenarios since this
would enable the correlation of the HW network inventory information with the
links information reported in the network topology model. This represent a priority for operators to implement this with a standard YANG data model that could be used as soon as possible in multi-vendor integrations of PNCs with MDSCs.</t>
      <t>The intention is to define a generic YANG base data model that would be as
much as possible technology agnostic (valid for IP, optical and
microwave networks) and that could be augmented, when required, to
include some technology-specific inventory details together with specific HW or SW component’s attributes.</t>
      <t><xref target="RFC8348"/> defines a YANG data model for the management of the hardware on a single server and therefore it is more applicable to the domain controller South Bound Interface (SBI) towards the network elements rather than at the domain controller's northbound. However, the YANG data model defined in <xref target="RFC8348"/> has been used as a reference for defining the YANG network inventory data model presented in this draft.</t>
      <t>The proposed YANG data model has been analyzed at the present stage to cover the common requirements for both HW and SW use cases for Network Inventory.</t>
      <t>Network Inventory is a collection of data for network devices and
their components managed by a specific management system.  Per the
definition of <xref target="RFC8969"/>,the network inventory model is a network
model.</t>
      <t>This document defines one YANG module "ietf-network-inventory" in <xref target="ni-yang"/>.</t>
      <t><xref target="ni-augment"/> provides a set of augmentation considerations for extensions
of hardware, software, entitlement, and inventory topology mapping.</t>
      <t>The YANG data model defined in this document conforms to the Network Management Datastore Architecture <xref target="RFC8342"/>.</t>
      <section anchor="terminology-and-notations">
        <name>Terminology and Notations</name>
        <t>The following terms are defined in <xref target="RFC7950"/> and are not
  redefined here:</t>
        <ul spacing="normal">
          <li>
            <t>client</t>
          </li>
          <li>
            <t>server</t>
          </li>
          <li>
            <t>augment</t>
          </li>
          <li>
            <t>data model</t>
          </li>
          <li>
            <t>data node</t>
          </li>
        </ul>
        <t>The following terms are defined in <xref target="RFC6241"/> and are not redefined
  here:</t>
        <ul spacing="normal">
          <li>
            <t>configuration data</t>
          </li>
          <li>
            <t>state data</t>
          </li>
        </ul>
        <t>The terminology for describing YANG data models is found in
  <xref target="RFC7950"/>.</t>
        <t>TBD: Recap the concept of chassis/slot/component/board/... in <xref target="TMF_SD2-20"/>.</t>
        <t>Following terms are used for the representation of the hierarchies in the network inventory.</t>
        <t>Network Inventory:</t>
        <ul empty="true">
          <li>
            <t>a collection of data for network devices and their components managed by a specific management system.</t>
          </li>
        </ul>
        <t>Network Element:</t>
        <ul empty="true">
          <li>
            <t>a manageable network entity that contains hardware and software units, e.g. a network device installed on one or several chassis</t>
          </li>
        </ul>
        <t>Chassis:</t>
        <ul empty="true">
          <li>
            <t>a holder of the device installation.</t>
          </li>
        </ul>
        <t>Slot:</t>
        <ul empty="true">
          <li>
            <t>a holder of the board.</t>
          </li>
        </ul>
        <t>Component:</t>
        <ul empty="true">
          <li>
            <t>a unit of the network element, e.g.  hardware components like chassis, card, port, software components like software-patch, bios, and boot-loader</t>
          </li>
        </ul>
        <t>Board/Card:</t>
        <ul empty="true">
          <li>
            <t>a pluggable equipment can be inserted into one or several slots/sub-slots and can afford a specific transmission function independently.</t>
          </li>
        </ul>
        <t>Port:</t>
        <ul empty="true">
          <li>
            <t>an interface on board</t>
          </li>
        </ul>
      </section>
      <section anchor="requirements-notation">
        <name>Requirements Notation</name>
        <t>The key words "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL
NOT", "SHOULD", "SHOULD NOT", "RECOMMENDED", "NOT RECOMMENDED",
"MAY", and "OPTIONAL" in this document are to be interpreted as
described in BCP 14 <xref target="RFC2119"/> <xref target="RFC8174"/> when, and only when, they
appear in all capitals, as shown here.
<?line -6?>
        </t>
      </section>
      <section anchor="tree-diagram">
        <name>Tree Diagram</name>
        <t>A simplified graphical representation of the data model is used in <xref target="ni-tree"/> of this document.
The meaning of the symbols in this diagram is defined in <xref target="RFC8340"/>.</t>
      </section>
      <section anchor="prefix-in-data-node-names">
        <name>Prefix in Data Node Names</name>
        <t>In this document, names of data nodes and other data model objects
  are prefixed using the standard prefix associated with the
  corresponding YANG imported modules, as shown in the following table.</t>
        <table anchor="tab-prefixes">
          <name>Prefixes and corresponding YANG modules</name>
          <thead>
            <tr>
              <th align="left">Prefix</th>
              <th align="left">Yang Module</th>
              <th align="left">Reference</th>
            </tr>
          </thead>
          <tbody>
            <tr>
              <td align="left">inet</td>
              <td align="left">ietf-inet-types</td>
              <td align="left">
                <xref target="RFC6991"/></td>
            </tr>
            <tr>
              <td align="left">yang</td>
              <td align="left">ietf-yang-types</td>
              <td align="left">
                <xref target="RFC6991"/></td>
            </tr>
            <tr>
              <td align="left">ianahw</td>
              <td align="left">iana-hardware</td>
              <td align="left">
                <xref target="IANA_YANG"/></td>
            </tr>
            <tr>
              <td align="left">ni</td>
              <td align="left">ietf-network-inventory</td>
              <td align="left">RFC XXXX</td>
            </tr>
          </tbody>
        </table>
        <t>RFC Editor Note:
Please replace XXXX with the RFC number assigned to this document.
Please remove this note.</t>
      </section>
    </section>
    <section anchor="yang-data-model-for-network-inventory-overview">
      <name>YANG Data Model for Network Inventory Overview</name>
      <t>The network element definition is generalized to support physical
devices and other types of inventory objects (e.g., virtual network
elements) that can be managed as physical network elements from an
inventory perspective. The data model for Network Element presented
in this document uses a flat list of network element.</t>
      <t>The "ne-type" is defined as a YANG identity to describe the type of the network element. This document defines only the "physical-network-element" identity.</t>
      <t>The component definition is also generalized to support any type of
component, such as hardware, software, or firmware.</t>
      <t>The component "class" is defined as a union between the hardware
class identity, defined in "iana-hardware", and the "non-hardware"
identity, defined in this document.</t>
      <t>The identity definition of additional types of "ne-type" and "non-
hardware" identity of component are outside the scope of this
document and could be defined in application-specific or technology-
specific companion augmentation data models, such as
<xref target="I-D.wzwb-ivy-network-inventory-software"/>.</t>
      <t>In <xref target="RFC8348"/>, rack, chassis, slot, sub-slot, board and port are defined as components of network elements with generic attributes.</t>
      <t>While <xref target="RFC8348"/> is used to manage the hardware of a single server (e.g., a network element), the Network Inventory YANG data model is used to retrieve the base network inventory information that a controller discovers from all the network elements under its control.</t>
      <t>However, the YANG data model defined in <xref target="RFC8348"/> has been used as a reference for defining the YANG network inventory data model. This approach can simplify the implementation of this network inventory model when the controller uses the YANG data model defined in <xref target="RFC8348"/> to retrieve the hardware  from the network elements under its control.</t>
      <artwork type="ascii-art"><![CDATA[
  +--rw network-elements
     +--rw network-element* [ne-id]
        +--rw ne-id            string
        ............................................
        +--rw components
           +--rw component* [component-id]
              +--rw component-id            string
              ......................................
]]></artwork>
      <section anchor="common-design-for-all-inventory-objects">
        <name>Common Design for All Inventory Objects</name>
        <t>For all the inventory objects, there are some common attributes existing. Such as:</t>
        <t>Identifier: here we suggest to use uuid format which is widely implemented with systems. It is guaranteed to be globally unique.</t>
        <t>Name: name is a human-readable label information which could be used to present on GUI. This name is suggested to be provided by server.</t>
        <t>Alias: alias is also a human-readable label information which could be modified by user. It could also be present on GUI instead of name.</t>
        <t>Description: description is a human-readable information which could be also input by user. Description provides more detailed information to prompt users when performing maintenance operations.</t>
        <artwork type="ascii-art"><![CDATA[
  +--rw network-elements
     +--rw network-element* [ne-id]
        +--rw ne-id            string
        +--rw ne-type?         identityref
        +--rw uuid?            yang:uuid
        +--rw name?            string
        +--rw description?     string
        +--rw alias?           string
        ...................................
        +--rw components
           +--rw component* [component-id]
              +--rw component-id            string
              +--rw uuid?                   yang:uuid
              +--rw name?                   string
              +--rw description?            string
              +--rw alias?                  string
              +--rw class                   union
              ...................................
]]></artwork>
      </section>
      <section anchor="network-element">
        <name>Network Element</name>
        <t>To be consistent with the component definition, some of the
attributes defined in <xref target="RFC8348"/> for components are reused for network
elements.  These attributes include:</t>
        <artwork type="ascii-art"><![CDATA[
  +--rw network-elements
     +--rw network-element* [ne-id]
        ...................................
        +--rw hardware-rev?    string
        +--rw software-rev?    string
        +--rw mfg-name?        string
        +--rw mfg-date?        yang:date-and-time
        +--rw part-number?     string
        +--rw serial-number?   string
        +--rw product-name?    string
        ...................................
]]></artwork>
        <t>Note: Not all the attributes defined in <xref target="RFC8348"/> are applicable for network element. And there could also be some missing attributes which are not recognized by <xref target="RFC8348"/>. More extensions could be introduced in later revisions after the missing attributes are fully discussed.</t>
      </section>
      <section anchor="ne-component">
        <name>Components</name>
        <t>The YANG data model for network inventory mainly follows the same approach of <xref target="RFC8348"/> and reports the network hardware inventory as a list of components with different types (e.g., chassis, module, port).</t>
        <t>The component definition is generalized to both hardware components
and non-hardware components (e.g., software components).</t>
        <artwork type="ascii-art"><![CDATA[
  +--rw components
      +--rw component* [component-id]
        +--rw component-id            string
        +--rw uuid?                   yang:uuid
        +--rw name?                   string
        +--rw description?            string
        +--rw alias?                  string
        +--rw class                   union
        +--rw child-component-ref
        +--rw parent-rel-pos?         int32
        +--rw parent-component-ref
        +--rw hardware-rev?           string
        +--rw firmware-rev?           string
        +--rw software-rev?           string
        +--rw serial-num?             string
        +--rw mfg-name?               string
        +--rw part-number?            string
        +--rw asset-id?               string
        +--rw is-fru?                 boolean
        +--rw mfg-date?               yang:date-and-time
        +--rw uri*                    inet:uri
]]></artwork>
        <t>For state data like admin-state, oper-state and so on, we consider they are related to device hardware management and not network inventory. Therefore, they are outside of scope of this document. Same for the sensor-data, they should be defined in some other performance monitoring data models instead of inventory data model.</t>
        <section anchor="hardware-components">
          <name>Hardware Components</name>
          <t>Based on TMF classification in <xref target="TMF_SD2-20"/>, hardware components can be divided into two groups, holder group and equipment group. The holder group contains rack, chassis, slot, sub-slot while the equipment group contains network-element, board and port.</t>
          <t>The relationship between typical inventory objects in a physical network element can be described by <xref target="fig-hw-inventory-object-relationship"/> below:</t>
          <figure anchor="fig-hw-inventory-object-relationship">
            <name>Relationship between typical inventory objects in physical network elements</name>
            <artwork type="ascii-art"><![CDATA[
                            +-----------------+
                            | network element |
                            +-----------------+
                                    ||
                                    ||
                                    ||
                                    ||1:M
                                    ||
                                    ||
                                    ||
                                    \/
                              +-------------+
                              |   chassis/  |---+
                              | sub-chassis |<--|
                              +-------------+
                                    ||
                     ______1:N______||_____1:M_______
                     ||------------------ ---------||
                     \/                            \/
              +--------------+               +-----------+
          +---|     slot     |               |   board   |
          |-->|  /sub-slot   |               |           |
              +--------------+               +-----------+
                                                   ||
                                                   ||1:N
                                                   \/
                                             +-----------+
                                             |    port   |
                                             +-----------+
]]></artwork>
          </figure>
          <t>The "iana-hardware" module <xref target="IANA_YANG"/> defines YANG identities for
the hardware component types in the IANA-maintained "IANA-ENTITY-MIB"
registry.</t>
          <t>Some of the definitions taken from <xref target="RFC8348"/> are actually based on the ENTITY-MIB <xref target="RFC6933"/>.</t>
          <t>For the additional attributes of specific hardware, such as CPU,
storage, port, power supply is defined in the hardware extension.</t>
        </section>
        <section anchor="software-components">
          <name>Software Components</name>
          <t>This document defines "software-rev" of NEs and components, which are
basic software attributes of a Network Element.</t>
          <t>The software and hardware components share the same attributes of the
component and have similar replaceable requirements. Generally, the
device also has other software data, for example, one or more
software patch information.</t>
          <t>The software components of other
classes, such as platform software, BIOS, bootloader, and software
patch information, are outside the scope of this document and defined other documents such as
<xref target="I-D.wzwb-ivy-network-inventory-software"/>.</t>
        </section>
      </section>
      <section anchor="changes-with-respect-to-rfc8348">
        <name>Changes with respect to RFC8348</name>
        <t>We re-defined some attributes listed in <xref target="RFC8348"/>, based on some integration experience for network wide inventory data.</t>
        <section anchor="new-parent-identifiers-reference">
          <name>New Parent Identifiers' Reference</name>
          <t><xref target="RFC8348"/> provided a "parent-ref" attribute, which was an identifier reference to its parent component. When the MDSC or OSS systems want to find this component's grandparent or higher level component in the hierarchy, they need to retrieve this parent-ref step by step. To reduce this iterative work, we decided to provide a list of hierarchical parent components' identifier references.</t>
          <artwork type="ascii-art"><![CDATA[
  +--ro components
     +--ro component* [uuid]
        ...................................
        +--ro parent-component-references
        |   +--ro component-reference* [index]
        |      +--ro index    uint8
        |      +--ro class?   -> ../../../class
        |      +--ro uuid?    -> ../../../uuid
        ...................................
]]></artwork>
          <t>The hierarchical components' identifier could be found by the "component-reference" list. The "index" attribute is used to order the list by the hierarchical relationship from topmost component (with the "index" set to 0) to bottom component.</t>
        </section>
        <section anchor="component-specific-info-design">
          <name>Component-Specific Info Design</name>
          <t>According to the management requirements from operators, some important attributes are not defined in <xref target="RFC8348"/>. These attributes could be component-specific and are not suitable to define under the component list node. So, the model can be augmented with HW/SW specific-info-grouping containing attributes applicable to HW e.g. boards/slot or SW e.g. software-module/boot-loader component only.</t>
          <artwork type="ascii-art"><![CDATA[
  augment /ni:network-elements/ni:network-element:
    +--rw virtual-ne-attributes
  augment /ni:network-elements/ni:network-element/ni:components
            /ni:component:
    +--rw software-module-specific-info
]]></artwork>
        </section>
        <section anchor="part-number">
          <name>Part Number</name>
          <t>According to the description in <xref target="RFC8348"/>, the attribute named "model-name" under the component, is preferred to have a customer-visible part number value. "Model-name" is not straightforward to understand and we suggest to rename it as "part-number" directly.</t>
          <artwork type="ascii-art"><![CDATA[
  +--ro components
     +--ro component* [uuid]
        ...................................
        +--ro part-number?           string
        ...................................
]]></artwork>
        </section>
      </section>
      <section anchor="efficiency-issue">
        <name>Efficiency Issue</name>
        <t>During  the integration with OSS in some operators, some efficiency/scalability concerns have been discovered when synchronizing network inventory data for big networks.  More discussions are needed to address these concerns.</t>
        <t>Considering that relational databases are widely used by traditional OSS systems and also by some network controllers, the inventory objects are most likely to be saved in different tables. With the model defined in current draft, when doing a full synchronization, network controller needs to convert all inventory objects of each NE into component objects and combine them together into a single list, and then construct a response and send to OSS or MDSC. The OSS or MDSC needs to classify the component list and divide them into different groups, in order to save them in different tables. The combining-regrouping steps are impacting the network controller &amp; OSS/MDSC processing, which may result in efficiency/scalability limitations in large scale networks.</t>
        <t>An alternative YANG model structure, which defines the inventory objects directly, instead of defining generic components, has also been analyzed. However, also with this model, there still could be some scalability limitations when synchronizing full inventory resources in large scale of networks. This scalability limitation is caused by the limited transmission capabilities of HTTP protocol. We think that this scalability limitation should be solved at protocol level rather than data model level.</t>
        <t>The model proposed by this draft is designed to be as generic as possible so to cover future special types of inventory objects that could be used in other technologies, that have not been identified yet. If the inventory objects were to be defined directly with fixed hierarchical relationships in YANG model, this new type of inventory objects needs to be manually defined, which is not a backward compatible change and therefore is not an acceptable approach for implementation. With a generic model, it is only needed to augment a new component class and extend some specific attributes for this new inventory component class, which is more flexible. We consider that this generic data model, enabling a flexible and backward compatible approach for other technologies, represents the main scope of this draft. Solution description to efficiency/scalability limitations mentioned above is considered as out-of-scope.</t>
      </section>
    </section>
    <section anchor="ni-augment">
      <name>Extending Network Inventory</name>
      <t>This document defines the basic network inventory attributes
applicable to typical network scenarios.  For finer-grained and
specific management scenarios, the relationship between this model
and other models is illustrated in Figure 4.</t>
      <artwork type="ascii-art"><![CDATA[
             +-------------------------+
             |                         |
             | Base Network Inventory  |
             |                         |
             +------------+------------+
                          |
       +------------------+-------------------+
       |                  |                   |
+------V------+    +------V------      +------V------    +-------------+
|             |    |             |     |             |   |             |
| Hardware    |    |  Software   |     |             |   |  Inventory  |
| Extensions  |    |  Extensions |     | Entitlement |   |  Topology   |
| e.g. Power  |    |  e.g.       |     |             |   |  Mapping    |
| supply unit |    |  SW patch   |     |             |   |             |
+-------------+    +-------------+     +-------------+   +-------------+
]]></artwork>
    </section>
    <section anchor="ni-tree">
      <name>Network Inventory Tree Diagram</name>
      <t><xref target="fig-ni-tree"/> below shows the tree diagram of the YANG data model defined in module "ietf-network-inventory" (<xref target="ni-yang"/>).</t>
      <figure anchor="fig-ni-tree">
        <name>Network inventory tree diagram</name>
        <artwork type="ascii-art" name="ietf-network-inventory.tree"><![CDATA[
module: ietf-network-inventory
  +--rw network-elements
     +--rw network-element* [ne-id]
        +--rw ne-id            string
        +--rw ne-type?         identityref
        +--rw uuid?            yang:uuid
        +--rw name?            string
        +--rw description?     string
        +--rw alias?           string
        +--rw hardware-rev?    string
        +--rw software-rev?    string
        +--rw mfg-name?        string
        +--rw mfg-date?        yang:date-and-time
        +--rw part-number?     string
        +--rw serial-number?   string
        +--rw product-name?    string
        +--rw components
           +--rw component* [component-id]
              +--rw component-id            string
              +--rw class                   union
              +--rw uuid?                   yang:uuid
              +--rw name?                   string
              +--rw description?            string
              +--rw alias?                  string
              +--rw child-component-ref
              +--rw parent-rel-pos?         int32
              +--rw parent-component-ref
              +--rw hardware-rev?           string
              +--rw firmware-rev?           string
              +--rw software-rev?           string
              +--rw serial-num?             string
              +--rw mfg-name?               string
              +--rw part-number?            string
              +--rw asset-id?               string
              +--rw is-fru?                 boolean
              +--rw mfg-date?               yang:date-and-time
              +--rw uri*                    inet:uri
]]></artwork>
      </figure>
    </section>
    <section anchor="ni-yang">
      <name>YANG Data Model for Network Inventory</name>
      <figure anchor="fig-ni-yang">
        <name>Network inventory YANG module</name>
        <sourcecode type="yang" markers="true" name="ietf-network-inventory@2023-03-07.yang"><![CDATA[
module ietf-network-inventory {
  yang-version 1.1;
  namespace "urn:ietf:params:xml:ns:yang:ietf-network-inventory";
  prefix ni;

  import iana-hardware {
    prefix ianahw;
    reference
      "https://www.iana.org/assignments/yang-parameters";
  }
  
  import ietf-yang-types {
    prefix yang;
    reference
      "RFC6991: Common YANG Data Types.";
  }
  
  import ietf-inet-types {
    prefix inet;
    reference
      "RFC6991: Common YANG Data Types.";
  } 

  organization
    "IETF IVY Working Group";
  contact
    "WG Web:   <https://datatracker.ietf.org/wg/ivy/>
     WG List:  <mailto:inventory-yang@ietf.org>

     Editor:   Chaode Yu
               <yuchaode@huawei.com>

     Editor:   Sergio Belotti
               <sergio.belotti@nokia.com>

     Editor:   Jean-Francois Bouquier
               <jeff.bouquier@vodafone.com>

     Editor:   Fabio Peruzzini
               <fabio.peruzzini@telecomitalia.it>

     Editor:   Phil Bedard
               <phbedard@cisco.com>";

  description
    "This module defines a base model for retrieving network 
    inventory.

    The model fully conforms to the Network Management 
    Datastore Architecture (NMDA).
    
    Copyright (c) 2023 IETF Trust and the persons
    identified as authors of the code.  All rights reserved.

    Redistribution and use in source and binary forms, with or
    without modification, is permitted pursuant to, and subject
    to the license terms contained in, the Revised BSD License
    set forth in Section 4.c of the IETF Trust's Legal Provisions
    Relating to IETF Documents
    (https://trustee.ietf.org/license-info).

    This version of this YANG module is part of RFC XXXX; see
    the RFC itself for full legal notices.

    The key words 'MUST', 'MUST NOT', 'REQUIRED', 'SHALL', 'SHALL
    NOT', 'SHOULD', 'SHOULD NOT', 'RECOMMENDED', 'NOT RECOMMENDED',
    'MAY', and 'OPTIONAL' in this document are to be interpreted as
    described in BCP 14 (RFC 2119) (RFC 8174) when, and only when,
    they appear in all capitals, as shown here.";

  // RFC Ed.: replace XXXX with actual RFC number and remove this
  // note.
  // RFC Ed.: update the date below with the date of RFC publication
  // and remove this note.
  
  revision 2023-10-23 {
    description
      "Initial version";
    reference
      "RFC XXXX: A YANG Data Model for Network Inventory.";
      //RFC Editor: replace XXXX with actual RFC number, update date
      //information and remove this note
  }

  identity non-hardware-component-class {
    description
      "Base identity for non hardware components (e.g., software 
      components) in a managed device.";
  }

  identity ne-type {
    description
      "Base identity for network element (NE) types.";
  }

    identity ne-physical {
      base ni:ne-type;
      description
        "A physical network element (NE). ";
    }

  grouping common-entity-attributes {
    description
      "A set of attributes which are common to all the entities
      (e.g., component, equipment room) defined in this module.";
    leaf uuid {
      type yang:uuid;
      description
        "Uniquely identifies an entity (e.g., component).";
    }
    leaf name {
      type string;
      description
        "A name for an entity (e.g., component), as specified by
        a network manager, that provides a non-volatile 'handle'
        for the entity and that can be modified anytime during the
        entity lifetime.

        If no configured value exists, the server MAY set the value
        of this node to a locally unique value in the operational
        state.";
    }
    leaf description {
      type string;
      description "a textual description of inventory object";
    }
    leaf alias {
      type string;
      description 
      "a alias name of inventory objects. This alias name can be 
      specified by network manager.";
    }
  }
 
  grouping ne-specific-info-grouping {
    description
      "Attributes applicable to network elements.";
    leaf hardware-rev {
      type string;
      description
        "The vendor-specific hardware revision string for the NE.";
    }
    leaf software-rev {
      type string;
      description
        "The vendor-specific software revision string for the NE.";
    }
    leaf mfg-name {
      type string;
      description "The name of the manufacturer of this NE";
    }
    leaf mfg-date {
      type yang:date-and-time;
      description "The date of manufacturing of the NE.";
    }
    leaf part-number {
      type string;
      description
        "The vendor-specific model name identifier string associated
         with this NE.  The preferred value is the customer-visible 
         part number, which may be printed on the NE itself.";
    }
    leaf serial-number {
      type string;
      description
        "The vendor-specific serial number string for the NE";
    }
    leaf product-name {
      type string;
      description
        "indicates the vendor-spefic device type infomation.";
    }
  }
  
  container network-elements {
    description
      "The top-level container for the list of network elements 
      within the network.";
    list network-element {
      key ne-id;
      description
        "The list of network elements within the network.";
      leaf ne-id {
        type string;
        description
          "Network Element (NE) identifier.";
      }
      leaf ne-type {
        type identityref {
          base ne-type;
        }
        default "ne-physical";
        description
          "The type of network element (NE).";
      }
      uses common-entity-attributes;
      uses ne-specific-info-grouping;
      container components {
        description
          "The top-level container for the list of components 
          within a network element.";
        list component {
          key component-id;
          description
            "The list of components within a network element.";
          leaf component-id {
            type string;
            description
              "Component identifier";
          }
          leaf class {
            type union {
              type identityref {
                base ianahw:hardware-class;
              }
              type identityref {
                base non-hardware-component-class;
              }
            }
            mandatory true;
            description
              "The type of the component.";
          }
          uses common-entity-attributes;
          container child-component-ref {
            description
              "A placeholder for adding the reference to child 
              component(s): to further discuss whether to define 
              a child leaf-list as RFC8348 or a list of 
              sub-components as openconfig-platform.";
          }
          leaf parent-rel-pos {
            type int32 {
              range "0 .. 2147483647";
            }
            description
              "The relative position with respect to the parent
              component among all the sibling components.";
            reference
              "RFC 6933: Entity MIB (Version 4) -
                        entPhysicalParentRelPos";
          }
          container parent-component-ref {
            description
              "A placeholder for adding the reference to parent 
              component(s): to further discuss whether to define 
              a parent attribute as RFC83458 or a 
              parent-component-references container as in 
              draft-ietf-ccamp-network-inventory-yang-02.";
          }
          leaf hardware-rev {
            type string;
            description
              "The vendor-specific hardware revision string for the
              component.  The preferred value is the hardware 
              revision identifier actually printed on the component 
              itself (if present).";
            reference
              "RFC 6933: Entity MIB (Version 4) -
                        entPhysicalHardwareRev";
          }
          leaf firmware-rev {
            type string;
            description
              "The vendor-specific firmware revision string for the
              component.";
            reference
              "RFC 6933: Entity MIB (Version 4) -
                        entPhysicalFirmwareRev";
          }
          leaf software-rev {
            type string;
            description
              "The vendor-specific software revision string for the
              component.";
            reference
              "RFC 6933: Entity MIB (Version 4) -
                        entPhysicalSoftwareRev";
          }
          leaf serial-num {
            type string;
            description
              "The vendor-specific serial number string for the
              component.  The preferred value is the serial number
              string actually printed on the component itself (if
              present).";
            reference
              "RFC 6933: Entity MIB (Version 4) - 
              entPhysicalSerialNum";
          }
          leaf mfg-name {
            type string;
            description
              "The name of the manufacturer of this physical 
              component.
              The preferred value is the manufacturer name string
              actually printed on the component itself (if present).

              Note that comparisons between instances of the
              'model-name', 'firmware-rev', 'software-rev', and
              'serial-num' nodes are only meaningful amongst 
              components with the same value of 'mfg-name'.

              If the manufacturer name string associated with the
              physical component is unknown to the server, then this
              node is not instantiated.";
            reference
              "RFC 6933: Entity MIB (Version 4) - 
              entPhysicalMfgName";
          }
          leaf part-number {
            type string;
            description
              "The vendor-specific model name identifier string
              associated with this physical component.  The preferred
              value is the customer-visible part number, which may be
              printed on the component itself.

              If the model name string associated with the physical
              component is unknown to the server, then this node is 
              not instantiated.";
            reference
              "RFC 6933: Entity MIB (Version 4) - 
              entPhysicalModelName";
          }
          leaf asset-id {
            type string;
            description
              "This node is a user-assigned asset tracking 
              identifier for the component.

              A server implementation MAY map this leaf to the
              entPhysicalAssetID MIB object.  Such an implementation
              needs to use some mechanism to handle the differences 
              in size and characters allowed between this leaf and
              entPhysicalAssetID.  The definition of such a 
              mechanism is outside the scope of this document.";
            reference
              "RFC 6933: Entity MIB (Version 4) - 
              entPhysicalAssetID";
          }
          leaf is-fru {
            type boolean;
            description
              "This node indicates whether or not this component is
              considered a 'field-replaceable unit' by the vendor.  
              If this node contains the value 'true', then this 
              component identifies a field-replaceable unit.  
              For all components that are permanently contained 
              within a field-replaceable unit, the value 'false' 
              should be returned for this node.";
            reference
              "RFC 6933: Entity MIB (Version 4) - entPhysicalIsFRU";
          }
          leaf mfg-date {
            type yang:date-and-time;
            description
              "The date of manufacturing of the managed component.";
            reference
              "RFC 6933: Entity MIB (Version 4) - 
              entPhysicalMfgDate";
          }
          leaf-list uri {
            type inet:uri;
            description
              "This node contains identification information about 
              the component.";
            reference
              "RFC 6933: Entity MIB (Version 4) - entPhysicalUris";
          }
        }
      }
    }
  }
}
]]></sourcecode>
      </figure>
    </section>
    <section anchor="manageability-considerations">
      <name>Manageability Considerations</name>
      <t>&lt;Add any manageability considerations&gt;</t>
    </section>
    <section anchor="security-considerations">
      <name>Security Considerations</name>
      <t>&lt;Add any security considerations&gt;</t>
    </section>
    <section anchor="iana-considerations">
      <name>IANA Considerations</name>
      <t>&lt;Add any IANA considerations&gt;</t>
    </section>
  </middle>
  <back>
    <references>
      <name>References</name>
      <references anchor="sec-normative-references">
        <name>Normative References</name>
        <reference anchor="TMF_SD2-20" target="https://www.tmforum.org/resources/suite/mtosi-4-0/">
          <front>
            <title>SD2-20_Equipment Model</title>
            <author>
              <organization>TM Forum</organization>
            </author>
            <date year="2008" month="May"/>
          </front>
          <seriesInfo name="TMF MTOSI 4.0, Network Resource Fulfilment (NRF), SD2-20" value=""/>
        </reference>
        <reference anchor="IANA_YANG" target="https://www.iana.org/assignments/yang-parameters">
          <front>
            <title>YANG Parameters</title>
            <author>
              <organization>IANA</organization>
            </author>
            <date>n.d.</date>
          </front>
        </reference>
        <reference anchor="RFC8348">
          <front>
            <title>A YANG Data Model for Hardware Management</title>
            <author fullname="A. Bierman" initials="A." surname="Bierman"/>
            <author fullname="M. Bjorklund" initials="M." surname="Bjorklund"/>
            <author fullname="J. Dong" initials="J." surname="Dong"/>
            <author fullname="D. Romascanu" initials="D." surname="Romascanu"/>
            <date month="March" year="2018"/>
            <abstract>
              <t>This document defines a YANG data model for the management of hardware on a single server.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="8348"/>
          <seriesInfo name="DOI" value="10.17487/RFC8348"/>
        </reference>
        <reference anchor="RFC8342">
          <front>
            <title>Network Management Datastore Architecture (NMDA)</title>
            <author fullname="M. Bjorklund" initials="M." surname="Bjorklund"/>
            <author fullname="J. Schoenwaelder" initials="J." surname="Schoenwaelder"/>
            <author fullname="P. Shafer" initials="P." surname="Shafer"/>
            <author fullname="K. Watsen" initials="K." surname="Watsen"/>
            <author fullname="R. Wilton" initials="R." surname="Wilton"/>
            <date month="March" year="2018"/>
            <abstract>
              <t>Datastores are a fundamental concept binding the data models written in the YANG data modeling language to network management protocols such as the Network Configuration Protocol (NETCONF) and RESTCONF. This document defines an architectural framework for datastores based on the experience gained with the initial simpler model, addressing requirements that were not well supported in the initial model. This document updates RFC 7950.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="8342"/>
          <seriesInfo name="DOI" value="10.17487/RFC8342"/>
        </reference>
        <reference anchor="RFC7950">
          <front>
            <title>The YANG 1.1 Data Modeling Language</title>
            <author fullname="M. Bjorklund" initials="M." role="editor" surname="Bjorklund"/>
            <date month="August" year="2016"/>
            <abstract>
              <t>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="RFC6241">
          <front>
            <title>Network Configuration Protocol (NETCONF)</title>
            <author fullname="R. Enns" initials="R." role="editor" surname="Enns"/>
            <author fullname="M. Bjorklund" initials="M." role="editor" surname="Bjorklund"/>
            <author fullname="J. Schoenwaelder" initials="J." role="editor" surname="Schoenwaelder"/>
            <author fullname="A. Bierman" initials="A." role="editor" surname="Bierman"/>
            <date month="June" year="2011"/>
            <abstract>
              <t>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="RFC2119">
          <front>
            <title>Key words for use in RFCs to Indicate Requirement Levels</title>
            <author fullname="S. Bradner" initials="S." surname="Bradner"/>
            <date month="March" year="1997"/>
            <abstract>
              <t>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="RFC8174">
          <front>
            <title>Ambiguity of Uppercase vs Lowercase in RFC 2119 Key Words</title>
            <author fullname="B. Leiba" initials="B." surname="Leiba"/>
            <date month="May" year="2017"/>
            <abstract>
              <t>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="RFC8340">
          <front>
            <title>YANG Tree Diagrams</title>
            <author fullname="M. Bjorklund" initials="M." surname="Bjorklund"/>
            <author fullname="L. Berger" initials="L." role="editor" surname="Berger"/>
            <date month="March" year="2018"/>
            <abstract>
              <t>This document captures the current syntax used in YANG module tree diagrams. The purpose of this document is to provide a single location for this definition. This syntax may be updated from time to time based on the evolution of the YANG language.</t>
            </abstract>
          </front>
          <seriesInfo name="BCP" value="215"/>
          <seriesInfo name="RFC" value="8340"/>
          <seriesInfo name="DOI" value="10.17487/RFC8340"/>
        </reference>
        <reference anchor="RFC6991">
          <front>
            <title>Common YANG Data Types</title>
            <author fullname="J. Schoenwaelder" initials="J." role="editor" surname="Schoenwaelder"/>
            <date month="July" year="2013"/>
            <abstract>
              <t>This document introduces a collection of common data types to be used with the YANG data modeling language. This document obsoletes RFC 6021.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="6991"/>
          <seriesInfo name="DOI" value="10.17487/RFC6991"/>
        </reference>
        <reference anchor="RFC6933">
          <front>
            <title>Entity MIB (Version 4)</title>
            <author fullname="A. Bierman" initials="A." surname="Bierman"/>
            <author fullname="D. Romascanu" initials="D." surname="Romascanu"/>
            <author fullname="J. Quittek" initials="J." surname="Quittek"/>
            <author fullname="M. Chandramouli" initials="M." surname="Chandramouli"/>
            <date month="May" year="2013"/>
            <abstract>
              <t>This memo defines a portion of the Management Information Base (MIB) for use with network management protocols in the Internet community. In particular, it describes managed objects used for managing multiple logical and physical entities managed by a single Simple Network Management Protocol (SNMP) agent. This document specifies version 4 of the Entity MIB. This memo obsoletes version 3 of the Entity MIB module published as RFC 4133.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="6933"/>
          <seriesInfo name="DOI" value="10.17487/RFC6933"/>
        </reference>
      </references>
      <references anchor="sec-informative-references">
        <name>Informative References</name>
        <reference anchor="I-D.ietf-teas-actn-poi-applicability">
          <front>
            <title>Applicability of Abstraction and Control of Traffic Engineered Networks (ACTN) to Packet Optical Integration (POI)</title>
            <author fullname="Fabio Peruzzini" initials="F." surname="Peruzzini">
              <organization>TIM</organization>
            </author>
            <author fullname="Jean-Francois Bouquier" initials="J." surname="Bouquier">
              <organization>Vodafone</organization>
            </author>
            <author fullname="Italo Busi" initials="I." surname="Busi">
              <organization>Huawei</organization>
            </author>
            <author fullname="Daniel King" initials="D." surname="King">
              <organization>Old Dog Consulting</organization>
            </author>
            <author fullname="Daniele Ceccarelli" initials="D." surname="Ceccarelli">
              <organization>Cisco</organization>
            </author>
            <date day="7" month="July" year="2023"/>
            <abstract>
              <t>   This document considers the applicability of Abstraction and Control
   of TE Networks (ACTN) architecture to Packet Optical Integration
   (POI)in the context of IP/MPLS and optical internetworking. It
   identifies the YANG data models defined by the IETF to support this
   deployment architecture and specific scenarios relevant to Service
   Providers.

   Existing IETF protocols and data models are identified for each
   multi-layer (packet over optical) scenario with a specific focus on
   the MPI (Multi-Domain Service Coordinator to Provisioning Network
   Controllers Interface)in the ACTN architecture.

              </t>
            </abstract>
          </front>
          <seriesInfo name="Internet-Draft" value="draft-ietf-teas-actn-poi-applicability-09"/>
        </reference>
        <reference anchor="RFC8345">
          <front>
            <title>A YANG Data Model for Network Topologies</title>
            <author fullname="A. Clemm" initials="A." surname="Clemm"/>
            <author fullname="J. Medved" initials="J." surname="Medved"/>
            <author fullname="R. Varga" initials="R." surname="Varga"/>
            <author fullname="N. Bahadur" initials="N." surname="Bahadur"/>
            <author fullname="H. Ananthakrishnan" initials="H." surname="Ananthakrishnan"/>
            <author fullname="X. Liu" initials="X." surname="Liu"/>
            <date month="March" year="2018"/>
            <abstract>
              <t>This document defines an abstract (generic, or base) YANG data model for network/service topologies and inventories. The data model serves as a base model that is augmented with technology-specific details in other, more specific topology and inventory data models.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="8345"/>
          <seriesInfo name="DOI" value="10.17487/RFC8345"/>
        </reference>
        <reference anchor="RFC8969">
          <front>
            <title>A Framework for Automating Service and Network Management with YANG</title>
            <author fullname="Q. Wu" initials="Q." role="editor" surname="Wu"/>
            <author fullname="M. Boucadair" initials="M." role="editor" surname="Boucadair"/>
            <author fullname="D. Lopez" initials="D." surname="Lopez"/>
            <author fullname="C. Xie" initials="C." surname="Xie"/>
            <author fullname="L. Geng" initials="L." surname="Geng"/>
            <date month="January" year="2021"/>
            <abstract>
              <t>Data models provide a programmatic approach to represent services and networks. Concretely, they can be used to derive configuration information for network and service components, and state information that will be monitored and tracked. Data models can be used during the service and network management life cycle (e.g., service instantiation, service provisioning, service optimization, service monitoring, service diagnosing, and service assurance). Data models are also instrumental in the automation of network management, and they can provide closed-loop control for adaptive and deterministic service creation, delivery, and maintenance.</t>
              <t>This document describes a framework for service and network management automation that takes advantage of YANG modeling technologies. This framework is drawn from a network operator perspective irrespective of the origin of a data model; thus, it can accommodate YANG modules that are developed outside the IETF.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="8969"/>
          <seriesInfo name="DOI" value="10.17487/RFC8969"/>
        </reference>
        <reference anchor="I-D.wzwb-ivy-network-inventory-software">
          <front>
            <title>A YANG Network Data Model of Network Inventory Software Extensions</title>
            <author fullname="Bo Wu" initials="B." surname="Wu">
              <organization>Huawei</organization>
            </author>
            <author fullname="Cheng Zhou" initials="C." surname="Zhou">
              <organization>China Mobile</organization>
            </author>
            <author fullname="Qin Wu" initials="Q." surname="Wu">
              <organization>Huawei</organization>
            </author>
            <author fullname="Mohamed Boucadair" initials="M." surname="Boucadair">
              <organization>Orange</organization>
            </author>
            <date day="18" month="October" year="2023"/>
            <abstract>
              <t>   This document defines the YANG model for network inventory software
   extensions to support more comprehensive software components and
   software-enabled network devices, e.g. virtual Provider Edge (PE),
   virtul Fire Wall (FW).

   This document augments the 'ietf-network-inventory' data model
   defined in xxx by adding the software components identification and
   new Network Element (NE) type.

              </t>
            </abstract>
          </front>
          <seriesInfo name="Internet-Draft" value="draft-wzwb-ivy-network-inventory-software-00"/>
        </reference>
      </references>
    </references>
    <?line 986?>

<section anchor="appendix">
      <name>Appendix</name>
      <section anchor="comparison-with-openconfig-platform-data-model">
        <name>Comparison With Openconfig-platform Data Model</name>
        <t>Since more and more devices can be managed by domain controller through OpenConfig, to ensure that our inventory data model can cover these devices' inventory data, we have compared our inventory data model with the "openconfig-platform" model which is the data model used to manage inventory information in OpenConfig.</t>
        <t>Openconfig-platform data model is NE-level and uses a generic component concept to describe its inner devices and containers, which is similar to "ietf-hardware" model in <xref target="RFC8348"/>. Since we have also reused the component concept of <xref target="RFC8348"/> in our inventory data model, we can compare the component's attributes between "openconfig-platform" and our model directly , which is stated below:</t>
        <table anchor="tab-oc">
          <name>Comparison between openconfig platform and inventory data models</name>
          <thead>
            <tr>
              <th align="left">Attributes in oc-platform</th>
              <th align="left">Attributes in our model</th>
              <th align="left">remark</th>
            </tr>
          </thead>
          <tbody>
            <tr>
              <td align="left">name</td>
              <td align="left">name</td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">type</td>
              <td align="left">class</td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">id</td>
              <td align="left">uuid</td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">location</td>
              <td align="left">location</td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">description</td>
              <td align="left">description</td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">mfg-name</td>
              <td align="left">mfg-name</td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">mfg-date</td>
              <td align="left">mfg-date</td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">hardware-version</td>
              <td align="left">hardware-rev</td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">firmware-version</td>
              <td align="left">firmware-rev</td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">software-version</td>
              <td align="left">software-rev</td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">serial-no</td>
              <td align="left">serial-num</td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">part-no</td>
              <td align="left">part-number</td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">clei-code</td>
              <td align="left"> </td>
              <td align="left">TBD</td>
            </tr>
            <tr>
              <td align="left">removable</td>
              <td align="left">is-fru</td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">oper-status</td>
              <td align="left"> </td>
              <td align="left">state data</td>
            </tr>
            <tr>
              <td align="left">empty</td>
              <td align="left">contained-child?</td>
              <td align="left">If there is no contained child, it is empty.</td>
            </tr>
            <tr>
              <td align="left">parent</td>
              <td align="left">parent-references</td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">redundant-role</td>
              <td align="left"> </td>
              <td align="left">TBD</td>
            </tr>
            <tr>
              <td align="left">last-switchover-reason</td>
              <td align="left"> </td>
              <td align="left">state data</td>
            </tr>
            <tr>
              <td align="left">last-switchover-time</td>
              <td align="left"> </td>
              <td align="left">state data</td>
            </tr>
            <tr>
              <td align="left">last-reboot-reason</td>
              <td align="left"> </td>
              <td align="left">state data</td>
            </tr>
            <tr>
              <td align="left">last-reboot-time</td>
              <td align="left"> </td>
              <td align="left">state data</td>
            </tr>
            <tr>
              <td align="left">switchover-ready</td>
              <td align="left"> </td>
              <td align="left">state data</td>
            </tr>
            <tr>
              <td align="left">temperature</td>
              <td align="left"> </td>
              <td align="left">performance data</td>
            </tr>
            <tr>
              <td align="left">memory</td>
              <td align="left"> </td>
              <td align="left">performance data</td>
            </tr>
            <tr>
              <td align="left">allocated-power</td>
              <td align="left"> </td>
              <td align="left">TBD</td>
            </tr>
            <tr>
              <td align="left">used-power</td>
              <td align="left"> </td>
              <td align="left">TBD</td>
            </tr>
            <tr>
              <td align="left">pcie</td>
              <td align="left"> </td>
              <td align="left">alarm  data</td>
            </tr>
            <tr>
              <td align="left">properties</td>
              <td align="left"> </td>
              <td align="left">TBD</td>
            </tr>
            <tr>
              <td align="left">subcomponents</td>
              <td align="left">contained-child</td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">chassis</td>
              <td align="left">chassis-specific-info</td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">port</td>
              <td align="left">port-specific-info</td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">power-supply</td>
              <td align="left"> </td>
              <td align="left">TBD</td>
            </tr>
            <tr>
              <td align="left">fan</td>
              <td align="left"> </td>
              <td align="left">Fan is considered as a specific board. And no need to define as a single component</td>
            </tr>
            <tr>
              <td align="left">fabric</td>
              <td align="left"> </td>
              <td align="left">TBD</td>
            </tr>
            <tr>
              <td align="left">storage</td>
              <td align="left"> </td>
              <td align="left">For Optical and IP technology, no need to manage storage on network element</td>
            </tr>
            <tr>
              <td align="left">cpu</td>
              <td align="left"> </td>
              <td align="left">For Optical and IP technology, no need to manage CPU on network element</td>
            </tr>
            <tr>
              <td align="left">integrated-circuit</td>
              <td align="left">board-specific-info</td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">backplane</td>
              <td align="left"> </td>
              <td align="left">Backplane is considered as a part of board. And no need to define as a single component</td>
            </tr>
            <tr>
              <td align="left">software-module</td>
              <td align="left"> </td>
              <td align="left">TBD</td>
            </tr>
            <tr>
              <td align="left">controller-card</td>
              <td align="left"> </td>
              <td align="left">Controller card is considered as a specific functional board. And no need to define as a single component</td>
            </tr>
          </tbody>
        </table>
        <t>As it mentioned in <xref target="ne-component"/> that state data and performance data are out of scope of our data model, it is same for alarm data and it should be defined in some other alarm data models separately. And for some component specific structures in "openconfig-platform", we consider some of them can be contained by our existing structure, such as fan, backplane, and controller-card, while some others do not need to be included in this network inventory model like storage and cpu.</t>
        <t>Mostly, our inventory data model can cover the attributes from OpenConfig.</t>
      </section>
    </section>
    <section numbered="false" anchor="acknowledgments">
      <name>Acknowledgments</name>
      <t>The authors of this document would like to thank the authors of <xref target="I-D.ietf-teas-actn-poi-applicability"/> for having identified the gap and requirements to trigger this work.</t>
      <t>This document was prepared using kramdown.</t>
    </section>
    <section anchor="contributors" numbered="false" toc="include" removeInRFC="false">
      <name>Contributors</name>
      <contact initials="I." surname="Busi" fullname="Italo Busi">
        <organization>Huawei Technologies</organization>
        <address>
          <email>italo.busi@huawei.com</email>
        </address>
      </contact>
      <contact initials="A." surname="Guo" fullname="Aihua Guo">
        <organization>Futurewei Technologies</organization>
        <address>
          <email>aihuaguo.ietf@gmail.com</email>
        </address>
      </contact>
      <contact initials="V." surname="Lopez" fullname="Victor Lopez">
        <organization>Nokia</organization>
        <address>
          <email>victor.lopez@nokia.com</email>
        </address>
      </contact>
      <contact initials="B." surname="Wu" fullname="Bo Wu">
        <organization>Huawei Technologies</organization>
        <address>
          <email>lana.wubo@huawei.com</email>
        </address>
      </contact>
      <contact initials="C." surname="Zhang" fullname="Chenfang Zhang">
        <organization>China Unicom</organization>
        <address>
          <email>zhangcf80@chinaunicom.cn</email>
        </address>
      </contact>
      <contact initials="O." surname="Gonzalez de Dios" fullname="Oscar Gonzalez de Dios">
        <organization>Telefonica</organization>
        <address>
          <email>oscar.gonzalezdedios@telefonica.com</email>
        </address>
      </contact>
      <contact initials="N." surname="Davis" fullname="Nigel Davis">
        <organization>Ciena</organization>
        <address>
          <email>ndavis@ciena.com</email>
        </address>
      </contact>
    </section>
  </back>
  <!-- ##markdown-source:
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
FpN8lY2C/wvWcIioy60AAA==

-->

</rfc>
