<?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.34 (Ruby 3.4.8) -->
<rfc xmlns:xi="http://www.w3.org/2001/XInclude" ipr="trust200902" docName="draft-ietf-netconf-trace-ctx-extension-06" category="std" consensus="true" submissionType="IETF" tocInclude="true" sortRefs="true" symRefs="true" version="3">
  <!-- xml2rfc v2v3 conversion 3.32.0 -->
  <front>
    <title abbrev="NETCONF Trace Context Extension">NETCONF Extension to support Trace Context propagation</title>
    <seriesInfo name="Internet-Draft" value="draft-ietf-netconf-trace-ctx-extension-06"/>
    <author fullname="Roque Gagliano">
      <organization>Cisco Systems</organization>
      <address>
        <postal>
          <street>Avenue des Uttins 5</street>
          <city>Rolle</city>
          <code>1180</code>
          <country>Switzerland</country>
        </postal>
        <email>rogaglia@cisco.com</email>
      </address>
    </author>
    <author fullname="Kristian Larsson">
      <organization>Deutsche Telekom AG</organization>
      <address>
        <email>kll@dev.terastrm.net</email>
      </address>
    </author>
    <author fullname="Jan Lindblad">
      <organization>All For Eco</organization>
      <address>
        <email>jan.lindblad+ietf@for.eco</email>
      </address>
    </author>
    <date year="2026" month="March" day="17"/>
    <area>Operations and Management</area>
    <workgroup>Network Configuration</workgroup>
    <keyword>telemetry</keyword>
    <keyword>distributed systems</keyword>
    <keyword>opentelemetry</keyword>
    <abstract>
      <?line 88?>

<t>This document defines how to propagate trace context information across the Network Configuration Protocol (NETCONF), that enables distributed tracing scenarios.  It is an adaption of the HTTP-based W3C specification.</t>
    </abstract>
    <note removeInRFC="true">
      <name>About This Document</name>
      <t>
        The latest revision of this draft can be found at <eref target="https://datatracker.ietf.org/doc/draft-ietf-netconf-trace-ctx-extension/"/>.
        Status information for this document may be found at <eref target="https://datatracker.ietf.org/doc/draft-ietf-netconf-trace-ctx-extension/"/>.
      </t>
      <t>
        Discussion of this document takes place on the
        Network Configuration Working Group mailing list (<eref target="mailto:netconf@ietf.org"/>),
        which is archived at <eref target="https://mailarchive.ietf.org/arch/browse/netconf/"/>.
        Subscribe at <eref target="https://www.ietf.org/mailman/listinfo/netconf/"/>.
      </t>
      <t>Source for this draft and an issue tracker can be found at
        <eref target="https://github.com/netconf-wg/trace-ctx-extension"/>.</t>
    </note>
  </front>
  <middle>
    <?line 92?>

<section anchor="introduction">
      <name>Introduction</name>
      <t>Network automation and management systems commonly consist of multiple
