<?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 3.3.3) -->
<rfc xmlns:xi="http://www.w3.org/2001/XInclude" ipr="trust200902" docName="draft-ietf-netconf-restconf-trace-ctx-headers-03" category="std" consensus="true" submissionType="IETF" tocInclude="true" sortRefs="true" symRefs="true" version="3">
  <!-- xml2rfc v2v3 conversion 3.24.0 -->
  <front>
    <title abbrev="rc_trace">RESTCONF Extension to Support Trace Context Headers</title>
    <seriesInfo name="Internet-Draft" value="draft-ietf-netconf-restconf-trace-ctx-headers-03"/>
    <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="2024" month="November" day="07"/>
    <area>Operations and Management</area>
    <workgroup>NETCONF</workgroup>
    <keyword>telemetry</keyword>
    <keyword>distributed systems</keyword>
    <keyword>opentelemetry</keyword>
    <abstract>
      <?line 74?>

<t>This document defines an extension to the RESTCONF protocol in order to support Trace Context propagation as defined by the W3C.</t>
    </abstract>
    <note removeInRFC="true">
      <name>About This Document</name>
      <t>
        The latest revision of this draft can be found at <eref target="https://github.com/netconf-wg/restconf-trace-ctx-headers/blob/gh-pages/draft-ietf-netconf-restconf-trace-ctx-headers.txt"/>.
        Status information for this document may be found at <eref target="https://datatracker.ietf.org/doc/draft-ietf-netconf-restconf-trace-ctx-headers/"/>.
      </t>
      <t>
        Discussion of this document takes place on the
        NETCONF 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/https://github.com/netconf-wg/restconf-trace-ctx-headers"/>.</t>
    </note>
  </front>
  <middle>
    <?line 78?>

<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 track, analyze and debug operations such as configuration transactions, across multiple distributed systems.</t>
      <t>The W3C has defined two HTTP headers (traceparent and tracestate) in <xref target="W3C-Trace-Context"/> for context propagation that are useful for distributed systems like the ones defined in section 4 of <xref target="RFC8309"/>.</t>
      <t>According to the W3C specification, each operation is uniquely identified by a "trace-id" field, and carries multiple metadata fields about the operation.  Propagating this Trace Context between systems provides a coherent view of the entire operation as carried out by all involved systems.</t>
      <t>In <xref target="I-D.draft-ietf-netconf-trace-ctx-extension"/>, the NETCONF protocol extension is defined and we will re-use several of the YANG and XML objects defined in that document for RESTCONF. Please refer to that document for additional context and example applications.</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>
      </section>
    </section>
    <section anchor="restconf-extensions">
      <name>RESTCONF Extensions</name>
      <t>A RESTCONF server that implements the Trace Context propagation mechanism defined in this document MUST support the Trace Context traceparent header as defined in <xref target="W3C-Trace-Context"/>.</t>
      <t>A RESTCONF server SHOULD support the Trace Context tracestate header as defined in <xref target="W3C-Trace-Context"/>.</t>
      <section anchor="error-handling">
        <name>Error Handling</name>
        <t>A RESTCONF 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 header values.</t>
        <t>If a server decides to reject an RPC because of the Trace Context header values, the server MUST return a RESTCONF 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 SHOULD contain a relevant details about the error.</t>
        <t>Finally, the sx:structure defined in <xref target="I-D.draft-ietf-netconf-trace-ctx-extension"/> SHOULD be present in any error message from the server.</t>
      </section>
      <section anchor="trace-context-header-versioning">
        <name>Trace Context Header Versioning</name>
        <t>The RESTCONF protocol extension described in this document 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 RESTCONF client to be able to discover the one or multiple versions of these headers supported by a server.</t>
        <t><xref target="I-D.draft-ietf-netconf-trace-ctx-extension"/> defines a pair YANG modules that SHOULD be included in the YANG library per <xref target="RFC8525"/> of the RESTCONF server supporting the RESTCONF Trace Context extension 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="security-considerations">
      <name>Security Considerations</name>
      <t>The related document <xref target="I-D.draft-ietf-netconf-trace-ctx-extension"/> defines two YANG modules that are used when implementing the Trace Context concept, regardless of YANG-based protocol.  These modules are completely empty, and therefore have very limited security considerations. Their purpose is only to indicate which Trace Context header versions the server supports using YANG Library <xref target="RFC8525"/>.</t>
      <t>The traceparent and tracestate headers make it easier to track and correlate the flow of requests and their downstream effect on other systems.  This is indeed the whole point with these headers.  This knowledge may be used by unauthorized entities to infer a map of a managed network.</t>
      <t>All advice mentioned in the <xref target="W3C-Trace-Context"/> under the Privacy Considerations and Security Considerations also apply to this document.</t>
      <t>The lowest RESTCONF layer is HTTPS, and the mandatory-to-implement secure transport is TLS <xref target="RFC8446"/>.</t>
    </section>
    <section anchor="iana-considerations">
      <name>IANA Considerations</name>
      <t>This document has no IANA actions.</t>
    </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 Med Boucadair, Jean Quilbeuf and Benoît 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="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="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="I-D.draft-ietf-netconf-trace-ctx-extension">
          <front>
            <title>NETCONF Extension to support Trace Context propagation</title>
            <author fullname="Roque Gagliano" initials="R." surname="Gagliano">
              <organization>Cisco Systems</organization>
            </author>
            <author fullname="Kristian Larsson" initials="K." surname="Larsson">
              <organization>Deutsche Telekom AG</organization>
            </author>
            <author fullname="Jan Lindblad" initials="J." surname="Lindblad">
              <organization>Cisco Systems</organization>
            </author>
            <date day="7" month="November" year="2024"/>
            <abstract>
              <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>
          </front>
          <seriesInfo name="Internet-Draft" value="draft-ietf-netconf-trace-ctx-extension-02"/>
        </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>
        <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>
      </references>
      <references anchor="sec-informative-references">
        <name>Informative References</name>
        <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 150?>

