<?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.21 (Ruby 3.3.4) -->
<rfc xmlns:xi="http://www.w3.org/2001/XInclude" ipr="trust200902" docName="draft-ietf-ace-authcred-dtls-profile-00" category="std" consensus="true" submissionType="IETF" updates="9202" tocInclude="true" sortRefs="true" symRefs="true" version="3">
  <!-- xml2rfc v2v3 conversion 3.25.0 -->
  <front>
    <title abbrev="Authentication Credentials DTLS profile">Additional Formats of Authentication Credentials for the Datagram Transport Layer Security (DTLS) Profile for Authentication and Authorization for Constrained Environments (ACE)</title>
    <seriesInfo name="Internet-Draft" value="draft-ietf-ace-authcred-dtls-profile-00"/>
    <author initials="M." surname="Tiloca" fullname="Marco Tiloca">
      <organization>RISE AB</organization>
      <address>
        <postal>
          <street>Isafjordsgatan 22</street>
          <city>Kista</city>
          <code>164 40</code>
          <country>Sweden</country>
        </postal>
        <email>marco.tiloca@ri.se</email>
      </address>
    </author>
    <author initials="J" surname="Preuß Mattsson" fullname="John Preuß Mattsson">
      <organization>Ericsson AB</organization>
      <address>
        <postal>
          <city>Stockholm</city>
          <code>164 80</code>
          <country>Sweden</country>
        </postal>
        <email>john.mattsson@ericsson.com</email>
      </address>
    </author>
    <date year="2025" month="January" day="15"/>
    <area>Security</area>
    <workgroup>ACE Working Group</workgroup>
    <keyword>Internet-Draft</keyword>
    <abstract>
      <?line 77?>

<t>This document updates the Datagram Transport Layer Security (DTLS) Profile for Authentication and Authorization for Constrained Environments (ACE). In particular, it specifies the use of additional formats of authentication credentials for establishing a DTLS session, when peer authentication is based on asymmetric cryptography. Therefore, this document updates RFC 9202. What is defined in this document is seamlessly applicable also if the profile uses Transport Layer Security (TLS) instead, as defined in RFC 9430.</t>
    </abstract>
    <note removeInRFC="true">
      <name>Discussion Venues</name>
      <t>Discussion of this document takes place on the
    Authentication and Authorization for Constrained Environments Working Group mailing list (ace@ietf.org),
    which is archived at <eref target="https://mailarchive.ietf.org/arch/browse/ace/"/>.</t>
      <t>Source for this draft and an issue tracker can be found at
    <eref target="https://github.com/ace-wg/ace-authcred-dtls-profile"/>.</t>
    </note>
  </front>
  <middle>
    <?line 82?>

<section anchor="intro">
      <name>Introduction</name>
      <t>The Authentication and Authorization for Constrained Environments (ACE) framework <xref target="RFC9200"/> defines an architecture to enforce access control for constrained devices. A client (C) requests an evidence of granted permissions from an authorization server (AS) in the form of an access token, then uploads the access token to the target resource server (RS), and finally accesses protected resources at RS according to what is specified in the access token.</t>
      <t>The framework has as main building blocks the OAuth 2.0 framework <xref target="RFC6749"/>, the Constrained Application Protocol (CoAP) <xref target="RFC7252"/> for message transfer, CBOR <xref target="RFC8949"/> for compact encoding, and COSE <xref target="RFC9052"/><xref target="RFC9053"/> for self-contained protection of access tokens.</t>
      <t>Separate profile documents define in detail how the participants in the ACE architecture communicate, especially as to the security protocols that they use. In particular, the ACE profile defined in <xref target="RFC9202"/> specifies how Datagram Transport Layer Security (DTLS) <xref target="RFC6347"/><xref target="RFC9147"/> is used to protect communications with transport-layer security in the ACE architecture. The profile has also been extended in <xref target="RFC9430"/>, in order to allow the alternative use of Transport Layer Security (TLS) <xref target="RFC8446"/> when CoAP is transported over TCP or WebSockets <xref target="RFC8323"/>.</t>
      <t>The DTLS profile <xref target="RFC9202"/> allows C and RS to establish a DTLS session with peer authentication based on symmetric or asymmetric cryptography. For the latter case, the profile defines an RPK mode (see <xref section="3.2" sectionFormat="of" target="RFC9202"/>), where authentication relies on the public keys of the two peers as raw public keys <xref target="RFC7250"/>.</t>
      <t>That is, C specifies its public key to the AS when requesting an access token, and the AS provides such public key to the target RS as included in the issued access token. Upon issuing the access token, the AS also provides C with the public key of RS. Then, C and RS use their asymmetric keys when performing the DTLS handshake, as defined in <xref target="RFC7250"/>.</t>
      <t>Per <xref target="RFC9202"/>, the DTLS profile admits only a COSE Key object <xref target="RFC9052"/> as the format of authentication credentials to use for transporting the public keys of C and RS, as raw public keys. However, it is desirable to enable additional formats of authentication credentials, as enhanced raw public keys or as public certificates.</t>
      <t>This document enables such additional formats in the DTLS profile, by defining how the public keys of C and RS can be specified by means of CBOR Web Token (CWT) Claims Sets (CCSs) <xref target="RFC8392"/>, or X.509 certificates <xref target="RFC5280"/>, or C509 certificates <xref target="I-D.ietf-cose-cbor-encoded-cert"/>. In particular, this document updates <xref target="RFC9202"/> as follows.</t>
      <ul spacing="normal">
        <li>
          <t>It extends the RPK mode defined in <xref section="3.2" sectionFormat="of" target="RFC9202"/>, by enabling the use of CCSs to wrap the raw public keys of C and RS (see <xref target="sec-rpk-mode"/>).  </t>
          <t>