sub-systems and together with the network devices they manage, they effectively form a distributed system.  Distributed tracing is a methodology implemented by tracing tools to follow, analyze and debug operations, such as configuration transactions, across multiple distributed systems.  An operation is uniquely identified by a trace-id and through a trace context, carries some metadata about the operation.  Propagating this "trace context" between systems enables forming a coherent view of the entire operation as carried out by all involved systems.</t>
      <t>The W3C has defined two HTTP headers for context propagation that are useful in use case scenarios of distributed systems like the ones defined in <xref target="RFC8309"/>.  This document defines an extension to the NETCONF protocol to add the same concepts and enable trace context propagation over NETCONF.</t>
      <t>It is worth noting that the trace context is not meant to have any relationship with the data that is carried with a given operation (including configurations, service identifiers or state information).</t>
      <t>A trace context also differs from <xref target="I-D.ietf-netconf-transaction-id"/> in several ways as the trace operation may involve any operation (including for example validate, lock, unlock, etc.) Additionally, a trace context scope may include the full application stack (orchestrator, controller, devices, etc) rather than a single NETCONF server, which is the scope for the transaction-id. The trace context is also complementary to <xref target="I-D.ietf-netconf-transaction-id"/> as a given trace-id can be associated with the different transaction-ids as part of the information exported to the collector.</t>
      <t>The following enhancement of the reference SDN Architecture from <xref target="RFC8309"/> shows the impact of distributed traces for a network operator.</t>
      <figure anchor="rfc8309-sample-arch">
        <name>A Sample SDN Architecture from RFC8309 augmented to include the export of metrics, events, logs and traces from the different components to a common collector.</name>
        <sourcecode type="art"><![CDATA[
                +------------------+                   +-----------+
                |   Orchestrator   |                   |           |
                |                  |     ------------> |           |
                .------------------.                   |           |
               .          :         .                  |           |
              .           :          .                 | Collector |
  +------------+   +------------+   +------------+     | (Metrics, |
  |            |   |            |   |            |     |  Events,  |
  | Controller |   | Controller |   | Controller | --> |  Logs,    |
  |            |   |            |   |            |     |  Traces)  |
  +------------+   +------------+   +------------+     |           |
      :              .       .               :         |           |
      :             .         .              :         |           |
      :            .           .             :         |           |
 +---------+  +---------+  +---------+  +---------+    |           |
 | Network |  | Network |  | Network |  | Network |    |           |
 | Element |  | Element |  | Element |  | Element | -> |           |
 +---------+  +---------+  +---------+  +---------+    +-----------+
]]></sourcecode>
      </figure>
      <t>The network automation, management and control architectures are distributed in nature.  In order to "manage the managers", operators would like to use the same techniques as any other distributed systems in their IT environment.  Solutions for analysing Metrics, Events, Logs and Traces (M.E.L.T) are key for the successful monitoring and troubleshooting of such applications.  Initiatives such as the OpenTelemetry <xref target="OpenTelemetry"/> enable rich ecosystems of tools that NETCONF-based applications would want to participate in.</t>
      <t>With the implementation of this trace context propagation extension to NETCONF, backend systems behind the M.E.L.T collector will be able to correlate information from different systems but related to a common context.</t>
      <t>This document does not cover the somewhat related functionality specified in <xref target="W3C-Baggage"/>.  Mapping of the Baggage functionality into YANG may be specified in a future document.</t>
      <section anchor="terminology">
        <name>Terminology</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.</t>
        <t>Additionally, the document utilizes the following abbreviations:</t>
        <dl>
          <dt>OTLP:</dt>
          <dd>
            <t>OpenTelemetry protocol as defined by <xref target="OpenTelemetry"/></t>
          </dd>
          <dt>M.E.L.T.:</dt>
          <dd>
            <t>Metrics, Events, Logs and Traces</t>
          </dd>
          <dt>gNMI:</dt>
          <dd>
            <t>gRPC Network Management Interface, as defined by <xref target="gNMI"/></t>
          </dd>
        </dl>
        <t>The XML prefixes used in this document are mapped as follows:</t>
        <ul spacing="normal">
          <li>
            <t>xmlns:nc="urn:ietf:params:xml:ns:netconf:base:1.0",</t>
          </li>
          <li>
            <t>xmlns:w3ctc="urn:ietf:params:xml:ns:netconf:w3ctc:1.0" and</t>
          </li>
          <li>
            <t>xmlns:ietf-trace-context=
  "urn:ietf:params:xml:ns:yang:ietf-trace-context"</t>
          </li>
        </ul>
      </section>
      <section anchor="implementation-example-1-opentelemetry">
        <name>Implementation example 1: OpenTelemetry</name>
        <t>We will describe an example to show the value of trace context propagation in the NETCONF protocol.  In the OTLP Sample Architecture <xref target="otlp-sample-arch"/>  below, we show a deployment based on the RFC8309 sample architecture <xref target="rfc8309-sample-arch"/> above, with a single controller and two network elements.  In this example, the NETCONF protocol is running between the Orchestrator and the Controller.  NETCONF is also used between the Controller and the Network Elements.</t>
        <t>Let's assume an edit-config operation between the orchestrator and the controller that results (either synchronously or asynchronously) in corresponding edit-config operations from the Controller towards the two network elements.  All trace operations are related and will create M.E.L.T data.</t>
        <figure anchor="otlp-sample-arch">
          <name>An implementation example where the NETCONF protocol is used between the Orchestrator and the Controller and also between the Controller and the Network Elements.  Every component exports M.E.L.T information to the collector using the OTLP protocol.</name>
          <sourcecode type="art"><![CDATA[
            +------------------+                        +-----------+
            |   Orchestrator   |    OTLP protocol       |           |
            |                  |  ------------------->  |           |
            .------------------+                        |           |
           .  NETCONF                                   |           |
          .   edit-config (trace-id "1", parent-id "A") | Collector |
+------------+                                          | (Metrics, |
|            |                                          |  Events,  |
| Controller |   ------------------------------------>  |  Logs,    |
|            |                 OTLP protocol            |  Traces)  |
+------------+                                          |           |
   :      .  NETCONF                                    |           |
   :        . edit-config (trace-id "1", parent-id "B") |           |
   :          .                                         |           |
+---------+   +---------+                               |           |
| Network |   | Network |       OTLP protocol           |           |
| Element |   | Element |  -------------------------->  |           |
+---------+   +---------+                               +-----------+
]]></sourcecode>
        </figure>
        <t>Each of the components in this example (Orchestrator, Controller and Network Elements) is exporting M.E.L.T information to the collector using the OpenTelemetry Protocol (OTLP).</t>
        <t>For every edit-config operation, the trace context is included.  In particular, the same trace-id "1" (simplified encoding for documentation) is included in all related NETCONF messages, which enables the collector and any backend application to correlate all M.E.L.T messages related to this transaction in this distributed stack.</t>
        <t>Another interesting attribute is the parent-id.  We can see in this example that the parent-id between the orchestrator and the controller ("A") is different from the one between the controller and the network elements ("B").  This attribute will help the collector and the backend applications to build a connectivity graph to understand how M.E.L.T information exported from one component relates to the information exported from a different component.</t>
        <t>With this additional metadata exchanged between the components and exposed to the M.E.L.T collector, there are important improvements to the monitoring and troubleshooting operations for the full application stack.</t>
      </section>
      <section anchor="implementation-example-2-yang-datastore">
        <name>Implementation example 2: YANG Datastore</name>
        <t>OpenTelemetry implements the "push" model for data streaming where information is sent to the back-end as soon as produced and is not required to be stored in the system. In certain cases, a "pull" model may be envisioned, for example for performing forensic analysis while not all OTLP traces are available in the back-end systems.</t>
        <t>An implementation of a "pull" mechanism for M.E.L.T. information in general and for traces in particular, could consist of storing traces in a YANG datastore (particularly the operational datastore.) Implementations should consider the use of circular buffers to avoid resource exhaustion. External systems could access traces (and particularly past traces) via NETCONF, RESTCONF, gNMI or other polling mechanisms. Finally, storing traces in a YANG datastore enables the use of YANG-Push <xref target="RFC8641"/> or gNMI Telemetry as additional "push" mechanisms.</t>
        <t>This document does not specify the YANG module in which traces could be stored inside the different components. That said, storing the context information described in this document as part of the recorded traces would allow back-end systems to correlate the information from different components as in the OpenTelemetry implementation.</t>
        <figure anchor="melt-example">
          <name>An implementation example where the NETCONF protocol is used between the Orchestrator and the Controller and also between the Controller and the Network Elements.  M.E.L.T. information is stored in local YANG Datastores and accessed by the collector using "pull" mechanisms using the NETCONF (NC), RESTCONF (RC) or gNMI protocols. A "push" strategy is also possible via YANG-Push or gNMI.</name>
          <sourcecode type="art"><![CDATA[
            +------------------+                        +-----------+
            | Orchestrator     |                        |           |
            |                  |    NC/RC/gNMI or YP    |           |
            |   YANG Datastore | <------------------->  |           |
            .------------------+     pull or push       |           |
           .  NETCONF                                   |           |
          .   edit-config (trace-id "1", parent-id "A") | Collector |
+----------------+                                      | (Metrics, |
|                |           NC/RC/gNMI or YP           |  Events,  |
| Controller     |   <------------------------------->  |  Logs,    |
|  YANG Datastore|             pull or push             |  Traces)  |
+----------------+                                      |           |
   :      .  NETCONF                                    |           |
   :        . edit-config (trace-id "1", parent-id "B") |           |
   :          .                                         |           |
+---------+   +---------+                               |           |
| Network |   | Network |        NC/RC/gNMI or YP       |           |
| Element |   | Element |  <------------------------->  |           |
| YANG DS |   | YANG DS |         pull or push          |           |
+---------+   +---------+                               +-----------+
]]></sourcecode>
        </figure>
      </section>
      <section anchor="use-cases">
        <name>Use Cases</name>
        <section anchor="provisioning-root-cause-analysis">
          <name>Provisioning root cause analysis</name>
          <t>When a provisioning activity fails, errors are typically propagated northbound, however this information may be difficult to troubleshoot and typically, operators are required to navigate logs across all the different components.</t>
          <t>With the support for trace context propagation as described in this document for NETCONF, the collector will be able to search every trace, event, metric, or log in connection to that trace-id and facilitate the performance of a root cause analysis due to a network changes. The trace information could also be included as an optional resource with the different NETCONF transaction ids described in <xref target="I-D.ietf-netconf-transaction-id"/>.</t>
        </section>
        <section anchor="system-performance-profiling">
          <name>System performance profiling</name>
          <t>When operating a distributed system such as the one shown in <xref target="otlp-sample-arch"/>, operators are expected to benchmark Key Performance Indicators (KPIs) for the most common tasks.  For example, what is the typical delay when provisioning a VPN service across different controllers and devices.</t>
          <t>Thanks to Application Performance Management (APM) systems, from these KPIs, an operator can detect a normal and abnormal behaviour of the distributed system. Also, an operator can better plan any upgrades or enhancements in the platform.</t>
          <t>With the support for context propagation as described in this document for NETCONF, much richer system-wide KPIs can be defined and used for troubleshooting as the metrics and traces propagated by the different components share a common context.  Troubleshooting for abnormal behaviours can also be troubleshot from the system view down to the individual element.</t>
        </section>
        <section anchor="billing-and-auditing">
          <name>Billing and auditing</name>
          <t>In certain circumstances, we could envision tracing information used as additional inputs to billing systems. In particular, trace context information could be used to validate that a certain northbound order was carried out in southbound systems.</t>
        </section>
      </section>
    </section>
    <section anchor="netconf-extension">
      <name>NETCONF Extension</name>
      <t>When performing NETCONF operations by sending NETCONF RPCs, a NETCONF client MAY include trace context information in the form of XML attributes.  The <xref target="W3C-Trace-Context"/> defines two HTTP headers; traceparent and tracestate for this purpose.  NETCONF clients that are taking advantage of this feature MUST add one w3ctc:traceparent attribute and MAY add one w3ctc:tracestate attribute to the nc:rpc tag.</t>
      <t>A NETCONF server that receives a trace context attribute in the form of a w3ctc:traceparent attribute SHOULD apply the mutation rules described in <xref target="W3C-Trace-Context"/>. A NETCONF server MAY add one w3ctc:traceparent attribute in the nc:rpc-reply response to the nc:rpc tag above.  NETCONF servers MAY also add one w3ctc:traceparent attribute in notification and update message envelopes: notif:notification, yp:push-update and yp:push-change-update.</t>
      <t>For example, a NETCONF client might send:</t>
      <sourcecode type="xml"><![CDATA[
<rpc xmlns="urn:ietf:params:xml:ns:netconf:base:1.0" message-id="1"
     xmlns:w3ctc="urn:ietf:params:xml:ns:netconf:w3ctc:1.0"
     w3ctc:traceparent=
       "00-4bf92f3577b34da6a3ce929d0e0e4736-00f067aa0ba902b7-01">
  <get-config/>
</rpc>
]]></sourcecode>
      <t>In all cases above where a client or server adds a w3ctc:traceparent attribute to a tag, that client or server MAY also add one w3ctc:tracestate attribute to the same tag.</t>
      <t>The proper encoding and interpretation of the contents of the w3ctc:traceparent attribute is described in <xref target="W3C-Trace-Context"/> section 3.2 except 3.2.1.  The proper encoding and interpretation of the contents in the w3ctc:tracestate attribute is described in <xref target="W3C-Trace-Context"/> section 3.3 except 3.3.1 and 3.3.1.1.  A NETCONF XML tag can only have zero or one w3ctc:tracestate attributes, so its content MUST always be encoded as a single string.  The tracestate field value is a list of list-members separated by commas (,).  A list-member is a key/value pair separated by an equals sign (=).  Spaces and horizontal tabs surrounding list-members are ignored.  There is no limit to the number of list-members in a list.</t>
      <t>For example, a NETCONF client might send:</t>
      <sourcecode type="xml"><![CDATA[
<rpc xmlns="urn:ietf:params:xml:ns:netconf:base:1.0" message-id="1"
     xmlns:w3ctc="urn:ietf:params:xml:ns:netconf:w3ctc:1.0"
     w3ctc:tracestate="rojo=00f067aa0ba902b7,congo=t61rcWkgMzE"
     w3ctc:traceparent=
       "00-4bf92f3577b34da6a3ce929d0e0e4736-00f067aa0ba902b7-01">
  <get-config/>
</rpc>
]]></sourcecode>
      <t>As in all XML documents, the order between the attributes in an XML tag has no significance.  Clients and servers MUST be prepared to handle the attributes no matter in which order they appear.  The tracestate value MAY contain double quotes in its payload.  If so, they MUST be encoded according to XML rules, for example:</t>
      <sourcecode type="xml"><![CDATA[
<rpc xmlns="urn:ietf:params:xml:ns:netconf:base:1.0" message-id="1"
     xmlns:w3ctc="urn:ietf:params:xml:ns:netconf:w3ctc:1.0"
     w3ctc:traceparent=
       "00-4bf92f3577b34da6a3ce929d0e0e4736-00f067aa0ba902b7-01"
     w3ctc:tracestate=
       "value-with-quotes=&quot;Quoted string&quot;,other-value=123">
  <get-config/>
</rpc>
]]></sourcecode>
      <section anchor="error-handling">
        <name>Error handling</name>
        <t>When interacting with these extensions, the NETCONF server follow the specifications of section 2.3 in <xref target="W3C-Trace-Context"/>. A detailed processing model example is also provided in the document.  Based on this processing model, it is NOT RECOMMENDED to reject an RPC because of the trace context attribute values.</t>
        <t>If the server still decides to reject the RPC because of the trace context attribute values, ietf-trace-context.yang SHOULD be included in the YANG library and the server MUST return a NETCONF rpc-error with the following values:</t>
        <artwork><![CDATA[
  error-tag:      operation-failed
  error-type:     protocol
  error-severity: error
]]></artwork>
        <t>Additionally, the error-info tag MUST contain a trace-context-error-info structure with relevant details about the error.  This structure is defined in the module ietf-trace-context.yang.  Example of a badly formatted trace context extension:</t>
        <sourcecode type="xml"><![CDATA[
<rpc xmlns="urn:ietf:params:xml:ns:netconf:base:1.0" message-id="1"
     xmlns:w3ctc="urn:ietf:params:xml:ns:netconf:w3ctc:1.0"
     w3ctc:traceparent=
       "Bad Format"
     w3ctc:tracestate=
       "value-with-quotes=&quot;Quoted string&quot;,other-value=123">
  <get-config/>
</rpc>
]]></sourcecode>
        <t>This might give the following error response:</t>
        <sourcecode type="xml"><![CDATA[
<rpc-reply xmlns="urn:ietf:params:xml:ns:netconf:base:1.0"
            xmlns:w3ctc="urn:ietf:params:xml:ns:netconf:w3ctc:1.0"
            xmlns:ietf-trace-context=
            "urn:ietf:params:xml:ns:yang:ietf-trace-context"
            message-id="1">
  <rpc-error>
    <error-type>protocol</error-type>
    <error-tag>operation-failed</error-tag>
    <error-severity>error</error-severity>
    <error-message>
      Context traceparent attribute incorrectly formatted
    </error-message>
    <error-info>
      <ietf-trace-context:trace-context-error-info>
        <ietf-trace-context:meta-name>
          w3ctc:traceparent
        </ietf-trace-context:meta-name>
        <ietf-trace-context:meta-value>
          Bad Format
        </ietf-trace-context:meta-value>
        <ietf-trace-context:error-type>
          ietf-trace-context:bad-format
        </ietf-trace-context:error-type>
      </ietf-trace-context:trace-context-error-info>
    </error-info>
  </rpc-error>
</rpc-reply>
]]></sourcecode>
      </section>
      <section anchor="trace-context-extension-versioning">
        <name>Trace Context extension versioning</name>
        <t>This extension refers to the <xref target="W3C-Trace-Context"/> trace context capability. The W3C traceparent and tracestate headers include the notion of versions. It would be desirable for a NETCONF client to be able to discover the one or multiple versions of these headers supported by a server.</t>
        <t>To achieve this goal, and to avoid having to define a new NETCONF extension for each headers versions, we define a pair of YANG modules (ietf-trace-ctx-traceparent-1.0.yang and ietf-trace-ctx-tracestate-1.0.yang) that MUST be included in the YANG library per <xref target="RFC8525"/> of the NETCONF server supporting the NETCONF Trace Context extension. These capabilities that will refer to the headers' supported versions. Future updates of this document could include additional YANG modules for new headers' versions.</t>
      </section>
    </section>
    <section anchor="yang-modules">
      <name>YANG Modules</name>
      <t>This document defines three YANG modules:</t>
      <artwork><![CDATA[
- YANG module for ietf-trace-context structure as mentioned in section 2.1
- YANG module for traceparent header version as mentioned in section 2.2
- YANG module for tracestate header version as mentioned in section 2.2
]]></artwork>
      <section anchor="yang-module-for-ietf-trace-context-structure">
        <name>YANG module for ietf-trace-context structure</name>
        <sourcecode type="yang" markers="true" name="ietf-trace-context@2024-11-07.yang"><![CDATA[
module ietf-trace-context {
  yang-version 1.1;
  namespace 
    "urn:ietf:params:xml:ns:yang:ietf-trace-context";
  prefix ietf-trace-context;

  import ietf-yang-structure-ext {
    prefix sx;
    reference
      "RFC8791: YANG Data Structure Extensions";
  }

  organization
    "IETF NETCONF (Network Configuration) Working Group";
  contact
    "WG Web:   <https://datatracker.ietf.org/wg/netconf/>
     WG List:  <mailto:netconf@ietf.org>

     Authors:  Roque Gagliano
               <mailto:rogaglia@cisco.com>

               Jan Lindblad
               <mailto:jlindbla@cisco.com>

               Kristian Larsson
               <mailto:kll@dev.terastrm.net>
    ";
  description
    "When propagating tracing information across applications,
     client and servers needs to share some specific contextual
     information. This  extensions aligns the NETCONF and RESTCONF
     protocols to the W3C trace-context document:
     https://www.w3.org/TR/2021/REC-trace-context-1-20211123

     This document has a normative reference to RFC 8791.

     Copyright (c) 2024 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
     (https://www.rfc-editor.org/info/rfcXXXX); 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.
    ";

  revision 2024-11-07 {
    description
      "Initial revision";
    reference
      "RFC XXXX:
       NETCONF Extension to support Trace Context propagation";
  }

  identity meta-error {
    description
      "Base identity for trace context attribute errors.";
  }

  identity missing {
    base meta-error;
    description
      "Indicates an attribute or header that is required
       (in the current situation) is missing.";
  }

  identity bad-format {
    base meta-error;
    description
      "Indicates an attribute or header value where the
       value is incorrectly formatted.";
  }

  identity processing-error {
    base meta-error;
    description
      "Indicates that the server encountered a processing
       error while processing the attribute or header value.";
  }

  typedef meta-error-type {
    type identityref {
      base meta-error;
    }
    description
      "Error type";
  }

  sx:structure trace-context-error-info {
    description
      "This error is returned by a NETCONF or RESTCONF server
        when a client sends a NETCONF RPC with additonal
        attributes or RESTCONF RPC with additional headers
        for trace context processing, and there is an error
        related to them.  The server has aborted the RPC.";
    leaf meta-name {
      type string;
      description
        "The name of the problematic or missing meta information.
          In NETCONF, the qualified XML attribute name.
          In RESTCONF, the HTTP header name.
          If a client sent a NETCONF RPC with the attribute
          w3ctc:traceparent='incorrect-format'
          this leaf would have the value 'w3ctc:traceparent'";
    }
    leaf meta-value {
      type string;
      description
        "The value of the problematic meta information received
          by the server.
          If a client sent a NETCONF RPC with the attribute
          w3ctc:traceparent='incorrect-format'
          this leaf would have the value 'incorrect-format'.";
    }
    leaf error-type {
      type meta-error-type;
      description
        "Indicates the type of meta information problem
          detected by the server.
          If a client sent an RPC annotated with the attribute
          w3ctc:traceparent='incorrect-format'
          this leaf might have the value
          'ietf-trace-context:bad-format'.";
    }
  }
}
]]></sourcecode>
      </section>
      <section anchor="yang-module-for-traceparent-header-version-10">
        <name>YANG module for traceparent header version 1.0</name>
        <sourcecode type="yang" markers="true" name="ietf-trace-ctx-traceparent-1.0@2024-11-07.yang"><![CDATA[
module ietf-trace-ctx-traceparent-1.0 {
  namespace 
  "urn:ietf:params:xml:ns:yang:ietf-trace-ctx-traceparent-1.0";
  prefix ietf-trace-ctx-traceparent-1.0;

  organization
    "IETF NETCONF (Network Configuration) Working Group";
  contact
    "WG Web:   <https://datatracker.ietf.org/wg/netconf/>
     WG List:  <mailto:netconf@ietf.org>

     Authors:  Roque Gagliano
               <mailto:rogaglia@cisco.com>

               Jan Lindblad
               <mailto:jlindbla@cisco.com>

               Kristian Larsson
               <mailto:kll@dev.terastrm.net>
    ";
  description
    "This module documents the support for trace context traceparent
     versiom 1.0 in alignment with W3C versions:
     https://www.w3.org/TR/2021/REC-trace-context-1-20211123

     Copyright (c) 2024 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
     (https://www.rfc-editor.org/info/rfcXXXX); 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.
    ";

  revision 2024-11-07 {
    description
      "Initial revision";
    reference
      "RFC XXXX:
       NETCONF Extension to support Trace Context propagation";
  }
}
]]></sourcecode>
      </section>
      <section anchor="yang-module-for-tracestate-header-version-10">
        <name>YANG module for tracestate header version 1.0</name>
        <sourcecode type="yang" markers="true" name="ietf-trace-ctx-tracestate-1.0@2024-11-07.yang"><![CDATA[
module ietf-trace-ctx-tracestate-1.0 {
  namespace 
    "urn:ietf:params:xml:ns:yang:ietf-trace-ctx-tracestate-1.0";
  prefix ietf-trace-ctx-tracestate-1.0;

  organization
    "IETF NETCONF (Network Configuration) Working Group";
  contact
    "WG Web:   <https://datatracker.ietf.org/wg/netconf/>
     WG List:  <mailto:netconf@ietf.org>

     Authors:  Roque Gagliano
               <mailto:rogaglia@cisco.com>

               Jan Lindblad
               <mailto:jlindbla@cisco.com>

               Kristian Larsson
               <mailto:kll@dev.terastrm.net>
    ";
  description
    "This module documents the support for trace context tracestate
     versiom 1.0 in alignment with W3C versions:
     https://www.w3.org/TR/2021/REC-trace-context-1-20211123

     Copyright (c) 2024 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
     (https://www.rfc-editor.org/info/rfcXXXX); 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.
    ";

  revision 2024-11-07 {
    description
      "Initial revision";
    reference
      "RFC XXXX:
       NETCONF Extension to support Trace Context propagation";
  }
}
]]></sourcecode>
      </section>
    </section>
    <section anchor="security-considerations">
      <name>Security Considerations</name>
      <t>This section is modeled after the template described in Section 3.7 of <xref target="I-D.draft-ietf-netmod-rfc8407bis-28"/>.</t>
      <t>The ietf-trace-context, ietf-trace-ctx-tracestate-1.0 and ietf-trace-ctx-traceparent-1.0  YANG modules define data models that are designed to be accessed via YANG-based management protocols, such as NETCONF <xref target="RFC6241"/> and RESTCONF <xref target="RFC8040"/>. These YANG-based management protocols (1) have to use a secure transport layer (e.g., SSH <xref target="RFC4252"/>, TLS <xref target="RFC8446"/>, and QUIC <xref target="RFC9000"/>) and (2) have to use mutual authentication.</t>
      <t>The Network Configuration Access Control Model (NACM) <xref target="RFC8341"/> provides the means to restrict access for particular NETCONF or RESTCONF users to a preconfigured subset of all available NETCONF or RESTCONF protocol operations and content.</t>
      <t>The YANG modules specified in this document are used to flag capabilities define and define an error information structure. As such, these YANG modules do not contain any configuration data, state data or RPC definitions, which makes their security implications very limited.  The additional attributes specified in this document (but not in YANG modules, since YANG cannot be used to specify attributes) are worth mentioning, however.</t>
      <t>The traceparent and tracestate attributes make it easier to track the flow of requests and their downstream effect on other systems.  This is indeed the whole point with these attributes.  This knowledge could also be of use to bad actors that are working to build a map of the managed network.</t>
      <t>The meta-name and meta-value attributes in the ietf-trace-context.yang should not echo any information received from an erroneos request or the system, in order to avoid bad actors receiving additional contextual information.</t>
    </section>
    <section anchor="iana-considerations">
      <name>IANA Considerations</name>
      <t>This document registers the following capability identifier URN in the 'Network Configuration Protocol (NETCONF) Capability URNs' registry:</t>
      <artwork><![CDATA[
  urn:ietf:params:netconf:capability:w3ctc:1.0
]]></artwork>
      <t>This document registers one XML namespace URN in the 'IETF XML registry', following the format defined in <xref target="RFC3688"/> (https://www.rfc-editor.org/rfc/rfc3688.html).</t>
      <artwork><![CDATA[
  URI: urn:ietf:params:xml:ns:netconf:w3ctc:1.0

  Registrant Contact: The IETF IESG.

  XML: N/A, the requested URI is an XML namespace.
]]></artwork>
      <t>This document registers three module names in the 'YANG Module Names' registry, defined in RFC 6020:</t>
      <artwork><![CDATA[
  name: ietf-trace-ctx-traceparent-1.0

  prefix: ietf-trace-ctx-traceparent-1.0

  namespace:
    urn:ietf:params:xml:ns:yang:ietf-trace-ctx-traceparent-1.0

  RFC: XXXX
]]></artwork>
      <t>and</t>
      <artwork><![CDATA[
  name: ietf-trace-ctx-tracestate-1.0

  prefix: ietf-trace-ctx-tracestate-1.0

  namespace:
    urn:ietf:params:xml:ns:yang:ietf-trace-ctx-tracestate-1.0

  RFC: XXXX
]]></artwork>
      <t>and</t>
      <artwork><![CDATA[
  name: ietf-trace-context

  prefix: ietf-trace-context

  namespace: urn:ietf:params:xml:ns:yang:ietf-trace-context

  RFC: XXXX
]]></artwork>
    </section>
    <section anchor="acknowledgments">
      <name>Acknowledgments</name>
      <t>The authors would like to acknowledge the valuable implementation feedback from Christian Rennerskog and Per Andersson.  Many thanks to Raul Rivas Felix, Alexander Stoklasa, Luca Relandini and Erwin Vrolijk for their help with the demos regarding integrations.  The help and support from Jean Quilbeuf and Benoit Claise has also been invaluable to this work.</t>
    </section>
  </middle>
  <back>
    <references anchor="sec-combined-references">
      <name>References</name>
      <references anchor="sec-normative-references">
        <name>Normative References</name>
        <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="RFC4252">
          <front>
            <title>The Secure Shell (SSH) Authentication Protocol</title>
            <author fullname="T. Ylonen" initials="T." surname="Ylonen"/>
            <author fullname="C. Lonvick" initials="C." role="editor" surname="Lonvick"/>
            <date month="January" year="2006"/>
            <abstract>
              <t>The Secure Shell Protocol (SSH) is a protocol for secure remote login and other secure network services over an insecure network. This document describes the SSH authentication protocol framework and public key, password, and host-based client authentication methods. Additional authentication methods are described in separate documents. The SSH authentication protocol runs on top of the SSH transport layer protocol and provides a single authenticated tunnel for the SSH connection protocol. [STANDARDS-TRACK]</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="4252"/>
          <seriesInfo name="DOI" value="10.17487/RFC4252"/>
        </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="RFC3688">
          <front>
            <title>The IETF XML Registry</title>
            <author fullname="M. Mealling" initials="M." surname="Mealling"/>
            <date month="January" year="2004"/>
            <abstract>
              <t>This document describes an IANA maintained registry for IETF standards which use Extensible Markup Language (XML) related items such as Namespaces, Document Type Declarations (DTDs), Schemas, and Resource Description Framework (RDF) Schemas.</t>
            </abstract>
          </front>
          <seriesInfo name="BCP" value="81"/>
          <seriesInfo name="RFC" value="3688"/>
          <seriesInfo name="DOI" value="10.17487/RFC3688"/>
        </reference>
        <reference anchor="RFC8040">
          <front>
            <title>RESTCONF Protocol</title>
            <author fullname="A. Bierman" initials="A." surname="Bierman"/>
            <author fullname="M. Bjorklund" initials="M." surname="Bjorklund"/>
            <author fullname="K. Watsen" initials="K." surname="Watsen"/>
            <date month="January" year="2017"/>
            <abstract>
              <t>This document describes an HTTP-based protocol that provides a programmatic interface for accessing data defined in YANG, using the datastore concepts defined in the Network Configuration Protocol (NETCONF).</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="8040"/>
          <seriesInfo name="DOI" value="10.17487/RFC8040"/>
        </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="RFC8341">
          <front>
            <title>Network Configuration Access Control Model</title>
            <author fullname="A. Bierman" initials="A." surname="Bierman"/>
            <author fullname="M. Bjorklund" initials="M." surname="Bjorklund"/>
            <date month="March" year="2018"/>
            <abstract>
              <t>The standardization of network configuration interfaces for use with the Network Configuration Protocol (NETCONF) or the RESTCONF protocol requires a structured and secure operating environment that promotes human usability and multi-vendor interoperability. There is a need for standard mechanisms to restrict NETCONF or RESTCONF protocol access for particular users to a preconfigured subset of all available NETCONF or RESTCONF protocol operations and content. This document defines such an access control model.</t>
              <t>This document obsoletes RFC 6536.</t>
            </abstract>
          </front>
          <seriesInfo name="STD" value="91"/>
          <seriesInfo name="RFC" value="8341"/>
          <seriesInfo name="DOI" value="10.17487/RFC8341"/>
        </reference>
        <reference anchor="RFC8446">
          <front>
            <title>The Transport Layer Security (TLS) Protocol Version 1.3</title>
            <author fullname="E. Rescorla" initials="E." surname="Rescorla"/>
            <date month="August" year="2018"/>
            <abstract>
              <t>This document specifies version 1.3 of the Transport Layer Security (TLS) protocol. TLS allows client/server applications to communicate over the Internet in a way that is designed to prevent eavesdropping, tampering, and message forgery.</t>
              <t>This document updates RFCs 5705 and 6066, and obsoletes RFCs 5077, 5246, and 6961. This document also specifies new requirements for TLS 1.2 implementations.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="8446"/>
          <seriesInfo name="DOI" value="10.17487/RFC8446"/>
        </reference>
        <reference anchor="RFC8525">
          <front>
            <title>YANG Library</title>
            <author fullname="A. Bierman" initials="A." surname="Bierman"/>
            <author fullname="M. Bjorklund" initials="M." surname="Bjorklund"/>
            <author fullname="J. Schoenwaelder" initials="J." surname="Schoenwaelder"/>
            <author fullname="K. Watsen" initials="K." surname="Watsen"/>
            <author fullname="R. Wilton" initials="R." surname="Wilton"/>
            <date month="March" year="2019"/>
            <abstract>
              <t>This document describes a YANG library that provides information about the YANG modules, datastores, and datastore schemas used by a network management server. Simple caching mechanisms are provided to allow clients to minimize retrieval of this information. This version of the YANG library supports the Network Management Datastore Architecture (NMDA) by listing all datastores supported by a network management server and the schema that is used by each of these datastores.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="8525"/>
          <seriesInfo name="DOI" value="10.17487/RFC8525"/>
        </reference>
        <reference anchor="RFC9000">
          <front>
            <title>QUIC: A UDP-Based Multiplexed and Secure Transport</title>
            <author fullname="J. Iyengar" initials="J." role="editor" surname="Iyengar"/>
            <author fullname="M. Thomson" initials="M." role="editor" surname="Thomson"/>
            <date month="May" year="2021"/>
            <abstract>
              <t>This document defines the core of the QUIC transport protocol. QUIC provides applications with flow-controlled streams for structured communication, low-latency connection establishment, and network path migration. QUIC includes security measures that ensure confidentiality, integrity, and availability in a range of deployment circumstances. Accompanying documents describe the integration of TLS for key negotiation, loss detection, and an exemplary congestion control algorithm.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="9000"/>
          <seriesInfo name="DOI" value="10.17487/RFC9000"/>
        </reference>
        <reference anchor="I-D.draft-ietf-netmod-rfc8407bis-28">
          <front>
            <title>Guidelines for Authors and Reviewers of Documents Containing YANG Data Models</title>
            <author fullname="Andy Bierman" initials="A." surname="Bierman">
              <organization>YumaWorks</organization>
            </author>
            <author fullname="Mohamed Boucadair" initials="M." surname="Boucadair">
              <organization>Orange</organization>
            </author>
            <author fullname="Qin Wu" initials="Q." surname="Wu">
              <organization>Huawei</organization>
            </author>
            <date day="5" month="June" year="2025"/>
            <abstract>
              <t>   This document provides guidelines for authors and reviewers of
   specifications containing YANG data models, including IANA-maintained
   modules.  Recommendations and procedures are defined, which are
   intended to increase interoperability and usability of Network
   Configuration Protocol (NETCONF) and RESTCONF Protocol
   implementations that utilize YANG modules.  This document obsoletes
   RFC 8407.

   Also, this document updates RFC 8126 by providing additional
   guidelines for writing the IANA considerations for RFCs that specify
   IANA-maintained modules.

              </t>
            </abstract>
          </front>
          <seriesInfo name="Internet-Draft" value="draft-ietf-netmod-rfc8407bis-28"/>
        </reference>
        <reference anchor="W3C-Trace-Context" target="https://www.w3.org/TR/2021/REC-trace-context-1-20211123/">
          <front>
            <title>W3C Recommendation on Trace Context</title>
            <author>
              <organization/>
            </author>
            <date year="2021" month="November" day="23"/>
          </front>
        </reference>
      </references>
      <references anchor="sec-informative-references">
        <name>Informative References</name>
        <reference anchor="OpenTelemetry" target="https://opentelemetry.io">
          <front>
            <title>OpenTelemetry Cloud Native Computing Foundation project</title>
            <author>
              <organization/>
            </author>
            <date year="2024" month="November" day="04"/>
          </front>
        </reference>
        <reference anchor="gNMI" target="https://github.com/openconfig/gnmi">
          <front>
            <title>gNMI - gRPC Network Management Interface</title>
            <author>
              <organization/>
            </author>
            <date year="2024" month="November" day="04"/>
          </front>
        </reference>
        <reference anchor="I-D.ietf-netconf-transaction-id">
          <front>
            <title>Transaction ID Mechanism for NETCONF</title>
            <author fullname="Jan Lindblad" initials="J." surname="Lindblad">
              <organization>All For Eco</organization>
            </author>
            <date day="7" month="October" year="2025"/>
            <abstract>
              <t>   NETCONF clients and servers often need to have a synchronized view of
   the server's configuration datastores.  The volume of configuration
   data in a server may be very large, while datastore changes typically
   are small when observed at typical client resynchronization
   intervals.

   Rereading the entire datastore and analyzing the response for changes
   is inefficient for synchronization.  This document specifies a
   NETCONF extension that allows clients and servers to keep
   synchronized with a much smaller data exchange and without any need
   for servers to store information about the clients.

              </t>
            </abstract>
          </front>
          <seriesInfo name="Internet-Draft" value="draft-ietf-netconf-transaction-id-11"/>
        </reference>
        <reference anchor="RFC8641">
          <front>
            <title>Subscription to YANG Notifications for Datastore Updates</title>
            <author fullname="A. Clemm" initials="A." surname="Clemm"/>
            <author fullname="E. Voit" initials="E." surname="Voit"/>
            <date month="September" year="2019"/>
            <abstract>
              <t>This document describes a mechanism that allows subscriber applications to request a continuous and customized stream of updates from a YANG datastore. Providing such visibility into updates enables new capabilities based on the remote mirroring and monitoring of configuration and operational state.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="8641"/>
          <seriesInfo name="DOI" value="10.17487/RFC8641"/>
        </reference>
        <reference anchor="W3C-Baggage" target="https://www.w3.org/TR/baggage/#examples-of-http-headers">
          <front>
            <title>W3C Propagation format for distributed context Baggage</title>
            <author>
              <organization/>
            </author>
            <date year="2021" month="November" day="23"/>
          </front>
        </reference>
        <reference anchor="RFC8309">
          <front>
            <title>Service Models Explained</title>
            <author fullname="Q. Wu" initials="Q." surname="Wu"/>
            <author fullname="W. Liu" initials="W." surname="Liu"/>
            <author fullname="A. Farrel" initials="A." surname="Farrel"/>
            <date month="January" year="2018"/>
            <abstract>
              <t>The IETF has produced many modules in the YANG modeling language. The majority of these modules are used to construct data models to model devices or monolithic functions.</t>
              <t>A small number of YANG modules have been defined to model services (for example, the Layer 3 Virtual Private Network Service Model (L3SM) produced by the L3SM working group and documented in RFC 8049).</t>
              <t>This document describes service models as used within the IETF and also shows where a service model might fit into a software-defined networking architecture. Note that service models do not make any assumption of how a service is actually engineered and delivered for a customer; details of how network protocols and devices are engineered to deliver a service are captured in other modules that are not exposed through the interface between the customer and the provider.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="8309"/>
          <seriesInfo name="DOI" value="10.17487/RFC8309"/>
        </reference>
      </references>
    </references>
    <?line 698?>

<section anchor="changes-to-be-deleted-by-rfc-editor">
      <name>Changes (to be deleted by RFC Editor)</name>
      <section anchor="from-version-05-to-version-06">
        <name>From version 05 to version 06</name>
        <ul spacing="normal">
          <li>
            <t>We introduced a bug in the YANG model in version 03 as container was not needed per RFC 8791.</t>
          </li>
          <li>
            <t>Serveral edits based on OpsDir comments</t>
          </li>
        </ul>
      </section>
      <section anchor="from-version-04-to-version-05">
        <name>From version 04 to version 05</name>
        <ul spacing="normal">
          <li>
            <t>More WGLC and sheepard comments</t>
          </li>
        </ul>
      </section>
      <section anchor="from-version-03-to-version-04">
        <name>From version 03 to version 04</name>
        <ul spacing="normal">
          <li>
            <t>WGLC data change.</t>
          </li>
        </ul>
      </section>
      <section anchor="from-version-02-to-03">
        <name>From version 02 to 03</name>
        <ul spacing="normal">
          <li>
            <t>Changed document Abbreviation</t>
          </li>
          <li>
            <t>trace-context-error-info is a container in example</t>
          </li>
        </ul>
      </section>
      <section anchor="from-version-01-to-02">
        <name>From version 01 to 02</name>
        <ul spacing="normal">
          <li>
            <t>Enhanced Terminology and moved it up in the document.</t>
          </li>
          <li>
            <t>Changed namespaces and module names to map WGLC comments
and IETF requirements</t>
          </li>
        </ul>
      </section>
      <section anchor="from-version-00-to-01">
        <name>From version 00 to 01</name>
        <ul spacing="normal">
          <li>
            <t>Added Security considerations</t>
          </li>
          <li>
            <t>Added Acknowledgements</t>
          </li>
          <li>
            <t>Added several Normative references</t>
          </li>
          <li>
            <t>Updated link to latest document on github</t>
          </li>
          <li>
            <t>Firmed up error handling and YANG-library to MUST-requirements</t>
          </li>
        </ul>
      </section>
      <section anchor="from-version-03-to-draft-ietf-netconf-trace-ctx-extension-00">
        <name>From version 03 to draft-ietf-netconf-trace-ctx-extension-00</name>
        <ul spacing="normal">
          <li>
            <t>Adopted by NETCONF WG</t>
          </li>
          <li>
            <t>Moved repository to NETCONF WG</t>
          </li>
          <li>
            <t>Changed build system to use martinthomson's excellent framework</t>
          </li>
          <li>
            <t>Ran make fix-lint to remove white space at EOL etc.</t>
          </li>
          <li>
            <t>Added this change note. No other content changes.</t>
          </li>
        </ul>
      </section>
      <section anchor="from-version-02-to-03-1">
        <name>From version 02 to 03</name>
        <ul spacing="normal">
          <li>
            <t>Changed IANA section to IESG per IANA email</t>
          </li>
          <li>
            <t>Created sx:structure and improved error example</t>
          </li>
          <li>
            <t>Added ietf-netconf-otlp-context.yang for the sx:structure</t>
          </li>
          <li>
            <t>Created a dedicated section for the YANG modules</t>
          </li>
        </ul>
      </section>
      <section anchor="from-version-01-to-02-1">
        <name>From version 01 to 02</name>
        <ul spacing="normal">
          <li>
            <t>Added Error Handling intial section</t>
          </li>
          <li>
            <t>Added how to manage versioning by defining YANG modules for each traceparent and trastate versions as defined by W3C.</t>
          </li>
          <li>
            <t>Added 'YANG Module Names'  to IANA Considerations</t>
          </li>
        </ul>
      </section>
      <section anchor="from-version-00-to-01-1">
        <name>From version 00 to 01</name>
        <ul spacing="normal">
          <li>
            <t>Added new section: Implementation example 2: YANG Datastore</t>
          </li>
          <li>
            <t>Added new use case: Billing and auditing</t>
          </li>
          <li>
            <t>Added in introduction and in "Provisioning root cause analysis" the idea that the different transaction-ids defined in <xref target="I-D.ietf-netconf-transaction-id"/> could be added as part of the tracing information to be exported to the collectors, showing how the two documents are complementary.</t>
          </li>
        </ul>
      </section>
    </section>
    <section anchor="xml-attributes-vs-rpcs-input-augmentations-discussion-to-be-deleted-by-rfc-editor">
      <name>XML Attributes vs RPCs input augmentations discussion (to be deleted by RFC Editor)</name>
      <t>There are arguments that can be raised regarding using XML Attribute or to augment NETCONF RPCs.</t>
      <t>We studied Pros/Cons of each option and decided to propose XML attributes:</t>
      <t>XML Attributes Pro:</t>
      <ul spacing="normal">
        <li>
          <t>Literal alignment with W3C specification</t>
        </li>
        <li>
          <t>Same encoding for RESTCONF and NETCONF enabling code reuse</t>
        </li>
        <li>
          <t>One specification for all current and future RPCss</t>
        </li>
      </ul>
      <t>XML Attributes Cons:</t>
      <ul spacing="normal">
        <li>
          <t>No YANG modeling, multiple values represented as a single string</t>
        </li>
        <li>
          <t>Dependency on W3C for any extension or changes in the future as encoding will be dictated by string encoding</t>
        </li>
      </ul>
      <t>RPCs Input Augmentations Pro:</t>
      <ul spacing="normal">
        <li>
          <t>YANG model of every leaf</t>
        </li>
        <li>
          <t>Re-use of YANG toolkits</t>
        </li>
        <li>
          <t>Simple updates by augmentations on existing YANG module</t>
        </li>
        <li>
          <t>Possibility to express deviations in case of partial support</t>
        </li>
      </ul>
      <t>RPCs Input Augmentations Cons:</t>
      <ul spacing="normal">
        <li>
          <t>Need to augment every RPC, including future RPCs would need to consider these augmentations, which is harder to maintain</t>
        </li>
        <li>
          <t>There is no literal alignment with W3C standard. However, as mentioned before most of the time there will be modifications to the content</t>
        </li>
        <li>
          <t>Would need updated RFP for each change at W3C, which will make adoption of new features slower</t>
        </li>
      </ul>
    </section>
  </back>
  <!-- ##markdown-source:
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
vf8C3UCsVleSAAA=

-->

</rfc>