<section anchor="example-restconf-calls">
      <name>Example RESTCONF Calls</name>
      <t>All examples from Appendix B of <xref target="RFC8040"/> could be recreated in this section by adding the new header described in this document. We selected one example from that document as reference.</t>
      <section anchor="successful-creation-of-new-data-resources-from-appendix-b21-of-rfc8040">
        <name>Successful creation of New Data Resources (from Appendix B.2.1 of <xref target="RFC8040"/>)</name>
        <t>To create a new "artist" resource within the "library" resource, a client might send the following request:</t>
        <artwork><![CDATA[
  POST /restconf/data/example-jukebox:jukebox/library HTTP/1.1
  Host: example.com
  Content-Type: application/yang-data+json
  traceparent: 00-405062f633be64ee006089dfca95a153-e021f9e263aad8e2-01
  tracestate: vendorname1=opaqueValue1,vendorname2=opaqueValue2

  {
    "example-jukebox:artist" : [
      {
        "name" : "Foo Fighters"
      }
    ]
  }
]]></artwork>
        <t>If the resource is created, the server might respond as follows:</t>
        <artwork><![CDATA[
  HTTP/1.1 201 Created
  Date: Thu, 26 Jan 2017 20:56:30 GMT
  Server: example-server
  Location: https://example.com/restconf/data/\
      example-jukebox:jukebox/library/artist=Foo%20Fighters
  Last-Modified: Thu, 26 Jan 2017 20:56:30 GMT
  ETag: "b3830f23a4c"
  traceparent: 00-405062f633be64ee006089dfca95a153-e021f9e263aad8e2-01
  tracestate: vendorname1=opaqueValue1,vendorname2=opaqueValue2
]]></artwork>
      </section>
      <section anchor="unsuccessful-creation-of-new-data-resources-from-appendix-b21-of-rfc8040">
        <name>Unsuccessful creation of New Data Resources (from Appendix B.2.1 of <xref target="RFC8040"/>)</name>
        <t><xref target="W3C-Trace-Context"/> specifies that a vendor may validate the tracestate header and that invalid headers may be discarded. Section 2.1 on <xref target="error-handling">Error handling</xref>, states that servers may return an error. Let's assume that an implementation follows that behavior.</t>
        <t>Example of a badly formated tracestate header using <xref target="RFC8040"/> example (Appendix B.2.1), in which a server receives the following:</t>
        <artwork><![CDATA[
  POST /restconf/data/example-jukebox:jukebox/library HTTP/1.1
  Host: example.com
  Content-Type: application/yang-data+json
  traceparent: 00-405062f633be64ee006089dfca95a153-e021f9e263aad8e2-01
  tracestate: SomeBadFormatHere

  {
    "example-jukebox:artist" : [
      {
        "name" : "Foo Fighters"
      }
    ]
  }
]]></artwork>
        <t>To which the server responds with an error message:</t>
        <artwork><![CDATA[
 HTTP/1.1 400 Bad Request
 Date: Thu, 20 Jun 2024 20:56:30 GMT
 Server: example-server
 Content-Type: application/yang-data+json

 { "ietf-restconf:errors" : {
     "error" : [
      "trace-context-error-info": {
        {
          "error-type" : "protocol",
          "error-tag" : "operation-failed",
          "error-severity" : "error",
          "error-message" :
          "Context traceparent header incorrectly formatted",
          "error-info": {
            "ietf-trace-context:meta-name" : "tracestate",
            "ietf-trace-context:meta-value" :
            "SomeBadFormatHere",
            "ietf-trace-context:error-type" :
            "ietf-trace-context:bad-format"
          }
        }
      }
     ]
   }
 }
]]></artwork>
      </section>
    </section>
    <section anchor="changes-to-be-deleted-by-rfc-editor">
      <name>Changes (to be deleted by RFC Editor)</name>
      <section anchor="from-version-01-to-02">
        <name>From version 01 to 02</name>
        <ul spacing="normal">
          <li>
            <t>Added WGLC comments</t>
          </li>
          <li>
            <t>Changed namespaces and module name</t>
          </li>
          <li>
            <t>Fix error in error response</t>
          </li>
          <li>
            <t>Comments from Med Boucadair</t>
          </li>
          <li>
            <t>Removed markdown formatting of tracestate and traceparent, as toolchain could not handle this properly</t>
          </li>
          <li>
            <t>Removed references to RFC8341 (NACM) as the passage in the security considerations no longer need it</t>
          </li>
          <li>
            <t>Rearranged text in introduction to include referenes in a more natural order</t>
          </li>
          <li>
            <t>Removed several references to "we" and replaced with more neutral language</t>
          </li>
          <li>
            <t>Clarified that everything described as MUST requirements in this document only apply to RESTCONF implementations that implement this document. Other RESTCONF implementations do not need to care about this document, it's an optional extension</t>
          </li>
          <li>
            <t>Clarified that the YANG modules used by this document is defined by the sibling document for NETCONF</t>
          </li>
          <li>
            <t>Lots of updated wording based on review feedback</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>Added links to latest document on github</t>
          </li>
          <li>
            <t>Added RESTCONF example for success and error</t>
          </li>
          <li>
            <t>Modified Error Handling to reflect better W3C alignment based on implementation feedback</t>
          </li>
          <li>
            <t>Firmed up error handling and YANG-library to MUST-requirements</t>
          </li>
        </ul>
      </section>
      <section anchor="from-version-00-to-draft-ietf-netconf-restconf-trace-ctx-headers-00">
        <name>From version 00 to draft-ietf-netconf-restconf-trace-ctx-headers-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>
  </back>
  <!-- ##markdown-source:
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
mvc9skh+xE/W5PrTNUOft+a5ypfrLClTC+MCknAjB/Ywqx2coykvoB1juszn
OYVBvTYgmyHG7IkfFU7210rnE1VNefZrVZh//qMUo1xqsnoZzGRC1T/K9Si1
aDDBcqlbRlIjpRyFara2mhGSIOetO1S6znNziHIOR78Tr323JDSDYddpjOBW
pXDhspFxxA4LBdssi2C7DhBfSFI64iOBVo4dOL1WdeUd0qVmvS6dj3QKuO3T
p6sqpTyc+kLMVEg9zkD6DTVYLpUzlaU23dOt43UGnf7WEZ/BWI3fBybL/Lcl
4rFDmWDDRqzw4P/tEN/Xo3vUfPF5zELP5uRuwR3XSXTAxTqLvjhHIl7f1nSp
L9QNMkg+VddqYu6G4W83JhTk691+px+2eGfoOigs4ua+f8+gVJTJmHPvRiuj
u5LFLCFSf/oUrytEMwwMRa+XHPSe914Mpi/29yfqxYFSvd6L3stX2TSVr57L
/vP9RPUG/ekrNXixL2X2Ug2SXr+5FUeQIeJTkRlL9xf9P6OMxel/ojqiv7ce
GDQHBlEyn8NfIdrbAolqGYqf60nNBbyIdqYp7WNjkPhDH8CGdmPOff38Syu+
oaKr5DwlKBzGGux9o37y+sWspSm4neI1vK6Ooo7EoNcXI79DGHrDchnPqz0x
eMF3OpjzPf43fP5iuN8Tb0/HYeYVE6t1m3jiYfDEpOHeJ7b4GyawZVF/bxz7
D6yr64X7Z0jtPwa9KLdIU7oyQWXN9fLXneFoTBVie7L/cr83HezLg7T9f87g
ACUfCve/DCa784PYbYgZa2CXkxZguc5iIrWjdcJgQs2igmc2sjNOeKhaQvhR
WYcSDOafGSvEz76ZMg/NlF+ePvHFdHzxbE8wpcCUNzO/b+wRFKGIFieq/A4h
yDmAcjhD8SBke2fwwxOFVFhz/R0DEWdbE5mFGxIZr0A2z+uT12YQisHh6abs
wT4w2efIdccEcUrpm+224v8f3L0yC/VaZscs33eImv9eXEVo9QpqgGiAT+fT
qGhisWMSVVUj6UGvJ3AiOCKH0NYDMO2JH6uC7zB3ANGXsPSrNeanfxZtLlWj
9QyZb0dCaciqzW+3hdnevJZeN7Xawy1Bb/6K+3EnjcUfq9P23iMT5Yznbffl
Hpsfe3C8yPP+yMygIEzcHv9Cj1kXXCimZe305eO87BQIj7PgN2Q4pPu0pLbK
tQ882PwLy7m3+fBAWPHAj75y2w1tfdUKAGLiJdPemn/feuxX4zk6W3zHdxAj
QPyMQpZvrGUqV6EvBlQVR5lGjfiMA+AxxbTQTBDIWbCgN2gl1IjFgo9vT0bC
f5qBqi4J+6JUhtjdkiTuL9y5QcJvMekYAO1dWkff9i7vaHQUdttRB2H0EgUV
3UMupL2mxkG0GQoJ1LZaR4u6ZeHtjW9k6H48nVNf2NcthSl99FN1Ax9eka8a
hOrSwpeLdEt80BdPzw5Hp894S+DWUvpebqgAHmnoUGGcG4iHumRU9JRMRlrr
ZcYeoql4W3/C4PsRvu0WOFGOG8mQqSWJIgzTpSh9R9HgOl6WbnLfvoXRkVys
WuaQTOYR1u+kqpJWoMadVTgMaSKX1t+AcMCmLVdU5swalRskEO4Mfqu0DVdV
D3rO3LiqGxh1vbmZHritK6/tkvCcW0KPLs4Mq5NFCyIpNeNiq7+xD93JfMdf
qJhlaGLWjcSHZ66btrHFF7tHm+fTD75NcXqSs6Sat8rxw8IESXrJXUXfcc34
ppimT+J9Et1xIsOMTY4drtijU1KMj754tdvs6vF1D0ZFd/UD0VjO4qdfDbOp
J+E0vmPivzNs6jZ8vVhPrVVUF+2Geo+cRvtrdL7MSUSsGLYu9fxt1pSqf/qe
AXkEXzkgt50VTLKW0iMtIcYYu8CcahkAJqa0TJ97uTF7AzGy4KRpwY+J+xs/
uu2xSGBn3i7ipw8f3/LZPbosjSOwZT42JkQonVQ6j99d0CS61aPvKgETc7NA
9gFrVnepynM2MwuMpV4PgQGMnDu0U32H4/prFMsIQUkXMJIhWsDOj85PBA7U
qXXI9p0yC+RWqgPrCE3Z1GdFYdS1/ht/jox+lywAAA==

-->

</rfc>