[ TODO: Further extend the RPK mode, by admitting the identification of COSE Keys by reference, using the CWT Confirmation Method 'ckt' defined in https://datatracker.ietf.org/doc/html/draft-ietf-cose-key-thumbprint ]</t>
        </li>
        <li>
          <t>It defines a new certificate mode, which enables the use of X.509 or C509 certificates to specify the public keys of C and RS (see <xref target="sec-cert-mode"/>). In either case, certificates can be transported by value or instead identified by reference.</t>
        </li>
      </ul>
      <t>When using the updated RPK mode, the raw public keys of C and RS do not have to be of the same format. That is, it is possible to have both public keys as a COSE Key object or as a CCS, or instead one as a COSE Key object while the other one as a CCS.</t>
      <t>When using the certificate mode, the certificates of C and RS do not have to be of the same format. That is, it is possible to have both as X.509 certificates, or both as C509 certificates, or one as an X.509 certificate while the other one as a C509 certificate. Furthermore, it is possible to have both certificates transported by value, or both identified by reference, or one transported by value while the other one identified by reference.</t>
      <t>Also, the RPK mode and the certificate mode can be combined. That is, it is possible that one of the two authentication credentials is a certificate, while the other one is a raw public key.</t>
      <t>When using the formats introduced in this document, authentication credentials are transported by means of the CWT Confirmation Methods "kccs", "x5bag", "x5chain", "x5t", "x5u", "c5b", "c5c", "c5t", and "c5u" that are defined in <xref target="I-D.ietf-ace-edhoc-oscore-profile"/>.</t>
      <t>What is defined in this document is seamlessly applicable if TLS is used instead, as defined in <xref target="RFC9430"/>.</t>
      <section anchor="terminology">
        <name>Terminology</name>
        <t>The key words "<bcp14>MUST</bcp14>", "<bcp14>MUST NOT</bcp14>", "<bcp14>REQUIRED</bcp14>", "<bcp14>SHALL</bcp14>", "<bcp14>SHALL
NOT</bcp14>", "<bcp14>SHOULD</bcp14>", "<bcp14>SHOULD NOT</bcp14>", "<bcp14>RECOMMENDED</bcp14>", "<bcp14>NOT RECOMMENDED</bcp14>",
"<bcp14>MAY</bcp14>", and "<bcp14>OPTIONAL</bcp14>" in this document are to be interpreted as
described in BCP 14 <xref target="RFC2119"/> <xref target="RFC8174"/> when, and only when, they
appear in all capitals, as shown here.</t>
        <?line -18?>

<t>Readers are expected to be familiar with the terms and concepts described in the ACE framework for Authentication and Authorization <xref target="RFC9200"/><xref target="RFC9201"/> and its DTLS profile <xref target="RFC9202"/>, as well as with terms and concepts related to CBOR Web Tokens (CWTs) <xref target="RFC8392"/> and CWT Confirmation Methods <xref target="RFC8747"/>.</t>
        <t>The terminology for entities in the considered architecture is defined in OAuth 2.0 <xref target="RFC6749"/>. In particular, this includes client (C), resource server (RS), and authorization server (AS).</t>
        <t>Readers are also expected to be familiar with the terms and concepts related to CoAP <xref target="RFC7252"/>, CBOR <xref target="RFC8949"/>, CDDL <xref target="RFC8610"/>, COSE <xref target="RFC9052"/><xref target="RFC9053"/>, the DTLS protocol suite <xref target="RFC6347"/><xref target="RFC9147"/>, and the use of raw public keys in DTLS <xref target="RFC7250"/>.</t>
        <t>Note that the term "endpoint" is used here following its OAuth definition, aimed at denoting resources such as /token and /introspect at the AS, and /authz-info at RS. This document does not use the CoAP definition of "endpoint", which is "An entity participating in the CoAP protocol."</t>
        <t>This document also refers to the term "authentication credential", which denotes the information associated with an entity, including that entity's public key and parameters associated with the public key. Examples of authentication credentials are CWT Claims Sets (CCSs) <xref target="RFC8392"/>, X.509 certificates <xref target="RFC5280"/>, and C509 certificates <xref target="I-D.ietf-cose-cbor-encoded-cert"/>.</t>
        <t>Examples throughout this document are expressed in CBOR diagnostic notation as defined in <xref section="8" sectionFormat="of" target="RFC8949"/> and <xref section="G" sectionFormat="of" target="RFC8610"/>. Diagnostic notation comments are often used to provide a textual representation of the parameters' keys and values.</t>
        <t>In the CBOR diagnostic notation used in this document, constructs of the form e'SOME_NAME' are replaced by the value assigned to SOME_NAME in the CDDL model shown in <xref target="fig-cddl-model"/> of <xref target="sec-cddl-model"/>. For example, {e'x5chain' : h'3081...cb02'} stands for {5 : h'3081...cb02'}.</t>
        <t>Note to RFC Editor: Please delete the paragraph immediately preceding this note. Also, in the CBOR diagnostic notation used in this document, please replace the constructs of the form e'SOME_NAME' with the value assigned to SOME_NAME in the CDDL model shown in <xref target="fig-cddl-model"/> of <xref target="sec-cddl-model"/>. Finally, please delete this note.</t>
      </section>
    </section>
    <section anchor="sec-rpk-mode">
      <name>Updates to the RPK Mode</name>
      <t>This section updates the RPK mode defined in <xref section="3.2" sectionFormat="of" target="RFC9202"/>, by defining how the raw public key of C and RS can be provided as wrapped by a CCS <xref target="RFC8392"/>, instead of as a COSE Key object <xref target="RFC9052"/>. Note that only the differences from <xref target="RFC9202"/> are compiled below.</t>
      <t>If the raw public key of C is wrapped by a CCS, then the following applies.</t>
      <ul spacing="normal">
        <li>
          <t>The payload of the Access Token Request (see <xref section="5.8.1" sectionFormat="of" target="RFC9200"/>) is as defined in <xref section="3.2.1" sectionFormat="of" target="RFC9202"/>, with the difference that the "req_cnf" parameter <xref target="RFC9201"/> <bcp14>MUST</bcp14> specify a "kccs" structure, with value a CCS specifying the public key of C that has to be bound to the access token.  </t>
          <t>
In particular, the CCS <bcp14>MUST</bcp14> include the "cnf" claim specifying the public key of C as a COSE Key object, <bcp14>SHOULD</bcp14> include the "sub" claim specifying the subject name of C associated with the public key of C, and <bcp14>MAY</bcp14> include additional claims.</t>
        </li>
        <li>
          <t>The content of the access token that the AS provides to C in the Access Token Response (see <xref section="5.8.2" sectionFormat="of" target="RFC9200"/>) is as defined in <xref section="3.2.1" sectionFormat="of" target="RFC9202"/>, with the difference that the "cnf" claim of the access token <bcp14>MUST</bcp14> specify a "kccs" structure, with value a CCS specifying the public key of C that is bound to the access token.  </t>
          <t>
In particular, the CCS <bcp14>MUST</bcp14> include the "cnf" claim specifying the public key of C as a COSE Key object, <bcp14>SHOULD</bcp14> include the "sub" claim specifying the subject name of C associated with the public key of C, and <bcp14>MAY</bcp14> include additional claims.</t>
        </li>
      </ul>
      <t>If the raw public key of RS is wrapped by a CCS, then the following applies.</t>
      <ul spacing="normal">
        <li>
          <t>The payload of the Access Token Response is as defined in <xref section="3.2.1" sectionFormat="of" target="RFC9202"/>, with the difference that the "rs_cnf" parameter <xref target="RFC9201"/> <bcp14>MUST</bcp14> specify a "kccs" structure, with value a CCS specifying the public key of RS.  </t>
          <t>
In particular, the CCS <bcp14>MUST</bcp14> include the "cnf" claim specifying the public key of RS as a COSE Key object, <bcp14>SHOULD</bcp14> include the "sub" claim specifying the subject name of RS associated with the public key of RS, and <bcp14>MAY</bcp14> include additional claims.</t>
        </li>
      </ul>
      <t>For the "req_cnf" parameter of the Access Token Request, the "rs_cnf" parameter of the Access Token Response, and the "cnf" claim of the access token, the Confirmation Method "kccs" structure and its identifier are defined in <xref target="I-D.ietf-ace-edhoc-oscore-profile"/>.</t>
      <t>It is not required that both public keys are wrapped by a CCS. That is, one of the two authentication credentials can be a CCS, while the other one can be a COSE Key object as per <xref section="3.2" sectionFormat="of" target="RFC9202"/>.</t>
      <section anchor="examples">
        <name>Examples</name>
        <t><xref target="fig-example-C-to-AS-ccs"/> shows an example of Access Token Request from C to the AS.</t>
        <figure anchor="fig-example-C-to-AS-ccs">
          <name>Access Token Request Example for RPK Mode, with the Public Key of C Wrapped by a CCS within "req_cnf"</name>
          <artwork><![CDATA[
   POST coaps://as.example.com/token
   Content-Format: 19 (application/ace+cbor)
   Payload:
   {
     / grant_type / 33 : 2 / client_credentials /,
     / audience /    5 : "tempSensor4711",
     / req_cnf /     4 : {
       e'kccs' : {
         / sub / 2 : "42-50-31-FF-EF-37-32-39",
         / cnf / 8 : {
           / COSE_Key / 1 : {
             / kty /    1 : 2 / EC2 /,
             / crv /   -1 : 1 / P-256 /,
             / x /     -2 : h'd7cc072de2205bdc1537a543d53c60a6
                              acb62eccd890c7fa27c9e354089bbe13',
             / y /     -3 : h'f95e1d4b851a2cc80fff87d8e23f22af
                              b725d535e515d020731e79a3b4e47120'
           }
         }
       }
     }
   }
]]></artwork>
        </figure>
        <t><xref target="fig-example-AS-to-C-ccs"/> shows an example of Access Token Response from the AS to C.</t>
        <figure anchor="fig-example-AS-to-C-ccs">
          <name>Access Token Response Example for RPK Mode, with the Public Key of RS Wrapped by a CCS within "rs_cnf"</name>
          <artwork><![CDATA[
   2.01 Created
   Content-Format: 19 (application/ace+cbor)
   Max-Age: 3560
   Payload:
   {
     / access_token / 1 : h'd83dd083...643b',
       / (remainder of CWT omitted for brevity;
       CWT contains the client's RPK in the cnf claim) /
     / expires_in /   2 : 3600,
     / rs_cnf /      41 : {
       e'kccs' : {
         / sub / 2 : "AA-BB-CC-00-01-02-03-04",
         / cnf / 8 : {
           / COSE_Key / 1 : {
             / kty /  1 : 2 / EC2 /,
             / crv / -1 : 1 / P-256 /,
             / x /   -2 : h'bbc34960526ea4d32e940cad2a234148
                            ddc21791a12afbcbac93622046dd44f0',
             / y /   -3 : h'4519e257236b2a0ce2023f0931f1f386
                            ca7afda64fcde0108c224c51eabf6072'
           }
         }
       }
     }
   }
]]></artwork>
        </figure>
      </section>
    </section>
    <section anchor="sec-cert-mode">
      <name>Certificate Mode</name>
      <t>This section defines a new certificate mode of the DTLS profile, which enables the use of public certificates to specify the public keys of C and RS. Compared to the RPK mode defined in <xref section="3.2" sectionFormat="of" target="RFC9202"/> and extended in <xref target="sec-rpk-mode"/> of this document, the certificate mode displays the differences compiled below.</t>
      <t>The authentication credential of C and/or RS is a public certificate, i.e., an X.509 certificate <xref target="RFC5280"/> or a C509 certificate <xref target="I-D.ietf-cose-cbor-encoded-cert"/>.</t>
      <ul spacing="normal">
        <li>
          <t>The CWT Confirmation Methods "x5chain", "x5bag", "c5c", and "c5b" defined in <xref target="I-D.ietf-ace-edhoc-oscore-profile"/> are used to transport such authentication credentials by value.</t>
        </li>
        <li>
          <t>The CWT Confirmation Methods "x5t", "x5u", "c5t", and "c5u" defined in <xref target="I-D.ietf-ace-edhoc-oscore-profile"/> are used to identify such authentication credentials by reference.</t>
        </li>
      </ul>
      <t>If the authentication credential AUTH_CRED_C of C is a public certificate, then the following applies.</t>
      <ul spacing="normal">
        <li>
          <t>The "req_cnf" parameter <xref target="RFC9201"/> of the Access Token Request (see <xref section="5.8.1" sectionFormat="of" target="RFC9200"/>) specifies AUTH_CRED_C as follows.  </t>
          <t>
If AUTH_CRED_C is an X.509 certificate, the "req_cnf" parameter <bcp14>MUST</bcp14> specify:  </t>
          <ul spacing="normal">
            <li>
              <t>An "x5chain" or "x5bag" structure, in case AUTH_CRED_C is transported by value within a certificate chain or a certificate bag, respectively; or</t>
            </li>
            <li>
              <t>An "x5t" or "x5u" structure, in case AUTH_CRED_C is identified by reference through a hash value (a thumbprint) or a URI <xref target="RFC3986"/>, respectively.</t>
            </li>
          </ul>
          <t>
If AUTH_CRED_C is a C509 certificate, the "req_cnf" parameter <bcp14>MUST</bcp14> specify:  </t>
          <ul spacing="normal">
            <li>
              <t>A "c5c" or "c5b" structure, in case AUTH_CRED_C is transported by value within a certificate chain or a certificate bag, respectively; or</t>
            </li>
            <li>
              <t>A "c5t" or "c5u" structure, in case AUTH_CRED_C is identified by reference through a hash value (a thumbprint) or a URI <xref target="RFC3986"/>, respectively.</t>
            </li>
          </ul>
        </li>
        <li>
          <t>The "cnf" claim of the access token that the AS provides to C in the Access Token Response (see <xref section="5.8.2" sectionFormat="of" target="RFC9200"/>) specifies AUTH_CRED_C as follows.  </t>
          <t>
If AUTH_CRED_C is an X.509 certificate, the "cnf" claim <bcp14>MUST</bcp14> specify:  </t>
          <ul spacing="normal">
            <li>
              <t>An "x5chain" or "x5bag" structure, in case AUTH_CRED_C is transported by value within a certificate chain or a certificate bag, respectively; or</t>
            </li>
            <li>
              <t>An "x5t" or "x5u" structure, in case AUTH_CRED_C is identified by reference through a hash value (a thumbprint) or a URI <xref target="RFC3986"/>, respectively.</t>
            </li>
          </ul>
          <t>
If AUTH_CRED_C is a C509 certificate, the "cnf" claim <bcp14>MUST</bcp14> specify:  </t>
          <ul spacing="normal">
            <li>
              <t>A "c5c" or "c5b" structure, in case AUTH_CRED_C is transported by value within a certificate chain or a certificate bag, respectively; or</t>
            </li>
            <li>
              <t>A "c5t" or "c5u" structure, in case AUTH_CRED_C is identified by reference through a hash value (a thumbprint) or a URI <xref target="RFC3986"/>, respectively.</t>
            </li>
          </ul>
        </li>
      </ul>
      <t>If the authentication credential AUTH_CRED_RS of RS is a public certificate, then the following applies.</t>
      <ul spacing="normal">
        <li>
          <t>The "rs_cnf" parameter <xref target="RFC9201"/> of the Access Token Response specifies AUTH_CRED_RS as follows.  </t>
          <t>
If AUTH_CRED_RS is an X.509 certificate, the "rs_cnf" parameter <bcp14>MUST</bcp14> specify:  </t>
          <ul spacing="normal">
            <li>
              <t>An "x5chain" or "x5bag" structure, in case AUTH_CRED_RS is transported by value within a certificate chain or a certificate bag, respectively; or</t>
            </li>
            <li>
              <t>An "x5t" or "x5u" structure, in case AUTH_CRED_RS is identified by reference through a hash value (a thumbprint) or a URI <xref target="RFC3986"/>, respectively.</t>
            </li>
          </ul>
          <t>
If AUTH_CRED_RS is a C509 certificate, the "rs_cnf" parameter <bcp14>MUST</bcp14> specify:  </t>
          <ul spacing="normal">
            <li>
              <t>A "c5c" or "c5b" structure, in case AUTH_CRED_RS is transported by value within a certificate chain or a certificate bag, respectively; or</t>
            </li>
            <li>
              <t>A "c5t" or "c5u" structure, in case AUTH_CRED_RS is identified by reference through a hash value (a thumbprint) or a URI <xref target="RFC3986"/>, respectively.</t>
            </li>
          </ul>
        </li>
      </ul>
      <t>For the "req_cnf" parameter of the Access Token Request, the "rs_cnf" parameter of the Access Token Response, and the "cnf" claim of the access token, the structures "x5bag", "x5chain", "x5t", "x5u", "c5b", "c5c", "c5t", and "c5u" are defined in <xref target="I-D.ietf-ace-edhoc-oscore-profile"/>, together with their identifiers.</t>
      <t>When using either of the structures, the specified authentication credential is just the end-entity certificate.</t>
      <t>As per <xref target="RFC6347"/> and <xref target="RFC9147"/>, a public certificate is specified in the Certificate message of the DTLS handshake. For X.509 certificates, the TLS Certificate Type is "X509", as defined in <xref target="RFC6091"/>. For C509 certificates, the TLS certificate type is "C509 Certificate", as defined in <xref target="I-D.ietf-cose-cbor-encoded-cert"/>.</t>
      <t>It is not required that AUTH_CRED_C and AUTH_CRED_RS are both X.509 certificates or both C509 certificates. Also, it is not required that AUTH_CRED_C and AUTH_CRED_RS are both transported by value or both identified by reference.</t>
      <t>Finally, one of the two authentication credentials can be a public certificate, while the other one can be a raw public key. This is consistent with the admitted, combined use of raw public keys and certificates, as discussed in <xref section="5.3" sectionFormat="of" target="RFC7250"/>.</t>
      <section anchor="examples-1">
        <name>Examples</name>
        <t><xref target="fig-example-C-to-AS-x509"/> shows an example of Access Token Request from C to the AS. In the example, C specifies its authentication credential by means of an "x5chain" structure, transporting by value only its own X.509 certificate.</t>
        <figure anchor="fig-example-C-to-AS-x509">
          <name>Access Token Request Example for Certificate Mode with an X.509 Certificate as Authentication Credential of C, Transported by Value within "req_cnf"</name>
          <artwork><![CDATA[
   POST coaps://as.example.com/token
   Content-Format: 19 (application/ace+cbor)
   Payload:
   {
     / grant_type / 33 : 2 / client_credentials /,
     / audience /    5 : "tempSensor4711",
     / req_cnf /     4 : {
       e'x5chain' : h'3081ee3081a1a003020102020462319ec430
                      0506032b6570301d311b301906035504030c
                      124544484f4320526f6f7420456432353531
                      39301e170d3232303331363038323433365a
                      170d3239313233313233303030305a302231
                      20301e06035504030c174544484f43205265
                      73706f6e6465722045643235353139302a30
                      0506032b6570032100a1db47b95184854ad1
                      2a0c1a354e418aace33aa0f2c662c00b3ac5
                      5de92f9359300506032b6570034100b723bc
                      01eab0928e8b2b6c98de19cc3823d46e7d69
                      87b032478fecfaf14537a1af14cc8be829c6
                      b73044101837eb4abc949565d86dce51cfae
                      52ab82c152cb02'
     }
   }
]]></artwork>
        </figure>
        <t><xref target="fig-example-AS-to-C-x509"/> shows an example of Access Token Response from the AS to C. In the example, the AS specifies the authentication credential of RS by means of an "x5chain" structure, transporting by value only the X.509 certificate of RS.</t>
        <figure anchor="fig-example-AS-to-C-x509">
          <name>Access Token Response Example for Certificate Mode with an X.509 Certificate as Authentication Credential of RS, Transported by Value within "rs_cnf"</name>
          <artwork><![CDATA[
   2.01 Created
   Content-Format: 19 (application/ace+cbor)
   Max-Age: 3560
   Payload:
   {
     / access_token / 1 : h'd83dd083...2fa6',
       / (remainder of CWT omitted for brevity;
       CWT contains the client's X.509 certificate in the cnf claim) /
     / expires_in /   2 : 3600,
     / rs_cnf /      41 : {
       e'x5chain' : h'3081ee3081a1a003020102020462319ea030
                      0506032b6570301d311b301906035504030c
                      124544484f4320526f6f7420456432353531
                      39301e170d3232303331363038323430305a
                      170d3239313233313233303030305a302231
                      20301e06035504030c174544484f4320496e
                      69746961746f722045643235353139302a30
                      0506032b6570032100ed06a8ae61a829ba5f
                      a54525c9d07f48dd44a302f43e0f23d8cc20
                      b73085141e300506032b6570034100521241
                      d8b3a770996bcfc9b9ead4e7e0a1c0db353a
                      3bdf2910b39275ae48b756015981850d27db
                      6734e37f67212267dd05eeff27b9e7a813fa
                      574b72a00b430b'
     }
   }
]]></artwork>
        </figure>
        <t>The following shows a variation of the two previous examples, where the same X.509 certificates are instead identified by reference.</t>
        <t><xref target="fig-example-C-to-AS-x509-ref"/> shows an example of Access Token Request from C to the AS. In the example, C specifies its authentication credential by means of an "x5t" structure, identifying by reference its own X.509 certificate.</t>
        <figure anchor="fig-example-C-to-AS-x509-ref">
          <name>Access Token Request Example for Certificate Mode with an X.509 Certificate as Authentication Credential of C, Identified by Reference within "req_cnf"</name>
          <artwork><![CDATA[
   POST coaps://as.example.com/token
   Content-Format: 19 (application/ace+cbor)
   Payload:
   {
     / grant_type / 33 : 2 / client_credentials /,
     / audience /    5 : "tempSensor4711",
     / req_cnf /     4 : {
       e'x5t' : [-15, h'79f2a41b510c1f9b']
       / SHA-2 256-bit Hash truncated to 64-bits /
     }
   }
]]></artwork>
        </figure>
        <t><xref target="fig-example-AS-to-C-x509-ref"/> shows an example of Access Token Response from the AS to C. In the example, the AS specifies the authentication credential of RS by means of an "x5t" structure, identifying by reference the X.509 certificate of RS.</t>
        <figure anchor="fig-example-AS-to-C-x509-ref">
          <name>Access Token Response Example for Certificate Mode with an X.509 Certificate as Authentication Credential of RS, Transported by Value within "rs_cnf"</name>
          <artwork><![CDATA[
   2.01 Created
   Content-Format: 19 (application/ace+cbor)
   Max-Age: 3560
   Payload:
   {
     / access_token / 1 : h'd83dd083...2fa6',
       / (remainder of CWT omitted for brevity;
       CWT contains the client's X.509 certificate in the cnf claim) /
     / expires_in /   2 : 3600,
     / rs_cnf /      41 : {
       e'x5t' : [-15, h'c24ab2fd7643c79f']
       / SHA-2 256-bit Hash truncated to 64-bits /
     }
   }
]]></artwork>
        </figure>
      </section>
    </section>
    <section anchor="sec-security-considerations">
      <name>Security Considerations</name>
      <t>The security considerations from <xref target="RFC9200"/> and <xref target="RFC9202"/> apply to this document as well.</t>
      <t>When using public certificates as authentication credentials, the security considerations from <xref section="C.2" sectionFormat="of" target="RFC8446"/> apply.</t>
      <t>When using X.509 certificates as authentication credentials, the security considerations from <xref target="RFC5280"/>, <xref target="RFC6818"/>, <xref target="RFC8398"/>, and <xref target="RFC8399"/> apply.</t>
      <t>When using C509 certificates as authentication credentials, the security considerations from <xref target="I-D.ietf-cose-cbor-encoded-cert"/> apply.</t>
    </section>
    <section anchor="iana-considerations">
      <name>IANA Considerations</name>
      <t>This document has no actions for IANA.</t>
    </section>
  </middle>
  <back>
    <references anchor="sec-combined-references">
      <name>References</name>
      <references anchor="sec-normative-references">
        <name>Normative References</name>
        <reference anchor="I-D.ietf-cose-cbor-encoded-cert">
          <front>
            <title>CBOR Encoded X.509 Certificates (C509 Certificates)</title>
            <author fullname="John Preuß Mattsson" initials="J. P." surname="Mattsson">
              <organization>Ericsson AB</organization>
            </author>
            <author fullname="Göran Selander" initials="G." surname="Selander">
              <organization>Ericsson AB</organization>
            </author>
            <author fullname="Shahid Raza" initials="S." surname="Raza">
              <organization>RISE AB</organization>
            </author>
            <author fullname="Joel Höglund" initials="J." surname="Höglund">
              <organization>RISE AB</organization>
            </author>
            <author fullname="Martin Furuhed" initials="M." surname="Furuhed">
              <organization>Nexus Group</organization>
            </author>
            <date day="8" month="January" year="2025"/>
            <abstract>
              <t>   This document specifies a CBOR encoding of X.509 certificates.  The
   resulting certificates are called C509 Certificates.  The CBOR
   encoding supports a large subset of RFC 5280 and all certificates
   compatible with the RFC 7925, IEEE 802.1AR (DevID), CNSA, RPKI, GSMA
   eUICC, and CA/Browser Forum Baseline Requirements profiles.  When
   used to re-encode DER encoded X.509 certificates, the CBOR encoding
   can in many cases reduce the size of RFC 7925 profiled certificates
   with over 50% while also significantly reducing memory and code size
   compared to ASN.1.  The CBOR encoded structure can alternatively be
   signed directly ("natively signed"), which does not require re-
   encoding for the signature to be verified.  The document also
   specifies C509 Certificate Signing Requests, C509 COSE headers, a
   C509 TLS certificate type, and a C509 file format.

              </t>
            </abstract>
          </front>
          <seriesInfo name="Internet-Draft" value="draft-ietf-cose-cbor-encoded-cert-12"/>
        </reference>
        <reference anchor="I-D.ietf-ace-edhoc-oscore-profile">
          <front>
            <title>Ephemeral Diffie-Hellman Over COSE (EDHOC) and Object Security for Constrained Environments (OSCORE) Profile for Authentication and Authorization for Constrained Environments (ACE)</title>
            <author fullname="Göran Selander" initials="G." surname="Selander">
              <organization>Ericsson</organization>
            </author>
            <author fullname="John Preuß Mattsson" initials="J. P." surname="Mattsson">
              <organization>Ericsson</organization>
            </author>
            <author fullname="Marco Tiloca" initials="M." surname="Tiloca">
              <organization>RISE</organization>
            </author>
            <author fullname="Rikard Höglund" initials="R." surname="Höglund">
              <organization>RISE</organization>
            </author>
            <date day="21" month="October" year="2024"/>
            <abstract>
              <t>   This document specifies a profile for the Authentication and
   Authorization for Constrained Environments (ACE) framework.  It
   utilizes Ephemeral Diffie-Hellman Over COSE (EDHOC) for achieving
   mutual authentication between an ACE-OAuth Client and Resource
   Server, and it binds an authentication credential of the Client to an
   ACE-OAuth access token.  EDHOC also establishes an Object Security
   for Constrained RESTful Environments (OSCORE) Security Context, which
   is used to secure communications when accessing protected resources
   according to the authorization information indicated in the access
   token.  This profile can be used to delegate management of
   authorization information from a resource-constrained server to a
   trusted host with less severe limitations regarding processing power
   and memory.

              </t>
            </abstract>
          </front>
          <seriesInfo name="Internet-Draft" value="draft-ietf-ace-edhoc-oscore-profile-06"/>
        </reference>
        <reference anchor="RFC3986">
          <front>
            <title>Uniform Resource Identifier (URI): Generic Syntax</title>
            <author fullname="T. Berners-Lee" initials="T." surname="Berners-Lee"/>
            <author fullname="R. Fielding" initials="R." surname="Fielding"/>
            <author fullname="L. Masinter" initials="L." surname="Masinter"/>
            <date month="January" year="2005"/>
            <abstract>
              <t>A Uniform Resource Identifier (URI) is a compact sequence of characters that identifies an abstract or physical resource. This specification defines the generic URI syntax and a process for resolving URI references that might be in relative form, along with guidelines and security considerations for the use of URIs on the Internet. The URI syntax defines a grammar that is a superset of all valid URIs, allowing an implementation to parse the common components of a URI reference without knowing the scheme-specific requirements of every possible identifier. This specification does not define a generative grammar for URIs; that task is performed by the individual specifications of each URI scheme. [STANDARDS-TRACK]</t>
            </abstract>
          </front>
          <seriesInfo name="STD" value="66"/>
          <seriesInfo name="RFC" value="3986"/>
          <seriesInfo name="DOI" value="10.17487/RFC3986"/>
        </reference>
        <reference anchor="RFC5280">
          <front>
            <title>Internet X.509 Public Key Infrastructure Certificate and Certificate Revocation List (CRL) Profile</title>
            <author fullname="D. Cooper" initials="D." surname="Cooper"/>
            <author fullname="S. Santesson" initials="S." surname="Santesson"/>
            <author fullname="S. Farrell" initials="S." surname="Farrell"/>
            <author fullname="S. Boeyen" initials="S." surname="Boeyen"/>
            <author fullname="R. Housley" initials="R." surname="Housley"/>
            <author fullname="W. Polk" initials="W." surname="Polk"/>
            <date month="May" year="2008"/>
            <abstract>
              <t>This memo profiles the X.509 v3 certificate and X.509 v2 certificate revocation list (CRL) for use in the Internet. An overview of this approach and model is provided as an introduction. The X.509 v3 certificate format is described in detail, with additional information regarding the format and semantics of Internet name forms. Standard certificate extensions are described and two Internet-specific extensions are defined. A set of required certificate extensions is specified. The X.509 v2 CRL format is described in detail along with standard and Internet-specific extensions. An algorithm for X.509 certification path validation is described. An ASN.1 module and examples are provided in the appendices. [STANDARDS-TRACK]</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="5280"/>
          <seriesInfo name="DOI" value="10.17487/RFC5280"/>
        </reference>
        <reference anchor="RFC6347">
          <front>
            <title>Datagram Transport Layer Security Version 1.2</title>
            <author fullname="E. Rescorla" initials="E." surname="Rescorla"/>
            <author fullname="N. Modadugu" initials="N." surname="Modadugu"/>
            <date month="January" year="2012"/>
            <abstract>
              <t>This document specifies version 1.2 of the Datagram Transport Layer Security (DTLS) protocol. The DTLS protocol provides communications privacy for datagram protocols. The protocol allows client/server applications to communicate in a way that is designed to prevent eavesdropping, tampering, or message forgery. The DTLS protocol is based on the Transport Layer Security (TLS) protocol and provides equivalent security guarantees. Datagram semantics of the underlying transport are preserved by the DTLS protocol. This document updates DTLS 1.0 to work with TLS version 1.2. [STANDARDS-TRACK]</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="6347"/>
          <seriesInfo name="DOI" value="10.17487/RFC6347"/>
        </reference>
        <reference anchor="RFC6749">
          <front>
            <title>The OAuth 2.0 Authorization Framework</title>
            <author fullname="D. Hardt" initials="D." role="editor" surname="Hardt"/>
            <date month="October" year="2012"/>
            <abstract>
              <t>The OAuth 2.0 authorization framework enables a third-party application to obtain limited access to an HTTP service, either on behalf of a resource owner by orchestrating an approval interaction between the resource owner and the HTTP service, or by allowing the third-party application to obtain access on its own behalf. This specification replaces and obsoletes the OAuth 1.0 protocol described in RFC 5849. [STANDARDS-TRACK]</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="6749"/>
          <seriesInfo name="DOI" value="10.17487/RFC6749"/>
        </reference>
        <reference anchor="RFC6818">
          <front>
            <title>Updates to the Internet X.509 Public Key Infrastructure Certificate and Certificate Revocation List (CRL) Profile</title>
            <author fullname="P. Yee" initials="P." surname="Yee"/>
            <date month="January" year="2013"/>
            <abstract>
              <t>This document updates RFC 5280, the "Internet X.509 Public Key Infrastructure Certificate and Certificate Revocation List (CRL) Profile". This document changes the set of acceptable encoding methods for the explicitText field of the user notice policy qualifier and clarifies the rules for converting internationalized domain name labels to ASCII. This document also provides some clarifications on the use of self-signed certificates, trust anchors, and some updated security considerations. [STANDARDS-TRACK]</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="6818"/>
          <seriesInfo name="DOI" value="10.17487/RFC6818"/>
        </reference>
        <reference anchor="RFC7250">
          <front>
            <title>Using Raw Public Keys in Transport Layer Security (TLS) and Datagram Transport Layer Security (DTLS)</title>
            <author fullname="P. Wouters" initials="P." role="editor" surname="Wouters"/>
            <author fullname="H. Tschofenig" initials="H." role="editor" surname="Tschofenig"/>
            <author fullname="J. Gilmore" initials="J." surname="Gilmore"/>
            <author fullname="S. Weiler" initials="S." surname="Weiler"/>
            <author fullname="T. Kivinen" initials="T." surname="Kivinen"/>
            <date month="June" year="2014"/>
            <abstract>
              <t>This document specifies a new certificate type and two TLS extensions for exchanging raw public keys in Transport Layer Security (TLS) and Datagram Transport Layer Security (DTLS). The new certificate type allows raw public keys to be used for authentication.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="7250"/>
          <seriesInfo name="DOI" value="10.17487/RFC7250"/>
        </reference>
        <reference anchor="RFC7252">
          <front>
            <title>The Constrained Application Protocol (CoAP)</title>
            <author fullname="Z. Shelby" initials="Z." surname="Shelby"/>
            <author fullname="K. Hartke" initials="K." surname="Hartke"/>
            <author fullname="C. Bormann" initials="C." surname="Bormann"/>
            <date month="June" year="2014"/>
            <abstract>
              <t>The Constrained Application Protocol (CoAP) is a specialized web transfer protocol for use with constrained nodes and constrained (e.g., low-power, lossy) networks. The nodes often have 8-bit microcontrollers with small amounts of ROM and RAM, while constrained networks such as IPv6 over Low-Power Wireless Personal Area Networks (6LoWPANs) often have high packet error rates and a typical throughput of 10s of kbit/s. The protocol is designed for machine- to-machine (M2M) applications such as smart energy and building automation.</t>
              <t>CoAP provides a request/response interaction model between application endpoints, supports built-in discovery of services and resources, and includes key concepts of the Web such as URIs and Internet media types. CoAP is designed to easily interface with HTTP for integration with the Web while meeting specialized requirements such as multicast support, very low overhead, and simplicity for constrained environments.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="7252"/>
          <seriesInfo name="DOI" value="10.17487/RFC7252"/>
        </reference>
        <reference anchor="RFC8323">
          <front>
            <title>CoAP (Constrained Application Protocol) over TCP, TLS, and WebSockets</title>
            <author fullname="C. Bormann" initials="C." surname="Bormann"/>
            <author fullname="S. Lemay" initials="S." surname="Lemay"/>
            <author fullname="H. Tschofenig" initials="H." surname="Tschofenig"/>
            <author fullname="K. Hartke" initials="K." surname="Hartke"/>
            <author fullname="B. Silverajan" initials="B." surname="Silverajan"/>
            <author fullname="B. Raymor" initials="B." role="editor" surname="Raymor"/>
            <date month="February" year="2018"/>
            <abstract>
              <t>The Constrained Application Protocol (CoAP), although inspired by HTTP, was designed to use UDP instead of TCP. The message layer of CoAP over UDP includes support for reliable delivery, simple congestion control, and flow control.</t>
              <t>Some environments benefit from the availability of CoAP carried over reliable transports such as TCP or Transport Layer Security (TLS). This document outlines the changes required to use CoAP over TCP, TLS, and WebSockets transports. It also formally updates RFC 7641 for use with these transports and RFC 7959 to enable the use of larger messages over a reliable transport.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="8323"/>
          <seriesInfo name="DOI" value="10.17487/RFC8323"/>
        </reference>
        <reference anchor="RFC8392">
          <front>
            <title>CBOR Web Token (CWT)</title>
            <author fullname="M. Jones" initials="M." surname="Jones"/>
            <author fullname="E. Wahlstroem" initials="E." surname="Wahlstroem"/>
            <author fullname="S. Erdtman" initials="S." surname="Erdtman"/>
            <author fullname="H. Tschofenig" initials="H." surname="Tschofenig"/>
            <date month="May" year="2018"/>
            <abstract>
              <t>CBOR Web Token (CWT) is a compact means of representing claims to be transferred between two parties. The claims in a CWT are encoded in the Concise Binary Object Representation (CBOR), and CBOR Object Signing and Encryption (COSE) is used for added application-layer security protection. A claim is a piece of information asserted about a subject and is represented as a name/value pair consisting of a claim name and a claim value. CWT is derived from JSON Web Token (JWT) but uses CBOR rather than JSON.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="8392"/>
          <seriesInfo name="DOI" value="10.17487/RFC8392"/>
        </reference>
        <reference anchor="RFC8398">
          <front>
            <title>Internationalized Email Addresses in X.509 Certificates</title>
            <author fullname="A. Melnikov" initials="A." role="editor" surname="Melnikov"/>
            <author fullname="W. Chuang" initials="W." role="editor" surname="Chuang"/>
            <date month="May" year="2018"/>
            <abstract>
              <t>This document defines a new name form for inclusion in the otherName field of an X.509 Subject Alternative Name and Issuer Alternative Name extension that allows a certificate subject to be associated with an internationalized email address.</t>
              <t>This document updates RFC 5280.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="8398"/>
          <seriesInfo name="DOI" value="10.17487/RFC8398"/>
        </reference>
        <reference anchor="RFC8399">
          <front>
            <title>Internationalization Updates to RFC 5280</title>
            <author fullname="R. Housley" initials="R." surname="Housley"/>
            <date month="May" year="2018"/>
            <abstract>
              <t>The updates to RFC 5280 described in this document provide alignment with the 2008 specification for Internationalized Domain Names (IDNs) and add support for internationalized email addresses in X.509 certificates.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="8399"/>
          <seriesInfo name="DOI" value="10.17487/RFC8399"/>
        </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="RFC8610">
          <front>
            <title>Concise Data Definition Language (CDDL): A Notational Convention to Express Concise Binary Object Representation (CBOR) and JSON Data Structures</title>
            <author fullname="H. Birkholz" initials="H." surname="Birkholz"/>
            <author fullname="C. Vigano" initials="C." surname="Vigano"/>
            <author fullname="C. Bormann" initials="C." surname="Bormann"/>
            <date month="June" year="2019"/>
            <abstract>
              <t>This document proposes a notational convention to express Concise Binary Object Representation (CBOR) data structures (RFC 7049). Its main goal is to provide an easy and unambiguous way to express structures for protocol messages and data formats that use CBOR or JSON.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="8610"/>
          <seriesInfo name="DOI" value="10.17487/RFC8610"/>
        </reference>
        <reference anchor="RFC8747">
          <front>
            <title>Proof-of-Possession Key Semantics for CBOR Web Tokens (CWTs)</title>
            <author fullname="M. Jones" initials="M." surname="Jones"/>
            <author fullname="L. Seitz" initials="L." surname="Seitz"/>
            <author fullname="G. Selander" initials="G." surname="Selander"/>
            <author fullname="S. Erdtman" initials="S." surname="Erdtman"/>
            <author fullname="H. Tschofenig" initials="H." surname="Tschofenig"/>
            <date month="March" year="2020"/>
            <abstract>
              <t>This specification describes how to declare in a CBOR Web Token (CWT) (which is defined by RFC 8392) that the presenter of the CWT possesses a particular proof-of-possession key. Being able to prove possession of a key is also sometimes described as being the holder-of-key. This specification provides equivalent functionality to "Proof-of-Possession Key Semantics for JSON Web Tokens (JWTs)" (RFC 7800) but using Concise Binary Object Representation (CBOR) and CWTs rather than JavaScript Object Notation (JSON) and JSON Web Tokens (JWTs).</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="8747"/>
          <seriesInfo name="DOI" value="10.17487/RFC8747"/>
        </reference>
        <reference anchor="RFC8949">
          <front>
            <title>Concise Binary Object Representation (CBOR)</title>
            <author fullname="C. Bormann" initials="C." surname="Bormann"/>
            <author fullname="P. Hoffman" initials="P." surname="Hoffman"/>
            <date month="December" year="2020"/>
            <abstract>
              <t>The Concise Binary Object Representation (CBOR) is a data format whose design goals include the possibility of extremely small code size, fairly small message size, and extensibility without the need for version negotiation. These design goals make it different from earlier binary serializations such as ASN.1 and MessagePack.</t>
              <t>This document obsoletes RFC 7049, providing editorial improvements, new details, and errata fixes while keeping full compatibility with the interchange format of RFC 7049. It does not create a new version of the format.</t>
            </abstract>
          </front>
          <seriesInfo name="STD" value="94"/>
          <seriesInfo name="RFC" value="8949"/>
          <seriesInfo name="DOI" value="10.17487/RFC8949"/>
        </reference>
        <reference anchor="RFC9052">
          <front>
            <title>CBOR Object Signing and Encryption (COSE): Structures and Process</title>
            <author fullname="J. Schaad" initials="J." surname="Schaad"/>
            <date month="August" year="2022"/>
            <abstract>
              <t>Concise Binary Object Representation (CBOR) is a data format designed for small code size and small message size. There is a need to be able to define basic security services for this data format. This document defines the CBOR Object Signing and Encryption (COSE) protocol. This specification describes how to create and process signatures, message authentication codes, and encryption using CBOR for serialization. This specification additionally describes how to represent cryptographic keys using CBOR.</t>
              <t>This document, along with RFC 9053, obsoletes RFC 8152.</t>
            </abstract>
          </front>
          <seriesInfo name="STD" value="96"/>
          <seriesInfo name="RFC" value="9052"/>
          <seriesInfo name="DOI" value="10.17487/RFC9052"/>
        </reference>
        <reference anchor="RFC9053">
          <front>
            <title>CBOR Object Signing and Encryption (COSE): Initial Algorithms</title>
            <author fullname="J. Schaad" initials="J." surname="Schaad"/>
            <date month="August" year="2022"/>
            <abstract>
              <t>Concise Binary Object Representation (CBOR) is a data format designed for small code size and small message size. There is a need to be able to define basic security services for this data format. This document defines a set of algorithms that can be used with the CBOR Object Signing and Encryption (COSE) protocol (RFC 9052).</t>
              <t>This document, along with RFC 9052, obsoletes RFC 8152.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="9053"/>
          <seriesInfo name="DOI" value="10.17487/RFC9053"/>
        </reference>
        <reference anchor="RFC9147">
          <front>
            <title>The Datagram Transport Layer Security (DTLS) Protocol Version 1.3</title>
            <author fullname="E. Rescorla" initials="E." surname="Rescorla"/>
            <author fullname="H. Tschofenig" initials="H." surname="Tschofenig"/>
            <author fullname="N. Modadugu" initials="N." surname="Modadugu"/>
            <date month="April" year="2022"/>
            <abstract>
              <t>This document specifies version 1.3 of the Datagram Transport Layer Security (DTLS) protocol. DTLS 1.3 allows client/server applications to communicate over the Internet in a way that is designed to prevent eavesdropping, tampering, and message forgery.</t>
              <t>The DTLS 1.3 protocol is based on the Transport Layer Security (TLS) 1.3 protocol and provides equivalent security guarantees with the exception of order protection / non-replayability. Datagram semantics of the underlying transport are preserved by the DTLS protocol.</t>
              <t>This document obsoletes RFC 6347.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="9147"/>
          <seriesInfo name="DOI" value="10.17487/RFC9147"/>
        </reference>
        <reference anchor="RFC9200">
          <front>
            <title>Authentication and Authorization for Constrained Environments Using the OAuth 2.0 Framework (ACE-OAuth)</title>
            <author fullname="L. Seitz" initials="L." surname="Seitz"/>
            <author fullname="G. Selander" initials="G." surname="Selander"/>
            <author fullname="E. Wahlstroem" initials="E." surname="Wahlstroem"/>
            <author fullname="S. Erdtman" initials="S." surname="Erdtman"/>
            <author fullname="H. Tschofenig" initials="H." surname="Tschofenig"/>
            <date month="August" year="2022"/>
            <abstract>
              <t>This specification defines a framework for authentication and authorization in Internet of Things (IoT) environments called ACE-OAuth. The framework is based on a set of building blocks including OAuth 2.0 and the Constrained Application Protocol (CoAP), thus transforming a well-known and widely used authorization solution into a form suitable for IoT devices. Existing specifications are used where possible, but extensions are added and profiles are defined to better serve the IoT use cases.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="9200"/>
          <seriesInfo name="DOI" value="10.17487/RFC9200"/>
        </reference>
        <reference anchor="RFC9201">
          <front>
            <title>Additional OAuth Parameters for Authentication and Authorization for Constrained Environments (ACE)</title>
            <author fullname="L. Seitz" initials="L." surname="Seitz"/>
            <date month="August" year="2022"/>
            <abstract>
              <t>This specification defines new parameters and encodings for the OAuth 2.0 token and introspection endpoints when used with the framework for Authentication and Authorization for Constrained Environments (ACE). These are used to express the proof-of-possession (PoP) key the client wishes to use, the PoP key that the authorization server has selected, and the PoP key the resource server uses to authenticate to the client.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="9201"/>
          <seriesInfo name="DOI" value="10.17487/RFC9201"/>
        </reference>
        <reference anchor="RFC9202">
          <front>
            <title>Datagram Transport Layer Security (DTLS) Profile for Authentication and Authorization for Constrained Environments (ACE)</title>
            <author fullname="S. Gerdes" initials="S." surname="Gerdes"/>
            <author fullname="O. Bergmann" initials="O." surname="Bergmann"/>
            <author fullname="C. Bormann" initials="C." surname="Bormann"/>
            <author fullname="G. Selander" initials="G." surname="Selander"/>
            <author fullname="L. Seitz" initials="L." surname="Seitz"/>
            <date month="August" year="2022"/>
            <abstract>
              <t>This specification defines a profile of the Authentication and Authorization for Constrained Environments (ACE) framework that allows constrained servers to delegate client authentication and authorization. The protocol relies on DTLS version 1.2 or later for communication security between entities in a constrained network using either raw public keys or pre-shared keys. A resource-constrained server can use this protocol to delegate management of authorization information to a trusted host with less-severe limitations regarding processing power and memory.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="9202"/>
          <seriesInfo name="DOI" value="10.17487/RFC9202"/>
        </reference>
        <reference anchor="RFC9430">
          <front>
            <title>Extension of the Datagram Transport Layer Security (DTLS) Profile for Authentication and Authorization for Constrained Environments (ACE) to Transport Layer Security (TLS)</title>
            <author fullname="O. Bergmann" initials="O." surname="Bergmann"/>
            <author fullname="J. Preuß Mattsson" initials="J." surname="Preuß Mattsson"/>
            <author fullname="G. Selander" initials="G." surname="Selander"/>
            <date month="July" year="2023"/>
            <abstract>
              <t>This document updates "Datagram Transport Layer Security (DTLS) Profile for Authentication and Authorization for Constrained Environments (ACE)" (RFC 9202) by specifying that the profile applies to TLS as well as DTLS.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="9430"/>
          <seriesInfo name="DOI" value="10.17487/RFC9430"/>
        </reference>
        <reference anchor="RFC2119">
          <front>
            <title>Key words for use in RFCs to Indicate Requirement Levels</title>
            <author fullname="S. Bradner" initials="S." surname="Bradner"/>
            <date month="March" year="1997"/>
            <abstract>
              <t>In many standards track documents several words are used to signify the requirements in the specification. These words are often capitalized. This document defines these words as they should be interpreted in IETF documents. This document specifies an Internet Best Current Practices for the Internet Community, and requests discussion and suggestions for improvements.</t>
            </abstract>
          </front>
          <seriesInfo name="BCP" value="14"/>
          <seriesInfo name="RFC" value="2119"/>
          <seriesInfo name="DOI" value="10.17487/RFC2119"/>
        </reference>
        <reference anchor="RFC8174">
          <front>
            <title>Ambiguity of Uppercase vs Lowercase in RFC 2119 Key Words</title>
            <author fullname="B. Leiba" initials="B." surname="Leiba"/>
            <date month="May" year="2017"/>
            <abstract>
              <t>RFC 2119 specifies common key words that may be used in protocol specifications. This document aims to reduce the ambiguity by clarifying that only UPPERCASE usage of the key words have the defined special meanings.</t>
            </abstract>
          </front>
          <seriesInfo name="BCP" value="14"/>
          <seriesInfo name="RFC" value="8174"/>
          <seriesInfo name="DOI" value="10.17487/RFC8174"/>
        </reference>
      </references>
      <references anchor="sec-informative-references">
        <name>Informative References</name>
        <reference anchor="RFC6091">
          <front>
            <title>Using OpenPGP Keys for Transport Layer Security (TLS) Authentication</title>
            <author fullname="N. Mavrogiannopoulos" initials="N." surname="Mavrogiannopoulos"/>
            <author fullname="D. Gillmor" initials="D." surname="Gillmor"/>
            <date month="February" year="2011"/>
            <abstract>
              <t>This memo defines Transport Layer Security (TLS) extensions and associated semantics that allow clients and servers to negotiate the use of OpenPGP certificates for a TLS session, and specifies how to transport OpenPGP certificates via TLS. It also defines the registry for non-X.509 certificate types. This document is not an Internet Standards Track specification; it is published for informational purposes.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="6091"/>
          <seriesInfo name="DOI" value="10.17487/RFC6091"/>
        </reference>
      </references>
    </references>
    <?line 421?>

<section anchor="ssec-example-hybrid">
      <name>Examples with Hybrid Settings</name>
      <t>This section provides additional examples where, within the same ACE execution workflow, C and RS use different formats of raw public keys (see <xref target="ssec-example-hybrid-1"/>), or different formats of certificates (see <xref target="ssec-example-hybrid-2"/>), or a combination of the RPK mode and certificate mode (see <xref target="ssec-example-hybrid-3"/>).</t>
      <section anchor="ssec-example-hybrid-1">
        <name>RPK Mode (Raw Public Keys of Different Formats)</name>
        <t><xref target="fig-example-C-to-AS-cose-key"/> shows an example of Access Token Request from C to the AS, where the public key of C is conveyed as a COSE Key.</t>
        <figure anchor="fig-example-C-to-AS-cose-key">
          <name>Access Token Request Example for RPK Mode, with the Public Key of C Conveyed as a COSE Key within "req_cnf"</name>
          <artwork><![CDATA[
   POST coaps://as.example.com/token
   Content-Format: 19 (application/ace+cbor)
   Payload:
   {
     / grant_type / 33 : 2 / client_credentials /,
     / audience /    5 : "tempSensor4711",
     / req_cnf /     4 : {
       / COSE_Key / 1 : {
         / kty /    1 : 2 / EC2 /,
         / crv /   -1 : 1 / P-256 /,
         / x /     -2 : h'd7cc072de2205bdc1537a543d53c60a6
                          acb62eccd890c7fa27c9e354089bbe13',
         / y /     -3 : h'f95e1d4b851a2cc80fff87d8e23f22af
                          b725d535e515d020731e79a3b4e47120'
       }
     }
   }
]]></artwork>
        </figure>
        <t><xref target="fig-example-AS-to-C-ccs-2"/> shows an example of Access Token Response from the AS to C, where the public key of RS is wrapped by a CCS.</t>
        <figure anchor="fig-example-AS-to-C-ccs-2">
          <name>Access Token Response Example for RPK Mode, with the Public Key of RS Wrapped by a CCS within "rs_cnf"</name>
          <artwork><![CDATA[
   2.01 Created
   Content-Format: 19 (application/ace+cbor)
   Max-Age: 3560
   Payload:
   {
     / access_token / 1 : h'd83dd083...c41a',
       / (remainder of CWT omitted for brevity;
       CWT contains the client's RPK in the cnf claim) /
     / expires_in /   2 : 3600,
     / rs_cnf /      41 : {
       e'kccs' : {
         / sub / 2 : "DD-EE-FF-05-06-07-08-09",
         / cnf / 8 : {
           / COSE_Key / 1 : {
             / kty /  1 : 2 / EC2 /,
             / crv / -1 : 1 / P-256 /,
             / x /   -2 : h'ac75e9ece3e50bfc8ed6039988952240
                            5c47bf16df96660a41298cb4307f7eb6',
             / y /   -3 : h'6e5de611388a4b8a8211334ac7d37ecb
                            52a387d257e6db3c2a93df21ff3affc8'
           }
         }
       }
     }
   }
]]></artwork>
        </figure>
      </section>
      <section anchor="ssec-example-hybrid-2">
        <name>Certificate Mode (Certificates of Different Formats)</name>
        <t><xref target="fig-example-C-to-AS-x509-2"/> shows an example of Access Token Request from C to the AS. In the example, C specifies its authentication credential by means of an "x5chain" structure, transporting by value only its own X.509 certificate.</t>
        <figure anchor="fig-example-C-to-AS-x509-2">
          <name>Access Token Request Example for Certificate Mode with an X.509 Certificate as Authentication Credential of C, Transported by Value within "req_cnf"</name>
          <artwork><![CDATA[
   POST coaps://as.example.com/token
   Content-Format: 19 (application/ace+cbor)
   Payload:
   {
     / grant_type / 33 : 2 / client_credentials /,
     / audience /    5 : "tempSensor4711",
     / req_cnf /     4 : {
       e'x5chain' : h'308201383081dea003020102020301f50d30
                      0a06082a8648ce3d04030230163114301206
                      035504030c0b524643207465737420434130
                      1e170d3233303130313030303030305a170d
                      3236303130313030303030305a3022312030
                      1e06035504030c1730312d32332d34352d46
                      462d46452d36372d38392d41423059301306
                      072a8648ce3d020106082a8648ce3d030107
                      03420004b1216ab96e5b3b3340f5bdf02e69
                      3f16213a04525ed44450b1019c2dfd3838ab
                      ac4e14d86c0983ed5e9eef2448c6861cc406
                      547177e6026030d051f7792ac206a30f300d
                      300b0603551d0f040403020780300a06082a
                      8648ce3d0403020349003046022100d4320b
                      1d6849e309219d30037e138166f2508247dd
                      dae76cceea55053c108e90022100d551f6d6
                      0106f1abb484cfbe6256c178e4ac3314ea19
                      191e8b607da5ae3bda16'
     }
   }
]]></artwork>
        </figure>
        <t><xref target="fig-example-AS-to-C-x509"/> shows an example of Access Token Response from the AS to C. In the example, the AS specifies the authentication credential of RS by means of a "c5c" structure, transporting by value only the C509 certificate of RS.</t>
        <figure anchor="fig-example-AS-to-C-c509">
          <name>Access Token Response Example for Certificate Mode with a C509 Certificate as Authentication Credential of RS, Transported by Value within "rs_cnf"</name>
          <artwork><![CDATA[
   2.01 Created
   Content-Format: 19 (application/ace+cbor)
   Max-Age: 3560
   Payload:
   {
     / access_token / 1 : h'd83dd083...2fa6',
       / (remainder of CWT omitted for brevity;
       CWT contains the client's X.509 certificate in the cnf claim) /
     / expires_in /   2 : 3600,
     / rs_cnf /      41 : {
       e'c5c' : h'03487e7661d7b54e46328a23625553066243
                  41086b4578616d706c6520496e63096d6365
                  7274696669636174696f6e016a3830322e31
                  41522043411a5c52dc0cf68c236255530662
                  434105624c41086b6578616d706c6520496e
                  630963496f542266577431323334015821fd
                  c8b421f11c25e47e3ac57123bf2d9fdc494f
                  028bc351cc80c03f150bf50cff958a042101
                  5496600d8716bf7fd0e752d0ac760777ad66
                  5d02a0075468d16551f951bfc82a431d0d9f
                  08bc2d205b1160210503822082492b060104
                  01b01f0a014401020304005840c0d81996d2
                  507d693f3c48eaa5ee9491bda6db214099d9
                  8117c63b361374cd86a774989f4c321a5cf2
                  5d832a4d336a08ad67df20f1506421188a0a
                  de6d349236'
     }
   }
]]></artwork>
        </figure>
      </section>
      <section anchor="ssec-example-hybrid-3">
        <name>Combination of RPK Mode and Certificate Mode</name>
        <t><xref target="fig-example-C-to-AS-ccs-2"/> shows an example of Access Token Request from C to the AS, where the public key of C is wrapped by a CCS.</t>
        <figure anchor="fig-example-C-to-AS-ccs-2">
          <name>Access Token Request Example for RPK Mode, with the Public Key of C Wrapped by a CCS within "req_cnf"</name>
          <artwork><![CDATA[
   POST coaps://as.example.com/token
   Content-Format: 19 (application/ace+cbor)
   Payload:
   {
     / grant_type / 33 : 2 / client_credentials /,
     / audience /    5 : "tempSensor4711",
     / req_cnf /     4 : {
       e'kccs' : {
         / sub / 2 : "55-11-44-AB-CD-EF-00-00",
         / cnf / 8 : {
           / COSE_Key / 1 : {
             / kty /    1 : 2 / EC2 /,
             / crv /   -1 : 1 / P-256 /,
             / x /     -2 : h'cd4177ba62433375ede279b5e18e8b91
                              bc3ed8f1e174474a26fc0edb44ea5373',
             / y /     -3 : h'a0391de29c5c5badda610d4e301eaaa1
                              8422367722289cd18cbe6624e89b9cfd'
           }
         }
       }
     }
   }
]]></artwork>
        </figure>
        <t><xref target="fig-example-AS-to-C-x509-3"/> shows an example of Access Token Response from the AS to C. In the example, the AS specifies the authentication credential of RS by means of an "x5chain" structure, transporting by value only the X.509 certificate of RS.</t>
        <figure anchor="fig-example-AS-to-C-x509-3">
          <name>Access Token Response Example for Certificate Mode with an X.509 Certificate as Authentication Credential of RS, Transported by Value within "rs_cnf"</name>
          <artwork><![CDATA[
   2.01 Created
   Content-Format: 19 (application/ace+cbor)
   Max-Age: 3560
   Payload:
   {
     / access_token / 1 : h'd83dd083...0f7b',
       / (remainder of CWT omitted for brevity;
       CWT contains the client's X.509 certificate in the cnf claim) /
     / expires_in /   2 : 3600,
     / rs_cnf /      41 : {
       e'x5chain' : h'3082023d308201e2a00302010202087e7661
                      d7b54e4632300a06082a8648ce3d04030230
                      5d310b3009060355040613025553310b3009
                      06035504080c02434131143012060355040a
                      0c0b4578616d706c6520496e633116301406
                      0355040b0c0d63657274696669636174696f
                      6e3113301106035504030c0a3830322e3141
                      522043413020170d31393031333131313239
                      31365a180f39393939313233313233353935
                      395a305c310b300906035504061302555331
                      0b300906035504080c024341310b30090603
                      5504070c024c4131143012060355040a0c0b
                      6578616d706c6520496e63310c300a060355
                      040b0c03496f54310f300d06035504051306
                      5774313233343059301306072a8648ce3d02
                      0106082a8648ce3d03010703420004c8b421
                      f11c25e47e3ac57123bf2d9fdc494f028bc3
                      51cc80c03f150bf50cff958d75419d81a6a2
                      45dffae790be95cf75f602f9152618f816a2
                      b23b5638e59fd9a3818a3081873009060355
                      1d1304023000301d0603551d0e0416041496
                      600d8716bf7fd0e752d0ac760777ad665d02
                      a0301f0603551d2304183016801468d16551
                      f951bfc82a431d0d9f08bc2d205b1160300e
                      0603551d0f0101ff0404030205a0302a0603
                      551d1104233021a01f06082b060105050708
                      04a013301106092b06010401b43b0a010404
                      01020304300a06082a8648ce3d0403020349
                      003046022100c0d81996d2507d693f3c48ea
                      a5ee9491bda6db214099d98117c63b361374
                      cd86022100a774989f4c321a5cf25d832a4d
                      336a08ad67df20f1506421188a0ade6d3492
                      36'
     }
   }
]]></artwork>
        </figure>
      </section>
    </section>
    <section anchor="sec-cddl-model" removeInRFC="true">
      <name>CDDL Model</name>
      <figure anchor="fig-cddl-model">
        <name>CDDL model</name>
        <artwork type="CDDL" align="left"><![CDATA[
; CWT Confirmation Methods
x5chain = 5
x5t = 7
c5c = 9
kccs = 14
]]></artwork>
      </figure>
    </section>
    <section numbered="false" anchor="acknowledgments">
      <name>Acknowledgments</name>
      <t>The authors sincerely thank <contact fullname="Rikard Höglund"/> and <contact fullname="Göran Selander"/> for their comments and feedback.</t>
      <t>This work was supported by the Sweden's Innovation Agency VINNOVA within the EUREKA CELTIC-NEXT project CYPRESS; and by the H2020 project SIFIS-Home (Grant agreement 952652).</t>
    </section>
  </back>
  <!-- ##markdown-source:
H4sIAAAAAAAAA+092XbbyJXv/Ioa+cH2jECjsEOdjU3Lsaa9jahOd06S41Oo
KkiIKYIBQMuKj+dXZr4iHzD5sbm3qrCRACV56e4kLR+LEFDLrbvfW7dAy7Im
b4+IO5lUWbWUR2QmRFZl+YotyZO8uGRVSfKUzDbVhVxVGWf4jMwLKfBPtixJ
mhcEHpLHrGLnBbskZwVbleu8qMgzdi0LspB8U2TVNXnw+OzZ4iF5VeRptpSq
49a4bCXUrbzI/qrvYKN5viqrgmUrKcjx6m1W5KtL6FSSB7P58cMJS5JCwhr2
wIgTk7WedyJyvmKXsFRRsLSyMlmlFuPSYtCfQydLVMvSMq2tJatkWU0m90hZ
AXiv2TJfQd+q2MjJJFsX6rKsHNuObWfCCsmOmhVPrs4BrPkx+S4v3mSrc/Lb
It+sJ2+ujsjJqpLFSlbWYwRiAjAfwQRiUm6Sy6wsYQHV9RrmOTk+ezLZrAVC
cURiB+aY8FzAYEdkA4BHk3V2RODnHuFsRTalJKwoGCA7SwlbLsm1LB8SQOIF
Ky/IhSwAakKqnB/hE7gsgVCFTMsjNYaQKdssAbVVXj+/vtSP8c8JU8Q5mhD1
Y5lPQrIVtHg+JWfZMuesua3x/JwVPN9+lBewgtOTxTGZfd3cBDJLCZg4KVn6
57wQ5Tkw1Yo4TtOCA1qPyDcZEKO9lwuYZXFs0cAjnt25v1lVBTRfXCErNPfl
JcuWR+QSwZpWCqzfFNm0lDvL0vD/Z36xAq6Vm7//D6ylqsoyX3VWnikeg2bt
MjaF7jnWSS3+uMg43u0iQC9vAfR5c5EvL4eXGN16iX8GyKeXZvbfSDPhlOeX
k8lKSXf2ViI1T6zHUyUIPC+lxZO8sOQKJxUWl0XVa4KyIsVFzq285Hkha1HB
RqdP5m4cBebSdyLbXAauF9aXoRfXlxGNzGXo+HZ76ZjLyHXc5jJu78ZRe1kP
FnlePXEU0HqwKGwmjuJm4thupoDLeoqYNm1B0uz2kraXTTfPhQaTbJV28Yhr
smNoPkHVA7SEe4vjZ0+OyMEf4Jn1Pfz86WAysSyLsAS1GgfdcnaRlQTU0gbV
GjHS/qMq1SkoKLJmBQyyWbLikGQVKdeSZ2lmIENNA4aBteYibc0F60PAt8wF
KFSWLLPyAnUi09q5lErrHZIr6EnWEta4NQrgKGElgItrArV0KStgaBj8el3l
gKT1xTUoIFRxMIc8BCiHsApUUGp0Sr67YBUOCjpPYSFbbXWB61KyyyVAtrwm
bL1eAigJIBnWkRPQr4gHw/yIj3IPlRSRQEtWkolDAL87qwIJ2Gk60YxxmQkB
dgpMDliJIhcbrtZ/j7y/l+GND8gx8nOQmaTAW/IKrBN5/95w/YcPBrYShgRj
wi+ySvJqU0g0ChL5nQMKOAe0gP5BgBTt8bqZSsi3GTSYkhnhywyR+WD+kBTy
LxugvRoYGgBPcMVEQDwwhwKoXhjjB3xS5JcKgN6SSlm8Bbw+mClsKgIg2yme
W9VAVfkbuUL6AyNt1sucCc2y3ce4FrxXseJcVgBZmW9wXfUEp4uHhwqlgAkw
o9emMyAFCI74AHDrTrCeipwusAnYLORpGPzKcFctNaKGtwvFVFOypQJYaWQO
0N4rkmyypRotAQv1Ri/hJVKYOFN7m3KoVD98UIvu0XymuVYhD3QEGBag1oN5
Pnv1UHdEZQskRwJeAlzsHHCCXJxKkPr51y9PdTPUnaYZWI81qC2iDATAp/E0
fwmmXDORjSPWl67pVcolWpdVpeEyWESwkHYdnJSAlIUE3QPi2khXLZO13CAy
hYSxluQiv9KCqLRVtmbYyuAafa8eBwPsl5sVIgQUhFS00dQta4Yoa5FdG2wh
4oGU8OwahXxHM9bzNKC2gl3LFCK41Z4I8K31uiYuGM8aoxQvkbE2qAoBaIPJ
ztKU/FxlwChVPTq4sTh6s7gR/Cj92axEMSOqukSCwMh3lVyJ7sJAZSHLwd/A
9jA6AAPINORgS3RwlWGsbcUN2lHzGRhxWJ8yAsiluNJmFaj7UTrP5q/Qpf1O
JguQDAn01n3BWfjwwchU1+XvEUKBWJK54lqQWlRqtT3aMkYaiUO2qDFErR0C
gEat0hMTI0EwAVgBT72Uhz3r0dG4p6++IZfgeZEHpUTIF0ZM3KmDSGwW8lCZ
SuDpLdAKuUQuyzWF1xtYGCdv5LUyzErlXeVqTUrTFOyq16bWCbZBpFJioAg6
/JsBvtsutdzMFppoRscry76tkRHjpi0sHA0A6McNvxgYzuhl1KoozXy5Ea0K
BRuxgb96mpR8u1Y+QrlRCnhL0R7W8yp+biafGzHpIUpheaFEYXXY8gkyMTTM
emRWODMeS4GWqJ5csdEFdC0v2Bu5bfH7WH4FLNHh0MN2gJo9mLhErOcrVFVa
1X6DgCZ/RsnvaF2lyIxRBNLtd8UA1bgoFcDXIlbDv8U3NRYOB3hmSp7mV/Kt
1F6icqjKrFCOknIYtMt0Rz9RTSRXgEGOlnaLS5Ws1XcwQAHORJ1eTredaT29
YbMBIAxHdbF9SJJrTSxERmNehhGiou5Edsw8dL6UgE3VCu0nqClypnyOB/Pv
zh6S+ZJllyVoP/TC5vNFWas+CHCQ+rC476e+HfcWpptgQGWazAda3BDFAbPt
Gq8hH7mnLtFlVyoTcPvv5KQyhkDzWaOsesw9prIUZhVFajYzlgGxoJwm0Jfq
/g7BOxg3ehFsmVWs31g4PWjDKeY1/vgHcvby8csj8mRTwDCFgbUHqgJCCVTD
7JniurRmQ5zMiFiJjSGgAD0LjHgI8NZ9gJToaKWZiv6g13MJjqog9/mb6n4X
HRdVtS6PHj0C1DKM997IQhFpmhfnjwD1jy6qy+WjTi5KEQ9WbVUXm8tkXYDP
T/74J4P8xlCQlbzq0t+s7eoiA0avub6DYs1Sg4wDiNfse72X0zt4x+4N4pGn
ZKbQrQ1bb3AjH10bDih9y5YbidCYkKghgX7cYByo+p1y4xu8ax4VHXLexC8i
J6u8AmX8VimkRNaGsAQP2igC1PbG1Gkdts7BAzAqTPVM8uqiNwU6RzuqWCsm
hgx92F1eDi7rYAeg11LZFZIrDLYN54vdxe/Se+vuF1s5wLSrlNQS68c7fKWe
1utZ7Xbfs/atltNani9VYL8Pzj5jDzBdC/MIyzVgD7LsEMzjvDsDb+Owryhr
H2iblLWggBufoOrYQxe8j/N2/Lk9Vj5DjHZmOxxeA7bqS9Eu+7VGU6clBpIm
h/tAYcUOVhtTuUenluTgDeflwSE5eOcn7Fxf8AuIJPVlpT82+MH9RH9w/YHP
EOdwuTnQuEMwevbqxtSmctM+Pl+UQewD/kUdtI2kgTpBFcx27x45w3TIKl/m
59fkHmZ/qvaGyQGhu3qFiXJy8PzbxRkuGT/Ji5fq+vT4v749OT1+jNeLp7Nn
z5qLiWmxePry22eP26u25/zl8+fHLx7rznCX9G5NDp7Pfl+j9uWrs5OXL2bP
DnZxwopa9WS447EuJBKelRNwEnmRJXrpX89f/d//Ug9Q8G+AA4dSzDXoPyIa
eiYg1LMpJ1j/iTH5BPAsGWpatd3B2Tqrav+xBOdtpTY90Hf5A2LmT0fkFwlf
U+9X5gYuuHezxlnvpsLZ7p2dzhqJA7cGpmmw2bu/hek+vLPf9/6u8d65+Ytf
LzE9YtHo17+aTCanwGcq0gMyyHdrnbfS9EjZZbbMAHNNCITsVSoc8xz011pl
WzpUqjMGberpVtnmTmaxvqToWEJDDGrGAnVFwSsJNGV1NmMXPgh2mVlS39cu
lbPdd611nmpMx+iGIaZXTAqhI246bY0pfRUBa1xgwhN0f4EM3U0y9XVEm7Lr
JOqGHXET55adnOnhntTkaGp02ie8ink/hvpd7GIuppMw3M0Nwp3Hj5+ZOwFV
ccqepGA/ytV5SYjdKzmS8mqzB8ah3Xb5ANVqtH5s/SKvZJPAU2skBxARrHNQ
RweNRlZ5FB3moK1DttRk02FgpTYmIGpDSqMPDl4VtmsTwDq8LMkjnVxGUB8p
K4mOdUXM9LOFXsUjpNxfLdw70qljNPZdrSlyGBNdN5N00OhvgcH1t8uovX4Y
4WC20mx63eZDFaiGZdU4Nb6nB9vRsuIU5cA0+VCNslGj3kyukGJCjmZTTO3U
lDnPFBspVmM1gIeG3bVzwSpz+34vuYTYwlTwJZgNlbDqD9YPV6bk+B27XC/l
TXtQKBRKD9wQid8Uhit98lFx+GTSgFpdFPnm/CLfVAOmE6S2wG0HpUmUxImM
na/yEtaFDFLjeDj+jkz0bZL3CO779zOwlyuRvSO/rZ8qYZ2SxwMjY1JZpd0R
mDytlDvY5J0xiQZuYwVR9oYtgXEQWGjehNEmL2/Id98ETgCGcqYxo3Bi+HJs
acZh2nYy9V7ThleN76i2geT9xcvnx69fzJ4f31cgA0hLxrWria20Ew9slJ2v
9DKaDo2IoBZDj3xp/AeF0jQ7t7gQSxX1LgGZMK2JhTt3daZXatIekvfyvvFT
75MjcnHftSM6nU55Yjv3P+h6Er0h+t7ffd4or1xtEB6LrMqLI/JqKSHIBnov
ZSUbBKtEM8mAWALFY4nbFxLWrYUrU8oEwigdj2Qfh/O1ntmgtLGAN5GhEdQv
j3u9VddA2uCoXj9uqX5b767nTVz2HMMv9K97KSWjG0sjS91d+Y/Ieu3kE/vm
ayilaARMKP+nQDdXsbFKDfT1VJNlSIeTDB0LPCWtRVSeNMIistTErGbftZcA
1Ntma3DPYH4JJhLFNh1dRLYLrdmL1fxRG1kVH0mdVVS7Tuwat2prRprp7L1O
nJ7qTYXtLRF/Gk1pi2vQYg9VIDuiDoEw3eYKdQ13tjho3YWDQv7lNV+lB60S
I10XVsUPdeqMmSiVaInYYKZCjW74XpHNNN7NsmvcqZkv9GZkghmNzUrUnLq1
b0yG9iFxCgWU8ST1KtQKONq6m+Yf4p5DYiKY3pjlJhkZE54opsMKqHrUfVZb
tdG2FOKbZpZOrl5N0zIKbiKjfTSM0t/Vv2hcrXaXB93XJn7ps1W5Bg22s9WG
fOV8Sb7qUGRoFV+Gr7B+5meG6jHUqBo7XXwhPWYY7vNqqfIHVFKniy/DK3qn
97Mzixr2Jm45XdyOXept/CG7sMdsHY6RaR+LtPHuDdqiqfnZ2YraJnWTcmkS
1sXH5kJPlDrBCBX3+zNMgSh+3N0lgfG3xaiT2r59Gts4RUYOh1LYbYst9we3
ipVQjHloOt1aR2STiXY5jRtvza0qt2YLC5CJdTwXWD2CUax+rKrjh3wV5UjN
2/IImOS/2x+s1H31EoSF50xtD7JyakbE8lydR8BGc23tLF2Mf0RoTB6wtqjr
EZDpPzDCfKhG1LpH1We/18XAj3R13WssJ4c/XBciDQcudIrpdRfFjw7rLgzC
cqVkHuHfGJwcVPJyvZCrMi+8kNKDpqkRBd2SeND0fV2FLO8jA97v3sIeIKLw
28FBPcfybcul1pMn1vETyw0t17HcuB5dt9ejR/1h8AHS+TXS+RGh20/x+Zvq
WoNFzZqP506zyM74xVvVzMJmFC5fWY4fDDR8ZxZpOSpaEyHndugI6Ti2nwhO
fTdkvucK3+WBzYJ+950fxpPAkZyLKLZ5mDIn5LF0fc+O4iSR1L2/M/91Pb+r
5k9jX1LhJZFPmcN5ZKdpGoUiko6bOg5Lb5g/CR0fQPWlT31hO3boUhnGzE08
CRR27Pvd/h8mu5fmQn186PH2+yNyb0SCiDpm8suDQZExEqhC4jow6xi/V1qv
fFM7F99tB0XYEpTYH2v9/MeDgw/b0gxgADDz20uzsdhKnI1niQ7lrjg7U5vi
qRO0NHeW3OfsnTU7l0fE9QN7VJS13n+tvUTN9cCHkSuEHbnT6TTw3KTlm0fk
QYEHAVZC2xpMeeVY9wA4QxTjsZmsuv6qbo/PTYWmjnO1jrhfKmLUSW+QRmWL
HpJHNVjy3RpMQPk6WykORfFwA9tudUTZURHEo3dTErOZ9fXX1nxu2bZlU8t2
LNu1bO/zKonbqIhbKgijHpKEu14cQNQdSOYJ15GxZ3MmHOa4HvWiveIpBHdo
GFNGQZATnjAeuwHoGS8QwvNSe0w5GNXg+TSWjh86bpA4zOYSzJyb2rFLU5q6
0X7VxFnIUsECL+VC2tSOuON43KeSJWkACu8zKoaOMI4oBiN9d9IM4PPtUQ1l
qxnukXlnF76XBmorXLbyQPsLcGpnpl9PNlqUM1DBdstqnCmol0vwJKXoZrJu
n5RSw/RLevsFVXolvQTgYNmCyMr1kl2XO4mknZwRBkejDl6ztkdI4YWuR9hF
zyHJpnJ6OFxP0snNq0Kcndz8LVPzOo4bL0bo1R6YegRdb2AKDSA4uatPrRzl
OrXe1EiYfaVxr7iuS7kV1P0yiX5hxCfBa+KJ69uA2y2PMeH3OFPMvj17+np+
evz49bxJLg6zxd7A3FKouSmb94mJx7ZAugt1r3wSwua09zQbrow6HI0yu8H8
EQ5okdmq5Uhke8OT3QgfiIqVedtTDxc4aUXZKxkianQtU93bMI/an8Y9zuyt
XF5/BW26UFU1RJvbwDNSR1XvkMHk6hCrhvMBI2195EMN27enJ5qieAYR8yZd
2Mbwv6Ml7oZ9LfpqmUrwf2S0a8k24Pw0sG6k74ac55fL3H5+wews5WeB/MEE
8gas/yyIN2H7DuYWPLAmC/4JBndvYnpvgnxIaHWKeFRqDbR77OkOOJ9LevXU
PyHx1QD90PJb88uYRb0V/u8kxz8A4u8kyD8Q3n/CGxENespPr9b+mM0JgCI/
l2pToE4PZEVnx6Psl7Wbgyv1uYgGeLOY5lTXuNIEev95U2rfBaJpy5TfdY8v
TCazeguiKW001Vjd+sYBPTt4grybtKjPbHfzDs2xQ12ONHRuA9ti0+5QZ7hD
gDWE30P7g8HqdHy3RV3lNHDeox61u4CqHlW178w3MMNtgvOxnaeeb4c1yD2z
UZjjIQMVffVxkJ31NOVSnzTj2MGnfUdQUMLrWqaP2CEbMtd7N8y2zn3oYtSs
1AXOpSq2aFJt+uScFIfNSZWxglxVStzjD6R3VvJNXdDY9dtd47U3lbu32JF7
ByT7pC05YsoPm4q97XPO42LfPbvCuj5Dxz70TtW2xMeyK3Wc92rAV/lX3Cbc
KZKUEn8zymzbtcFbhP+Y+3ZcGkvuufZI/tr27cB2nSTwQ+hHhUtpAp8x3vV9
24ObfKQrdTzf87zISz3XwZx9GqShB5P6AdxwffhHR7q6McwhaWgLaOi4tuu6
1A3gE99H4MFfgc/GZtWdYujgqG7429b/fAZLd0ZndXCFsrsyGm4twR/pGrqh
DeuTgQeIcvprxMU47FYYhk9q24yKxAuT2KeRF/keE6MAMwCRub4nPRox4EfX
ZcxOHR4EDrftxGV8DGBfyNhJY9cH4PoQeABBEjpuMkZXG7ct7NiJZJRAJx5H
QtKYczdyXOEFMhRBPNI1ChOYyAujVPKUpdTD/V2KF5xHiYycmI9tpCSha3sA
G43cUCYeS3jsxX7giygQXPoUxpNja3VYEjmc+o4qA77zHivqxFtvsu5sf9Ql
+lotdR+D7h59wZ6puDrrm7rfdd3wW+3J3l6fj23K7ih087D/7qq9uxBgvD9R
t+MUu7sTde3UT2/X2ElZ8CV2jXdx8MX2kO9kQZj9j2VBlDH44S2IFwdjSiqI
Qy+IA2gPa/xUCyKFHbCIyYAy0KkJ88cqV5jv+Y7PY2GHqRfhRjguEGCVYEZc
EXHujM2KCjnyqUflkAXxHSDeGJpEBKYpDO04DhKe8jgBBhKeDCWYPm6LBNY8
Rhw3EakTU7BtsRP6THpREoKgUj+OaOTbwglFMobh0PWkG6ZBCLA5QQiy6kuZ
pg6YWhmyiLrp2Kx+6IFJBMZPgHWS21uQrha+/W78ZzQhWIZ5gw3pbN6f9XKP
xmaAGi6y3vEj9bYjVFn5pqzNQlm/OknF+FgpOhAXYgR389spxgMTC5r9dIKT
qp+4Mhu2xna1Gaqfw5KeUanQoPzBov4hmJUwTh3m0cSnoCnTOLn/p9ZkLp7O
LIc4fmAlWUWeYnYPsL3i9fHZwMMHZW3u7ujPISv9SD7dSY/zTxtGuatbd3tp
+KFdu1tKxs9O3Y/g1PXkjzsQSDmpCMHX4CCMX1b+tpn3H8Ai3mvfqDg3ryYw
L4Osq9rq9z9avPfcWNPm7ZD9p/0jgXYvdW1qyYCVzZv7egeY9fsb+gn3oZI3
tseW1Zn4/bDVecR5s/tvXiSpQOtDMGTrPxmAzqlwnSkHD6/5A99XXZ8Xr2/E
w8DtHif/dNhuTKs3gNwjJ7MXsy3u2X5JAJ5PXOWggMwkwPLYa6pfXpww/gYH
as63K+5/ep0UmcCT9hgvG4ZEjqzF7UI12C62bApBOqdxZDMwunCHtSg0rhy+
oUS+A4yoEfA1JSn4iFsvcqwLFavu2wi3E9j1C8924bSoev8mrHxwoB799ozi
1KMwk0zvea69V0bt1F3uGdbVr8O7d6893fzgFNbWVskqKB83oJsveng4RhZY
7uihGPOyuk/xdLve+MBpYmDqt/Jan4NuD/f86zmk+2rZb3HY5VYHXT7nIZe7
HHD5nIdbbn2w5SMOsBhu/5ynWOaD7H3XsyyW80ne9bgIDp+E/Um6vNyj7J/u
9Mvjx9bxMZ6Ps33LDiw7tOzIsj/zEbnPf/qF8dCXseTSlb6dpDySIrDB64mi
2HccbyxPp3987oVJSgORxkEAWsajThxxTGeFaSiT4IbTL4H0hQwodaOIgQZh
kQPXrgcgCTeUfCzlZuZ2mAuKxvFDGYjE5Q6LXZE6NE1dlsI6vszpF8Daj3H+
ZeAAzIN5rzjiTm6CM+omqCjqlirq5736n64PsrvT4tggZ7jXImRvr8W1aerb
YnwfgNkB9GZR4EWgJYTagXCgV+BSCpIOhnrMuWg3LOzEdzzcerBD3Mt21X6L
69HRWZtdFtwkoea/3W6Y4NOxZL6jtmQGOuldFmd8V2l7lwWHcBQU8NtzfUd4
Y2v1AnzoQROYHfwwF9/5IzzqAapwOxxAGUVT2MEukqWPb+hrh6MYBkTatpdQ
hwYsiUGjJm4COtROwQlMbUeO7pq7oLcd6jIb92qk8DwP9D+1acwdkSL4ERtT
wIx7knoiCrgdR64UaEBk6ngAcBAFlHNvdK0+cHAIGtt2ANG2sH2ahmHsMA5c
BPRJXXucrradaPJQYadAIsWIdhjBR82kYxUCPd4FpMUoAR5AgftaAvlybK1U
BJEH7rAdOzQGKbHBMoEg0SBIHR+m9EIxBrBgMgxAZUoGHAVuOLUjCRPrOWEV
aSBGWQKYIKUsSbzI42kiA7DkwI+RBOPoutSTjI7RlcZURklgh4L5TLqJYDT4
uOqEUVv3c33CxySxTb307UsTdk5F/pzE/oJJbCCOtpWgHqIQJDegIkywCipw
nYiBUXF83wctHjieOyB7Hoh3kHh+CBowEKEd8MDXe/NgjWIQdXewzit01A59
AP9dtU8fY8UXWFeG1tp1HDlYF+BR39EmlDKfg9XhNk+DiHfBHOqG2+g+rIBr
cIMBcAe6qRXgIfnU9xwngF6hZ0oYPJv64LenQ0qQR4kHjyjlYGG8UGLlGAT2
bpI6Ik4F92JvKD9gO1HCXZ9iNoHbYKcwMPFhfWnsR2CvQH8OocQH+IDcIgpp
kKRhKmwZAmJsCCdAG4YhE8GQusXUAzhEoe8FkaAB6uXYpxgJOQwWKWwAdQhI
gNERmGuhFOwIYNV2IyAJWITYQTtFbW+oG03A3wJzRT1POWBghmzbjzxYqYho
DIwyRDffxvo3N3W5F0nGfCljL6ag2yH0cahnx7EYsgcRpSEPwCEIKLhcHCw2
A8rFUZx63HWQc9LB2UCyHXwVghswOwK8hRBY2UiHAJBPIVqzhywtxHLgJcXA
gnevZeCfo5aBbJeuf+59m3t4mL+b/m3ytuoNs4PvKBjM++55ddGnRV83pGhv
Tg/98wdGNyVyfN+i1PI8a/a1NX+MrzvC95nY/xjvOuIQcoRhwtBIuW4Ijr10
wjjxJcXC2nisdqr+Ab0rRZRi9OV5ocecIOW2FIkHHqfvhje/64jZbgwRphOD
OfUTJkBDUXCwJVawMcZumj8C8+IGYeg4ThRzQSMOvi+sRUZxEvNUfJl3Hd3B
0f3SbztSfrf7k/Nd//lra+00/CJvZPoRa2vxXUJCZ36k08v5GP92LG5t3N42
sN7O/oyF98LFKkr8jvU6kQKuh61c0vrJWMhbd0Cnz1HJoSa/ZJ6MhfeYXxp2
vGEI8F3peD7CjJyg+4Ue+pA7PtI1AM+cujA67SaN7I7fPlqqWvvuiiKY51LF
uPAbC4Op8qxH0zYUj6nQyE6hi/7XrSj24e+x0xlujCkwn+8j0Ria+h06JGqf
jK0VO4SqAx+iKRJvDMMjNLW5YUwYYgxgTVMTs0AXlVlqZvX3pOO6wU2bu+sn
6fakbXZzd3WSTodDI133R0k6JBoDeDhSEhDS0BiCChawMYA9X6Qpk2FsJzKG
aCD0Uwhm0hiiy4BGaUTHuyYAoR+4kfQByBi4nkYM08tR2LLKaE6NYtiD6kUV
7zdZPWl7EEx5FKg2xhI3BHj+OHGYSnXXc8HkHo0wjR2BfqhDvzHi7ESE/fAP
FjJWgd/JWELYmrZ5Sx/hcdheyQFEQRgJnAgBJtPARya49OFfaI+9nM72oHmt
m5p4FIJPz00w+EQoxnlYRaVjuh9laqxrJ6nahrP92HWMOIMhbT9+HemKYa2e
cze4rSPZMY24J8Cto9mxrh8R5Grn7h+iQFF9wcNz9QUPzZv22u9wgBWCe5S/
ldmqSPmHnj/X/KgxJl+NvulsYvwV8kviw3UFn+EEwgb4jCcYpMEF9QaHbjDc
wlRjtf1mCnwtQYVlZRZbZuerXx4sZVrp1c34m1V+tZTiXH9pCi6R9e/hGleb
ywS/NeqXBymEorI+zKC/zqkkZQbRaCGVs8tW+P3u70+zN6wQ5Onf/3a+3KzE
h6YG8/1v//43QD9ZyCVDp/KD+bZ1/daD9ttb8IvsJQRcAE39FbnqC7yu8FvS
NuuWeuhCLq6QxOBknqxW+VuNXPCEVxyIe/LixcvfzbpFd8ffnh5/MyPz42dn
J3PrxfH3Z1i2p168PP/9q9PjxeIrNb8Z/Ck6ik2LxcmTk4X1NL+U5MFvMXYn
7LyQUtUZxniE1Xk4nfw/rtR0DKSIAAA=

-->

</rfc>
