<?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.20 (Ruby 2.6.10) -->
<rfc xmlns:xi="http://www.w3.org/2001/XInclude" ipr="trust200902" docName="draft-ietf-netconf-trace-ctx-extension-05" category="std" consensus="true" submissionType="IETF" tocInclude="true" sortRefs="true" symRefs="true" version="3">
  <!-- xml2rfc v2v3 conversion 3.24.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-05"/>
    <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>Cisco Systems</organization>
      <address>
        <email>jlindbla@cisco.com</email>
      </address>
    </author>
    <date year="2025" month="October" day="19"/>
    <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>The NETCONF server SHOULD follow the "Processing Model for Working with Trace Context" as specified in <xref target="W3C-Trace-Context"/>.  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 {
    container 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 700?>

<section anchor="changes-to-be-deleted-by-rfc-editor">
      <name>Changes (to be deleted by RFC Editor)</name>
      <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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
oVMAuuj8D2Idp5fDkQAA

-->

</rfc>
