<?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.29 (Ruby 3.3.7) -->
<rfc xmlns:xi="http://www.w3.org/2001/XInclude" ipr="trust200902" docName="draft-ietf-schc-8824-update-06" category="std" consensus="true" submissionType="IETF" obsoletes="8824" tocInclude="true" sortRefs="true" symRefs="true" version="3">
  <!-- xml2rfc v2v3 conversion 3.30.2 -->
  <front>
    <title abbrev="SCHC for CoAP">Static Context Header Compression (SCHC) for the Constrained Application Protocol (CoAP)</title>
    <seriesInfo name="Internet-Draft" value="draft-ietf-schc-8824-update-06"/>
    <author initials="M." surname="Tiloca" fullname="Marco Tiloca">
      <organization>RISE AB</organization>
      <address>
        <postal>
          <street>Isafjordsgatan 22</street>
          <city>Kista</city>
          <code>16440</code>
          <country>Sweden</country>
        </postal>
        <email>marco.tiloca@ri.se</email>
      </address>
    </author>
    <author initials="L." surname="Toutain" fullname="Laurent Toutain">
      <organization>IMT Atlantique</organization>
      <address>
        <postal>
          <street>CS 17607, 2 rue de la Chataigneraie</street>
          <city>Cesson-Sevigne Cedex</city>
          <code>35576</code>
          <country>France</country>
        </postal>
        <email>Laurent.Toutain@imt-atlantique.fr</email>
      </address>
    </author>
    <author initials="I." surname="Martínez" fullname="Iván Martínez">
      <organization>IRISA</organization>
      <address>
        <postal>
          <street>263 Av. Général Leclerc</street>
          <city>Rennes</city>
          <code>35000</code>
          <country>France</country>
        </postal>
        <email>ivan-marino.martinez-bolivar@irisa.fr</email>
      </address>
    </author>
    <author initials="A." surname="Minaburo" fullname="Ana Minaburo">
      <organization>Consultant</organization>
      <address>
        <postal>
          <street>Rue de Rennes</street>
          <city>Cesson-Sevigne</city>
          <code>35510</code>
          <country>France</country>
        </postal>
        <email>anaminaburo@gmail.com</email>
      </address>
    </author>
    <date year="2025" month="October" day="20"/>
    <area>Internet</area>
    <workgroup>SCHC Working Group</workgroup>
    <keyword>Internet-Draft</keyword>
    <abstract>
      <?line 96?>

<t>This document defines how to compress Constrained Application Protocol (CoAP) headers using the Static Context Header Compression and fragmentation (SCHC) framework. SCHC defines a header compression mechanism adapted for constrained devices. SCHC uses a static description of the header to reduce the header's redundancy and size. While RFC 8724 describes the SCHC compression and fragmentation framework and its application for IPv6 and UDP headers, this document applies SCHC to CoAP headers. The CoAP header structure differs from that of IPv6 and UDP headers, since CoAP uses a flexible header with a variable number of options that are in turn of variable length. The CoAP message format is asymmetric, i.e., request messages have a header format different from that of response messages. This specification gives guidance on applying SCHC to flexible headers and on leveraging the message format asymmetry for defining more efficient compression Rules. This document replaces and obsoletes RFC 8824.</t>
    </abstract>
    <note removeInRFC="true">
      <name>Discussion Venues</name>
      <t>Discussion of this document takes place on the
    Static Context Header Compression Working Group mailing list (schc@ietf.org),
    which is archived at <eref target="https://mailarchive.ietf.org/arch/browse/schc/"/>.</t>
      <t>Source for this draft and an issue tracker can be found at
    <eref target="https://github.com/ietf-wg-schc/draft-ietf-schc-8824-update"/>.</t>
    </note>
  </front>
  <middle>
    <?line 100?>

<section anchor="intro">
      <name>Introduction</name>
      <t>The Constrained Application Protocol (CoAP) <xref target="RFC7252"/> is a request/response protocol designed for microcontrollers with small RAM and ROM, and optimized for services based on REST (Representational State Transfer). Although the constrained devices are a leading factor in the design of CoAP, a CoAP header's size is still too large for LPWANs (Low-Power Wide-Area Networks). Static Context Header Compression and fragmentation (SCHC) over CoAP headers is required to increase performance or to use CoAP over LPWAN technologies.</t>
      <t><xref target="RFC8724"/> defines the SCHC framework, which includes a header compression mechanism for LPWANs that is based on a static context. <xref section="5" sectionFormat="of" target="RFC8724"/> explains where compression and decompression occur in the architecture. The SCHC compression scheme assumes as a prerequisite that both endpoints know the static context before transmission. The way the context is configured, provisioned, or exchanged is out of the scope of this document.</t>
      <t>Since CoAP is an application-layer protocol, compressing CoAP headers requires installing common Rules between the two SCHC instances. SCHC compression may apply at two different levels: at the IP and UDP level in the LPWAN, as well as at the application level for CoAP. These two compression techniques may be independent. Both follow the same principle as that described in <xref target="RFC8724"/>. As different entities manage the CoAP compression process at different levels, the SCHC Rules driving the compression/decompression are also different. <xref target="RFC8724"/> describes how to use SCHC for IP and UDP headers. This document specifies how to apply SCHC compression to CoAP headers.</t>
      <t>SCHC compresses and decompresses headers based on common contexts between Devices. The SCHC context includes multiple Rules. Each Rule can match the header fields to specific values or ranges of values. If a Rule matches, the matched header fields are replaced by the RuleID and the Compression Residue that contains the residual bits of the compression. Thus, different Rules may correspond to different protocol headers in the packet that a Device expects to send or receive.</t>
      <t>A Rule describes the packets' entire header with an ordered list of Field Descriptors (see <xref section="7" sectionFormat="of" target="RFC8724"/>). In turn, each Field Descriptor contains the Field ID (FID), Field Length (FL), and Field Position (FP), as well as a Direction Indicator (DI) (upstream, downstream, or bidirectional) and some associated Target Values (TVs). The DI allows the compression to be based on the best TV for the Field Descriptor, when the TV to consider is different for the different transmission directions. Therefore, a field may be described several times in the same Rule.</t>
      <t>Furthermore, a Matching Operator (MO) is associated with each header Field Descriptor. The Rule is selected if all the MOs fit the TVs for all the fields of the header. A Rule cannot be selected if the message contains a field that is unknown to the SCHC compressor.</t>
      <t>In that case, a Compression/Decompression Action (CDA) associated with each field specifies the method to compress and decompress that field. Compression mainly results in one of four actions:</t>
      <ul spacing="normal">
        <li>
          <t>send the field value (value-sent),</t>
        </li>
        <li>
          <t>send nothing (not-sent),</t>
        </li>
        <li>
          <t>send some Least Significant Bits (LSBs) of the field, or</t>
        </li>
        <li>
          <t>send an index (mapping-sent).</t>
        </li>
      </ul>
      <t>After applying the compression, there may be some bits to be sent. These values are called "Compression Residue".</t>
      <t>SCHC is a general mechanism applied to different protocols, with the exact Rules to be used depending on the protocol and the application. <xref section="10" sectionFormat="of" target="RFC8724"/> describes the compression scheme for IPv6 and UDP headers. This document targets CoAP header compression using SCHC.</t>
      <t>The use of SCHC compression applied to CoAP headers was originally defined in <xref target="RFC8824"/>. While this document does not alter the core approach, design choices, and features specified therein, this document clarifies, updates, and extends the SCHC compression of CoAP headers defined in <xref target="RFC8824"/>.</t>
      <t>In particular, this documents replaces and obsoletes <xref target="RFC8824"/> as follows:</t>
      <ul spacing="normal">
        <li>
          <t>It provides clarifications and amendments to the original specification text, based on collected feedback and reported errata.</t>
        </li>
        <li>
          <t>It clarifies the use of the FL within Field Descriptors corresponding to variable-length header fields (see <xref target="ssec-differences-with-udp-ip"/>).</t>
        </li>
        <li>
          <t>It generalizes the handling of the Token Length field and of the Token field as well as the use of the "tkl" function to comply with <xref target="RFC8974"/> (see <xref target="ssec-coap-tkl-field"/> and <xref target="ssec-coap-token-field"/>).</t>
        </li>
        <li>
          <t>It clarifies how the SCHC compression handles CoAP options in general (see <xref target="sec-field-descriptors-coap-options"/>).</t>
        </li>
        <li>
          <t>It clarifies the SCHC compression for the CoAP options: Size1, Size2, Proxy-Uri, and Proxy-Scheme (see <xref target="ssec-size1-size2-proxy-uri-proxy-scheme-option"/>); ETag and If-Match (see <xref target="ssec-etag-if-match-option"/>); and If-None-Match (see <xref target="ssec-if-none-match"/>).</t>
        </li>
        <li>
          <t>It defines the SCHC compression for the recently defined CoAP options Proxy-Cri and Proxy-Scheme-Number (see <xref target="ssec-proxy-cri-proxy-scheme-number-option"/>).</t>
        </li>
        <li>
          <t>It defines the SCHC compression for the CoAP option Hop-Limit (see <xref target="coap-options-hop-limit"/>).</t>
        </li>
        <li>
          <t>It defines the SCHC compression for the recently defined CoAP options Echo (see <xref target="coap-options-echo"/>), Request-Tag (see <xref target="coap-options-request-tag"/>), EDHOC (see <xref target="coap-options-edhoc"/>), as well as Q-Block1 and Q-Block2 (see <xref target="ssec-coap-extensions-block"/>).</t>
        </li>
        <li>
          <t>It updates the SCHC compression processing for the CoAP option OSCORE (see <xref target="ssec-coap-extensions-oscore"/>), also in the light of recent developments related to the security protocol Object Security for Constrained RESTful Environments (OSCORE) as defined in <xref target="I-D.ietf-core-oscore-key-update"/> and <xref target="I-D.ietf-core-oscore-groupcomm"/>.</t>
        </li>
        <li>
          <t>It clarifies how the SCHC compression handles the CoAP payload marker (see <xref target="payload-marker"/>).</t>
        </li>
        <li>
          <t>It defines the SCHC compression of CoAP headers in the presence of CoAP proxies (see <xref target="compression-with-proxies"/>), for which examples are provided (see <xref target="examples"/>).</t>
        </li>
      </ul>
      <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 related to the SCHC framework <xref target="RFC8724"/>, CoAP <xref target="RFC7252"/>, and the security protocols OSCORE <xref target="RFC8613"/> and Group Object Security for Constrained RESTful Environments (Group OSCORE) <xref target="I-D.ietf-core-oscore-groupcomm"/>.</t>
      </section>
    </section>
    <section anchor="sec-applicability-to-coap">
      <name>SCHC Applicability to CoAP</name>
      <t>SCHC compression for CoAP headers <bcp14>MAY</bcp14> be done in conjunction with the lower layers (IPv6/UDP) or independently. The SCHC adaptation layers described in <xref section="5" sectionFormat="of" target="RFC8724"/> may be used as shown in <xref target="fig-applicability-to-coap-1"/>, <xref target="fig-applicability-to-coap-2"/>, and <xref target="fig-applicability-to-coap-3"/> below.</t>
      <t>In the first example depicted in <xref target="fig-applicability-to-coap-1"/>, a Rule compresses the complete header stack from IPv6 to CoAP. In this case, the Device and the Network Gateway (NGW) perform SCHC Compression/Decompression (SCHC C/D), see <xref target="RFC8724"/>). The application communicating with the Device does not implement SCHC C/D.</t>
      <figure anchor="fig-applicability-to-coap-1">
        <name>Compression/Decompression at the LPWAN Boundary.</name>
        <artset>
          <artwork type="svg" align="center"><svg xmlns="http://www.w3.org/2000/svg" version="1.1" height="256" width="512" viewBox="0 0 512 256" class="diagram" text-anchor="middle" font-family="monospace" font-size="13px" stroke-linecap="round">
              <path d="M 8,64 L 8,224" fill="none" stroke="black"/>
              <path d="M 80,64 L 80,232" fill="none" stroke="black"/>
              <path d="M 128,128 L 128,232" fill="none" stroke="black"/>
              <path d="M 200,160 L 200,224" fill="none" stroke="black"/>
              <path d="M 264,128 L 264,224" fill="none" stroke="black"/>
              <path d="M 432,64 L 432,224" fill="none" stroke="black"/>
              <path d="M 504,64 L 504,224" fill="none" stroke="black"/>
              <path d="M 8,64 L 80,64" fill="none" stroke="black"/>
              <path d="M 432,64 L 504,64" fill="none" stroke="black"/>
              <path d="M 8,96 L 80,96" fill="none" stroke="black"/>
              <path d="M 432,96 L 504,96" fill="none" stroke="black"/>
              <path d="M 8,128 L 80,128" fill="none" stroke="black"/>
              <path d="M 128,128 L 264,128" fill="none" stroke="black"/>
              <path d="M 432,128 L 504,128" fill="none" stroke="black"/>
              <path d="M 8,160 L 80,160" fill="none" stroke="black"/>
              <path d="M 128,160 L 264,160" fill="none" stroke="black"/>
              <path d="M 432,160 L 504,160" fill="none" stroke="black"/>
              <path d="M 8,192 L 80,192" fill="none" stroke="black"/>
              <path d="M 128,192 L 200,192" fill="none" stroke="black"/>
              <path d="M 8,224 L 80,224" fill="none" stroke="black"/>
              <path d="M 128,224 L 264,224" fill="none" stroke="black"/>
              <path d="M 432,224 L 504,224" fill="none" stroke="black"/>
              <path d="M 56,240 L 80,240" fill="none" stroke="black"/>
              <path d="M 128,240 L 152,240" fill="none" stroke="black"/>
              <path d="M 248,240 L 288,240" fill="none" stroke="black"/>
              <path d="M 400,240 L 448,240" fill="none" stroke="black"/>
              <g class="text">
                <text x="44" y="36">(Device)</text>
                <text x="200" y="36">(NGW)</text>
                <text x="464" y="36">(App)</text>
                <text x="44" y="84">CoAP</text>
                <text x="468" y="84">CoAP</text>
                <text x="40" y="116">UDP</text>
                <text x="464" y="116">UDP</text>
                <text x="44" y="148">IPv6</text>
                <text x="196" y="148">IPv6</text>
                <text x="468" y="148">IPv6</text>
                <text x="44" y="180">SCHC</text>
                <text x="164" y="180">SCHC</text>
                <text x="48" y="212">LPWAN</text>
                <text x="160" y="212">LPWAN</text>
                <text x="104" y="244">LPWAN</text>
                <text x="348" y="244">Internet</text>
              </g>
            </svg>
          </artwork>
          <artwork type="ascii-art" align="center"><![CDATA[
 (Device)             (NGW)                            (App)

+--------+                                           +--------+
|  CoAP  |                                           |  CoAP  |
+--------+                                           +--------+
|  UDP   |                                           |  UDP   |
+--------+     +----------------+                    +--------+
|  IPv6  |     |      IPv6      |                    |  IPv6  |
+--------+     +--------+-------+                    +--------+
|  SCHC  |     |  SCHC  |       |                    |        |
+--------+     +--------+       +                    +        +
|  LPWAN |     | LPWAN  |       |                    |        |
+--------+     +--------+-------+                    +--------+
      ((((LPWAN))))           ------   Internet  -------
]]></artwork>
        </artset>
      </figure>
      <t><xref target="fig-applicability-to-coap-1"/> shows the use of SCHC header compression above Layer 2 in the Device and the NGW. The SCHC layer receives non-encrypted packets and can apply compression Rules to all the headers in the stack. On the other end, the NGW receives the SCHC packet and reconstructs the headers using the Rule and the Compression Residue. After the decompression, the NGW forwards the IPv6 packet toward the destination. The same process applies in the other direction when a non-encrypted packet arrives at the NGW. Thanks to the IP forwarding based on the IPv6 prefix, the NGW identifies the Device and compresses headers using the Device's Rules.</t>
      <t>In the second example depicted in <xref target="fig-applicability-to-coap-2"/>, SCHC compression is applied in the CoAP layer, compressing the CoAP header independently of the other layers. The RuleID, Compression Residue, and CoAP payload are encrypted using a mechanism such as DTLS <xref target="RFC9147"/>. Only the other end (App) can decipher the information. If needed, layers below use SCHC to compress the header as defined in <xref target="RFC8724"/> (represented by dotted lines in the figure).</t>
      <t>This use case needs an end-to-end context initialization between the Device and the application. The context initialization is out of scope for this document.</t>
      <figure anchor="fig-applicability-to-coap-2">
        <name>Standalone CoAP End-to-End Compression/Decompression.</name>
        <artset>
          <artwork type="svg" align="center"><svg xmlns="http://www.w3.org/2000/svg" version="1.1" height="320" width="512" viewBox="0 0 512 320" class="diagram" text-anchor="middle" font-family="monospace" font-size="13px" stroke-linecap="round">
              <path d="M 8,64 L 8,160" fill="none" stroke="black"/>
              <path d="M 80,64 L 80,160" fill="none" stroke="black"/>
              <path d="M 432,64 L 432,160" fill="none" stroke="black"/>
              <path d="M 504,64 L 504,160" fill="none" stroke="black"/>
              <path d="M 8,64 L 80,64" fill="none" stroke="black"/>
              <path d="M 432,64 L 504,64" fill="none" stroke="black"/>
              <path d="M 8,96 L 80,96" fill="none" stroke="black"/>
              <path d="M 432,96 L 504,96" fill="none" stroke="black"/>
              <path d="M 8,128 L 80,128" fill="none" stroke="black"/>
              <path d="M 432,128 L 504,128" fill="none" stroke="black"/>
              <path d="M 8,160 L 80,160" fill="none" stroke="black"/>
              <path d="M 432,160 L 504,160" fill="none" stroke="black"/>
              <path d="M 56,304 L 80,304" fill="none" stroke="black"/>
              <path d="M 128,304 L 152,304" fill="none" stroke="black"/>
              <path d="M 248,304 L 288,304" fill="none" stroke="black"/>
              <path d="M 400,304 L 448,304" fill="none" stroke="black"/>
              <g class="text">
                <text x="44" y="36">(Device)</text>
                <text x="200" y="36">(NGW)</text>
                <text x="464" y="36">(App)</text>
                <text x="44" y="84">CoAP</text>
                <text x="468" y="84">CoAP</text>
                <text x="44" y="116">SCHC</text>
                <text x="468" y="116">SCHC</text>
                <text x="44" y="148">DTLS</text>
                <text x="468" y="148">DTLS</text>
                <text x="8" y="180">.</text>
                <text x="40" y="180">udp</text>
                <text x="80" y="180">.</text>
                <text x="432" y="180">.</text>
                <text x="464" y="180">udp</text>
                <text x="504" y="180">.</text>
                <text x="44" y="196">..........</text>
                <text x="196" y="196">..................</text>
                <text x="468" y="196">..........</text>
                <text x="8" y="212">.</text>
                <text x="44" y="212">ipv6</text>
                <text x="80" y="212">.</text>
                <text x="128" y="212">.</text>
                <text x="196" y="212">ipv6</text>
                <text x="264" y="212">.</text>
                <text x="432" y="212">.</text>
                <text x="468" y="212">ipv6</text>
                <text x="504" y="212">.</text>
                <text x="44" y="228">..........</text>
                <text x="196" y="228">..................</text>
                <text x="468" y="228">..........</text>
                <text x="8" y="244">.</text>
                <text x="44" y="244">schc</text>
                <text x="80" y="244">.</text>
                <text x="128" y="244">.</text>
                <text x="164" y="244">schc</text>
                <text x="200" y="244">.</text>
                <text x="264" y="244">.</text>
                <text x="432" y="244">.</text>
                <text x="504" y="244">.</text>
                <text x="44" y="260">..........</text>
                <text x="164" y="260">..........</text>
                <text x="264" y="260">.</text>
                <text x="432" y="260">.</text>
                <text x="504" y="260">.</text>
                <text x="8" y="276">.</text>
                <text x="48" y="276">lpwan</text>
                <text x="80" y="276">.</text>
                <text x="128" y="276">.</text>
                <text x="160" y="276">lpwan</text>
                <text x="200" y="276">.</text>
                <text x="264" y="276">.</text>
                <text x="432" y="276">.</text>
                <text x="504" y="276">.</text>
                <text x="44" y="292">..........</text>
                <text x="196" y="292">..................</text>
                <text x="468" y="292">..........</text>
                <text x="104" y="308">LPWAN</text>
                <text x="348" y="308">Internet</text>
              </g>
            </svg>
          </artwork>
          <artwork type="ascii-art" align="center"><![CDATA[
 (Device)             (NGW)                            (App)

+--------+                                           +--------+
|  CoAP  |                                           |  CoAP  |
+--------+                                           +--------+
|  SCHC  |                                           |  SCHC  |
+--------+                                           +--------+
|  DTLS  |                                           |  DTLS  |
+--------+                                           +--------+
.  udp   .                                           .  udp   .
..........     ..................                    ..........
.  ipv6  .     .      ipv6      .                    .  ipv6  .
..........     ..................                    ..........
.  schc  .     .  schc  .       .                    .        .
..........     ..........       .                    .        .
.  lpwan .     . lpwan  .       .                    .        .
..........     ..................                    ..........
      ((((LPWAN))))           ------   Internet  -------
]]></artwork>
        </artset>
      </figure>
      <t>The third example depicted in <xref target="fig-applicability-to-coap-3"/> shows the use of the security protocol OSCORE <xref target="RFC8613"/>. In this case, SCHC needs two Rules to compress the CoAP header. A first Rule focuses on the Inner header. The result of this first compression is encrypted using OSCORE. Then, a second Rule compresses the Outer header including the CoAP option OSCORE.</t>
      <figure anchor="fig-applicability-to-coap-3">
        <name>Compression/Decompression when Using OSCORE.</name>
        <artset>
          <artwork type="svg" align="center"><svg xmlns="http://www.w3.org/2000/svg" version="1.1" height="416" width="512" viewBox="0 0 512 416" class="diagram" text-anchor="middle" font-family="monospace" font-size="13px" stroke-linecap="round">
              <path d="M 8,64 L 8,256" fill="none" stroke="black"/>
              <path d="M 80,64 L 80,256" fill="none" stroke="black"/>
              <path d="M 432,64 L 432,256" fill="none" stroke="black"/>
              <path d="M 504,64 L 504,256" fill="none" stroke="black"/>
              <path d="M 8,64 L 80,64" fill="none" stroke="black"/>
              <path d="M 432,64 L 504,64" fill="none" stroke="black"/>
              <path d="M 8,112 L 80,112" fill="none" stroke="black"/>
              <path d="M 432,112 L 504,112" fill="none" stroke="black"/>
              <path d="M 8,160 L 80,160" fill="none" stroke="black"/>
              <path d="M 432,160 L 504,160" fill="none" stroke="black"/>
              <path d="M 8,208 L 80,208" fill="none" stroke="black"/>
              <path d="M 432,208 L 504,208" fill="none" stroke="black"/>
              <path d="M 8,256 L 80,256" fill="none" stroke="black"/>
              <path d="M 432,256 L 504,256" fill="none" stroke="black"/>
              <path d="M 56,400 L 80,400" fill="none" stroke="black"/>
              <path d="M 128,400 L 152,400" fill="none" stroke="black"/>
              <path d="M 248,400 L 288,400" fill="none" stroke="black"/>
              <path d="M 400,400 L 448,400" fill="none" stroke="black"/>
              <g class="text">
                <text x="44" y="36">(Device)</text>
                <text x="200" y="36">(NGW)</text>
                <text x="464" y="36">(App)</text>
                <text x="44" y="84">CoAP</text>
                <text x="468" y="84">CoAP</text>
                <text x="48" y="100">Inner</text>
                <text x="472" y="100">Inner</text>
                <text x="44" y="132">SCHC</text>
                <text x="468" y="132">SCHC</text>
                <text x="48" y="148">Inner</text>
                <text x="472" y="148">Inner</text>
                <text x="44" y="180">CoAP</text>
                <text x="468" y="180">CoAP</text>
                <text x="48" y="196">Outer</text>
                <text x="472" y="196">Outer</text>
                <text x="44" y="228">SCHC</text>
                <text x="468" y="228">SCHC</text>
                <text x="48" y="244">Outer</text>
                <text x="472" y="244">Outer</text>
                <text x="8" y="276">.</text>
                <text x="40" y="276">udp</text>
                <text x="80" y="276">.</text>
                <text x="432" y="276">.</text>
                <text x="464" y="276">udp</text>
                <text x="504" y="276">.</text>
                <text x="44" y="292">..........</text>
                <text x="196" y="292">..................</text>
                <text x="468" y="292">..........</text>
                <text x="8" y="308">.</text>
                <text x="44" y="308">ipv6</text>
                <text x="80" y="308">.</text>
                <text x="128" y="308">.</text>
                <text x="196" y="308">ipv6</text>
                <text x="264" y="308">.</text>
                <text x="432" y="308">.</text>
                <text x="468" y="308">ipv6</text>
                <text x="504" y="308">.</text>
                <text x="44" y="324">..........</text>
                <text x="196" y="324">..................</text>
                <text x="468" y="324">..........</text>
                <text x="8" y="340">.</text>
                <text x="44" y="340">schc</text>
                <text x="80" y="340">.</text>
                <text x="128" y="340">.</text>
                <text x="164" y="340">schc</text>
                <text x="200" y="340">.</text>
                <text x="264" y="340">.</text>
                <text x="432" y="340">.</text>
                <text x="504" y="340">.</text>
                <text x="44" y="356">..........</text>
                <text x="164" y="356">..........</text>
                <text x="264" y="356">.</text>
                <text x="432" y="356">.</text>
                <text x="504" y="356">.</text>
                <text x="8" y="372">.</text>
                <text x="48" y="372">lpwan</text>
                <text x="80" y="372">.</text>
                <text x="128" y="372">.</text>
                <text x="160" y="372">lpwan</text>
                <text x="200" y="372">.</text>
                <text x="264" y="372">.</text>
                <text x="432" y="372">.</text>
                <text x="504" y="372">.</text>
                <text x="44" y="388">..........</text>
                <text x="196" y="388">..................</text>
                <text x="468" y="388">..........</text>
                <text x="104" y="404">LPWAN</text>
                <text x="348" y="404">Internet</text>
              </g>
            </svg>
          </artwork>
          <artwork type="ascii-art" align="center"><![CDATA[
 (Device)             (NGW)                            (App)

+--------+                                           +--------+
|  CoAP  |                                           |  CoAP  |
|  Inner |                                           |  Inner |
+--------+                                           +--------+
|  SCHC  |                                           |  SCHC  |
|  Inner |                                           |  Inner |
+--------+                                           +--------+
|  CoAP  |                                           |  CoAP  |
|  Outer |                                           |  Outer |
+--------+                                           +--------+
|  SCHC  |                                           |  SCHC  |
|  Outer |                                           |  Outer |
+--------+                                           +--------+
.  udp   .                                           .  udp   .
..........     ..................                    ..........
.  ipv6  .     .      ipv6      .                    .  ipv6  .
..........     ..................                    ..........
.  schc  .     .  schc  .       .                    .        .
..........     ..........       .                    .        .
.  lpwan .     . lpwan  .       .                    .        .
..........     ..................                    ..........
      ((((LPWAN))))           ------   Internet  -------
]]></artwork>
        </artset>
      </figure>
      <t>In the case of several SCHC instances as shown in <xref target="fig-applicability-to-coap-2"/> and <xref target="fig-applicability-to-coap-3"/>, the Rules may come from different provisioning domains.</t>
      <t>This document focuses on CoAP compression, as represented by the dashed boxes in the previous figures.</t>
    </section>
    <section anchor="sec-coap-header-compression">
      <name>CoAP Headers Compressed with SCHC</name>
      <t>The use of SCHC over the CoAP header relies on the same principles and compression/decompression techniques used for IP and UDP headers, as explained in <xref target="RFC8724"/>. For CoAP, the SCHC Rules description uses the direction information to optimize the compression by reducing the number of Rules needed to compress headers. The Field Descriptor <bcp14>MAY</bcp14> define both request/response headers and TVs in the same Rule, using the DI to indicate the header type.</t>
      <t>Like for other header compression protocols, when the compressor does not find a correct Rule to compress the header, the packet <bcp14>MUST</bcp14> be sent uncompressed using the RuleID dedicated to this purpose. In such a case, the Compression Residue is the complete header of the packet (see <xref section="6" sectionFormat="of" target="RFC8724"/>).</t>
      <section anchor="ssec-differences-with-udp-ip">
        <name>Differences between CoAP and UDP/IP Compression</name>
        <t>CoAP compression differs from IPv6 and UDP compression in the following aspects:</t>
        <ul spacing="normal">
          <li>
            <t>The CoAP message format is asymmetric, i.e., the headers are different for a request and a response.  </t>
            <t>
For example, the Uri-Path Option can be used in a request, while it is not used in a response. A request might contain an Accept Option, while both a request and a response might include a Content-Format Option. In comparison, the IPv6 and UDP returning path swaps the value of some fields in the header. However, all the directions have the same fields (e.g., source and destination address fields).  </t>
            <t><xref target="RFC8724"/> defines the use of a DI in the Field Descriptor, which allows a single Rule to process a message header differently, depending on the direction.</t>
          </li>
          <li>
            <t>Even when a field is "symmetric" (i.e., found in both directions), the values carried in each direction are different. The compression may use a "match-mapping" MO to limit the range of expected values in a particular direction and reduce the Compression Residue's size. Through the DI, a Field Descriptor in the Rules splits the possible field value into two parts, one for each direction.  </t>
            <t>
For instance, if a client sends only Confirmable (CON) requests <xref target="RFC7252"/>, the Type can be elided through the compression process, and the reply from the server may use one single bit to carry either the Acknowledgement (ACK) or Reset (RST) type. The field Code has the same behavior: the 0.0X code format value in a request and the Y.ZZ code format in a response.</t>
          </li>
          <li>
            <t>In SCHC, the Rule defines the different header fields' length, so SCHC does not need to send it. In IPv6 and UDP headers, the fields have a fixed size, known by definition.  </t>
            <t>
On the other hand, some CoAP header fields have variable lengths and the Rule description makes it possible to specify it. For example, the size of the Token field may vary from 0 to 65804 bytes <xref target="RFC8974"/>, and the CoAP options rely on the Type-Length-Value encoding format to specify the size of the actual option value in bytes.  </t>
            <t>
Given a Rule description, the following defines how the FL is used within the Field Descriptor corresponding to a variable-length field.  </t>
            <t>
If the CDA in the Field Descriptor is set to "not-sent" or to "mapping-sent", then the FL is not set. In fact, the field length can always be determined based on what is specified in the TV of the Field Descriptor.  </t>
            <t>
Otherwise, the FL can specify an exact length in bits, in case it is known in advance that the present header field is going to be used with such a length. More generally and building on <xref section="7.4.2" sectionFormat="of" target="RFC8724"/>, the following applies when doing SCHC compression of a variable-length field for which it is not possible to specify an exact, expected length in the FL of the corresponding Field Descriptor.  </t>
            <t>
If the field compression relies on the CDA "value-sent" or LSB, then a function "var" is used for the FL in the Field Descriptor, with byte being the unit used for the residue value's size. Alternatively, a function "var_X" can be used for the FL in the Field Descriptor, with X being the unit other than byte used for the residue value's size. In particular, the function "var_bit" is defined and indicates bit as the unit used for the residue value's size. Consequently, SCHC will send the residue value's size in the Compression Residue as specified in <xref section="7.4.2" sectionFormat="of" target="RFC8724"/>.  </t>
            <t>
As an alternative, if the length of the present field can be determined from the value of a previous field in the CoAP header, then it is possible to define a specific function for the FL in the Field Descriptor of the present field, with that function returning the length of the field in the unit specified with the function (e.g., see the "tkl" function defined in <xref target="ssec-coap-token-field"/>). This holds irrespective of the CDA used for compressing the field.</t>
          </li>
          <li>
            <t>A field can appear several times in a CoAP header. This is typically the case for elements of a URI (i.e., path segments or query parameters). The SCHC specification <xref target="RFC8724"/> allows a FID to appear several times in the Rule and uses the Field Position (FP) to identify the correct instance, thus preventing MO's possible ambiguities.</t>
          </li>
          <li>
            <t>Field Lengths defined in CoAP can be too large when it comes to LPWAN traffic constraints. For instance, this is particularly true for the Message ID field and the Token field. SCHC uses different MOs to perform the compression (see <xref section="7.4" sectionFormat="of" target="RFC8724"/>). In this case, SCHC can apply the Most Significant Bits (MSBs) MO to reduce the information carried on LPWANs.</t>
          </li>
        </ul>
      </section>
    </section>
    <section anchor="sec-coap-fields-compression">
      <name>Compression of CoAP Header Fields</name>
      <t>This section discusses the SCHC compression of the CoAP header fields (see <xref section="3" sectionFormat="of" target="RFC7252"/>), building on what is specified in <xref section="7.1" sectionFormat="of" target="RFC8724"/>.</t>
      <t>In a SCHC Rule, the first Field Descriptors <bcp14>MUST</bcp14> be those related to the CoAP header fields discussed in this section. In particular, such Field Descriptors <bcp14>MUST</bcp14> be listed in the same order according to which the related CoAP header fields are specified in a CoAP message, i.e.: Version; Type; Token Length; Code; Message ID; and Token (if any). In the rest of this section, those CoAP header fields are discussed according to such an order.</t>
      <section anchor="ssec-coap-version-field">
        <name>CoAP Version Field</name>
        <t>The Version field is described as bidirectional in a SCHC Rule, and it <bcp14>MUST</bcp14> be elided during SCHC compression, since it always contains the same value. If a new version of CoAP is defined in the future, new Rules will be needed to avoid ambiguities between versions.</t>
      </section>
      <section anchor="ssec-coap-type-field">
        <name>CoAP Type Field</name>
        <t>The Type field specifies one of the four types of CoAP messages, encoded as specified in <xref section="3" sectionFormat="of" target="RFC7252"/>: Confirmable (CON), Non-confirmable (NON), Acknowledgement (ACK), and Reset (RST).</t>
        <t>The SCHC compression scheme <bcp14>SHOULD</bcp14> elide this field if, for instance, a client is sending only NON messages or only CON messages. For RST messages, SCHC may use a dedicated Rule. For other usages, SCHC can use a "match-mapping" MO.</t>
      </section>
      <section anchor="ssec-coap-tkl-field">
        <name>CoAP Token Length (TKL) Field</name>
        <t>The Token Length (TKL) field specifies the size in bytes of the later Token field (see <xref target="ssec-coap-token-field"/>) and is described as bidirectional in a SCHC Rule.</t>
        <t>The Token Length field was originally defined to have a fixed length of 4 bits (see <xref section="3" sectionFormat="of" target="RFC7252"/>). Later on, its definition was updated by <xref section="2.1" sectionFormat="of" target="RFC8974"/>, thus making Token Length a variable-length field that can have a length of 4, 12, or 20 bits.</t>
        <t>In particular, the first 4 bits are always present and directly precede the Code field. The value of the first 4 bits determines whether the field comprises 8 or 16 additional bits. In such a case, the additional 8 or 16 bits immediately precede the Token field. In any case, SCHC treats Token Length as a single field of size 4, 12, or 20 bits, which still specifies the size in bytes of the later Token field, as per <xref section="2.1" sectionFormat="of" target="RFC8974"/>.</t>
        <t>If the Token Length field value does not change over time, the SCHC Rule describes the TV set to that value, the MO set to "equal", and the CDA set to "not-sent", thereby eliding the field.</t>
        <t>Otherwise, if the Token Length field value changes over time, the SCHC Rule does not set the TV, while setting the MO to "ignore" and the CDA to "value-sent". The Rule may also use a "match-mapping" MO to compress the value.</t>
        <t>Editor's note: in the YANG data model created by <xref target="RFC9363"/>, the description of the Token Length field should be updated by adding a reference to <xref target="RFC8974"/>.</t>
      </section>
      <section anchor="ssec-coap-code-field">
        <name>CoAP Code Field</name>
        <t>The Code field takes value from the "Code" column of the "CoAP Codes" IANA registry, encoded as specified in <xref section="3" sectionFormat="of" target="RFC7252"/>. This field indicates the Method Code of a CoAP request or the Response Code of a CoAP Response, while the value 0.00 indicates an Empty message. The compression of the CoAP Code field follows the same principle as that of the CoAP Type field.</t>
        <t>If the Device plays a specific role, SCHC may split the code values into two Field Descriptors: (1) the Method Codes with the 0 class and (2) the Response Codes. SCHC will then use the DI to identify the correct value in the packet. If the Device only implements a CoAP client, SCHC compression may focus only on the Method Codes that the client uses in its outgoing requests.</t>
        <t>For known values, SCHC can use a "match-mapping" MO. If SCHC cannot compress the Code field, it will send the values in the Compression Residue.</t>
      </section>
      <section anchor="ssec-coap-message-id-field">
        <name>CoAP Message ID Field</name>
        <t>SCHC can compress the Message ID field with the MSB MO and the LSB CDA (see <xref section="7.4" sectionFormat="of" target="RFC8724"/>).</t>
      </section>
      <section anchor="ssec-coap-token-field">
        <name>CoAP Token Field</name>
        <t>A CoAP message fully specifies the Token by using two CoAP fields: the Token Length (TKL) field in the mandatory header (see <xref target="ssec-coap-tkl-field"/>) and the variable-length Token field that directly follows the mandatory CoAP header and specifies the Token value.</t>
        <t>For the Token field, SCHC <bcp14>MUST NOT</bcp14> send it as variable-size data in the Compression Residue. As a result, SCHC does not send the size of the residue resulting from the compression of the Token field, which is otherwise requested for variable-size fields when the CDA specified in the Field Descriptor is "value-sent" or LSB (see <xref section="7.4.2" sectionFormat="of" target="RFC8724"/>).</t>
        <t>Instead, SCHC <bcp14>MUST</bcp14> use the value of the Token Length field to define the size of the Token field in the Compression Residue. To this end, SCHC designates a specific function, "tkl", that the Rule <bcp14>MUST</bcp14> use to complete the Field Descriptor. During the decompression, this function returns the length of the Token field in bytes, which is specified by the Token Length field as per <xref section="2.1" sectionFormat="of" target="RFC8974"/>.</t>
        <t>This construct avoids ambiguity with the Token Length field and results in a more efficient compression of the Token field.</t>
        <t>Editor's note: in the YANG data model created by <xref target="RFC9363"/>, the description of the "tkl" function and of the Token field should be updated by adding a reference to <xref target="RFC8974"/>.</t>
      </section>
    </section>
    <section anchor="sec-coap-options">
      <name>Compression of CoAP Options</name>
      <t>CoAP defines the use of options, which are placed after the mandatory header and the Token field and are ordered by option number (see <xref section="3" sectionFormat="of" target="RFC7252"/>). As per <xref section="3.1" sectionFormat="of" target="RFC7252"/>, each option instance in a message relies on a format consisting of an Option Delta (D), an Option Length (L), and an Option Value (V).</t>
      <t>The Option Delta is used to express the option number of a CoAP option within a CoAP message, as the difference between the Option Number of that option and the Option Number of the previous option in that message (or zero for the first option). In the byte-representation of CoAP options used on the wire, Option Delta is encoded either by a 4-bit "Option Delta" field or by that field together with an additional 1- or 2-byte "Option Delta (Extended)" field.</t>
      <t>The Option Length specifies the length of the Option Value in bytes. In the byte-representation of CoAP options used on the wire, Option Length is encoded either by a 4-bit "Option Length" field or by that field together with an additional 1- or 2-byte "Option Length (Extended)" field.</t>
      <section anchor="sec-field-descriptors-coap-options">
        <name>Field Descriptors for CoAP Options</name>
        <t>In a SCHC Rule, the Field Descriptors related to CoAP options <bcp14>MUST</bcp14> be specified after the Field Descriptors related to the CoAP header fields discussed in <xref target="sec-coap-fields-compression"/>.</t>
        <t>In particular, the Field Descriptors related to CoAP options <bcp14>MUST</bcp14> be listed in the same order according to which the corresponding CoAP options appear in the CoAP message (i.e., ordered by option number).</t>
        <t>If a SCHC Rule is intended to compress a CoAP message where a repeatable CoAP option is specified multiple times, then the SCHC Rule <bcp14>MUST</bcp14> include different Field Descriptors that separately correspond to the different instances of that CoAP option. Those Field Descriptors <bcp14>MUST</bcp14> be listed in the same order of the corresponding CoAP option instances in the CoAP message.</t>
        <t>As further discussed in <xref target="I-D.ietf-schc-universal-option"/>, the composition and use of Field Descriptors for compressing/decompressing CoAP options can take a "syntactic" approach or a "semantic" approach.</t>
        <t>The syntactic approach operates faithfully to the byte-representation of CoAP options used on the wire. Consequently, it requires multiple Field Descriptors for each given instance of CoAP option to be compressed/decompressed. That is, each of such Field Descriptors pertains to the compression/decompression of the Option Delta, the Option Length, or the Option Value of the CoAP option in question.</t>
        <t>On the contrary, the typically used semantic approach abstracts away from the byte-representation of CoAP options (or, more generally, of protocol header fields) and map those into generic representations identified by the FIDs of the related Field Descriptors. The semantic approach effectively streamlines Field Descriptors related to CoAP options as required to specify only information about the compression/decompression of the Option Value.</t>
        <t>The rest of this document refers to the semantic approach, especially when defining the SCHC compression/decompression of CoAP options as well as when providing examples of CoAP header compression.</t>
        <section anchor="sec-field-descriptors-coap-options-value">
          <name>Option Value</name>
          <t>For most CoAP options, the Option Value is a single indivisible field. Consequently, the compression/decompression of the Option Value for such a CoAP option is specified by a Field Descriptor for which the following applies:</t>
          <ul spacing="normal">
            <li>
              <t>The FID is set to an identifier that unambiguously refers to the CoAP option in question. To this end, the FID provides the following information:  </t>
              <ul spacing="normal">
                <li>
                  <t>An unambiguous identifier of CoAP, as the protocol for which a message is meant to be compressed/decompressed per the present Field Descriptor.</t>
                </li>
                <li>
                  <t>The option number of the CoAP option to be compressed/decompressed per the present Field Descriptor. For registered CoAP options, the value is taken from the "Number" column of the corresponding entry in the "CoAP Option Numbers" IANA registry <xref target="CoAP.Option.Numbers"/>.</t>
                </li>
              </ul>
              <t>
For example, the FID can be set to "CoAP.option(3)" in a Field Descriptor related to the CoAP Uri-Host Option (see <xref target="ssec-max-age-uri-host-uri-port-option"/>).</t>
            </li>
            <li>
              <t>The FL represents the Option Length L of the CoAP option encoded as per <xref section="7.1" sectionFormat="of" target="RFC8724"/>.</t>
            </li>
            <li>
              <t>The TV is either set to an appropriate value (e.g., the Option Value V of the CoAP option) or not set, consistently with the intent of the SCHC Rule and with the MO and CDA used in the Field Descriptor.</t>
            </li>
          </ul>
          <t>For some CoAP options, it might be possible and more convenient for SCHC to consider the Option Value as composed of distinct subfields. An example is the CoAP OSCORE Option defined in <xref target="RFC8613"/> and for which the SCHC compression/decompression is defined in <xref target="ssec-coap-extensions-oscore"/> of this document. Instead of pertaining to the SCHC compression/decompression of the Option Value as a whole, a Field Descriptor related to such a CoAP option can instead specifically pertain to the SCHC compression/decompression of one subfield of the Option Value. In this case, the Field Descriptors related to different subfields of the Option Value of a given CoAP option <bcp14>MUST</bcp14> be listed in the same order according to which the corresponding subfields appear in the Option Value. Furthermore, the following applies to each of such Field Descriptors:</t>
          <ul spacing="normal">
            <li>
              <t>The FID is set to an identifier that unambiguously refers to the CoAP option in question and to the subfield to be compressed/decompressed. To this end, in addition to the two pieces of information mentioned above for the previous case, the FID further provides the following information:  </t>
              <ul spacing="normal">
                <li>
                  <t>An unambiguous identifier of the subfield of the Option Value of the CoAP option to be compressed/decompressed per the present Field Descriptor.</t>
                </li>
              </ul>
              <t>
For example, the FID can be set to "CoAP.option(9).flags" in a Field Descriptor pertaining to the "flags" subfield of the Option Value of the CoAP OSCORE Option (see <xref target="ssec-coap-extensions-oscore"/>).</t>
            </li>
            <li>
              <t>The FL either represents the length of the subfield encoded as per <xref section="7.1" sectionFormat="of" target="RFC8724"/> or denotes a designated function to compute that length.</t>
            </li>
            <li>
              <t>The TV is either set to an appropriate value (e.g., the value of the subfield) or not set, consistently with the intent of the SCHC Rule and with the MO and CDA used in the Field Descriptor.</t>
            </li>
          </ul>
          <t>Note that the MO and the CDA specified in the Field Descriptor operates only on the (subfield of the) Option Value V. That is, SCHC compression produces a residue from the (subfield of the) Option Value V, while ignoring the option number, the Option Delta, and the Option Length or the length of the Option Value's subfield. Therefore, the residue of a SCHC packet conveying a compressed CoAP header does not include the option number, the Option Delta, and the Option Length of the compressed CoAP options. The recipient will be able to reconstruct those when performing SCHC decompression, leveraging the FID and FL of the Field Descriptors within the SCHC Rule used.</t>
          <t>When the Option Length or the length of the Option Value's subfield has a well-known value, the Rule may specify that information in the FL of the Field Descriptor (see above). In such a case, SCHC compression treats the (subfield of the) Option Value as a fixed-length field (see <xref section="7.4.1" sectionFormat="of" target="RFC8724"/>).</t>
          <t>Otherwise, the Rule specifies the FL of the Field Descriptor as indicating a variable length and SCHC compression treats the (subfield of the) Option Value as a variable-length field (see <xref section="7.4.2" sectionFormat="of" target="RFC8724"/>). In such a case, when the CDA specified in the Field Descriptor is "value-sent" or LSB, then SCHC compression additionally carries the length of the Compression Residue, as prepended to the Compression Residue value. Note that the length coding differs between CoAP options and the Compression Residue of SCHC variable-length fields.</t>
          <t>CoAP requests and responses do not include the same options. Compression Rules may reflect this asymmetry by using the DI.</t>
          <t>The following sections present how SCHC compresses some specific CoAP options. Unless otherwise indicated, the referred CoAP options are specified in <xref target="RFC7252"/>.</t>
          <t>If the use of an additional CoAP option is later introduced, the SCHC Rules <bcp14>MAY</bcp14> be updated, in which case a new FID description <bcp14>MUST</bcp14> be assigned to perform the compression of the CoAP option. Otherwise, if no Rule describes that CoAP option, SCHC compression is not achieved and SCHC sends the CoAP header without compression.</t>
        </section>
      </section>
      <section anchor="ssec-content-format-accept-option">
        <name>CoAP Option Content-Format and Accept Fields</name>
        <t>If the client expects a single specific value, SCHC can elide these fields, by specifying the value in the TV of a Rule description with an "equal" MO and a "not-sent" CDA.</t>
        <t>Otherwise, if the client expects several possible values, a "match-mapping" MO <bcp14>SHOULD</bcp14> be used to limit the Compression Residue's size. If not, SCHC has to send the Option Value in the Compression Residue (with fixed or variable length).</t>
      </section>
      <section anchor="ssec-max-age-uri-host-uri-port-option">
        <name>CoAP Option Max-Age, Uri-Host, and Uri-Port Fields</name>
        <t>SCHC compresses these three fields in the same way. When the values of these options are known, SCHC can elide these fields. If the option uses well-known values, SCHC can use a "match-mapping" MO.</t>
        <t>Otherwise, these options' values will be sent in the Compression Residue, i.e., the SCHC Rule description does not set the TV, while setting the MO to "ignore" and the CDA to "value-sent".</t>
      </section>
      <section anchor="ssec-uri-path-uri-query-option">
        <name>CoAP Option Uri-Path and Uri-Query Fields</name>
        <t>The Uri-Path and Uri-Query fields are repeatable options, i.e., the CoAP header may include them several times and with different values. The SCHC Rule description uses the FP to distinguish the different instances of such options.</t>
        <t>To compress these repeatable field values, SCHC can use a "match-mapping" MO to reduce the size of variable paths or queries. When doing so, several elements can be regrouped into a single entry in order to optimize the compression. The numbering of elements does not change, and the first matching element sets the MO comparison.</t>
        <t>For example, as per the Rule descriptions shown in <xref target="_table-complex-path"/>, SCHC can use a single bit in the Compression Residue to code the path segments "/a/b" or the path segments "/c/d". If regrouping were not allowed, then 2 bits in the Compression Residue would be needed. At the same time, SCHC sends the third path element following "/a/b" or "/c/d" as a variable-size field in the Compression Residue.</t>
        <table align="center" anchor="_table-complex-path">
          <name>Complex Path Example. CoAP Option Numbers: 11 (Uri-Path).</name>
          <thead>
            <tr>
              <th align="left">FID</th>
              <th align="left">FL</th>
              <th align="left">FP</th>
              <th align="left">DI</th>
              <th align="left">TV</th>
              <th align="left">MO</th>
              <th align="left">CDA</th>
            </tr>
          </thead>
          <tbody>
            <tr>
              <td align="left">CoAP.<br/>option(11)</td>
              <td align="left"> </td>
              <td align="left">1</td>
              <td align="left">Up</td>
              <td align="left">["/a/b", <br/> "/c/d"]</td>
              <td align="left">match-mapping</td>
              <td align="left">mapping-sent</td>
            </tr>
            <tr>
              <td align="left">CoAP.<br/>option(11)</td>
              <td align="left">var</td>
              <td align="left">3</td>
              <td align="left">Up</td>
              <td align="left"> </td>
              <td align="left">ignore</td>
              <td align="left">value-sent</td>
            </tr>
          </tbody>
        </table>
        <t>The length of the Uri-Path and Uri-Query Options may be known when the Rule is defined. In any other case, SCHC <bcp14>MUST</bcp14> set the Field Length (FL) to a variable value. The unit of the variable length is bytes, hence the Compression Residue size is expressed in bytes, encoded as defined in <xref section="7.4.2" sectionFormat="of" target="RFC8724"/>.</t>
        <t>SCHC compression can use the MSB MO for a Uri-Path or Uri-Query element. In such a case, care must be taken when specifying the MSB parameter value in bits, which <bcp14>MUST</bcp14> be a multiple of 8. The length sent at the beginning of the variable-size field Compression Residue indicates the LSB's size in bytes, consistent with the unit of the variable length in the Rule description.</t>
        <t>For instance, for a CORECONF path /c/X6?k=eth0, the Rule description can be as shown in <xref target="_table-CoMicompress"/>. That is, SCHC compresses the first part of the URI path with a "not-sent" CDA. Also, SCHC will send the second element of the URI path preceded by the length (i.e., 0b0010 "X6"), which is followed by the query parameter's value preceded by the length (i.e., 0b0100 "eth0").</t>
        <table align="center" anchor="_table-CoMicompress">
          <name>CORECONF URI compression. CoAP Option Numbers: 11 (Uri-Path), 15 (Uri-Query).</name>
          <thead>
            <tr>
              <th align="left">FID</th>
              <th align="left">FL</th>
              <th align="left">FP</th>
              <th align="left">DI</th>
              <th align="left">TV</th>
              <th align="left">MO</th>
              <th align="left">CDA</th>
            </tr>
          </thead>
          <tbody>
            <tr>
              <td align="left">CoAP.<br/>option(11)</td>
              <td align="left"> </td>
              <td align="left">1</td>
              <td align="left">Up</td>
              <td align="left">"c"</td>
              <td align="left">equal</td>
              <td align="left">not-sent</td>
            </tr>
            <tr>
              <td align="left">CoAP.<br/>option(11)</td>
              <td align="left">var</td>
              <td align="left">2</td>
              <td align="left">Up</td>
              <td align="left"> </td>
              <td align="left">ignore</td>
              <td align="left">value-sent</td>
            </tr>
            <tr>
              <td align="left">CoAP.<br/>option(15)</td>
              <td align="left">var</td>
              <td align="left">1</td>
              <td align="left">Up</td>
              <td align="left">"k="</td>
              <td align="left">MSB(16)</td>
              <td align="left">LSB</td>
            </tr>
          </tbody>
        </table>
        <section anchor="variable-number-of-path-or-query-elements">
          <name>Variable Number of Path or Query Elements</name>
          <t>SCHC fixes the number of Uri-Path or Uri-Query elements in a Rule at Rule creation time. If the number of such elements varies, SCHC <bcp14>SHOULD</bcp14> either:</t>
          <ul spacing="normal">
            <li>
              <t>create several Rules to cover all possibilities; or</t>
            </li>
            <li>
              <t>create a Rule that defines several entries for Uri-Path to cover the longest path and send a Compression Residue with a length of 0 to indicate that a Uri-Path entry is empty.  </t>
              <t>
However, this adds 4 bits to the variable Compression Residue size (see <xref section="7.4.2" sectionFormat="of" target="RFC8724"/>).</t>
            </li>
          </ul>
        </section>
      </section>
      <section anchor="ssec-size1-size2-proxy-uri-proxy-scheme-option">
        <name>CoAP Option Size1, Size2, Proxy-Uri, and Proxy-Scheme Fields</name>
        <t>The Size2 field is an option defined in <xref target="RFC7959"/>.</t>
        <t>The SCHC Rule description <bcp14>MAY</bcp14> define sending some field values by not setting the TV, while setting the MO to "ignore" and the CDA to "value-sent". A Rule <bcp14>MAY</bcp14> also use a "match-mapping" MO when there are different alternatives for the same FID. Otherwise, the Rule sets the TV to a specific value, the MO to "equal", and the CDA to "not-sent".</t>
      </section>
      <section anchor="ssec-proxy-cri-proxy-scheme-number-option">
        <name>CoAP Option Proxy-Cri and Proxy-Scheme-Number Fields</name>
        <t>The Proxy-Cri field is an option defined in <xref target="I-D.ietf-core-href"/>. The option carries an encoded CBOR data item <xref target="RFC8949"/> that represents an absolute CRI reference (see <xref section="5" sectionFormat="of" target="I-D.ietf-core-href"/>). The option is used analogously to the Proxy-Uri option as defined in <xref section="5.10.2" sectionFormat="of" target="RFC7252"/>.</t>
        <t>The Proxy-Scheme-Number field is an option defined in <xref target="I-D.ietf-core-href"/>. The option carries a CRI Scheme Number represented as a CoAP unsigned integer (see Sections <xref target="I-D.ietf-core-href" section="5.1.1" sectionFormat="bare"/> and <xref target="I-D.ietf-core-href" section="8.1" sectionFormat="bare"/> of <xref target="I-D.ietf-core-href"/>). The option is used analogously to the Proxy-Scheme option as defined in <xref section="5.10.2" sectionFormat="of" target="RFC7252"/>.</t>
        <t>The SCHC Rule description <bcp14>MAY</bcp14> define sending some field values by not setting the TV, while setting the MO to "ignore" and the CDA to "value-sent". A Rule <bcp14>MAY</bcp14> also use a "match-mapping" MO when there are different alternatives for the same FID. Otherwise, the Rule sets the TV to a specific value, the MO to "equal", and the CDA to "not-sent".</t>
      </section>
      <section anchor="ssec-location-path-location-query-option">
        <name>CoAP Location-Path and Location-Query Fields</name>
        <t>A Rule entry cannot store these fields' values. Therefore, SCHC compression <bcp14>MUST</bcp14> always send these values in the Compression Residue. That is, in the SCHC Rule, the TV is not set, while the MO is set to "ignore" and the CDA is set to "value-sent".</t>
      </section>
      <section anchor="ssec-etag-if-match-option">
        <name>CoAP Option ETag and If-Match Fields</name>
        <t>When a CoAP message uses the ETag Option or the If-Match Option, SCHC compression <bcp14>MAY</bcp14> send its content in the Compression Residue. That is, in the SCHC Rule, the TV is not set, while the MO is set to "ignore" and the CDA is set to "value-sent". Alternatively, if a pre-defined set of values determined by the server is known and is used by the client as ETag values or If-Match values, then a Rule <bcp14>MAY</bcp14> use a "match-mapping" MO when there are different alternatives for the same FID.</t>
      </section>
      <section anchor="ssec-if-none-match">
        <name>CoAP Option If-None-Match</name>
        <t>The If-None-Match Option occurs at most once and is always empty. The SCHC Rule <bcp14>MUST</bcp14> describe an empty TV, with the MO set to "equal" and the CDA set to "not-sent".</t>
      </section>
      <section anchor="coap-options-hop-limit">
        <name>CoAP Option Hop-Limit Field</name>
        <t>The Hop-Limit field is an option defined in <xref target="RFC8768"/> that can be used to detect forwarding loops through a chain of CoAP proxies. The first proxy in the chain that understands the option includes it in a received request with a proper value set, before forwarding the request. Any following proxy that understands the option decrements the Option Value and forwards the request if the new value is different than zero, or returns a 5.08 (Hop Limit Reached) error response otherwise.</t>
        <t>When a CoAP message uses the Hop-Limit Option, SCHC compression <bcp14>SHOULD</bcp14> send its content in the Compression Residue. That is, in the SCHC Rule, the TV is not set, while the MO is set to "ignore" and the CDA is set to "value-sent". As an exception, and consistently with the default value 16 defined for the Hop-Limit Option in <xref section="3" sectionFormat="of" target="RFC8768"/>, a Rule <bcp14>MAY</bcp14> describe a TV with value 16, with the MO set to "equal" and the CDA set to "not-sent".</t>
      </section>
      <section anchor="coap-options-echo">
        <name>CoAP Option Echo Field</name>
        <t>The Echo field is an option defined in <xref target="RFC9175"/> that a server can include in a CoAP response as a challenge to the client, and that the client echoes back to the server in one or more CoAP requests. This enables the server to verify the freshness of a request and to cryptographically verify the aliveness of the client. Also, it forces the client to demonstrate reachability at its claimed network address.</t>
        <t>When a CoAP message uses the Echo Option, SCHC compression <bcp14>SHOULD</bcp14> send its content in the Compression Residue. That is, in the SCHC Rule, the TV is not set, while the MO is set to "ignore" and the CDA is set to "value-sent". An exception applies in case the server generates the values to use for the Echo Option by means of a persistent counter (see <xref section="A" sectionFormat="of" target="RFC9175"/>). In such a case, a Rule <bcp14>MAY</bcp14> use the MSB MO and the LSB CDA. This would be effectively applicable until the persistent counter at the server becomes greater than the maximum threshold value that produces an MSB-matching.</t>
      </section>
      <section anchor="coap-options-request-tag">
        <name>CoAP Option Request-Tag Field</name>
        <t>The Request-Tag field is an option defined in <xref target="RFC9175"/> that the client can set in CoAP requests throughout block-wise operations, with value an ephemeral short-lived identifier of the specific block-wise operation in question. This allows the server to match message fragments belonging to the same request operation and, if the server supports it, to reliably process simultaneous block-wise request operations on a single resource. If requests are integrity protected, this also protects against interchange of fragments between different block-wise request operations.</t>
        <t>When a CoAP message uses the Request-Tag Option, SCHC compression <bcp14>MAY</bcp14> send its content in the Compression Residue. That is, in the SCHC Rule, the TV is not set, while the MO is set to "ignore" and the CDA is set to "value-sent". Alternatively, if a pre-defined set of Request-Tag values used by the client is known, a Rule <bcp14>MAY</bcp14> use a "match-mapping" MO when there are different alternatives for the same FID.</t>
      </section>
      <section anchor="coap-options-edhoc">
        <name>CoAP Option EDHOC Field</name>
        <t>The EDHOC field is an option defined in <xref target="RFC9668"/> that a client can include in a CoAP request, in order to perform an optimized, shortened execution of the authenticated key exchange protocol EDHOC <xref target="RFC9528"/>. Such a request conveys both the final EDHOC message and actual application data, where the latter is protected with OSCORE <xref target="RFC8613"/> using a Security Context derived from the result of the current EDHOC execution.</t>
        <t>The EDHOC Option occurs at most once and is always empty. The SCHC Rule <bcp14>MUST</bcp14> describe an empty TV, with the MO set to "equal" and the CDA set to "not-sent".</t>
      </section>
    </section>
    <section anchor="sec-coap-extensions">
      <name>Compression of CoAP Extensions</name>
      <t>The following sections present how SCHC compresses some specific CoAP options that, when used, play a major role in the processing and exchange of CoAP messages.</t>
      <section anchor="ssec-coap-extensions-block">
        <name>Block-Wise Transfers</name>
        <t>When a CoAP message uses a Block1 or Block2 Option <xref target="RFC7959"/> or a Q-Block1 or Q-Block2 Option <xref target="RFC9177"/>, SCHC compression <bcp14>MUST</bcp14> send its content in the Compression Residue. In the SCHC Rule, the TV is not set, while the MO is set to "ignore" and the CDA is set to "value-sent".</t>
        <t>The Block1, Block2, Q-Block1, and Q-Block2 options allow fragmentation at the CoAP level that is compatible with SCHC fragmentation. Both fragmentation mechanisms are complementary, and the node may use them for the same packet as needed.</t>
      </section>
      <section anchor="ssec-coap-extensions-observe">
        <name>Observe</name>
        <t><xref target="RFC7641"/> defines the Observe Option. The SCHC Rule description does not set the TV, while setting the MO to "ignore" and the CDA to "value-sent". SCHC does not limit the maximum size for this option (3 bytes). To reduce the transmission size, either the Device implementation <bcp14>MAY</bcp14> limit the delta between two consecutive values or a proxy can modify the increment.</t>
        <t>Since the client <bcp14>MAY</bcp14> use a RST message to inform a server that the Observe response is not required, a specific SCHC Rule <bcp14>SHOULD</bcp14> exist to allow the compression of a RST message.</t>
      </section>
      <section anchor="ssec-coap-extensions-no-response">
        <name>No-Response</name>
        <t><xref target="RFC7967"/> defines a No-Response Option limiting the CoAP responses made by a server to a CoAP request. Different behaviors exist while using this option to limit the responses made by a server to a request. If both ends know the specific value, then the SCHC Rule describes the TV set to that value, the MO set to "equal", and the CDA set to "not-sent".</t>
        <t>Otherwise, if the value changes over time, the SCHC Rule does not set the TV, while setting the MO to "ignore" and the CDA to "value-sent". The Rule may also use a "match-mapping" MO to compress the value.</t>
      </section>
      <section anchor="ssec-coap-extensions-oscore">
        <name>OSCORE</name>
        <t>The security protocol OSCORE <xref target="RFC8613"/> provides end-to-end protection for CoAP messages. Group OSCORE <xref target="I-D.ietf-core-oscore-groupcomm"/> builds on OSCORE and defines end-to-end protection of CoAP messages in group communication <xref target="I-D.ietf-core-groupcomm-bis"/>. This section describes how SCHC Rules can be applied to compress messages protected with OSCORE or Group OSCORE.</t>
        <t><xref target="fig-oscore-option"/> shows the OSCORE Option value encoding, as it was originally defined in <xref section="6.1" sectionFormat="of" target="RFC8613"/>. As explained later in this section, this has been extended in <xref target="I-D.ietf-core-oscore-key-update"/> and <xref target="I-D.ietf-core-oscore-groupcomm"/>. The first byte of the OSCORE Option value specifies information to parse the rest of the value by using flags, as described below.</t>
        <ul spacing="normal">
          <li>
            <t>As defined in <xref section="4.1" sectionFormat="of" target="I-D.ietf-core-oscore-key-update"/>, the eight least significant bit, when set, indicates that the OSCORE Option value includes a second byte of flags. The seventh least significant bit is currently unassigned.</t>
          </li>
          <li>
            <t>As defined in <xref section="5" sectionFormat="of" target="I-D.ietf-core-oscore-groupcomm"/>, the sixth least significant bit, when set, indicates that the message including the OSCORE Option is protected with the group mode of Group OSCORE (see <xref section="8" sectionFormat="of" target="I-D.ietf-core-oscore-groupcomm"/>). When not set, the bit indicates that the message is protected either with OSCORE or with the pairwise mode of Group OSCORE (see <xref section="9" sectionFormat="of" target="I-D.ietf-core-oscore-groupcomm"/>), while the specific OSCORE Security Context used to protect the message determines which of the two cases applies.</t>
          </li>
          <li>
            <t>As defined in <xref section="6.1" sectionFormat="of" target="RFC8613"/>, bit h, when set, indicates the presence of the kid context field in the OSCORE Option value. Also, bit k, when set, indicates the presence of the kid field. Finally, the three least significant bits form the n field, which indicates the length of the Partial IV (Partial Initialization Vector) field in bytes. When n = 0, no Partial IV is present.</t>
          </li>
        </ul>
        <t>Assuming the presence of a single flag byte, this is followed by the Partial IV field. After that, if the h bit is set, the kid context field is present, preceded by one byte "s" indicating its length in bytes. After that, if the k bit is set, the kid field is present, and it ends where the OSCORE Option value ends.</t>
        <figure anchor="fig-oscore-option">
          <name>OSCORE Option Value.</name>
          <artwork align="center"><![CDATA[
 0 1 2 3 4 5 6 7 <------ n bytes ------->
+-+-+-+-+-+-+-+-+-----------------------+
|0 0 0|h|k|  n  |  Partial IV (if any)  |
+-+-+-+-+-+-+-+-+-----------------------+
|               |                       |
|<--- flags --->|<-------- piv -------->|


 <--- 1 byte --> <------- s bytes ----->
+---------------+-----------------------+------------------+
|   s (if any)  |  kid context (if any) | kid (if any) ... |
+---------------+-----------------------+------------------+
|                                       |                  |
|<--------------- kid_ctx ------------->|<------ kid ----->|
]]></artwork>
        </figure>
        <t><xref target="fig-oscore-option-kudos"/> shows the extended OSCORE Option value encoding, with the second byte of flags also present. As defined in <xref section="4.1" sectionFormat="of" target="I-D.ietf-core-oscore-key-update"/>, the least significant bit d of this byte, when set, indicates that two additional fields are included in the OSCORE Option value, following the kid context field (if any).</t>
        <t>These two fields, namely x and nonce, are used when running the key update protocol KUDOS defined in <xref target="I-D.ietf-core-oscore-key-update"/>, with x specifying the length of the nonce field in bytes as well as further information concerning the KUDOS execution in question.</t>
        <t><xref target="fig-oscore-option-kudos"/> provides the breakdown of the x field, where its four least significant bits encode the value m, which specifies the size of nonce in bytes, minus 1.</t>
        <figure anchor="fig-oscore-option-kudos">
          <name>OSCORE Option Value Extended to Support a KUDOS Execution.</name>
          <artwork align="center"><![CDATA[
 0 1 2 3 4 5 6 7  8   9   10  11  12  13  14  15 <----- n bytes ----->
+-+-+-+-+-+-+-+-+---+---+---+---+---+---+---+---+---------------------+
|1|0|0|h|k|  n  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | d | Partial IV (if any) |
+-+-+-+-+-+-+-+-+---+---+---+---+---+---+---+---+---------------------+
|                                               |                     |
|<------------------- flags ------------------->|<------- piv ------->|


 <- 1 byte -> <--------- s bytes --------->
+------------+----------------------------+
| s (if any) |    kid context (if any)    |
+------------+----------------------------+
|                                         |
|<--------------- kid_ctx --------------->|


 <------ 1 byte -----> <-- m + 1 bytes -->
+---------------------+-------------------+
|     x (if any)      |  nonce (if any)   |
+---------------------+-------------------+
|<-------- x -------->|<----- nonce ----->|
|                     |
|   0 1 2 3 4 5 6 7   |
|  +-+-+-+-+-+-+-+-+  |
|  |0|z|b|p|   m   |  |
|  +-+-+-+-+-+-+-+-+  |


+---------------------+
|   kid (if any) ...  |
+---------------------+
|                     |
|<------- kid ------->|
]]></artwork>
        </figure>
        <t>To better perform OSCORE SCHC compression, the Rule description needs to identify the OSCORE Option value and its inner fields mentioned above.</t>
        <t>Conceptually, SCHC discerns six distinct pieces of information within the OSCORE Option value: the flag bits, the Partial IV, the kid context prepended by its size s, the x byte, the nonce, and the kid. The SCHC Rule splits the OSCORE Option value into six corresponding Field Descriptors, in order to separately compress those pieces of information as distinct subfields:</t>
        <ul spacing="normal">
          <li>
            <t>flags</t>
          </li>
          <li>
            <t>piv</t>
          </li>
          <li>
            <t>kid_ctx</t>
          </li>
          <li>
            <t>x</t>
          </li>
          <li>
            <t>nonce</t>
          </li>
          <li>
            <t>kid</t>
          </li>
        </ul>
        <t>If a SCHC Rule is intended to compress a CoAP message that specifies the OSCORE Option, then the related Field Descriptors defined above <bcp14>MUST</bcp14> be listed in the same order according to which the corresponding pieces of information appear in the OSCORE Option value.</t>
        <t><xref target="fig-oscore-option"/> shows the original format of the OSCORE Option value with the four subfields flags, piv, kid_ctx, and kid superimposed on it. Also, <xref target="fig-oscore-option-kudos"/> shows the extended format of the OSCORE Option value with all the six subfields superimposed on it.</t>
        <t>If a subfield is not present, then the corresponding Field Descriptor in the SCHC Rule describes the TV set to b'', with the MO set to "equal" and the CDA set to "not-sent". Note that, if the subfield kid_context is present, it directly includes the size octet, i.e., s.</t>
        <t>In addition, the following applies.</t>
        <ul spacing="normal">
          <li>
            <t>If the piv subfield is present, SCHC <bcp14>MUST NOT</bcp14> send it as variable-size data in the Compression Residue. As a result, SCHC does not send the size of the residue resulting from the compression of the piv subfield, which is otherwise requested for variable-size fields when the CDA specified in the Field Descriptor is "value-sent" or LSB (see <xref section="7.4.2" sectionFormat="of" target="RFC8724"/>).  </t>
            <t>
Instead, SCHC <bcp14>MUST</bcp14> use the value n from the first byte of the OSCORE Option value to define the size of the piv subfield in the Compression Residue. To this end, SCHC designates a specific function, "osc.piv", that the Rule <bcp14>MUST</bcp14> use to complete the Field Descriptor. During the decompression, this function returns the value n, hence the length of the piv subfield in bytes.  </t>
            <t>
This construct avoids ambiguity with the value n from the first byte of the OSCORE Option value and results in a more efficient compression of the piv subfield.</t>
          </li>
          <li>
            <t>For the x subfield, if both endpoints know the value, then the corresponding Field Descriptor in the SCHC Rule describes the TV set to that value, with the MO set to "equal" and the CDA set to "not-sent". This models the following cases:  </t>
            <ul spacing="normal">
              <li>
                <t>The x subfield is not present, and thus TV is set to b''.</t>
              </li>
              <li>
                <t>Given a fixed z bit of the x subfield as denoting either a "divergent" or "convergent" KUDOS message, the two endpoints run KUDOS with a pre-agreed size of the nonce subfield as per the value encoded by m within the x subfield, as well as with a pre-agreed combination of its modes of operation, as per the bits b and p of the x subfield.      </t>
                <t>
Under the assumed pre-agreements above, this requires two distinct SCHC Rules, whose respective TV is set to a value that reflects the z bit as set or not set, respectively.</t>
              </li>
            </ul>
            <t>
As an alternative that is more flexible to changes in the value of the x subfield, the corresponding Field Descriptor in the SCHC Rule does not set the TV, while it sets the MO to "ignore" and the CDA to "value-sent". In the same spirit, the Rule may also use a "match-mapping" MO to compress this subfield, in case the two endpoints pre-agree on a set of alternative ways to run KUDOS, with respect to the size of the nonce subfield and the combination of the KUDOS modes of operation to use.</t>
          </li>
          <li>
            <t>If the nonce subfield is present, then the corresponding Field Descriptor in the SCHC Rule has the TV not set, while the MO is set to "ignore" and the CDA is set to "value-sent".  </t>
            <t>
For the value of the nonce subfield, SCHC <bcp14>MUST NOT</bcp14> send it as variable-length data in the Compression Residue. As a result, SCHC does not send the size of the residue resulting from the compression of the nonce subfield, which is otherwise requested for variable-size fields when the CDA specified in the Field Descriptor is "value-sent" or LSB (see <xref section="7.4.2" sectionFormat="of" target="RFC8724"/>).  </t>
            <t>
Instead, SCHC <bcp14>MUST</bcp14> use the value encoded by m within the x subfield to define the size of the Compression Residue. SCHC designates a specific function, "osc.x.m", that the Rule <bcp14>MUST</bcp14> use to complete the Field Descriptor. During the decompression, this function returns the length of the nonce subfield in bytes, as the value encoded by m within the x subfield, plus 1.  </t>
            <t>
This construct avoids ambiguity with the value m within the x subfield and results in a more efficient compression of the nonce subfield.</t>
          </li>
        </ul>
      </section>
    </section>
    <section anchor="payload-marker">
      <name>Compression of the CoAP Payload Marker</name>
      <t>The following applies with respect to the 0xFF payload marker. A SCHC compression Rule for CoAP includes all the expected CoAP options, therefore the payload marker does not have to be specified in a SCHC Rule description.</t>
      <t>If the CoAP message to compress with SCHC is not going to be protected with OSCORE <xref target="RFC8613"/> and includes a payload, then the 0xFF payload marker <bcp14>MUST NOT</bcp14> be included in the compressed message, which is composed of the Compression RuleID, the Compression Residue (if any), and the CoAP payload.</t>
      <t>After having decompressed an incoming message, the recipient endpoint <bcp14>MUST</bcp14> prepend the 0xFF payload marker to the CoAP payload, if any was present after the consumed Compression Residue.</t>
      <t>If the CoAP message to compress with SCHC is going to be protected with OSCORE, the 0xFF payload marker is compressed as specified later in <xref target="ssec-examples-oscore"/>.</t>
    </section>
    <section anchor="sec-examples">
      <name>Examples of CoAP Header Compression</name>
      <section anchor="ssec-examples-con-message">
        <name>Mandatory Header with CON Message</name>
        <t>In this first scenario, the SCHC compressor on the NGW side receives a POST message from an Internet client, which is immediately acknowledged by the Device. <xref target="_table-CoAP-header-1"/> describes the SCHC Rule descriptions for this scenario.</t>
        <artwork><![CDATA[
+----------+
| RuleID 1 |
+----------+
]]></artwork>
        <table align="center" anchor="_table-CoAP-header-1">
          <name>CoAP Context to compress header without Token. CoAP Option Numbers: 11 (Uri-Path).</name>
          <thead>
            <tr>
              <th align="left">FID</th>
              <th align="left">FL</th>
              <th align="left">FP</th>
              <th align="left">DI</th>
              <th align="left">TV</th>
              <th align="left">MO</th>
              <th align="left">CDA</th>
              <th align="left">Sent 
 [bits]</th>
            </tr>
          </thead>
          <tbody>
            <tr>
              <td align="left">CoAP.<br/>Version</td>
              <td align="left">2</td>
              <td align="left">1</td>
              <td align="left">Bi</td>
              <td align="left">1</td>
              <td align="left">equal</td>
              <td align="left">not-sent</td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">CoAP.<br/>Type</td>
              <td align="left">2</td>
              <td align="left">1</td>
              <td align="left">Dw</td>
              <td align="left">CON</td>
              <td align="left">equal</td>
              <td align="left">not-sent</td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">CoAP.<br/>Type</td>
              <td align="left">2</td>
              <td align="left">1</td>
              <td align="left">Up</td>
              <td align="left">[ACK, <br/> RST]</td>
              <td align="left">match- <br/> mapping</td>
              <td align="left">mapping- <br/> sent</td>
              <td align="left">T</td>
            </tr>
            <tr>
              <td align="left">CoAP.<br/>TKL</td>
              <td align="left"> </td>
              <td align="left">1</td>
              <td align="left">Bi</td>
              <td align="left">0b0000</td>
              <td align="left">equal</td>
              <td align="left">not-sent</td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">CoAP.<br/>Code</td>
              <td align="left">8</td>
              <td align="left">1</td>
              <td align="left">Bi</td>
              <td align="left">[0.00, <br/> ... <br/> 5.05]</td>
              <td align="left">match- <br/> mapping</td>
              <td align="left">mapping- <br/> sent</td>
              <td align="left">CC CCC</td>
            </tr>
            <tr>
              <td align="left">CoAP.<br/>MID</td>
              <td align="left">16</td>
              <td align="left">1</td>
              <td align="left">Bi</td>
              <td align="left">0x0000</td>
              <td align="left">MSB(7)</td>
              <td align="left">LSB</td>
              <td align="left">MID</td>
            </tr>
            <tr>
              <td align="left">CoAP.<br/>option(11)</td>
              <td align="left"> </td>
              <td align="left">1</td>
              <td align="left">Dw</td>
              <td align="left">"status"</td>
              <td align="left">equal</td>
              <td align="left">not-sent</td>
              <td align="left"> </td>
            </tr>
          </tbody>
        </table>
        <t>In this example, SCHC compression elides the version and Token Length fields. The 25 Method and Response Codes defined in <xref target="RFC7252"/> have been shrunk to 5 bits using a "match-mapping" MO. The Uri-Path contains a single element with the TV set to "status" and the CDA set to "not-sent", thereby eliding the single occurrence of the Uri-Path Option with value "status".</t>
        <t>SCHC compression reduces the header, sending only a mapped Type (and only for uplink messages), a mapped code, and the least significant bits of the Message ID (9 bits in the example above).</t>
        <t>Note that, if a client is located in an Application Server and sends a request to a server located in the Device, then the request may not be compressed through this Rule, since the MID might not start with 7 bits equal to 0. A CoAP proxy placed before SCHC C/D can rewrite the Message ID to fit the value and match the Rule.</t>
      </section>
      <section anchor="ssec-examples-oscore">
        <name>OSCORE Compression</name>
        <t>The OSCORE security protocol specified in <xref target="RFC8613"/> provides end-to-end protection for CoAP messages. When doing so, it hides as much as possible of a CoAP message, while still enabling proxy operations.</t>
        <t>Conceptually, this is achieved by splitting the CoAP message into an Inner Plaintext and an Outer OSCORE message. The Inner Plaintext contains (sensitive) information that is not necessary for performing proxy operations. Therefore, that information can be encrypted end-to-end until it reaches the other origin endpoint as its final destination. The Outer Message acts as a shell matching the regular CoAP message format, and includes all the CoAP options and information needed for performing proxy operations and caching. This is summarized in <xref target="fig-inner-outer"/>.</t>
        <t>In particular, the CoAP options are arranged into three classes, each of which is granted a specific type of protection by the OSCORE protocol:</t>
        <ul spacing="normal">
          <li>
            <t>Class E: Encrypted and integrity-protected options, which are moved to the Inner Plaintext.</t>
          </li>
          <li>
            <t>Class I: Integrity-protected options, which are included in the Additional Authenticated Data (AAD) when protecting the Plaintext, but are otherwise left untouched in the Outer Message.</t>
          </li>
          <li>
            <t>Class U: Unprotected options, which are left untouched in the Outer Message.</t>
          </li>
        </ul>
        <t>As per these classes, the Outer options comprise the OSCORE Option, which indicates that the message is protected with OSCORE and carries the information necessary for the recipient endpoint to retrieve the Security Context for decrypting the message.</t>
        <figure anchor="fig-inner-outer">
          <name>CoAP Message Split into OSCORE Outer Header and Plaintext.</name>
          <artset>
            <artwork type="svg" align="center"><svg xmlns="http://www.w3.org/2000/svg" version="1.1" height="672" width="576" viewBox="0 0 576 672" class="diagram" text-anchor="middle" font-family="monospace" font-size="13px" stroke-linecap="round">
                <path d="M 8,464 L 8,544" fill="none" stroke="black"/>
                <path d="M 8,592 L 8,640" fill="none" stroke="black"/>
                <path d="M 24,464 L 24,496" fill="none" stroke="black"/>
                <path d="M 40,464 L 40,496" fill="none" stroke="black"/>
                <path d="M 64,608 L 64,640" fill="none" stroke="black"/>
                <path d="M 72,464 L 72,496" fill="none" stroke="black"/>
                <path d="M 112,48 L 112,352" fill="none" stroke="black"/>
                <path d="M 136,80 L 136,160" fill="none" stroke="black"/>
                <path d="M 136,208 L 136,320" fill="none" stroke="black"/>
                <path d="M 152,80 L 152,112" fill="none" stroke="black"/>
                <path d="M 160,464 L 160,496" fill="none" stroke="black"/>
                <path d="M 168,80 L 168,112" fill="none" stroke="black"/>
                <path d="M 192,224 L 192,256" fill="none" stroke="black"/>
                <path d="M 200,80 L 200,112" fill="none" stroke="black"/>
                <path d="M 224,592 L 224,608" fill="none" stroke="black"/>
                <path d="M 256,80 L 256,112" fill="none" stroke="black"/>
                <path d="M 264,464 L 264,496" fill="none" stroke="black"/>
                <path d="M 352,144 L 352,160" fill="none" stroke="black"/>
                <path d="M 352,208 L 352,224" fill="none" stroke="black"/>
                <path d="M 352,256 L 352,320" fill="none" stroke="black"/>
                <path d="M 352,496 L 352,528" fill="none" stroke="black"/>
                <path d="M 360,80 L 360,112" fill="none" stroke="black"/>
                <path d="M 392,464 L 392,640" fill="none" stroke="black"/>
                <path d="M 440,112 L 440,144" fill="none" stroke="black"/>
                <path d="M 456,464 L 456,496" fill="none" stroke="black"/>
                <path d="M 456,528 L 456,560" fill="none" stroke="black"/>
                <path d="M 464,48 L 464,352" fill="none" stroke="black"/>
                <path d="M 552,560 L 552,640" fill="none" stroke="black"/>
                <path d="M 568,496 L 568,528" fill="none" stroke="black"/>
                <path d="M 112,48 L 464,48" fill="none" stroke="black"/>
                <path d="M 136,80 L 360,80" fill="none" stroke="black"/>
                <path d="M 136,112 L 376,112" fill="none" stroke="black"/>
                <path d="M 424,112 L 440,112" fill="none" stroke="black"/>
                <path d="M 136,144 L 376,144" fill="none" stroke="black"/>
                <path d="M 424,144 L 440,144" fill="none" stroke="black"/>
                <path d="M 136,224 L 352,224" fill="none" stroke="black"/>
                <path d="M 136,256 L 352,256" fill="none" stroke="black"/>
                <path d="M 136,320 L 352,320" fill="none" stroke="black"/>
                <path d="M 112,352 L 464,352" fill="none" stroke="black"/>
                <path d="M 8,464 L 264,464" fill="none" stroke="black"/>
                <path d="M 392,464 L 456,464" fill="none" stroke="black"/>
                <path d="M 8,496 L 280,496" fill="none" stroke="black"/>
                <path d="M 336,496 L 352,496" fill="none" stroke="black"/>
                <path d="M 392,496 L 504,496" fill="none" stroke="black"/>
                <path d="M 552,496 L 568,496" fill="none" stroke="black"/>
                <path d="M 8,528 L 280,528" fill="none" stroke="black"/>
                <path d="M 336,528 L 352,528" fill="none" stroke="black"/>
                <path d="M 392,528 L 504,528" fill="none" stroke="black"/>
                <path d="M 552,528 L 568,528" fill="none" stroke="black"/>
                <path d="M 392,560 L 552,560" fill="none" stroke="black"/>
                <path d="M 8,608 L 224,608" fill="none" stroke="black"/>
                <path d="M 8,640 L 64,640" fill="none" stroke="black"/>
                <path d="M 392,640 L 552,640" fill="none" stroke="black"/>
                <path d="M 356,360 L 404,456" fill="none" stroke="black"/>
                <path d="M 180,456 L 228,360" fill="none" stroke="black"/>
                <polygon class="arrowhead" points="412,456 400,450.4 400,461.6" fill="black" transform="rotate(63.43494882292201,404,456)"/>
                <polygon class="arrowhead" points="188,456 176,450.4 176,461.6" fill="black" transform="rotate(116.56505117707799,180,456)"/>
                <g class="text">
                  <text x="172" y="36">Original</text>
                  <text x="228" y="36">CoAP</text>
                  <text x="280" y="36">Message</text>
                  <text x="144" y="100">v</text>
                  <text x="160" y="100">t</text>
                  <text x="184" y="100">TKL</text>
                  <text x="228" y="100">code</text>
                  <text x="296" y="100">Message</text>
                  <text x="340" y="100">ID</text>
                  <text x="400" y="116">...</text>
                  <text x="168" y="132">Token</text>
                  <text x="400" y="148">...</text>
                  <text x="176" y="164">Options</text>
                  <text x="232" y="164">(EIU)</text>
                  <text x="136" y="180">:</text>
                  <text x="352" y="180">:</text>
                  <text x="136" y="196">:</text>
                  <text x="352" y="196">:</text>
                  <text x="164" y="244">0xFF</text>
                  <text x="176" y="276">Payload</text>
                  <text x="56" y="452">Outer</text>
                  <text x="108" y="452">Header</text>
                  <text x="464" y="452">Plaintext</text>
                  <text x="16" y="484">v</text>
                  <text x="32" y="484">t</text>
                  <text x="56" y="484">TKL</text>
                  <text x="96" y="484">new</text>
                  <text x="132" y="484">code</text>
                  <text x="200" y="484">Message</text>
                  <text x="244" y="484">ID</text>
                  <text x="420" y="484">code</text>
                  <text x="308" y="500">....</text>
                  <text x="528" y="500">...</text>
                  <text x="40" y="516">Token</text>
                  <text x="432" y="516">Options</text>
                  <text x="480" y="516">(E)</text>
                  <text x="304" y="532">...</text>
                  <text x="528" y="532">...</text>
                  <text x="48" y="548">Options</text>
                  <text x="100" y="548">(IU)</text>
                  <text x="224" y="548">|</text>
                  <text x="420" y="548">0xFF</text>
                  <text x="8" y="564">:</text>
                  <text x="224" y="564">:</text>
                  <text x="8" y="580">:</text>
                  <text x="44" y="580">OSCORE</text>
                  <text x="100" y="580">Option</text>
                  <text x="224" y="580">:</text>
                  <text x="432" y="580">Payload</text>
                  <text x="36" y="628">0xFF</text>
                </g>
              </svg>
            </artwork>
            <artwork type="ascii-art" align="center"><![CDATA[
                 Original CoAP Message
             +-------------------------------------------+
             |                                           |
             |  +-+-+---+------+------------+            |
             |  |v|t|TKL| code | Message ID |            |
             |  +-+-+---+------+------------+-- ... --+  |
             |  | Token                               |  |
             |  +--------------------------+--- ... --+  |
             |  | Options (EIU)            |             |
             |  :                          :             |
             |  :                          :             |
             |  |                          |             |
             |  +------+-------------------+             |
             |  | 0xFF |                                 |
             |  +------+-------------------+             |
             |  | Payload                  |             |
             |  |                          |             |
             |  |                          |             |
             |  +--------------------------+             |
             |                                           |
             +-------------------------------------------+
                           /                \
                          /                  \
                         /                    \
                        /                      \
                       /                        \
    Outer Header      v                          v   Plaintext
+-+-+---+----------+------------+               +-------+
|v|t|TKL| new code | Message ID |               | code  |
+-+-+---+----------+------------+-- .... --+    +-------+------ ... --+
| Token                                    |    | Options (E)         |
+---------------------------------- ...  --+    +-------+------ ... --+
| Options (IU)             |                    | 0xFF  |
:                          :                    +-------+-----------+
: OSCORE Option            :                    | Payload           |
|                          |                    |                   |
+------+-------------------+                    |                   |
| 0xFF |                                        |                   |
+------+                                        +-------------------+

]]></artwork>
          </artset>
        </figure>
        <t><xref target="fig-inner-outer"/> shows the packet format for the OSCORE Outer header and Plaintext.</t>
        <t>In the Outer header, the original header code is hidden and replaced by a well-known value. As specified in Sections <xref target="RFC8613" section="4.1.3.5" sectionFormat="bare"/> and <xref target="RFC8613" section="4.2" sectionFormat="bare"/> of <xref target="RFC8613"/>, the original header code is replaced with POST for requests and Changed for responses, when the message does not include the Observe Option. Otherwise, the original header code is replaced with FETCH for requests and Content for responses.</t>
        <t>The first byte of the Plaintext contains the original header code, the Class E options, and, if present, the original message payload preceded by the payload marker.</t>
        <t>After that, an Authenticated Encryption with Associated Data (AEAD) algorithm encrypts the Plaintext. This also integrity-protects the Security Context parameters and, if present, any Class I options from the Outer header. The resulting ciphertext becomes the new payload of the OSCORE message, as illustrated in <xref target="fig-full-oscore"/>.</t>
        <t>As defined in <xref target="RFC5116"/>, this ciphertext is the encrypted Plaintext's concatenation with the Authentication Tag. Note that Inner Compression only affects the Plaintext before encryption. The Authentication Tag, fixed in length and uncompressed, is considered part of the cost of protection.</t>
        <t>When the CoAP message is specifically protected with the group mode of Group OSCORE (see <xref section="8" sectionFormat="of" target="I-D.ietf-core-oscore-groupcomm"/>), the ciphertext is followed by a signature, which is computed over the ciphertext and additional authenticated data. That is, in the message protected with Group OSCORE, the CoAP payload includes the ciphertext concatenated with the signature. This has no impact on the SCHC compression/decompression. That is, like in any other case, the CoAP payload of the protected message is sent as-is within the SCHC packet, following the Compression Residue (if any).</t>
        <figure anchor="fig-full-oscore">
          <name>OSCORE Message.</name>
          <artset>
            <artwork type="svg" align="center"><svg xmlns="http://www.w3.org/2000/svg" version="1.1" height="304" width="464" viewBox="0 0 464 304" class="diagram" text-anchor="middle" font-family="monospace" font-size="13px" stroke-linecap="round">
                <path d="M 112,32 L 112,112" fill="none" stroke="black"/>
                <path d="M 112,160 L 112,288" fill="none" stroke="black"/>
                <path d="M 128,32 L 128,64" fill="none" stroke="black"/>
                <path d="M 144,32 L 144,64" fill="none" stroke="black"/>
                <path d="M 168,176 L 168,208" fill="none" stroke="black"/>
                <path d="M 176,32 L 176,64" fill="none" stroke="black"/>
                <path d="M 264,32 L 264,64" fill="none" stroke="black"/>
                <path d="M 328,160 L 328,176" fill="none" stroke="black"/>
                <path d="M 368,32 L 368,64" fill="none" stroke="black"/>
                <path d="M 392,208 L 392,288" fill="none" stroke="black"/>
                <path d="M 456,64 L 456,96" fill="none" stroke="black"/>
                <path d="M 112,32 L 368,32" fill="none" stroke="black"/>
                <path d="M 112,64 L 384,64" fill="none" stroke="black"/>
                <path d="M 440,64 L 456,64" fill="none" stroke="black"/>
                <path d="M 112,96 L 384,96" fill="none" stroke="black"/>
                <path d="M 440,96 L 456,96" fill="none" stroke="black"/>
                <path d="M 112,176 L 328,176" fill="none" stroke="black"/>
                <path d="M 112,208 L 392,208" fill="none" stroke="black"/>
                <path d="M 112,288 L 392,288" fill="none" stroke="black"/>
                <g class="text">
                  <text x="84" y="52">....</text>
                  <text x="120" y="52">v</text>
                  <text x="136" y="52">t</text>
                  <text x="160" y="52">TKL</text>
                  <text x="200" y="52">new</text>
                  <text x="236" y="52">code</text>
                  <text x="304" y="52">Message</text>
                  <text x="348" y="52">ID</text>
                  <text x="72" y="68">:</text>
                  <text x="412" y="68">....</text>
                  <text x="72" y="84">:</text>
                  <text x="144" y="84">Token</text>
                  <text x="72" y="100">:</text>
                  <text x="412" y="100">....</text>
                  <text x="32" y="116">Outer</text>
                  <text x="72" y="116">:</text>
                  <text x="152" y="116">Options</text>
                  <text x="204" y="116">(IU)</text>
                  <text x="328" y="116">|</text>
                  <text x="72" y="132">:</text>
                  <text x="112" y="132">:</text>
                  <text x="328" y="132">:</text>
                  <text x="36" y="148">Header</text>
                  <text x="72" y="148">:</text>
                  <text x="112" y="148">:</text>
                  <text x="148" y="148">OSCORE</text>
                  <text x="204" y="148">Option</text>
                  <text x="328" y="148">:</text>
                  <text x="72" y="164">:</text>
                  <text x="72" y="180">:</text>
                  <text x="84" y="196">:...</text>
                  <text x="140" y="196">0xFF</text>
                  <text x="84" y="228">....</text>
                  <text x="168" y="228">Ciphertext:</text>
                  <text x="256" y="228">Encrypted</text>
                  <text x="320" y="228">Inner</text>
                  <text x="72" y="244">:</text>
                  <text x="244" y="244">Header</text>
                  <text x="288" y="244">and</text>
                  <text x="336" y="244">Payload</text>
                  <text x="32" y="260">Payload</text>
                  <text x="72" y="260">:</text>
                  <text x="224" y="260">+</text>
                  <text x="292" y="260">Authentication</text>
                  <text x="368" y="260">Tag</text>
                  <text x="84" y="276">:...</text>
                </g>
              </svg>
            </artwork>
            <artwork type="ascii-art" align="center"><![CDATA[
             +-+-+---+----------+------------+
        .... |v|t|TKL| new code | Message ID |
        :    +-+-+---+----------+------------+-- .... --+
        :    | Token                                    |
        :    +---------------------------------- .... --+
 Outer  :    | Options (IU)             |
        :    :                          :
 Header :    : OSCORE Option            :
        :    |                          |
        :    +------+-------------------+
        :... | 0xFF |
             +------+---------------------------+
        .... | Ciphertext: Encrypted Inner      |
        :    |             Header and Payload   |
Payload :    |             + Authentication Tag |
        :... |                                  |
             +----------------------------------+
]]></artwork>
          </artset>
        </figure>
        <t>The SCHC compression scheme consists of compressing both the Plaintext before encryption and the resulting OSCORE message after encryption, as shown in <xref target="fig-OSCORE-Compression"/>. Note that, since the recipient endpoint can only decrypt the Inner part of the message, that endpoint will also have to implement Inner SCHC Compression/Decompression.</t>
        <figure anchor="fig-OSCORE-Compression">
          <name>OSCORE Compression Diagram.</name>
          <artset>
            <artwork type="svg" align="center"><svg xmlns="http://www.w3.org/2000/svg" version="1.1" height="608" width="576" viewBox="0 0 576 608" class="diagram" text-anchor="middle" font-family="monospace" font-size="13px" stroke-linecap="round">
                <path d="M 8,48 L 8,128" fill="none" stroke="black"/>
                <path d="M 8,176 L 8,288" fill="none" stroke="black"/>
                <path d="M 8,352 L 8,400" fill="none" stroke="black"/>
                <path d="M 8,464 L 8,592" fill="none" stroke="black"/>
                <path d="M 24,48 L 24,80" fill="none" stroke="black"/>
                <path d="M 40,48 L 40,80" fill="none" stroke="black"/>
                <path d="M 64,192 L 64,224" fill="none" stroke="black"/>
                <path d="M 72,48 L 72,80" fill="none" stroke="black"/>
                <path d="M 72,296 L 72,344" fill="none" stroke="black"/>
                <path d="M 72,408 L 72,456" fill="none" stroke="black"/>
                <path d="M 88,464 L 88,496" fill="none" stroke="black"/>
                <path d="M 152,352 L 152,400" fill="none" stroke="black"/>
                <path d="M 160,48 L 160,80" fill="none" stroke="black"/>
                <path d="M 168,224 L 168,288" fill="none" stroke="black"/>
                <path d="M 192,496 L 192,592" fill="none" stroke="black"/>
                <path d="M 216,464 L 216,496" fill="none" stroke="black"/>
                <path d="M 224,176 L 224,192" fill="none" stroke="black"/>
                <path d="M 256,256 L 256,456" fill="none" stroke="black"/>
                <path d="M 264,48 L 264,80" fill="none" stroke="black"/>
                <path d="M 320,464 L 320,496" fill="none" stroke="black"/>
                <path d="M 344,80 L 344,112" fill="none" stroke="black"/>
                <path d="M 376,48 L 376,224" fill="none" stroke="black"/>
                <path d="M 376,288 L 376,336" fill="none" stroke="black"/>
                <path d="M 376,400 L 376,528" fill="none" stroke="black"/>
                <path d="M 440,48 L 440,80" fill="none" stroke="black"/>
                <path d="M 440,112 L 440,144" fill="none" stroke="black"/>
                <path d="M 440,232 L 440,280" fill="none" stroke="black"/>
                <path d="M 440,344 L 440,392" fill="none" stroke="black"/>
                <path d="M 464,400 L 464,432" fill="none" stroke="black"/>
                <path d="M 520,288 L 520,336" fill="none" stroke="black"/>
                <path d="M 552,144 L 552,224" fill="none" stroke="black"/>
                <path d="M 552,432 L 552,528" fill="none" stroke="black"/>
                <path d="M 568,80 L 568,112" fill="none" stroke="black"/>
                <path d="M 8,48 L 264,48" fill="none" stroke="black"/>
                <path d="M 376,48 L 440,48" fill="none" stroke="black"/>
                <path d="M 8,80 L 280,80" fill="none" stroke="black"/>
                <path d="M 328,80 L 344,80" fill="none" stroke="black"/>
                <path d="M 376,80 L 504,80" fill="none" stroke="black"/>
                <path d="M 552,80 L 568,80" fill="none" stroke="black"/>
                <path d="M 8,112 L 280,112" fill="none" stroke="black"/>
                <path d="M 328,112 L 344,112" fill="none" stroke="black"/>
                <path d="M 376,112 L 504,112" fill="none" stroke="black"/>
                <path d="M 552,112 L 568,112" fill="none" stroke="black"/>
                <path d="M 376,144 L 552,144" fill="none" stroke="black"/>
                <path d="M 8,192 L 224,192" fill="none" stroke="black"/>
                <path d="M 8,224 L 168,224" fill="none" stroke="black"/>
                <path d="M 376,224 L 552,224" fill="none" stroke="black"/>
                <path d="M 176,256 L 256,256" fill="none" stroke="black"/>
                <path d="M 8,288 L 168,288" fill="none" stroke="black"/>
                <path d="M 376,288 L 520,288" fill="none" stroke="black"/>
                <path d="M 376,336 L 520,336" fill="none" stroke="black"/>
                <path d="M 8,352 L 152,352" fill="none" stroke="black"/>
                <path d="M 8,400 L 152,400" fill="none" stroke="black"/>
                <path d="M 376,400 L 464,400" fill="none" stroke="black"/>
                <path d="M 376,432 L 552,432" fill="none" stroke="black"/>
                <path d="M 8,464 L 88,464" fill="none" stroke="black"/>
                <path d="M 216,464 L 320,464" fill="none" stroke="black"/>
                <path d="M 376,464 L 552,464" fill="none" stroke="black"/>
                <path d="M 328,480 L 368,480" fill="none" stroke="black"/>
                <path d="M 8,496 L 192,496" fill="none" stroke="black"/>
                <path d="M 216,496 L 320,496" fill="none" stroke="black"/>
                <path d="M 8,528 L 192,528" fill="none" stroke="black"/>
                <path d="M 376,528 L 552,528" fill="none" stroke="black"/>
                <path d="M 8,592 L 192,592" fill="none" stroke="black"/>
                <polygon class="arrowhead" points="448,392 436,386.4 436,397.6" fill="black" transform="rotate(90,440,392)"/>
                <polygon class="arrowhead" points="448,280 436,274.4 436,285.6" fill="black" transform="rotate(90,440,280)"/>
                <polygon class="arrowhead" points="336,480 324,474.4 324,485.6" fill="black" transform="rotate(180,328,480)"/>
                <polygon class="arrowhead" points="184,256 172,250.4 172,261.6" fill="black" transform="rotate(180,176,256)"/>
                <polygon class="arrowhead" points="80,456 68,450.4 68,461.6" fill="black" transform="rotate(90,72,456)"/>
                <polygon class="arrowhead" points="80,344 68,338.4 68,349.6" fill="black" transform="rotate(90,72,344)"/>
                <g class="text">
                  <text x="48" y="36">Outer</text>
                  <text x="104" y="36">Message</text>
                  <text x="420" y="36">OSCORE</text>
                  <text x="488" y="36">Plaintext</text>
                  <text x="16" y="68">v</text>
                  <text x="32" y="68">t</text>
                  <text x="56" y="68">TKL</text>
                  <text x="96" y="68">new</text>
                  <text x="132" y="68">code</text>
                  <text x="200" y="68">Message</text>
                  <text x="244" y="68">ID</text>
                  <text x="404" y="68">code</text>
                  <text x="304" y="84">...</text>
                  <text x="528" y="84">...</text>
                  <text x="40" y="100">Token</text>
                  <text x="416" y="100">Options</text>
                  <text x="464" y="100">(E)</text>
                  <text x="304" y="116">...</text>
                  <text x="528" y="116">...</text>
                  <text x="48" y="132">Options</text>
                  <text x="100" y="132">(IU)</text>
                  <text x="224" y="132">|</text>
                  <text x="404" y="132">OxFF</text>
                  <text x="8" y="148">:</text>
                  <text x="224" y="148">:</text>
                  <text x="8" y="164">:</text>
                  <text x="44" y="164">OSCORE</text>
                  <text x="100" y="164">Option</text>
                  <text x="224" y="164">:</text>
                  <text x="416" y="164">Payload</text>
                  <text x="36" y="212">0xFF</text>
                  <text x="60" y="260">Ciphertext</text>
                  <text x="424" y="308">Inner</text>
                  <text x="468" y="308">SCHC</text>
                  <text x="448" y="324">Compression</text>
                  <text x="56" y="372">Outer</text>
                  <text x="100" y="372">SCHC</text>
                  <text x="80" y="388">Compression</text>
                  <text x="412" y="420">RuleID</text>
                  <text x="432" y="452">Compression</text>
                  <text x="512" y="452">Residue</text>
                  <text x="48" y="484">RuleID'</text>
                  <text x="268" y="484">Encryption</text>
                  <text x="416" y="500">Payload</text>
                  <text x="64" y="516">Compression</text>
                  <text x="148" y="516">Residue'</text>
                  <text x="60" y="564">Ciphertext</text>
                </g>
              </svg>
            </artwork>
            <artwork type="ascii-art" align="center"><![CDATA[
   Outer Message                                 OSCORE Plaintext
+-+-+---+----------+------------+             +-------+
|v|t|TKL| new code | Message ID |             | code  |
+-+-+---+----------+------------+-- ... --+   +-------+-------- ... --+
| Token                                   |   | Options (E)           |
+---------------------------------- ... --+   +-------+-------- ... --+
| Options (IU)             |                  | OxFF  |
:                          :                  +-------+-------------+
: OSCORE Option            :                  | Payload             |
|                          |                  |                     |
+------+-------------------+                  |                     |
| 0xFF |                                      |                     |
+------+------------+                         +---------------------+
|                   |                                 |
| Ciphertext        |<---------+                      |
|                   |          |                      v
+-------------------+          |              +-----------------+
        |                      |              |   Inner SCHC    |
        |                      |              |   Compression   |
        v                      |              +-----------------+
+-----------------+            |                      |
|   Outer SCHC    |            |                      |
|   Compression   |            |                      v
+-----------------+            |              +----------+
        |                      |              | RuleID   |
        |                      |              +----------+----------+
        v                      |              | Compression Residue |
+---------+               +------------+      +---------------------+
| RuleID' |               | Encryption |<-----|                     |
+---------+------------+  +------------+      | Payload             |
| Compression Residue' |                      |                     |
+----------------------+                      +---------------------+
|                      |
| Ciphertext           |
|                      |
+----------------------+
]]></artwork>
          </artset>
        </figure>
        <t>The OSCORE message translates into a segmented process where SCHC compression is applied independently in two stages, each with its corresponding set of Rules, i.e., the Inner SCHC Rules and the Outer SCHC Rules. By doing so, compression is applied to all the fields of the original CoAP message.</t>
        <t>As to the compression of the 0xFF payload marker, the same rationale described in <xref target="payload-marker"/> applies to both the Inner SCHC Compression and the Outer SCHC Compression. That is:</t>
        <ul spacing="normal">
          <li>
            <t>After the Inner SCHC Compression of a CoAP message including a payload, the payload marker <bcp14>MUST NOT</bcp14> be included in the input to the AEAD Encryption, which is composed of the Inner Compression RuleID, the Inner Compression Residue (if any), and the CoAP payload.</t>
          </li>
          <li>
            <t>The Outer SCHC Compression takes as input the OSCORE-protected message, which always includes a payload (i.e., the OSCORE Ciphertext) preceded by the payload marker.</t>
          </li>
          <li>
            <t>After the Outer SCHC Compression, the payload marker <bcp14>MUST NOT</bcp14> be included in the final compressed message, which is composed of the Outer Compression RuleID, the Outer Compression Residue (if any), and the OSCORE Ciphertext.</t>
          </li>
        </ul>
        <t>After having completed the Outer SCHC Decompression of an incoming message, the recipient endpoint <bcp14>MUST</bcp14> prepend the 0xFF payload marker to the OSCORE Ciphertext.</t>
        <t>After having completed the Inner SCHC Decompression of an incoming message, the recipient endpoint <bcp14>MUST</bcp14> prepend the 0xFF payload marker to the CoAP payload, if any was present after the consumed Compression Residue.</t>
      </section>
      <section anchor="example-oscore-compression">
        <name>Example OSCORE Compression</name>
        <t>This section provides an example with a GET request and a corresponding Content response, exchanged between a Device-based CoAP client and a cloud-based CoAP server. The example also describes a possible set of Rules for Inner SCHC Compression and Outer SCHC Compression. A dump of the results and a contrast between SCHC + OSCORE performance and SCHC + CoAP performance are also listed. This example shows an estimate of the cost of security with SCHC-OSCORE.</t>
        <t>Our first CoAP message is the GET request in <xref target="fig-GET-temp"/>.</t>
        <figure anchor="fig-GET-temp">
          <name>CoAP GET Request.</name>
          <artwork><![CDATA[
Original message:
=================
0x4101000182bb74656d7065726174757265

Header:
0x4101
01   Ver
  00   CON
    0001   TKL
        00000001   Request Code 1 (GET)

0x0001   MID
0x82   Token

Options:

0xbb74656d7065726174757265
Option 11: Uri-Path
Value = "temperature"

Original message length: 17 bytes
]]></artwork>
        </figure>
        <t>Its corresponding response is the Content response in <xref target="fig-CONTENT-temp"/>.</t>
        <figure anchor="fig-CONTENT-temp">
          <name>CoAP Content Response.</name>
          <artwork><![CDATA[
Original message:
=================
0x6145000182ff32332043

Header:
0x6145
01   Ver
  10   ACK
    0001   TKL
        01000101 Successful Response Code 69 (2.05 Content)

0x0001   MID
0x82   Token

0xFF  Payload marker

Payload:
0x32332043

Original message length: 10 bytes
]]></artwork>
        </figure>
        <t>The SCHC Rules for the Inner Compression include all the fields that are present in a regular CoAP message. The methods described in <xref target="sec-coap-fields-compression"/> apply to these fields. <xref target="_table-Inner-Rules"/> provides an example.</t>
        <artwork><![CDATA[
 +----------+
 | RuleID 0 |
 +----------+
]]></artwork>
        <table align="center" anchor="_table-Inner-Rules">
          <name>Inner SCHC Rule. CoAP Option Numbers: 11 (Uri-Path).</name>
          <thead>
            <tr>
              <th align="left">FID</th>
              <th align="left">FL</th>
              <th align="left">FP</th>
              <th align="left">DI</th>
              <th align="left">TV</th>
              <th align="left">MO</th>
              <th align="left">CDA</th>
              <th align="left">Sent 
 [bits]</th>
            </tr>
          </thead>
          <tbody>
            <tr>
              <td align="left">CoAP.<br/>Code</td>
              <td align="left">8</td>
              <td align="left">1</td>
              <td align="left">Up</td>
              <td align="left">1</td>
              <td align="left">equal</td>
              <td align="left">not-sent</td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">CoAP.<br/>Code</td>
              <td align="left">8</td>
              <td align="left">1</td>
              <td align="left">Dw</td>
              <td align="left">[69, 132]</td>
              <td align="left">match- <br/> mapping</td>
              <td align="left">mapping- <br/> sent</td>
              <td align="left">C</td>
            </tr>
            <tr>
              <td align="left">CoAP.<br/>option(11)</td>
              <td align="left"> </td>
              <td align="left">1</td>
              <td align="left">Up</td>
              <td align="left">"temperature"</td>
              <td align="left">equal</td>
              <td align="left">not-sent</td>
              <td align="left"> </td>
            </tr>
          </tbody>
        </table>
        <t><xref target="fig-Inner-Compression-GET"/> shows the Plaintext obtained for the example GET request. The packet follows the process of Inner Compression and encryption until the payload. The Outer OSCORE message adds the result of the Inner process.</t>
        <figure anchor="fig-Inner-Compression-GET">
          <name>Plaintext Compression and Encryption for GET Request.</name>
          <artset>
            <artwork type="svg" align="center"><svg xmlns="http://www.w3.org/2000/svg" version="1.1" height="656" width="432" viewBox="0 0 432 656" class="diagram" text-anchor="middle" font-family="monospace" font-size="13px" stroke-linecap="round">
                <path d="M 8,32 L 8,208" fill="none" stroke="black"/>
                <path d="M 48,528 L 48,640" fill="none" stroke="black"/>
                <path d="M 120,288 L 120,432" fill="none" stroke="black"/>
                <path d="M 232,216 L 232,280" fill="none" stroke="black"/>
                <path d="M 232,440 L 232,520" fill="none" stroke="black"/>
                <path d="M 336,288 L 336,432" fill="none" stroke="black"/>
                <path d="M 424,32 L 424,208" fill="none" stroke="black"/>
                <path d="M 424,528 L 424,640" fill="none" stroke="black"/>
                <path d="M 8,32 L 424,32" fill="none" stroke="black"/>
                <path d="M 8,208 L 424,208" fill="none" stroke="black"/>
                <path d="M 120,288 L 336,288" fill="none" stroke="black"/>
                <path d="M 120,432 L 336,432" fill="none" stroke="black"/>
                <path d="M 48,528 L 424,528" fill="none" stroke="black"/>
                <path d="M 48,640 L 424,640" fill="none" stroke="black"/>
                <polygon class="arrowhead" points="240,520 228,514.4 228,525.6" fill="black" transform="rotate(90,232,520)"/>
                <polygon class="arrowhead" points="240,280 228,274.4 228,285.6" fill="black" transform="rotate(90,232,280)"/>
                <g class="text">
                  <text x="44" y="68">OSCORE</text>
                  <text x="112" y="68">Plaintext</text>
                  <text x="132" y="100">0x01bb74656d7065726174757265</text>
                  <text x="272" y="100">(13</text>
                  <text x="316" y="100">bytes)</text>
                  <text x="36" y="132">0x01</text>
                  <text x="88" y="132">Request</text>
                  <text x="140" y="132">Code</text>
                  <text x="176" y="132">GET</text>
                  <text x="156" y="164">bb74656d7065726174757265</text>
                  <text x="284" y="164">Option</text>
                  <text x="328" y="164">11:</text>
                  <text x="380" y="164">Uri-Path</text>
                  <text x="280" y="180">Value</text>
                  <text x="312" y="180">=</text>
                  <text x="368" y="180">temperature</text>
                  <text x="264" y="244">Inner</text>
                  <text x="308" y="244">SCHC</text>
                  <text x="376" y="244">Compression</text>
                  <text x="172" y="324">Compressed</text>
                  <text x="256" y="324">Plaintext</text>
                  <text x="148" y="356">0x00</text>
                  <text x="156" y="388">RuleID</text>
                  <text x="192" y="388">=</text>
                  <text x="220" y="388">0x00</text>
                  <text x="252" y="388">(1</text>
                  <text x="288" y="388">byte)</text>
                  <text x="144" y="404">(No</text>
                  <text x="208" y="404">Compression</text>
                  <text x="292" y="404">Residue)</text>
                  <text x="260" y="468">AEAD</text>
                  <text x="324" y="468">Encryption</text>
                  <text x="268" y="484">(piv</text>
                  <text x="296" y="484">=</text>
                  <text x="328" y="484">0x04)</text>
                  <text x="144" y="564">encrypted_plaintext</text>
                  <text x="232" y="564">=</text>
                  <text x="260" y="564">0xa2</text>
                  <text x="292" y="564">(1</text>
                  <text x="328" y="564">byte)</text>
                  <text x="80" y="580">tag</text>
                  <text x="104" y="580">=</text>
                  <text x="188" y="580">0xc54fe1b434297b62</text>
                  <text x="276" y="580">(8</text>
                  <text x="316" y="580">bytes)</text>
                  <text x="108" y="612">ciphertext</text>
                  <text x="160" y="612">=</text>
                  <text x="252" y="612">0xa2c54fe1b434297b62</text>
                  <text x="348" y="612">(9</text>
                  <text x="388" y="612">bytes)</text>
                </g>
              </svg>
            </artwork>
            <artwork type="ascii-art" align="center"><![CDATA[
+---------------------------------------------------+
|                                                   |
| OSCORE Plaintext                                  |
|                                                   |
| 0x01bb74656d7065726174757265  (13 bytes)          |
|                                                   |
| 0x01 Request Code GET                             |
|                                                   |
|      bb74656d7065726174757265 Option 11: Uri-Path |
|                               Value = temperature |
|                                                   |
+---------------------------------------------------+
                            |
                            | Inner SCHC Compression
                            |
                            v
              +--------------------------+
              |                          |
              | Compressed Plaintext     |
              |                          |
              | 0x00                     |
              |                          |
              | RuleID = 0x00 (1 byte)   |
              | (No Compression Residue) |
              |                          |
              +--------------------------+
                            |
                            | AEAD Encryption
                            |  (piv = 0x04)
                            |
                            v
     +----------------------------------------------+
     |                                              |
     |  encrypted_plaintext = 0xa2 (1 byte)         |
     |  tag = 0xc54fe1b434297b62 (8 bytes)          |
     |                                              |
     |  ciphertext = 0xa2c54fe1b434297b62 (9 bytes) |
     |                                              |
     +----------------------------------------------+
]]></artwork>
          </artset>
        </figure>
        <t>In this case, the original message has no payload and its resulting Plaintext is compressed up to only 1 byte (the size of the RuleID). The AEAD algorithm preserves this length in its first output and yields a fixed-size tag. SCHC cannot compress the tag, and the OSCORE message must include it without compression. The use of integrity protection translates into an overhead on the total message length, thus limiting the amount of compression that can be achieved and contributing to the cost of applying security to the message exchange.</t>
        <t><xref target="fig-Inner-Compression-CONTENT"/> shows the process for the example Content response. The Compression Residue is 1 bit long. Note that since SCHC adds padding after the payload, this misalignment causes the hexadecimal code from the payload to differ from the original, even if SCHC cannot compress the tag. The overhead for the tag bytes limits SCHC's performance but adds security to the message exchange.</t>
        <figure anchor="fig-Inner-Compression-CONTENT">
          <name>Plaintext Compression and Encryption for Content Response</name>
          <artset>
            <artwork type="svg" align="center"><svg xmlns="http://www.w3.org/2000/svg" version="1.1" height="720" width="488" viewBox="0 0 488 720" class="diagram" text-anchor="middle" font-family="monospace" font-size="13px" stroke-linecap="round">
                <path d="M 8,32 L 8,224" fill="none" stroke="black"/>
                <path d="M 16,304 L 16,496" fill="none" stroke="black"/>
                <path d="M 16,592 L 16,704" fill="none" stroke="black"/>
                <path d="M 232,232 L 232,296" fill="none" stroke="black"/>
                <path d="M 232,504 L 232,584" fill="none" stroke="black"/>
                <path d="M 408,32 L 408,224" fill="none" stroke="black"/>
                <path d="M 408,304 L 408,496" fill="none" stroke="black"/>
                <path d="M 480,592 L 480,704" fill="none" stroke="black"/>
                <path d="M 8,32 L 408,32" fill="none" stroke="black"/>
                <path d="M 8,224 L 408,224" fill="none" stroke="black"/>
                <path d="M 16,304 L 408,304" fill="none" stroke="black"/>
                <path d="M 16,496 L 408,496" fill="none" stroke="black"/>
                <path d="M 16,592 L 480,592" fill="none" stroke="black"/>
                <path d="M 16,704 L 480,704" fill="none" stroke="black"/>
                <polygon class="arrowhead" points="240,584 228,578.4 228,589.6" fill="black" transform="rotate(90,232,584)"/>
                <polygon class="arrowhead" points="240,296 228,290.4 228,301.6" fill="black" transform="rotate(90,232,296)"/>
                <g class="text">
                  <text x="44" y="68">OSCORE</text>
                  <text x="112" y="68">Plaintext</text>
                  <text x="76" y="100">0x45ff32332043</text>
                  <text x="156" y="100">(6</text>
                  <text x="196" y="100">bytes)</text>
                  <text x="36" y="132">0x45</text>
                  <text x="100" y="132">Successful</text>
                  <text x="180" y="132">Response</text>
                  <text x="236" y="132">Code</text>
                  <text x="268" y="132">69</text>
                  <text x="304" y="132">"2.05</text>
                  <text x="364" y="132">Content"</text>
                  <text x="60" y="164">ff</text>
                  <text x="104" y="164">Payload</text>
                  <text x="164" y="164">marker</text>
                  <text x="100" y="196">32332043</text>
                  <text x="168" y="196">Payload</text>
                  <text x="264" y="260">Inner</text>
                  <text x="308" y="260">SCHC</text>
                  <text x="376" y="260">Compression</text>
                  <text x="68" y="340">Compressed</text>
                  <text x="152" y="340">Plaintext</text>
                  <text x="84" y="372">0x001919902180</text>
                  <text x="156" y="372">(6</text>
                  <text x="196" y="372">bytes)</text>
                  <text x="52" y="404">00</text>
                  <text x="92" y="404">RuleID</text>
                  <text x="48" y="436">0b0</text>
                  <text x="76" y="436">(1</text>
                  <text x="104" y="436">bit</text>
                  <text x="176" y="436">match-mapping</text>
                  <text x="280" y="436">Compression</text>
                  <text x="364" y="436">Residue)</text>
                  <text x="116" y="452">0x32332043</text>
                  <text x="172" y="452">&gt;&gt;</text>
                  <text x="192" y="452">1</text>
                  <text x="236" y="452">(shifted</text>
                  <text x="308" y="452">payload)</text>
                  <text x="248" y="468">0b0000000</text>
                  <text x="320" y="468">Padding</text>
                  <text x="260" y="532">AEAD</text>
                  <text x="324" y="532">Encryption</text>
                  <text x="268" y="548">(piv</text>
                  <text x="296" y="548">=</text>
                  <text x="328" y="548">0x04)</text>
                  <text x="112" y="628">encrypted_plaintext</text>
                  <text x="200" y="628">=</text>
                  <text x="268" y="628">0x10c6d7c26cc1</text>
                  <text x="340" y="628">(6</text>
                  <text x="380" y="628">bytes)</text>
                  <text x="48" y="644">tag</text>
                  <text x="72" y="644">=</text>
                  <text x="156" y="644">0xe9aef3f2461e0c29</text>
                  <text x="244" y="644">(8</text>
                  <text x="284" y="644">bytes)</text>
                  <text x="76" y="676">ciphertext</text>
                  <text x="128" y="676">=</text>
                  <text x="260" y="676">0x10c6d7c26cc1e9aef3f2461e0c29</text>
                  <text x="400" y="676">(14</text>
                  <text x="444" y="676">bytes)</text>
                </g>
              </svg>
            </artwork>
            <artwork type="ascii-art" align="center"><![CDATA[
+-------------------------------------------------+
|                                                 |
| OSCORE Plaintext                                |
|                                                 |
| 0x45ff32332043  (6 bytes)                       |
|                                                 |
| 0x45 Successful Response Code 69 "2.05 Content" |
|                                                 |
|     ff Payload marker                           |
|                                                 |
|       32332043 Payload                          |
|                                                 |
+-------------------------------------------------+
                            |
                            | Inner SCHC Compression
                            |
                            v
 +------------------------------------------------+
 |                                                |
 | Compressed Plaintext                           |
 |                                                |
 | 0x001919902180 (6 bytes)                       |
 |                                                |
 |   00 RuleID                                    |
 |                                                |
 |  0b0 (1 bit match-mapping Compression Residue) |
 |       0x32332043 >> 1 (shifted payload)        |
 |                        0b0000000 Padding       |
 |                                                |
 +------------------------------------------------+
                            |
                            | AEAD Encryption
                            |  (piv = 0x04)
                            |
                            v
 +---------------------------------------------------------+
 |                                                         |
 |  encrypted_plaintext = 0x10c6d7c26cc1 (6 bytes)         |
 |  tag = 0xe9aef3f2461e0c29 (8 bytes)                     |
 |                                                         |
 |  ciphertext = 0x10c6d7c26cc1e9aef3f2461e0c29 (14 bytes) |
 |                                                         |
 +---------------------------------------------------------+
]]></artwork>
          </artset>
        </figure>
        <t>The Outer SCHC Rule shown in <xref target="_table-Outer-Rules"/> is used, also to process the OSCORE Option fields. <xref target="fig-Protected-Compressed-GET"/> and <xref target="fig-Protected-Compressed-CONTENT"/> show a dump of the OSCORE messages generated from the example messages, also including the Inner Compressed ciphertext in the payload. These are the messages that have to be compressed via the Outer SCHC Compression scheme.</t>
        <t><xref target="_table-Outer-Rules"/> shows a possible set of Outer Rule items to compress the Outer header.</t>
        <artwork><![CDATA[
+----------+
| RuleID 1 |
+----------+
]]></artwork>
        <table align="center" anchor="_table-Outer-Rules">
          <name>Outer SCHC Rule. CoAP Option Numbers: 9 (OSCORE).</name>
          <thead>
            <tr>
              <th align="left">FID</th>
              <th align="left">FL</th>
              <th align="left">FP</th>
              <th align="left">DI</th>
              <th align="left">TV</th>
              <th align="left">MO</th>
              <th align="left">CDA</th>
              <th align="left">Sent 
 [bits]</th>
            </tr>
          </thead>
          <tbody>
            <tr>
              <td align="left">CoAP.<br/>Version</td>
              <td align="left">2</td>
              <td align="left">1</td>
              <td align="left">Bi</td>
              <td align="left">1</td>
              <td align="left">equal</td>
              <td align="left">not- <br/> sent</td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">CoAP.<br/>Type</td>
              <td align="left">2</td>
              <td align="left">1</td>
              <td align="left">Up</td>
              <td align="left">0</td>
              <td align="left">equal</td>
              <td align="left">not- <br/> sent</td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">CoAP.<br/>Type</td>
              <td align="left">2</td>
              <td align="left">1</td>
              <td align="left">Dw</td>
              <td align="left">2</td>
              <td align="left">equal</td>
              <td align="left">not- <br/> sent</td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">CoAP.<br/>TKL</td>
              <td align="left"> </td>
              <td align="left">1</td>
              <td align="left">Bi</td>
              <td align="left">0b0001</td>
              <td align="left">equal</td>
              <td align="left">not- <br/> sent</td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">CoAP.<br/>Code</td>
              <td align="left">8</td>
              <td align="left">1</td>
              <td align="left">Up</td>
              <td align="left">2</td>
              <td align="left">equal</td>
              <td align="left">not- <br/> sent</td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">CoAP.<br/>Code</td>
              <td align="left">8</td>
              <td align="left">1</td>
              <td align="left">Dw</td>
              <td align="left">68</td>
              <td align="left">equal</td>
              <td align="left">not- <br/> sent</td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">CoAP.<br/>MID</td>
              <td align="left">16</td>
              <td align="left">1</td>
              <td align="left">Bi</td>
              <td align="left">0x0000</td>
              <td align="left">MSB(12)</td>
              <td align="left">LSB</td>
              <td align="left">MMMM</td>
            </tr>
            <tr>
              <td align="left">CoAP.<br/>Token</td>
              <td align="left">tkl</td>
              <td align="left">1</td>
              <td align="left">Bi</td>
              <td align="left">0x80</td>
              <td align="left">MSB(5)</td>
              <td align="left">LSB</td>
              <td align="left">TTT</td>
            </tr>
            <tr>
              <td align="left">CoAP.<br/>option(9).<br/>flags</td>
              <td align="left"> </td>
              <td align="left">1</td>
              <td align="left">Up</td>
              <td align="left">0x09</td>
              <td align="left">equal</td>
              <td align="left">not- <br/> sent</td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">CoAP.<br/>option(9).<br/>flags</td>
              <td align="left"> </td>
              <td align="left">1</td>
              <td align="left">Dw</td>
              <td align="left">b''</td>
              <td align="left">equal</td>
              <td align="left">not- <br/> sent</td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">CoAP.<br/>option(9).<br/>piv</td>
              <td align="left">osc.piv</td>
              <td align="left">1</td>
              <td align="left">Up</td>
              <td align="left">0x00</td>
              <td align="left">MSB(4)</td>
              <td align="left">LSB</td>
              <td align="left">PPPP</td>
            </tr>
            <tr>
              <td align="left">CoAP.<br/>option(9).<br/>piv</td>
              <td align="left"> </td>
              <td align="left">1</td>
              <td align="left">Dw</td>
              <td align="left">b''</td>
              <td align="left">equal</td>
              <td align="left">not- <br/> sent</td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">CoAP.<br/>option(9).<br/>kid_ctx</td>
              <td align="left"> </td>
              <td align="left">1</td>
              <td align="left">Bi</td>
              <td align="left">b''</td>
              <td align="left">equal</td>
              <td align="left">not- <br/> sent</td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">CoAP.<br/>option(9).<br/>x</td>
              <td align="left">8</td>
              <td align="left">1</td>
              <td align="left">Bi</td>
              <td align="left">b''</td>
              <td align="left">equal</td>
              <td align="left">not- <br/> sent</td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">CoAP.<br/>option(9).<br/>nonce</td>
              <td align="left"> </td>
              <td align="left">1</td>
              <td align="left">Bi</td>
              <td align="left">b''</td>
              <td align="left">equal</td>
              <td align="left">not- <br/> sent</td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">CoAP.<br/>option(9).<br/>kid</td>
              <td align="left">var_bit</td>
              <td align="left">1</td>
              <td align="left">Up</td>
              <td align="left">0x636c69 <br/> 656e70</td>
              <td align="left">MSB(44)</td>
              <td align="left">LSB</td>
              <td align="left">KKKK</td>
            </tr>
            <tr>
              <td align="left">CoAP.<br/>option(9).<br/>kid</td>
              <td align="left"> </td>
              <td align="left">1</td>
              <td align="left">Dw</td>
              <td align="left">b''</td>
              <td align="left">equal</td>
              <td align="left">not- <br/> sent</td>
              <td align="left"> </td>
            </tr>
          </tbody>
        </table>
        <figure anchor="fig-Protected-Compressed-GET">
          <name>Protected and Inner SCHC Compressed GET Request.</name>
          <artwork><![CDATA[
Protected message:
==================
0x4102000182980904636c69656e74ffa2c54fe1b434297b62
(24 bytes)

Header:
0x4102
01   Ver
  00   CON
    0001   TKL
        00000010   Request Code 2 (POST)

0x0001   MID
0x82   Token

Options:

0x98 0904636c69656e74 (9 bytes)
Option 9: OSCORE
Value = 0x0904636c69656e74
          09 = 000 0 1 001 flags
                   h k  n
            04 piv
              636c69656e74 kid

0xFF  Payload marker

Payload:
0xa2c54fe1b434297b62 (9 bytes)
]]></artwork>
        </figure>
        <figure anchor="fig-Protected-Compressed-CONTENT">
          <name>Protected and Inner SCHC Compressed Content Response.</name>
          <artwork><![CDATA[
Protected message:
==================
0x614400018290ff10c6d7c26cc1e9aef3f2461e0c29
(21 bytes)

Header:
0x6144
01   Ver
  10   ACK
    0001   TKL
        01000100   Successful Response Code 68 (2.04 Changed)

0x0001   MID
0x82   Token

Options:

0x90 (1 byte)
Option 9: OSCORE
Value = 0x (empty)

0xFF  Payload marker

Payload:
0x10c6d7c26cc1e9aef3f2461e0c29 (14 bytes)
]]></artwork>
        </figure>
        <t>For the flag bits, some SCHC compression methods are useful, depending on the application. The most straightforward alternative is to provide a fixed value for the flags, combining an "equal" MO and a "not-sent" CDA. This SCHC description saves most bits but could prevent flexibility. Otherwise, SCHC could use a "match-mapping" MO to choose from several configurations for the exchange. If not, the SCHC description may use an MSB MO to mask off the three hard-coded most significant bits.</t>
        <t>Note that fixing a flag bit will limit the possible OSCORE options that can be used in the exchange, since the value of the flag bits plays a role in determining a specific OSCORE option.</t>
        <t>The piv field lends itself to having some bits masked off with an MSB MO and an LSB CDA. This SCHC description could be useful in applications where the message transmission frequency is low, such as with LPWAN technologies. Note that compressing the piv field may reduce the maximum number of sequence numbers that can be used in an exchange. Once the sequence number exceeds the maximum value, the OSCORE keys need to be re-established.</t>
        <t>The size, s, that is included in the kid_ctx field <bcp14>MAY</bcp14> be masked off with an LSB CDA. The rest of the kid_ctx field could have additional bits masked off, or the whole field could be fixed in accordance with an "equal" MO and a "not-sent" CDA. The same holds for the kid field.</t>
        <t>The Outer Rule of <xref target="_table-Outer-Rules"/> is applied to the example GET request and Content response. <xref target="fig-Compressed-GET"/> and <xref target="fig-Compressed-CONTENT"/> show the resulting messages.</t>
        <figure anchor="fig-Compressed-GET">
          <name>SCHC-OSCORE Compressed GET Request.</name>
          <artwork><![CDATA[
Compressed message:
==================
0x0114889458a9fc3686852f6c40 (13 bytes)
0x01 RuleID
    148894 compression residue
          58a9fc3686852f6c40 padded payload

Compression Residue:
0b0001   010 0100  0100 0100
   MID Token  piv   kid (residue size and residue)

  (19 bits -> 3 bytes with padding)

Payload
0xa2c54fe1b434297b62 (9 bytes)

Compressed message length: 13 bytes
]]></artwork>
        </figure>
        <figure anchor="fig-Compressed-CONTENT">
          <name>SCHC-OSCORE Compressed Content Response.</name>
          <artwork><![CDATA[
Compressed message:
==================
0x0114218daf84d983d35de7e48c3c1852 (16 bytes)
0x01 RuleID
    14 Compression Residue
      218daf84d983d35de7e48c3c1852 Padded payload

Compression Residue:
0b0001   010 (7 bits -> 1 byte with padding)
   MID Token

Payload
0x10c6d7c26cc1e9aef3f2461e0c29 (14 bytes)
]]></artwork>
        </figure>
        <t>In contrast, the following compares these results with what would be obtained by SCHC compressing the original CoAP messages without protecting them with OSCORE, according to the SCHC Rule in <xref target="_table-NoOsc-Rules"/>.</t>
        <artwork><![CDATA[
+----------+
| RuleID 2 |
+----------+
]]></artwork>
        <table align="center" anchor="_table-NoOsc-Rules">
          <name>SCHC-CoAP Rule (No OSCORE). CoAP Option Numbers: 11 (Uri-Path).</name>
          <thead>
            <tr>
              <th align="left">FID</th>
              <th align="left">FL</th>
              <th align="left">FP</th>
              <th align="left">DI</th>
              <th align="left">TV</th>
              <th align="left">MO</th>
              <th align="left">CDA</th>
              <th align="left">Sent 
 [bits]</th>
            </tr>
          </thead>
          <tbody>
            <tr>
              <td align="left">CoAP.<br/>Version</td>
              <td align="left">2</td>
              <td align="left">1</td>
              <td align="left">Bi</td>
              <td align="left">1</td>
              <td align="left">equal</td>
              <td align="left">not-sent</td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">CoAP.<br/>Type</td>
              <td align="left">2</td>
              <td align="left">1</td>
              <td align="left">Up</td>
              <td align="left">0</td>
              <td align="left">equal</td>
              <td align="left">not-sent</td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">CoAP.<br/>Type</td>
              <td align="left">2</td>
              <td align="left">1</td>
              <td align="left">Dw</td>
              <td align="left">2</td>
              <td align="left">equal</td>
              <td align="left">not-sent</td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">CoAP.<br/>TKL</td>
              <td align="left"> </td>
              <td align="left">1</td>
              <td align="left">Bi</td>
              <td align="left">0b0001</td>
              <td align="left">equal</td>
              <td align="left">not-sent</td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">CoAP.<br/>Code</td>
              <td align="left">8</td>
              <td align="left">1</td>
              <td align="left">Up</td>
              <td align="left">2</td>
              <td align="left">equal</td>
              <td align="left">not-sent</td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">CoAP.<br/>Code</td>
              <td align="left">8</td>
              <td align="left">1</td>
              <td align="left">Dw</td>
              <td align="left">[69, 132]</td>
              <td align="left">match- <br/> mapping</td>
              <td align="left">mapping- <br/> sent</td>
              <td align="left">C</td>
            </tr>
            <tr>
              <td align="left">CoAP.<br/>MID</td>
              <td align="left">16</td>
              <td align="left">1</td>
              <td align="left">Bi</td>
              <td align="left">0x0000</td>
              <td align="left">MSB(12)</td>
              <td align="left">LSB</td>
              <td align="left">MMMM</td>
            </tr>
            <tr>
              <td align="left">CoAP.<br/>Token</td>
              <td align="left">tkl</td>
              <td align="left">1</td>
              <td align="left">Bi</td>
              <td align="left">0x80</td>
              <td align="left">MSB(5)</td>
              <td align="left">LSB</td>
              <td align="left">TTT</td>
            </tr>
            <tr>
              <td align="left">CoAP.<br/>option(11)</td>
              <td align="left"> </td>
              <td align="left">1</td>
              <td align="left">Up</td>
              <td align="left">"temperature"</td>
              <td align="left">equal</td>
              <td align="left">not-sent</td>
              <td align="left"> </td>
            </tr>
          </tbody>
        </table>
        <t>The Rule in <xref target="_table-NoOsc-Rules"/> yields the SCHC compression results shown in <xref target="fig-GET-temp-no-oscore"/> for the request and in <xref target="fig-CONTENT-temp-no-oscore"/> for the response.</t>
        <figure anchor="fig-GET-temp-no-oscore">
          <name>CoAP GET Compressed without OSCORE.</name>
          <artwork><![CDATA[
Compressed message:
==================
0x0214
0x02 = RuleID

Compression Residue:
0b00010100 (1 byte)

Compressed message length: 2 bytes
]]></artwork>
        </figure>
        <figure anchor="fig-CONTENT-temp-no-oscore">
          <name>CoAP Content Compressed without OSCORE.</name>
          <artwork><![CDATA[
Compressed message:
==================
0x020a32332043
0x02 = RuleID

Compression Residue:
0b00001010 (1 byte)

Payload
0x32332043

Compressed message length: 6 bytes
]]></artwork>
        </figure>
        <t>As it can be seen, the difference between applying SCHC + OSCORE as compared to regular SCHC + CoAP is about 10 bytes.</t>
      </section>
    </section>
    <section anchor="compression-with-proxies">
      <name>CoAP Header Compression with Proxies</name>
      <t>This section defines how SCHC Compression/Decompression is performed when CoAP proxies are deployed. The following refers to the origin client and origin server as application endpoints.</t>
      <t>Note that SCHC Compression/Decompression of CoAP headers is not necessarily used between each pair of hops in the communication chain. For example, if a proxy is deployed between an origin client and an origin server, SCHC might be used on the communication leg between the origin client and the proxy, but not on the communication leg between the proxy and the origin server.</t>
      <section anchor="compression-with-proxies-without-oscore">
        <name>Without End-to-End Security</name>
        <t>In case OSCORE is not used end-to-end between client and server, the SCHC processing occurs hop-by-hop, by relying on SCHC Rules that are consistently shared between two adjacent hops.</t>
        <t>In particular, SCHC is used as defined below.</t>
        <ul spacing="normal">
          <li>
            <t>The sender application endpoint compresses the CoAP message, by using the SCHC Rules that it shares with the next hop towards the recipient application endpoint. The resulting, compressed message is sent to the next hop towards the recipient application endpoint.</t>
          </li>
          <li>
            <t>Each proxy decompresses the incoming compressed message, by using the SCHC Rules that it shares with the (previous hop towards the) sender application endpoint.  </t>
            <t>
Then, the proxy compresses the CoAP message to be forwarded, by using the SCHC Rules that it shares with the (next hop towards the) recipient application endpoint.  </t>
            <t>
The resulting, compressed message is sent to the (next hop towards the) recipient application endpoint.</t>
          </li>
          <li>
            <t>The recipient application endpoint decompresses the incoming compressed message, by using the SCHC Rules that it shares with the previous hop towards the sender application endpoint.</t>
          </li>
        </ul>
      </section>
      <section anchor="compression-with-proxies-with-oscore">
        <name>With End-to-End Security</name>
        <t>In case OSCORE is used end-to-end between client and server (see <xref target="ssec-examples-oscore"/>), the following applies.</t>
        <t>The SCHC processing occurs end-to-end as to the Inner SCHC Compression/Decompression, by relying on Inner SCHC Rules that are consistently shared between the two application endpoints acting as OSCORE endpoints and sharing the used OSCORE Security Context.</t>
        <t>Instead, the SCHC processing occurs hop-by-hop as to the Outer SCHC Compression/Decompression, by relying on Outer SCHC Rules that are consistently shared between two adjacent hops.</t>
        <t>In particular, SCHC is used as defined below.</t>
        <ul spacing="normal">
          <li>
            <t>The sender application endpoint performs the Inner SCHC Compression on the original CoAP message, by using the Inner SCHC Rules that it shares with the recipient application endpoint.  </t>
            <t>
Following the AEAD Encryption of the compressed input obtained from the previous step, the sender application endpoint performs the Outer SCHC Compression on the resulting OSCORE-protected message, by using the Outer SCHC Rules that it shares with the next hop towards the recipient application endpoint.  </t>
            <t>
The resulting, compressed message is sent to the next hop towards the recipient application endpoint.</t>
          </li>
          <li>
            <t>Each proxy performs the Outer SCHC Decompression on the incoming compressed message, by using the SCHC Rules that it shares with the (previous hop towards the) sender application endpoint.  </t>
            <t>
Then, the proxy performs the Outer SCHC Compression of the OSCORE-protected message to be forwarded, by using the SCHC Rules that it shares with the (next hop towards the) recipient application endpoint.  </t>
            <t>
The resulting, compressed message is sent to the (next hop towards the) recipient application endpoint.</t>
          </li>
          <li>
            <t>The recipient application endpoint performs the Outer SCHC Decompression on the incoming compressed message, by using the Outer SCHC Rules that it shares with the previous hop towards the sender application endpoint.  </t>
            <t>
Then, the recipient application endpoint performs the AEAD Decryption of the OSCORE-protected message obtained from the previous step.  </t>
            <t>
Finally, the recipient application endpoint performs the Inner SCHC Decompression on the compressed input obtained from the previous step, by using the Inner SCHC Rules that it shares with the sender application endpoint. The result is the original CoAP message produced by the sender application endpoint.</t>
          </li>
        </ul>
      </section>
    </section>
    <section anchor="examples">
      <name>Examples of CoAP Header Compression with Proxies</name>
      <t>This section provides examples of SCHC Compression/Decompression in the presence of a CoAP proxy.</t>
      <t>The presented examples refer to the same deployment considered in <xref target="sec-applicability-to-coap"/>, including a Device communicating over LPWAN with a Network Gateway (NGW), which in turn communicates with an Application Server over the Internet. The Application Server and the Device exchange CoAP messages through the NGW.</t>
      <t>The following also applies in the presented examples.</t>
      <ul spacing="normal">
        <li>
          <t>CoAP request messages are sent only by the Device as targeting the Application Server (uplink traffic), which replies to the Device with corresponding CoAP response messages (downlink traffic). That is, the Device acts as CoAP client, while the Application Server acts as CoAP server.</t>
        </li>
        <li>
          <t>A CoAP proxy is co-located on the Network Gateway (NGW) deployed between the Application Server and the Device.</t>
        </li>
        <li>
          <t>SCHC is used also on the communication leg between the Application Server and the proxy.</t>
        </li>
      </ul>
      <t>Like in <xref target="sec-applicability-to-coap"/>, the presented examples focus on SCHC Compression/Decompression of CoAP headers, i.e., irrespective of possible SCHC Compression/Decompression applied to further protocol headers.</t>
      <t>The example in <xref target="examples-without-oscore"/> considers an exchange of two unprotected messages, while the example in <xref target="examples-with-oscore"/> considers an exchange of two messages protected end-to-end with OSCORE. In the examples, the character | denotes bit concatenation.</t>
      <t><xref target="fig-example-req"/> and <xref target="fig-example-resp"/> show the two CoAP messages exchanged between the Device and the Application Server via the proxy. The figures show the two messages as originally generated by the application at the two origin endpoints, i.e., before they are possibly protected end-to-end with OSCORE as considered by the example in <xref target="examples-with-oscore"/>.</t>
      <t>Note that:</t>
      <ul spacing="normal">
        <li>
          <t>On the communication leg between the Device and the proxy, the CoAP Message ID has value 0x0001 and the CoAP Token has value 0x82.</t>
        </li>
        <li>
          <t>On the communication leg between the proxy and the Application Server, the CoAP Message ID has value 0x0004 and the CoAP Token has value 0x75.</t>
        </li>
      </ul>
      <figure anchor="fig-example-req">
        <name>CoAP GET Request.</name>
        <artwork align="left"><![CDATA[
Original message:
=================
0x41010001823b6578616d706c652e636f6d
  8b74656d7065726174757265d40f636f6170

Header:
0x4101
01   Ver
  00   CON
    0001   TKL
        00000001   Request Code 1 (GET)

0x0001   MID
0x82   Token

Options:

0x3b6578616d706c652e636f6d
Option 3: Uri-Host
Value = "example.com"

0x8b74656d7065726174757265
Option 11: Uri-Path
Value = "temperature"

0xd40f636f6170
Option 39: Proxy-Scheme
Value = "coap"

Original message length: 35 bytes

]]></artwork>
      </figure>
      <figure anchor="fig-example-resp">
        <name>CoAP Content Response.</name>
        <artwork align="left"><![CDATA[
Original message:
=================
0x6145000475ff32332043

Header:
0x6145
01   Ver
  10   ACK
    0001   TKL
        01000101 Successful Response Code 69 (2.05 Content)

0x0004   MID
0x75   Token


0xFF Payload marker

Payload:
0x32332043

Original message length: 10 bytes

]]></artwork>
      </figure>
      <section anchor="examples-without-oscore">
        <name>Without End-to-End Security</name>
        <t>In case OSCORE is not used end-to-end between the Device and the Application Server, the following SCHC Rules are shared between the different entities. Based on those Rules, the SCHC Compression/Decompression is performed as per <xref target="compression-with-proxies-without-oscore"/>.</t>
        <t>The Device and the proxy share the SCHC Rule shown in <xref target="fig-rules-device-proxy"/>, with RuleID 0.</t>
        <artwork><![CDATA[
+----------+
| RuleID 0 |
+----------+
]]></artwork>
        <table align="center" anchor="fig-rules-device-proxy">
          <name>SCHC Rule between the Device and the Proxy. CoAP Option Numbers: 3 (Uri-Host), 11 (Uri-Path), 39 (Proxy-Scheme).</name>
          <thead>
            <tr>
              <th align="left">FID</th>
              <th align="left">FL</th>
              <th align="left">FP</th>
              <th align="left">DI</th>
              <th align="left">TV</th>
              <th align="left">MO</th>
              <th align="left">CDA</th>
              <th align="left">Sent 
 [bits]</th>
            </tr>
          </thead>
          <tbody>
            <tr>
              <td align="left">CoAP.<br/>Version</td>
              <td align="left">2</td>
              <td align="left">1</td>
              <td align="left">Bi</td>
              <td align="left">1</td>
              <td align="left">equal</td>
              <td align="left">not-sent</td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">CoAP.<br/>Type</td>
              <td align="left">2</td>
              <td align="left">1</td>
              <td align="left">Up</td>
              <td align="left">0</td>
              <td align="left">equal</td>
              <td align="left">not-sent</td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">CoAP.<br/>Type</td>
              <td align="left">2</td>
              <td align="left">1</td>
              <td align="left">Dw</td>
              <td align="left">[0, 2]</td>
              <td align="left">match- <br/> mapping</td>
              <td align="left">mapping- <br/> sent</td>
              <td align="left">T</td>
            </tr>
            <tr>
              <td align="left">CoAP.<br/>TKL</td>
              <td align="left"> </td>
              <td align="left">1</td>
              <td align="left">Bi</td>
              <td align="left">0b0001</td>
              <td align="left">equal</td>
              <td align="left">not-sent</td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">CoAP.<br/>Code</td>
              <td align="left">8</td>
              <td align="left">1</td>
              <td align="left">Up</td>
              <td align="left">[1, 2, <br/> 3, 4]</td>
              <td align="left">match- <br/> mapping</td>
              <td align="left">mapping- <br/> sent</td>
              <td align="left">CC</td>
            </tr>
            <tr>
              <td align="left">CoAP.<br/>Code</td>
              <td align="left">8</td>
              <td align="left">1</td>
              <td align="left">Dw</td>
              <td align="left">[65, 68, <br/> 69, 132]</td>
              <td align="left">match- <br/> mapping</td>
              <td align="left">mapping- <br/> sent</td>
              <td align="left">CC</td>
            </tr>
            <tr>
              <td align="left">CoAP.<br/>MID</td>
              <td align="left">16</td>
              <td align="left">1</td>
              <td align="left">Bi</td>
              <td align="left">0x0000</td>
              <td align="left">MSB(12)</td>
              <td align="left">LSB</td>
              <td align="left">MMMM</td>
            </tr>
            <tr>
              <td align="left">CoAP.<br/>Token</td>
              <td align="left">tkl</td>
              <td align="left">1</td>
              <td align="left">Bi</td>
              <td align="left">0x80</td>
              <td align="left">MSB(5)</td>
              <td align="left">LSB</td>
              <td align="left">TTT</td>
            </tr>
            <tr>
              <td align="left">CoAP.<br/>option(3)</td>
              <td align="left">var</td>
              <td align="left">1</td>
              <td align="left">Up</td>
              <td align="left"> </td>
              <td align="left">ignore</td>
              <td align="left">value- <br/> sent</td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">CoAP.<br/>option(11)</td>
              <td align="left"> </td>
              <td align="left">1</td>
              <td align="left">Up</td>
              <td align="left">"temperature"</td>
              <td align="left">equal</td>
              <td align="left">not-sent</td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">CoAP.<br/>option(39)</td>
              <td align="left"> </td>
              <td align="left">1</td>
              <td align="left">Up</td>
              <td align="left">"coap"</td>
              <td align="left">equal</td>
              <td align="left">not-sent</td>
              <td align="left"> </td>
            </tr>
          </tbody>
        </table>
        <t>Instead, the proxy and the Application Server share the SCHC Rule shown in <xref target="fig-rules-proxy-server"/>, with RuleID 1.</t>
        <artwork><![CDATA[
+----------+
| RuleID 1 |
+----------+
]]></artwork>
        <table align="center" anchor="fig-rules-proxy-server">
          <name>SCHC Rule between the Proxy and the Application Server. CoAP Option Numbers: 3 (Uri-Host), 11 (Uri-Path).</name>
          <thead>
            <tr>
              <th align="left">FID</th>
              <th align="left">FL</th>
              <th align="left">FP</th>
              <th align="left">DI</th>
              <th align="left">TV</th>
              <th align="left">MO</th>
              <th align="left">CDA</th>
              <th align="left">Sent 
 [bits]</th>
            </tr>
          </thead>
          <tbody>
            <tr>
              <td align="left">CoAP.<br/>Version</td>
              <td align="left">2</td>
              <td align="left">1</td>
              <td align="left">Bi</td>
              <td align="left">1</td>
              <td align="left">equal</td>
              <td align="left">not-sent</td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">CoAP.<br/>Type</td>
              <td align="left">2</td>
              <td align="left">1</td>
              <td align="left">Up</td>
              <td align="left">0</td>
              <td align="left">equal</td>
              <td align="left">not-sent</td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">CoAP.<br/>Type</td>
              <td align="left">2</td>
              <td align="left">1</td>
              <td align="left">Dw</td>
              <td align="left">[0, 2]</td>
              <td align="left">match- <br/> mapping</td>
              <td align="left">mapping- <br/> sent</td>
              <td align="left">T</td>
            </tr>
            <tr>
              <td align="left">CoAP.<br/>TKL</td>
              <td align="left"> </td>
              <td align="left">1</td>
              <td align="left">Bi</td>
              <td align="left">0b0001</td>
              <td align="left">equal</td>
              <td align="left">not-sent</td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">CoAP.<br/>Code</td>
              <td align="left">8</td>
              <td align="left">1</td>
              <td align="left">Up</td>
              <td align="left">[1, 2, <br/> 3, 4]</td>
              <td align="left">match- <br/> mapping</td>
              <td align="left">mapping- <br/> sent</td>
              <td align="left">CC</td>
            </tr>
            <tr>
              <td align="left">CoAP.<br/>Code</td>
              <td align="left">8</td>
              <td align="left">1</td>
              <td align="left">Dw</td>
              <td align="left">[65, 68, <br/> 69, 132]</td>
              <td align="left">match- <br/> mapping</td>
              <td align="left">mapping- <br/> sent</td>
              <td align="left">CC</td>
            </tr>
            <tr>
              <td align="left">CoAP.<br/>MID</td>
              <td align="left">16</td>
              <td align="left">1</td>
              <td align="left">Bi</td>
              <td align="left">0x0000</td>
              <td align="left">MSB(12)</td>
              <td align="left">LSB</td>
              <td align="left">MMMM</td>
            </tr>
            <tr>
              <td align="left">CoAP.<br/>Token</td>
              <td align="left">tkl</td>
              <td align="left">1</td>
              <td align="left">Bi</td>
              <td align="left">0x70</td>
              <td align="left">MSB(5)</td>
              <td align="left">LSB</td>
              <td align="left">TTT</td>
            </tr>
            <tr>
              <td align="left">CoAP.<br/>option(3)</td>
              <td align="left">var</td>
              <td align="left">1</td>
              <td align="left">Up</td>
              <td align="left"> </td>
              <td align="left">ignore</td>
              <td align="left">value- <br/> sent</td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">CoAP.<br/>option(11)</td>
              <td align="left"> </td>
              <td align="left">1</td>
              <td align="left">Up</td>
              <td align="left">"temperature"</td>
              <td align="left">equal</td>
              <td align="left">not-sent</td>
              <td align="left"> </td>
            </tr>
          </tbody>
        </table>
        <t>First, the Device applies the Rule in <xref target="fig-rules-device-proxy"/> shared with the proxy to the CoAP request in <xref target="fig-example-req"/>. The result is the compressed CoAP request in <xref target="fig-example-req-to-proxy"/> that the Device sends to the proxy.</t>
        <figure anchor="fig-example-req-to-proxy">
          <name>CoAP GET Request Compressed for the Proxy.</name>
          <artwork align="left"><![CDATA[
Compressed message:
=================
0x00055b2bc30b6b836329731b7b68 (14 bytes)
0x00 RuleID
    055b2bc30b6b836329731b7b68 compression residue
                                and padded payload

Compression Residue (101 bits -> 13 bytes with padding)
0b   00 0001   010      1011  |  0x6578616d706c652e636f6d
   Code  MID Token  Uri-Host (residue size and residue)

Compressed message length: 14 bytes

]]></artwork>
        </figure>
        <t>Upon receiving the message in <xref target="fig-example-req-to-proxy"/>, the proxy decompresses it with the Rule in <xref target="fig-rules-device-proxy"/> shared with the Device and obtains the same CoAP request in <xref target="fig-example-req"/>.</t>
        <t>After that, the proxy removes the Proxy-Scheme Option from the decompressed CoAP request. Also, the proxy replaces the values of the CoAP Message ID and of the CoAP Token to 0x0004 and 0x75, respectively. The result is the CoAP request shown in <xref target="fig-example-req-from-proxy"/>.</t>
        <figure anchor="fig-example-req-from-proxy">
          <name>CoAP GET Request to be Compressed by the Proxy.</name>
          <artwork align="left"><![CDATA[
Message to forward:
=================
0x41010004753b6578616d706c652e636f6d
  8b74656d7065726174757265

Header:
0x4101
01   Ver
  00   CON
    0001   TKL
        00000001   Request Code 1 (GET)

0x0004   MID
0x75   Token

Options:

0x3b6578616d706c652e636f6d
Option 3: Uri-Host
Value = "example.com"

0x8b74656d7065726174757265
Option 11: Uri-Path
Value = "temperature"

Original message length: 29 bytes

]]></artwork>
        </figure>
        <t>Then, the proxy applies the Rule in <xref target="fig-rules-proxy-server"/> shared with the Application Server to the CoAP request in <xref target="fig-example-req-from-proxy"/>.</t>
        <t>The result is the compressed CoAP request in <xref target="fig-example-req-from-proxy-compressed"/> that the proxy forwards to the Application Server.</t>
        <figure anchor="fig-example-req-from-proxy-compressed">
          <name>CoAP GET Request Forwarded by the Proxy.</name>
          <artwork align="left"><![CDATA[
Compressed message to forward:
=================
0x0112db2bc30b6b836329731b7b68 (14 bytes)
0x01 RuleID
    12db2bc30b6b836329731b7b68 compression residue
                                and padded payload


Compression Residue (101 bits -> 13 bytes with padding)
0b   00 0100   101      1011  |  0x6578616d706c652e636f6d
   Code  MID Token  Uri-Host (residue size and residue)

Compressed message length: 14 bytes

]]></artwork>
        </figure>
        <t>Upon receiving the message in <xref target="fig-example-req-from-proxy-compressed"/>, the Application Server decompresses it using the Rule in <xref target="fig-rules-proxy-server"/> shared with the proxy. The result is the same CoAP request in <xref target="fig-example-req-from-proxy"/> that the Application Server delivers to the application.</t>
        <t>After that, the Application Server produces the CoAP response in <xref target="fig-example-resp"/> and compresses it using the Rule in <xref target="fig-rules-proxy-server"/> shared with the proxy. The result is the compressed CoAP response shown in <xref target="fig-example-resp-to-proxy"/> that the Application Server sends to the proxy.</t>
        <figure anchor="fig-example-resp-to-proxy">
          <name>CoAP Content Response Compressed for the Proxy.</name>
          <artwork align="left"><![CDATA[
Compressed message:
=================
0x01c94c8cc810c0 (7 bytes)
0x01 RuleID
    c94c8cc810c0 compression residue
                 and padded payload


Compression Residue (10 bits -> 2 bytes with padding)
0b    1   10 0100   101
   Type Code  MID Token

Payload
0x32332043 (4 bytes)

Compressed message length: 7 bytes

]]></artwork>
        </figure>
        <t>Upon receiving the message in <xref target="fig-example-resp-to-proxy"/>, the proxy decompresses it using the Rule in <xref target="fig-rules-proxy-server"/> shared with the Application Server. The result is the same CoAP response in <xref target="fig-example-resp"/>.</t>
        <t>Then, the proxy replaces the values of the CoAP Message ID and of the CoAP Token to 0x0001 and 0x82, respectively. The result is the CoAP response shown in <xref target="fig-example-resp-from-proxy"/>.</t>
        <figure anchor="fig-example-resp-from-proxy">
          <name>CoAP Content Response to be Compressed by the Proxy.</name>
          <artwork align="left"><![CDATA[
Message to forward:
=================
0x6145000182ff32332043

Header:
0x6145
01   Ver
  10   ACK
    0001   TKL
        01000101 Successful Response Code 69 (2.05 Content)

0x0001   MID
0x82   Token


0xFF Payload marker

Payload:
0x32332043

Original message length: 10 bytes

]]></artwork>
        </figure>
        <t>Then, the proxy compresses the CoAP response in <xref target="fig-example-resp-from-proxy"/> with the Rule in <xref target="fig-rules-device-proxy"/> shared with the Device. The result is the compressed CoAP response shown in <xref target="fig-example-resp-from-proxy-compressed"/> that the proxy forwards to the Device.</t>
        <figure anchor="fig-example-resp-from-proxy-compressed">
          <name>CoAP Content Response Forwarded by the Proxy.</name>
          <artwork align="left"><![CDATA[
Compressed message:
=================
0x00c28c8cc810c0 (7 bytes)
0x00 RuleID
    c28c8cc810c0 compression residue
                 and padded payload


Compression Residue (10 bits -> 2 bytes with padding)
0b    1   10 0001   010
   Type Code  MID Token

Payload
0x32332043 (4 bytes)

Compressed message length: 7 bytes

]]></artwork>
        </figure>
        <t>Upon receiving the message in <xref target="fig-example-resp-from-proxy-compressed"/>, the Device decompresses it using the Rule in <xref target="fig-rules-device-proxy"/> shared with the proxy. The result is the same CoAP request in <xref target="fig-example-resp-from-proxy"/> that the Device delivers to the application.</t>
      </section>
      <section anchor="examples-with-oscore">
        <name>With End-to-End Security</name>
        <t>In case OSCORE is used end-to-end between the Device and the Application Server, the following SCHC Rules are shared between the different entities. Based on those Rules, the SCHC Compression/Decompression is performed as per <xref target="compression-with-proxies-with-oscore"/>.</t>
        <t>The Device and the Application Server share the SCHC Rule shown in <xref target="fig-rules-oscore-device-server"/>, with RuleID 2. The Device and the Application Server use this Rule to perform the Inner SCHC Compression/Decompression end-to-end.</t>
        <artwork><![CDATA[
+----------+
| RuleID 2 |
+----------+
]]></artwork>
        <table align="center" anchor="fig-rules-oscore-device-server">
          <name>Inner SCHC Rule between the Device and the Application Server. CoAP Option Numbers: 11 (Uri-Path).</name>
          <thead>
            <tr>
              <th align="left">FID</th>
              <th align="left">FL</th>
              <th align="left">FP</th>
              <th align="left">DI</th>
              <th align="left">TV</th>
              <th align="left">MO</th>
              <th align="left">CDA</th>
              <th align="left">Sent 
 [bits]</th>
            </tr>
          </thead>
          <tbody>
            <tr>
              <td align="left">CoAP.<br/>Code</td>
              <td align="left">8</td>
              <td align="left">1</td>
              <td align="left">Up</td>
              <td align="left">[1, 2, <br/> 3, 4]</td>
              <td align="left">match- <br/> mapping</td>
              <td align="left">mapping- <br/> sent</td>
              <td align="left">CC</td>
            </tr>
            <tr>
              <td align="left">CoAP.<br/>Code</td>
              <td align="left">8</td>
              <td align="left">1</td>
              <td align="left">Dw</td>
              <td align="left">[65, 68, <br/> 69, 132]</td>
              <td align="left">match- <br/> mapping</td>
              <td align="left">mapping- <br/> sent</td>
              <td align="left">CC</td>
            </tr>
            <tr>
              <td align="left">CoAP.<br/>option(11)</td>
              <td align="left"> </td>
              <td align="left">1</td>
              <td align="left">Up</td>
              <td align="left">"temperature"</td>
              <td align="left">equal</td>
              <td align="left">not-sent</td>
              <td align="left"> </td>
            </tr>
          </tbody>
        </table>
        <t>The Device and the proxy share the SCHC Rule shown in <xref target="fig-rules-oscore-device-proxy"/>, with RuleID 3. The Device and the proxy use this Rule to perform the Outer SCHC Compression/Decompression hop-by-hop on their communication leg.</t>
        <artwork><![CDATA[
+----------+
| RuleID 3 |
+----------+
]]></artwork>
        <table align="center" anchor="fig-rules-oscore-device-proxy">
          <name>Outer SCHC Rule between the Device and the Proxy. CoAP Option Numbers: 3 (Uri-Host), 9 (OSCORE), 39 (Proxy-Scheme).</name>
          <thead>
            <tr>
              <th align="left">FID</th>
              <th align="left">FL</th>
              <th align="left">FP</th>
              <th align="left">DI</th>
              <th align="left">TV</th>
              <th align="left">MO</th>
              <th align="left">CDA</th>
              <th align="left">Sent 
 [bits]</th>
            </tr>
          </thead>
          <tbody>
            <tr>
              <td align="left">CoAP.<br/>Version</td>
              <td align="left">2</td>
              <td align="left">1</td>
              <td align="left">Bi</td>
              <td align="left">1</td>
              <td align="left">equal</td>
              <td align="left">not-sent</td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">CoAP.<br/>Type</td>
              <td align="left">2</td>
              <td align="left">1</td>
              <td align="left">Up</td>
              <td align="left">0</td>
              <td align="left">equal</td>
              <td align="left">not-sent</td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">CoAP.<br/>Type</td>
              <td align="left">2</td>
              <td align="left">1</td>
              <td align="left">Dw</td>
              <td align="left">[0, 2]</td>
              <td align="left">match- <br/> mapping</td>
              <td align="left">mapping- <br/> sent</td>
              <td align="left">T</td>
            </tr>
            <tr>
              <td align="left">CoAP.<br/>TKL</td>
              <td align="left"> </td>
              <td align="left">1</td>
              <td align="left">Bi</td>
              <td align="left">0b0001</td>
              <td align="left">equal</td>
              <td align="left">not-sent</td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">CoAP.<br/>Code</td>
              <td align="left">8</td>
              <td align="left">1</td>
              <td align="left">Up</td>
              <td align="left">2</td>
              <td align="left">equal</td>
              <td align="left">not-sent</td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">CoAP.<br/>Code</td>
              <td align="left">8</td>
              <td align="left">1</td>
              <td align="left">Dw</td>
              <td align="left">68</td>
              <td align="left">equal</td>
              <td align="left">not-sent</td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">CoAP.<br/>MID</td>
              <td align="left">16</td>
              <td align="left">1</td>
              <td align="left">Bi</td>
              <td align="left">0x0000</td>
              <td align="left">MSB(12)</td>
              <td align="left">LSB</td>
              <td align="left">MMMM</td>
            </tr>
            <tr>
              <td align="left">CoAP.<br/>Token</td>
              <td align="left">tkl</td>
              <td align="left">1</td>
              <td align="left">Bi</td>
              <td align="left">0x80</td>
              <td align="left">MSB(5)</td>
              <td align="left">LSB</td>
              <td align="left">TTT</td>
            </tr>
            <tr>
              <td align="left">CoAP.<br/>option(3)</td>
              <td align="left">var</td>
              <td align="left">1</td>
              <td align="left">Up</td>
              <td align="left"> </td>
              <td align="left">ignore</td>
              <td align="left">value- <br/> sent</td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">CoAP.<br/>option(9).<br/>flags</td>
              <td align="left"> </td>
              <td align="left">1</td>
              <td align="left">Up</td>
              <td align="left">0x09</td>
              <td align="left">equal</td>
              <td align="left">not-sent</td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">CoAP.<br/>option(9).<br/>flags</td>
              <td align="left"> </td>
              <td align="left">1</td>
              <td align="left">Dw</td>
              <td align="left">b''</td>
              <td align="left">equal</td>
              <td align="left">not-sent</td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">CoAP.<br/>option(9).<br/>piv</td>
              <td align="left">osc.piv</td>
              <td align="left">1</td>
              <td align="left">Up</td>
              <td align="left">0x00</td>
              <td align="left">MSB(4)</td>
              <td align="left">LSB</td>
              <td align="left">PPPP</td>
            </tr>
            <tr>
              <td align="left">CoAP.<br/>option(9).<br/>piv</td>
              <td align="left"> </td>
              <td align="left">1</td>
              <td align="left">Dw</td>
              <td align="left">b''</td>
              <td align="left">equal</td>
              <td align="left">not-sent</td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">CoAP.<br/>option(9).<br/>kid_ctx</td>
              <td align="left"> </td>
              <td align="left">1</td>
              <td align="left">Bi</td>
              <td align="left">b''</td>
              <td align="left">equal</td>
              <td align="left">not-sent</td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">CoAP.<br/>option(9).<br/>x</td>
              <td align="left">8</td>
              <td align="left">1</td>
              <td align="left">Bi</td>
              <td align="left">b''</td>
              <td align="left">equal</td>
              <td align="left">not-sent</td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">CoAP.<br/>option(9).<br/>nonce</td>
              <td align="left"> </td>
              <td align="left">1</td>
              <td align="left">Bi</td>
              <td align="left">b''</td>
              <td align="left">equal</td>
              <td align="left">not-sent</td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">CoAP.<br/>option(9).<br/>kid</td>
              <td align="left">var_bit</td>
              <td align="left">1</td>
              <td align="left">Up</td>
              <td align="left">0x0000</td>
              <td align="left">MSB(12)</td>
              <td align="left">LSB</td>
              <td align="left">KKKK</td>
            </tr>
            <tr>
              <td align="left">CoAP.<br/>option(9).<br/>kid</td>
              <td align="left"> </td>
              <td align="left">1</td>
              <td align="left">Dw</td>
              <td align="left">b''</td>
              <td align="left">equal</td>
              <td align="left">not-sent</td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">CoAP.<br/>option(39)</td>
              <td align="left"> </td>
              <td align="left">1</td>
              <td align="left">Up</td>
              <td align="left">"coap"</td>
              <td align="left">equal</td>
              <td align="left">not-sent</td>
              <td align="left"> </td>
            </tr>
          </tbody>
        </table>
        <t>The proxy and the Application Server share the SCHC Rule shown in <xref target="fig-rules-oscore-proxy-server"/>, with RuleID 4. The proxy and the Application Server use this Rule to perform the Outer SCHC Compression/Decompression hop-by-hop on their communication leg.</t>
        <artwork><![CDATA[
 +----------+
 | RuleID 4 |
 +----------+
]]></artwork>
        <table align="center" anchor="fig-rules-oscore-proxy-server">
          <name>Outer SCHC Rule between the Proxy and the Application Server. CoAP Option Numbers: 3 (Uri-Host), 9 (OSCORE).</name>
          <thead>
            <tr>
              <th align="left">FID</th>
              <th align="left">FL</th>
              <th align="left">FP</th>
              <th align="left">DI</th>
              <th align="left">TV</th>
              <th align="left">MO</th>
              <th align="left">CDA</th>
              <th align="left">Sent 
 [bits]</th>
            </tr>
          </thead>
          <tbody>
            <tr>
              <td align="left">CoAP.<br/>Version</td>
              <td align="left">2</td>
              <td align="left">1</td>
              <td align="left">Bi</td>
              <td align="left">1</td>
              <td align="left">equal</td>
              <td align="left">not-sent</td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">CoAP.<br/>Type</td>
              <td align="left">2</td>
              <td align="left">1</td>
              <td align="left">Up</td>
              <td align="left">0</td>
              <td align="left">equal</td>
              <td align="left">not-sent</td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">CoAP.<br/>Type</td>
              <td align="left">2</td>
              <td align="left">1</td>
              <td align="left">Dw</td>
              <td align="left">[0, 2]</td>
              <td align="left">match- <br/> mapping</td>
              <td align="left">mapping- <br/> sent</td>
              <td align="left">T</td>
            </tr>
            <tr>
              <td align="left">CoAP.<br/>TKL</td>
              <td align="left"> </td>
              <td align="left">1</td>
              <td align="left">Bi</td>
              <td align="left">0b0001</td>
              <td align="left">equal</td>
              <td align="left">not-sent</td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">CoAP.<br/>Code</td>
              <td align="left">8</td>
              <td align="left">1</td>
              <td align="left">Up</td>
              <td align="left">2</td>
              <td align="left">equal</td>
              <td align="left">not-sent</td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">CoAP.<br/>Code</td>
              <td align="left">8</td>
              <td align="left">1</td>
              <td align="left">Dw</td>
              <td align="left">68</td>
              <td align="left">equal</td>
              <td align="left">not-sent</td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">CoAP.<br/>MID</td>
              <td align="left">16</td>
              <td align="left">1</td>
              <td align="left">Bi</td>
              <td align="left">0x0000</td>
              <td align="left">MSB(12)</td>
              <td align="left">LSB</td>
              <td align="left">MMMM</td>
            </tr>
            <tr>
              <td align="left">CoAP.<br/>Token</td>
              <td align="left">tkl</td>
              <td align="left">1</td>
              <td align="left">Bi</td>
              <td align="left">0x70</td>
              <td align="left">MSB(5)</td>
              <td align="left">LSB</td>
              <td align="left">TTT</td>
            </tr>
            <tr>
              <td align="left">CoAP.<br/>option(3)</td>
              <td align="left">var</td>
              <td align="left">1</td>
              <td align="left">Up</td>
              <td align="left"> </td>
              <td align="left">ignore</td>
              <td align="left">value- <br/> sent</td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">CoAP.<br/>option(9).<br/>flags</td>
              <td align="left"> </td>
              <td align="left">1</td>
              <td align="left">Up</td>
              <td align="left">0x09</td>
              <td align="left">equal</td>
              <td align="left">not-sent</td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">CoAP.<br/>option(9).<br/>flags</td>
              <td align="left"> </td>
              <td align="left">1</td>
              <td align="left">Dw</td>
              <td align="left">b''</td>
              <td align="left">equal</td>
              <td align="left">not-sent</td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">CoAP.<br/>option(9).<br/>piv</td>
              <td align="left">osc.piv</td>
              <td align="left">1</td>
              <td align="left">Up</td>
              <td align="left">0x00</td>
              <td align="left">MSB(4)</td>
              <td align="left">LSB</td>
              <td align="left">PPPP</td>
            </tr>
            <tr>
              <td align="left">CoAP.<br/>option(9).<br/>piv</td>
              <td align="left"> </td>
              <td align="left">1</td>
              <td align="left">Dw</td>
              <td align="left">b''</td>
              <td align="left">equal</td>
              <td align="left">not-sent</td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">CoAP.<br/>option(9).<br/>kid_ctx</td>
              <td align="left"> </td>
              <td align="left">1</td>
              <td align="left">Bi</td>
              <td align="left">b''</td>
              <td align="left">equal</td>
              <td align="left">not-sent</td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">CoAP.<br/>option(9).<br/>x</td>
              <td align="left">8</td>
              <td align="left">1</td>
              <td align="left">Bi</td>
              <td align="left">b''</td>
              <td align="left">equal</td>
              <td align="left">not-sent</td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">CoAP.<br/>option(9).<br/>nonce</td>
              <td align="left"> </td>
              <td align="left">1</td>
              <td align="left">Bi</td>
              <td align="left">b''</td>
              <td align="left">equal</td>
              <td align="left">not-sent</td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">CoAP.<br/>option(9).<br/>kid</td>
              <td align="left">var_bit</td>
              <td align="left">1</td>
              <td align="left">Up</td>
              <td align="left">0x0000</td>
              <td align="left">MSB(12)</td>
              <td align="left">LSB</td>
              <td align="left">KKKK</td>
            </tr>
            <tr>
              <td align="left">CoAP.<br/>option(9).<br/>kid</td>
              <td align="left"> </td>
              <td align="left">1</td>
              <td align="left">Dw</td>
              <td align="left">b''</td>
              <td align="left">equal</td>
              <td align="left">not-sent</td>
              <td align="left"> </td>
            </tr>
          </tbody>
        </table>
        <t>When the Device applies the Rule in <xref target="fig-rules-oscore-device-server"/> shared with the Application Server to the CoAP request in <xref target="fig-example-req"/>, this results in the Compressed Plaintext shown in <xref target="fig-plaintext-req"/>.</t>
        <t>As per <xref target="ssec-examples-oscore"/>, the message follows the process of SCHC Inner Compression and encryption until the payload (if any). The ciphertext resulting from the overall Inner process is used as payload of the Outer OSCORE message.</t>
        <figure anchor="fig-plaintext-req">
          <name>Plaintext Compression and Encryption for the GET Request.</name>
          <artset>
            <artwork type="svg" align="center"><svg xmlns="http://www.w3.org/2000/svg" version="1.1" height="784" width="448" viewBox="0 0 448 784" class="diagram" text-anchor="middle" font-family="monospace" font-size="13px" stroke-linecap="round">
                <path d="M 8,32 L 8,208" fill="none" stroke="black"/>
                <path d="M 8,288 L 8,544" fill="none" stroke="black"/>
                <path d="M 8,640 L 8,752" fill="none" stroke="black"/>
                <path d="M 200,216 L 200,280" fill="none" stroke="black"/>
                <path d="M 200,552 L 200,632" fill="none" stroke="black"/>
                <path d="M 400,640 L 400,752" fill="none" stroke="black"/>
                <path d="M 408,288 L 408,544" fill="none" stroke="black"/>
                <path d="M 440,32 L 440,208" fill="none" stroke="black"/>
                <path d="M 8,32 L 440,32" fill="none" stroke="black"/>
                <path d="M 8,208 L 440,208" fill="none" stroke="black"/>
                <path d="M 8,288 L 408,288" fill="none" stroke="black"/>
                <path d="M 8,544 L 408,544" fill="none" stroke="black"/>
                <path d="M 8,640 L 400,640" fill="none" stroke="black"/>
                <path d="M 8,752 L 400,752" fill="none" stroke="black"/>
                <polygon class="arrowhead" points="208,632 196,626.4 196,637.6" fill="black" transform="rotate(90,200,632)"/>
                <polygon class="arrowhead" points="208,280 196,274.4 196,285.6" fill="black" transform="rotate(90,200,280)"/>
                <g class="text">
                  <text x="44" y="68">OSCORE</text>
                  <text x="112" y="68">Plaintext</text>
                  <text x="132" y="100">0x01bb74656d7065726174757265</text>
                  <text x="272" y="100">(13</text>
                  <text x="316" y="100">bytes)</text>
                  <text x="36" y="132">0x01</text>
                  <text x="88" y="132">Request</text>
                  <text x="140" y="132">Code</text>
                  <text x="176" y="132">GET</text>
                  <text x="164" y="164">0xbb74656d7065726174757265</text>
                  <text x="300" y="164">Option</text>
                  <text x="344" y="164">11:</text>
                  <text x="396" y="164">Uri-Path</text>
                  <text x="296" y="180">Value</text>
                  <text x="328" y="180">=</text>
                  <text x="384" y="180">temperature</text>
                  <text x="232" y="244">Inner</text>
                  <text x="276" y="244">SCHC</text>
                  <text x="344" y="244">Compression</text>
                  <text x="60" y="324">Compressed</text>
                  <text x="144" y="324">Plaintext</text>
                  <text x="44" y="356">0x0200</text>
                  <text x="84" y="356">(2</text>
                  <text x="124" y="356">bytes)</text>
                  <text x="44" y="404">RuleID</text>
                  <text x="80" y="404">=</text>
                  <text x="108" y="404">0x02</text>
                  <text x="140" y="404">(1</text>
                  <text x="176" y="404">byte)</text>
                  <text x="64" y="452">Compression</text>
                  <text x="144" y="452">residue</text>
                  <text x="32" y="468">and</text>
                  <text x="76" y="468">padded</text>
                  <text x="136" y="468">payload</text>
                  <text x="176" y="468">=</text>
                  <text x="204" y="468">0x00</text>
                  <text x="236" y="468">(1</text>
                  <text x="272" y="468">byte)</text>
                  <text x="36" y="500">0b00</text>
                  <text x="68" y="500">(2</text>
                  <text x="100" y="500">bits</text>
                  <text x="176" y="500">match-mapping</text>
                  <text x="280" y="500">Compression</text>
                  <text x="364" y="500">Residue)</text>
                  <text x="52" y="516">0b000000</text>
                  <text x="100" y="516">(6</text>
                  <text x="128" y="516">bit</text>
                  <text x="180" y="516">padding)</text>
                  <text x="228" y="580">AEAD</text>
                  <text x="292" y="580">Encryption</text>
                  <text x="236" y="596">(piv</text>
                  <text x="264" y="596">=</text>
                  <text x="296" y="596">0x04)</text>
                  <text x="96" y="676">encrypted_plaintext</text>
                  <text x="184" y="676">=</text>
                  <text x="220" y="676">0xa2cf</text>
                  <text x="260" y="676">(2</text>
                  <text x="300" y="676">bytes)</text>
                  <text x="32" y="692">tag</text>
                  <text x="56" y="692">=</text>
                  <text x="140" y="692">0xc54fe1b434297b62</text>
                  <text x="228" y="692">(8</text>
                  <text x="268" y="692">bytes)</text>
                  <text x="60" y="724">ciphertext</text>
                  <text x="112" y="724">=</text>
                  <text x="212" y="724">0xa2cfc54fe1b434297b62</text>
                  <text x="320" y="724">(10</text>
                  <text x="364" y="724">bytes)</text>
                </g>
              </svg>
            </artwork>
            <artwork type="ascii-art" align="center"><![CDATA[
+-----------------------------------------------------+
|                                                     |
| OSCORE Plaintext                                    |
|                                                     |
| 0x01bb74656d7065726174757265  (13 bytes)            |
|                                                     |
| 0x01 Request Code GET                               |
|                                                     |
|      0xbb74656d7065726174757265 Option 11: Uri-Path |
|                                 Value = temperature |
|                                                     |
+-----------------------------------------------------+
                        |
                        | Inner SCHC Compression
                        |
                        v
+-------------------------------------------------+
|                                                 |
| Compressed Plaintext                            |
|                                                 |
| 0x0200 (2 bytes)                                |
|                                                 |
|                                                 |
| RuleID = 0x02 (1 byte)                          |
|                                                 |
|                                                 |
| Compression residue                             |
| and padded payload = 0x00 (1 byte)              |
|                                                 |
| 0b00 (2 bits match-mapping Compression Residue) |
| 0b000000 (6 bit padding)                        |
|                                                 |
+-------------------------------------------------+
                        |
                        | AEAD Encryption
                        |  (piv = 0x04)
                        |
                        v
+------------------------------------------------+
|                                                |
| encrypted_plaintext = 0xa2cf (2 bytes)         |
| tag = 0xc54fe1b434297b62 (8 bytes)             |
|                                                |
| ciphertext = 0xa2cfc54fe1b434297b62 (10 bytes) |
|                                                |
+------------------------------------------------+

]]></artwork>
          </artset>
        </figure>
        <t>When the Application Server applies the Rule in <xref target="fig-rules-oscore-device-server"/> shared with the Device to the CoAP response in <xref target="fig-example-resp"/>, this results in the Compressed Plaintext shown in <xref target="fig-plaintext-resp"/>.</t>
        <t>As per <xref target="ssec-examples-oscore"/>, the message follows the process of SCHC Inner Compression and encryption until the payload (if any). The ciphertext resulting from the overall Inner process is used as payload of the Outer OSCORE message.</t>
        <figure anchor="fig-plaintext-resp">
          <name>Plaintext Compression and Encryption for the Content Response.</name>
          <artset>
            <artwork type="svg" align="center"><svg xmlns="http://www.w3.org/2000/svg" version="1.1" height="816" width="480" viewBox="0 0 480 816" class="diagram" text-anchor="middle" font-family="monospace" font-size="13px" stroke-linecap="round">
                <path d="M 8,32 L 8,224" fill="none" stroke="black"/>
                <path d="M 8,304 L 8,576" fill="none" stroke="black"/>
                <path d="M 8,672 L 8,784" fill="none" stroke="black"/>
                <path d="M 168,232 L 168,296" fill="none" stroke="black"/>
                <path d="M 168,584 L 168,664" fill="none" stroke="black"/>
                <path d="M 408,32 L 408,224" fill="none" stroke="black"/>
                <path d="M 408,304 L 408,576" fill="none" stroke="black"/>
                <path d="M 472,672 L 472,784" fill="none" stroke="black"/>
                <path d="M 8,32 L 408,32" fill="none" stroke="black"/>
                <path d="M 8,224 L 408,224" fill="none" stroke="black"/>
                <path d="M 8,304 L 408,304" fill="none" stroke="black"/>
                <path d="M 8,576 L 408,576" fill="none" stroke="black"/>
                <path d="M 8,672 L 472,672" fill="none" stroke="black"/>
                <path d="M 8,784 L 472,784" fill="none" stroke="black"/>
                <polygon class="arrowhead" points="176,664 164,658.4 164,669.6" fill="black" transform="rotate(90,168,664)"/>
                <polygon class="arrowhead" points="176,296 164,290.4 164,301.6" fill="black" transform="rotate(90,168,296)"/>
                <g class="text">
                  <text x="44" y="68">OSCORE</text>
                  <text x="112" y="68">Plaintext</text>
                  <text x="76" y="100">0x45ff32332043</text>
                  <text x="156" y="100">(6</text>
                  <text x="196" y="100">bytes)</text>
                  <text x="36" y="132">0x45</text>
                  <text x="100" y="132">Successful</text>
                  <text x="180" y="132">Response</text>
                  <text x="236" y="132">Code</text>
                  <text x="268" y="132">69</text>
                  <text x="304" y="132">"2.05</text>
                  <text x="364" y="132">Content"</text>
                  <text x="68" y="164">0xff</text>
                  <text x="120" y="164">Payload</text>
                  <text x="180" y="164">marker</text>
                  <text x="124" y="196">0x32332043</text>
                  <text x="200" y="196">Payload</text>
                  <text x="200" y="260">Inner</text>
                  <text x="244" y="260">SCHC</text>
                  <text x="312" y="260">Compression</text>
                  <text x="60" y="340">Compressed</text>
                  <text x="144" y="340">Plaintext</text>
                  <text x="76" y="372">0x028c8cc810c0</text>
                  <text x="148" y="372">(6</text>
                  <text x="188" y="372">bytes)</text>
                  <text x="44" y="420">RuleID</text>
                  <text x="80" y="420">=</text>
                  <text x="108" y="420">0x02</text>
                  <text x="64" y="468">Compression</text>
                  <text x="144" y="468">residue</text>
                  <text x="32" y="484">and</text>
                  <text x="76" y="484">padded</text>
                  <text x="136" y="484">payload</text>
                  <text x="176" y="484">=</text>
                  <text x="236" y="484">0x8c8cc810c0</text>
                  <text x="300" y="484">(5</text>
                  <text x="340" y="484">bytes)</text>
                  <text x="36" y="516">0b10</text>
                  <text x="68" y="516">(2</text>
                  <text x="100" y="516">bits</text>
                  <text x="176" y="516">match-mapping</text>
                  <text x="280" y="516">Compression</text>
                  <text x="364" y="516">Residue)</text>
                  <text x="108" y="532">0x32332043</text>
                  <text x="164" y="532">&gt;&gt;</text>
                  <text x="184" y="532">2</text>
                  <text x="228" y="532">(shifted</text>
                  <text x="300" y="532">payload)</text>
                  <text x="236" y="548">0b000000</text>
                  <text x="304" y="548">Padding</text>
                  <text x="196" y="612">AEAD</text>
                  <text x="260" y="612">Encryption</text>
                  <text x="204" y="628">(piv</text>
                  <text x="232" y="628">=</text>
                  <text x="264" y="628">0x04)</text>
                  <text x="104" y="708">encrypted_plaintext</text>
                  <text x="192" y="708">=</text>
                  <text x="260" y="708">0x10c6d7c26cc1</text>
                  <text x="332" y="708">(6</text>
                  <text x="372" y="708">bytes)</text>
                  <text x="40" y="724">tag</text>
                  <text x="64" y="724">=</text>
                  <text x="148" y="724">0xe9aef3f2461e0c29</text>
                  <text x="236" y="724">(8</text>
                  <text x="276" y="724">bytes)</text>
                  <text x="68" y="756">ciphertext</text>
                  <text x="120" y="756">=</text>
                  <text x="252" y="756">0x10c6d7c26cc1e9aef3f2461e0c29</text>
                  <text x="392" y="756">(14</text>
                  <text x="436" y="756">bytes)</text>
                </g>
              </svg>
            </artwork>
            <artwork type="ascii-art" align="center"><![CDATA[
+-------------------------------------------------+
|                                                 |
| OSCORE Plaintext                                |
|                                                 |
| 0x45ff32332043  (6 bytes)                       |
|                                                 |
| 0x45 Successful Response Code 69 "2.05 Content" |
|                                                 |
|     0xff Payload marker                         |
|                                                 |
|         0x32332043 Payload                      |
|                                                 |
+-------------------------------------------------+
                    |
                    | Inner SCHC Compression
                    |
                    v
+-------------------------------------------------+
|                                                 |
| Compressed Plaintext                            |
|                                                 |
| 0x028c8cc810c0 (6 bytes)                        |
|                                                 |
|                                                 |
| RuleID = 0x02                                   |
|                                                 |
|                                                 |
| Compression residue                             |
| and padded payload = 0x8c8cc810c0 (5 bytes)     |
|                                                 |
| 0b10 (2 bits match-mapping Compression Residue) |
|       0x32332043 >> 2 (shifted payload)         |
|                        0b000000 Padding         |
|                                                 |
+-------------------------------------------------+
                    |
                    | AEAD Encryption
                    |  (piv = 0x04)
                    |
                    v
+---------------------------------------------------------+
|                                                         |
|  encrypted_plaintext = 0x10c6d7c26cc1 (6 bytes)         |
|  tag = 0xe9aef3f2461e0c29 (8 bytes)                     |
|                                                         |
|  ciphertext = 0x10c6d7c26cc1e9aef3f2461e0c29 (14 bytes) |
|                                                         |
+---------------------------------------------------------+

]]></artwork>
          </artset>
        </figure>
        <t>After having performed the SCHC Inner Compression of the CoAP request in <xref target="fig-example-req"/>, the Device protects it with OSCORE by considering the Compressed Plaintext in <xref target="fig-plaintext-req"/>. The result is the OSCORE-protected CoAP request shown in <xref target="fig-example-oscore-req"/>.</t>
        <figure anchor="fig-example-oscore-req">
          <name>Protected and Inner SCHC Compressed CoAP GET Request.</name>
          <artwork align="left"><![CDATA[
Protected message:
==================
0x41020001823b6578616d706c652e636f6d
  6409040005d411636f6170ffa2cfc54fe1b434297b62
(39 bytes)

Header:
0x4102
01   Ver
  00   CON
    0001   TKL
        00000010   Request Code 2 (POST)

0x0001   MID
0x82   Token

Options:

0x3b6578616d706c652e636f6d
Option 3: Uri-Host
Value = "example.com"

0x6409040005
Option 9: OSCORE
Value = 0x09040005
          09 = 000 0 1 001 flags
                   h k  n
            04 piv
              0005 kid

0xd411636f6170
Option 39: Proxy-Scheme
Value = "coap"


0xFF Payload marker

Payload:
0xa2cfc54fe1b434297b62 (10 bytes)

]]></artwork>
        </figure>
        <t>Then, the Device applies the Rule in <xref target="fig-rules-oscore-device-proxy"/> shared with the proxy to the OSCORE-protected CoAP request in <xref target="fig-example-oscore-req"/>, thus performing the SCHC Outer Compression of such request. The result is the OSCORE-protected and Outer Compressed CoAP request shown in <xref target="fig-example-oscore-req-to-proxy"/> that the Device sends to the proxy.</t>
        <figure anchor="fig-example-oscore-req-to-proxy">
          <name>SCHC-OSCORE CoAP GET Request Compressed for the Proxy.</name>
          <artwork align="left"><![CDATA[
Compressed message:
=================
0x03156caf0c2dae0d8ca5cc6deda88b459f8a9fc3686852f6c4 (25 bytes)
0x03 RuleID
    156caf0c2dae0d8ca5cc6deda88b compression residue
                                459f8a9fc3686852f6c4 padded payload

Compression Residue
0b0001   010      1011 | 0x6578616d706c652e636f6d |
   MID Token  Uri-Host (residue size and residue)

0b0100  0100 0101
   piv   kid (residue size and residue)

   (111 bits -> 14 bytes with padding)

Payload
0xa2cfc54fe1b434297b62 (10 bytes)

Compressed message length: 25 bytes

]]></artwork>
        </figure>
        <t>Upon receiving the message in <xref target="fig-example-oscore-req-to-proxy"/>, the proxy decompresses it with the Rule in <xref target="fig-rules-oscore-device-proxy"/> shared with the Device, thus performing the SCHC Outer Decompression. The result is the same OSCORE-protected CoAP request in <xref target="fig-example-oscore-req"/>.</t>
        <t>After that, the proxy removes the Proxy-Scheme Option from the decompressed OSCORE-protected CoAP request. Also, the proxy replaces the values of the CoAP Message ID and of the CoAP Token to 0x0004 and 0x75, respectively. The result is the OSCORE-protected CoAP request shown in <xref target="fig-example-oscore-req-from-proxy"/>.</t>
        <figure anchor="fig-example-oscore-req-from-proxy">
          <name>SCHC-OSCORE CoAP GET Request to be Compressed by the Proxy.</name>
          <artwork align="left"><![CDATA[
Protected message:
==================
0x41020004753b6578616d706c652e636f6d
  6409040005ffa2cfc54fe1b434297b62
(33 bytes)

Header:
0x4102
01   Ver
  00   CON
    0001   TKL
        00000010   Request Code 2 (POST)

0x0004   MID
0x75   Token

Options:

0x3b6578616d706c652e636f6d
Option 3: Uri-Host
Value = "example.com"

0x6409040005
Option 9: OSCORE
Value = 0x09040005
          09 = 000 0 1 001 flags
                   h k  n
            04 piv
              0005 kid


0xFF Payload marker

Payload:
0xa2cfc54fe1b434297b62 (10 bytes)

]]></artwork>
        </figure>
        <t>Then, the proxy applies the Rule in <xref target="fig-rules-oscore-proxy-server"/> shared with the Application Server to the OSCORE-protected CoAP request in <xref target="fig-example-oscore-req-from-proxy"/>, thus performing the SCHC Outer Compression of such request. The result is the OSCORE-protected and Outer Compressed CoAP request shown in <xref target="fig-example-oscore-req-from-proxy-compressed"/> that the proxy forwards to the Application Server.</t>
        <figure anchor="fig-example-oscore-req-from-proxy-compressed">
          <name>SCHC-OSCORE CoAP GET Request Forwarded by the Proxy.</name>
          <artwork align="left"><![CDATA[
Compressed message:
=================
0x044b6caf0c2dae0d8ca5cc6deda88b459f8a9fc3686852f6c4 (25 bytes)
0x04 RuleID
    4b6caf0c2dae0d8ca5cc6deda88b compression residue
                                459f8a9fc3686852f6c4 padded payload


Compression Residue
0b0100   101      1011 | 0x6578616d706c652e636f6d |
   MID Token  Uri-Host (residue size and residue)

0b0100  0100 0101
   piv   kid (residue size and residue)

   (111 bits -> 14 bytes with padding)


Payload
0xa2cfc54fe1b434297b62 (10 bytes)

Compressed message length: 25 bytes

]]></artwork>
        </figure>
        <t>Upon receiving the message in <xref target="fig-example-oscore-req-from-proxy-compressed"/>, the Application Server decompresses it using the Rule in <xref target="fig-rules-oscore-proxy-server"/> shared with the proxy, thus performing the SCHC Outer Decompression. The result is the same OSCORE-protected CoAP request in <xref target="fig-example-oscore-req-from-proxy"/>.</t>
        <t>The Application Server decrypts and verifies such a request, which results in the same Compressed Plaintext in <xref target="fig-plaintext-req"/>. Then, the Application Server applies the Rule in <xref target="fig-rules-oscore-device-server"/> shared with the Device to such a Compressed Plaintext, thus performing the SCHC Inner Decompression. The result is used to rebuild the same CoAP request in <xref target="fig-example-req"/> that the Application Server delivers to the application.</t>
        <t>After having performed the SCHC Inner Compression of the CoAP response in <xref target="fig-example-resp"/>, the Application Server protects it with OSCORE by considering the Compressed Plaintext in <xref target="fig-plaintext-resp"/>. The result is the OSCORE-protected CoAP response shown in <xref target="fig-example-oscore-resp"/>.</t>
        <figure anchor="fig-example-oscore-resp">
          <name>Protected and Inner SCHC Compressed CoAP Content Response.</name>
          <artwork align="left"><![CDATA[
Protected message:
==================
0x614400047590ff10c6d7c26cc1e9aef3f2461e0c29
(21 bytes)

Header:
0x6144
01   Ver
  10   ACK
    0001   TKL
        01000100   Successful Response Code 68 (2.04 Changed)

0x0004   MID
0x75   Token

Options:

0x90
Option 9: OSCORE
Value = 0x (empty)


0xFF Payload marker

Payload:
0x10c6d7c26cc1e9aef3f2461e0c29 (14 bytes)

]]></artwork>
        </figure>
        <t>Then, the Application Server applies the Rule in <xref target="fig-rules-oscore-proxy-server"/> shared with the proxy to the OSCORE-protected CoAP response in <xref target="fig-example-oscore-resp"/>, thus performing the SCHC Outer Compression of such response. The result is the OSCORE-protected and Outer Compressed CoAP response shown in <xref target="fig-example-oscore-resp-to-proxy"/> that the Application Server sends to the proxy.</t>
        <figure anchor="fig-example-oscore-resp-to-proxy">
          <name>SCHC-OSCORE CoAP Content Response Compressed for the Proxy.</name>
          <artwork align="left"><![CDATA[
Compressed message:
=================
0x04a510c6d7c26cc1e9aef3f2461e0c29  (16 bytes)
0x04 RuleID
    a510c6d7c26cc1e9aef3f2461e0c29 compression residue
                                   and padded payload


Compression Residue (8 bits -> 1 byte with padding)
0b    1 0100   101
   Type  MID Token

Payload
0x10c6d7c26cc1e9aef3f2461e0c29 (14 bytes)

Compressed message length: 16 bytes

]]></artwork>
        </figure>
        <t>Upon receiving the message in <xref target="fig-example-oscore-resp-to-proxy"/>, the proxy decompresses it with the Rule in <xref target="fig-rules-oscore-proxy-server"/> shared with the Application Server, thus performing the SCHC Outer Decompression. The result is the same OSCORE-protected CoAP response in <xref target="fig-example-oscore-resp"/>.</t>
        <t>After that, the proxy replaces the values of the CoAP Message ID and of the CoAP Token to 0x0001 and 0x82, respectively. The result is the OSCORE-protected CoAP response shown in <xref target="fig-example-oscore-resp-from-proxy"/>.</t>
        <figure anchor="fig-example-oscore-resp-from-proxy">
          <name>SCHC-OSCORE CoAP Content Response to be Compressed by the Proxy.</name>
          <artwork align="left"><![CDATA[
Protected message:
==================
0x614400018290ff10c6d7c26cc1e9aef3f2461e0c29
(21 bytes)

Header:
0x6144
01   Ver
  10   ACK
    0001   TKL
        01000100   Successful Response Code 68 (2.04 Changed)

0x0001   MID
0x82   Token

Options:

0x90
Option 9: OSCORE
Value = 0x (empty)


0xFF Payload marker

Payload:
0x10c6d7c26cc1e9aef3f2461e0c29 (14 bytes)

]]></artwork>
        </figure>
        <t>Then, the proxy applies the Rule in <xref target="fig-rules-oscore-device-proxy"/> shared with the Device to the OSCORE-protected CoAP response in <xref target="fig-example-oscore-resp-from-proxy"/>, thus performing the SCHC Outer Compression of such response. The result is the OSCORE-protected and Outer Compressed CoAP response shown in <xref target="fig-example-oscore-resp-from-proxy-compressed"/> that the proxy forwards to the Device.</t>
        <figure anchor="fig-example-oscore-resp-from-proxy-compressed">
          <name>SCHC-OSCORE CoAP Content Response Forwarded by the Proxy.</name>
          <artwork align="left"><![CDATA[
Compressed message:
=================
0x038a10c6d7c26cc1e9aef3f2461e0c29 (16 bytes)
0x03 RuleID
    8a10c6d7c26cc1e9aef3f2461e0c29 compression residue
                                   and padded payload


Compression Residue (8 bits -> 1 byte with padding)
0b    1 0001   010
   Type  MID Token

Payload
0x10c6d7c26cc1e9aef3f2461e0c29 (14 bytes)

Compressed message length: 16 bytes

]]></artwork>
        </figure>
        <t>Upon receiving the message in <xref target="fig-example-oscore-resp-from-proxy-compressed"/>, the Device decompresses it using the Rule in <xref target="fig-rules-oscore-device-proxy"/> shared with the proxy, thus performing the SCHC Outer Decompression. The result is the same OSCORE-protected CoAP response in <xref target="fig-example-oscore-resp-from-proxy"/>.</t>
        <t>The Device decrypts and verifies such a response, which results in the same Compressed Plaintext shown in <xref target="fig-plaintext-resp"/>. Then, the Device applies the Rule in <xref target="fig-rules-oscore-device-server"/> shared with the Application Server to such a Compressed Plaintext, thus performing the SCHC Inner Decompression. The result is used to rebuild the same CoAP response in <xref target="fig-example-resp"/> that the Device delivers to the application.</t>
      </section>
    </section>
    <section anchor="sec-coap-fields">
      <name>CoAP Fields</name>
      <t><xref target="_table-coap-fields"/> lists the CoAP fields and subfields for which SCHC compression has been defined or revised in this document.</t>
      <t>Editor's note: Before publication, confirm or amend the option numbers associated with the CoAP options Proxy-Cri and Proxy-Scheme-Number defined in <xref target="I-D.ietf-core-href"/>, to ensure that they are consistent with those registered in the "CoAP Option Numbers" registry.</t>
      <table align="center" anchor="_table-coap-fields">
        <name>CoAP Fields.</name>
        <thead>
          <tr>
            <th align="left">Field</th>
            <th align="left">Description</th>
          </tr>
        </thead>
        <tbody>
          <tr>
            <td align="left">CoAP.Version</td>
            <td align="left">CoAP header field Version <xref target="RFC7252"/></td>
          </tr>
          <tr>
            <td align="left">CoAP.Type</td>
            <td align="left">CoAP header field Type <xref target="RFC7252"/></td>
          </tr>
          <tr>
            <td align="left">CoAP.TKL</td>
            <td align="left">CoAP header field Token Length (TKL) <xref target="RFC7252"/><xref target="RFC8974"/></td>
          </tr>
          <tr>
            <td align="left">CoAP.Code</td>
            <td align="left">CoAP header field Code <xref target="RFC7252"/></td>
          </tr>
          <tr>
            <td align="left">CoAP.Code.Class</td>
            <td align="left">CoAP header field Code (subfield Class) <xref target="RFC7252"/></td>
          </tr>
          <tr>
            <td align="left">CoAP.Code.Detail</td>
            <td align="left">CoAP header field Code (subfield Detail) <xref target="RFC7252"/></td>
          </tr>
          <tr>
            <td align="left">CoAP.MID</td>
            <td align="left">CoAP header field Message ID <xref target="RFC7252"/></td>
          </tr>
          <tr>
            <td align="left">CoAP.Token</td>
            <td align="left">CoAP field Token <xref target="RFC7252"/><xref target="RFC8974"/></td>
          </tr>
          <tr>
            <td align="left">CoAP.option(1)</td>
            <td align="left">CoAP option If-Match <xref target="RFC7252"/></td>
          </tr>
          <tr>
            <td align="left">CoAP.option(3)</td>
            <td align="left">CoAP option Uri-Host <xref target="RFC7252"/></td>
          </tr>
          <tr>
            <td align="left">CoAP.option(4)</td>
            <td align="left">CoAP option ETag <xref target="RFC7252"/></td>
          </tr>
          <tr>
            <td align="left">CoAP.option(5)</td>
            <td align="left">CoAP option If-None-Match <xref target="RFC7252"/></td>
          </tr>
          <tr>
            <td align="left">CoAP.option(6)</td>
            <td align="left">CoAP option Observe <xref target="RFC7641"/></td>
          </tr>
          <tr>
            <td align="left">CoAP.option(7)</td>
            <td align="left">CoAP option Uri-Port <xref target="RFC7252"/></td>
          </tr>
          <tr>
            <td align="left">CoAP.option(8)</td>
            <td align="left">CoAP option Location-Path <xref target="RFC7252"/></td>
          </tr>
          <tr>
            <td align="left">CoAP.option(9)</td>
            <td align="left">CoAP option OSCORE <xref target="RFC8613"/><xref target="I-D.ietf-core-oscore-key-update"/></td>
          </tr>
          <tr>
            <td align="left">CoAP.option(9).flags</td>
            <td align="left">CoAP option OSCORE (subfield flags) <xref target="RFC8613"/><xref target="I-D.ietf-core-oscore-key-update"/></td>
          </tr>
          <tr>
            <td align="left">CoAP.option(9).piv</td>
            <td align="left">CoAP option OSCORE (subfield piv) <xref target="RFC8613"/></td>
          </tr>
          <tr>
            <td align="left">CoAP.option(9).kid_ctx</td>
            <td align="left">CoAP option OSCORE (subfield kid_ctx) <xref target="RFC8613"/></td>
          </tr>
          <tr>
            <td align="left">CoAP.option(9).x</td>
            <td align="left">CoAP option OSCORE (subfield x) <xref target="I-D.ietf-core-oscore-key-update"/></td>
          </tr>
          <tr>
            <td align="left">CoAP.option(9).nonce</td>
            <td align="left">CoAP option OSCORE (subfield nonce) <xref target="I-D.ietf-core-oscore-key-update"/></td>
          </tr>
          <tr>
            <td align="left">CoAP.option(9).kid</td>
            <td align="left">CoAP option OSCORE (subfield kid) <xref target="RFC8613"/></td>
          </tr>
          <tr>
            <td align="left">CoAP.option(11)</td>
            <td align="left">CoAP option Uri-Path <xref target="RFC7252"/></td>
          </tr>
          <tr>
            <td align="left">CoAP.option(12)</td>
            <td align="left">CoAP option Content-Format <xref target="RFC7252"/></td>
          </tr>
          <tr>
            <td align="left">CoAP.option(14)</td>
            <td align="left">CoAP option Max-Age <xref target="RFC7252"/></td>
          </tr>
          <tr>
            <td align="left">CoAP.option(15)</td>
            <td align="left">CoAP option Uri-Query <xref target="RFC7252"/></td>
          </tr>
          <tr>
            <td align="left">CoAP.option(16)</td>
            <td align="left">CoAP option Hop-Limit <xref target="RFC8768"/></td>
          </tr>
          <tr>
            <td align="left">CoAP.option(17)</td>
            <td align="left">CoAP option Accept <xref target="RFC7252"/></td>
          </tr>
          <tr>
            <td align="left">CoAP.option(19)</td>
            <td align="left">CoAP option Q-Block1 <xref target="RFC9177"/></td>
          </tr>
          <tr>
            <td align="left">CoAP.option(20)</td>
            <td align="left">CoAP option Location-Query <xref target="RFC7252"/></td>
          </tr>
          <tr>
            <td align="left">CoAP.option(21)</td>
            <td align="left">CoAP option EDHOC <xref target="RFC9668"/></td>
          </tr>
          <tr>
            <td align="left">CoAP.option(23)</td>
            <td align="left">CoAP option Block2 <xref target="RFC7959"/><xref target="RFC8323"/></td>
          </tr>
          <tr>
            <td align="left">CoAP.option(27)</td>
            <td align="left">CoAP option Block1 <xref target="RFC7959"/><xref target="RFC8323"/></td>
          </tr>
          <tr>
            <td align="left">CoAP.option(28)</td>
            <td align="left">CoAP option Size2 <xref target="RFC7959"/></td>
          </tr>
          <tr>
            <td align="left">CoAP.option(31)</td>
            <td align="left">CoAP option Q-Block2 <xref target="RFC9177"/></td>
          </tr>
          <tr>
            <td align="left">CoAP.option(35)</td>
            <td align="left">CoAP option Proxy-Uri <xref target="RFC7252"/></td>
          </tr>
          <tr>
            <td align="left">CoAP.option(39)</td>
            <td align="left">CoAP option Proxy-Scheme <xref target="RFC7252"/></td>
          </tr>
          <tr>
            <td align="left">CoAP.option(60)</td>
            <td align="left">CoAP option Size1 <xref target="RFC7252"/></td>
          </tr>
          <tr>
            <td align="left">CoAP.option(235)</td>
            <td align="left">CoAP option Proxy-Cri <xref target="I-D.ietf-core-href"/></td>
          </tr>
          <tr>
            <td align="left">CoAP.option(239)</td>
            <td align="left">CoAP option Proxy-Scheme-Number <xref target="I-D.ietf-core-href"/></td>
          </tr>
          <tr>
            <td align="left">CoAP.option(252)</td>
            <td align="left">CoAP option Echo <xref target="RFC9175"/></td>
          </tr>
          <tr>
            <td align="left">CoAP.option(258)</td>
            <td align="left">CoAP option No-Response <xref target="RFC7967"/></td>
          </tr>
          <tr>
            <td align="left">CoAP.option(292)</td>
            <td align="left">CoAP option Request-Tag <xref target="RFC9175"/></td>
          </tr>
        </tbody>
      </table>
    </section>
    <section anchor="security-considerations">
      <name>Security Considerations</name>
      <t>The use of SCHC header compression for CoAP header fields only affects the representation of the header information. SCHC header compression itself does not increase or decrease the overall level of security of the communication. When the connection does not use a security protocol (e.g., OSCORE or DTLS), it is necessary to use a Layer 2 security mechanism to protect the SCHC packets.</t>
      <t>If an LPWAN is the Layer 2 technology being used, the SCHC security considerations discussed in <xref target="RFC8724"/> continue to apply. When using another Layer 2 protocol, the use of a cryptographic integrity-protection mechanism to protect the SCHC headers is <bcp14>REQUIRED</bcp14>. Such cryptographic integrity protection is necessary in order to continue to provide the properties that <xref target="RFC8724"/> relies upon.</t>
      <t>When SCHC is used with OSCORE, the security considerations discussed in <xref target="RFC8613"/> continue to apply. When SCHC is used with Group OSCORE, the security considerations discussed in <xref target="I-D.ietf-core-oscore-groupcomm"/> apply. When SCHC is used in the presence of CoAP proxies, the security considerations discussed in <xref section="11.2" sectionFormat="of" target="RFC7252"/> continue to apply.</t>
      <t>When SCHC is used with the OSCORE Outer headers, the Initialization Vector (IV) size in the Compression Residue must be carefully selected. There is a trade-off between compression efficiency (with a longer MSB MO prefix) and the frequency at which the Device must renew its key material (in order to prevent the IV from expanding to an incompressible value). The key-renewal operation itself may require several message exchanges and result in energy-intensive computation, but the optimal trade-off will depend on the specifics of the Device and expected usage patterns. In order to renew its key material with another OSCORE endpoint, the Device can rely on the lightweight key update protocol KUDOS defined in <xref target="I-D.ietf-core-oscore-key-update"/>.</t>
      <t>If an attacker can introduce a corrupted SCHC-compressed packet onto a link, DoS attacks can be mounted by causing excessive resource consumption at the decompressor. However, an attacker able to inject packets at the link layer is also capable of other, potentially more damaging, attacks.</t>
      <t>SCHC compression emits variable-length Compression Residues for some CoAP fields. In the representation of the compressed header, the length field that is sent is not the length of the original header field but rather the length of the Compression Residue that is being transmitted. If a corrupted packet arrives at the decompressor with a longer or shorter length than that of the original compressed representation, the SCHC decompression procedures will detect an error and drop the packet.</t>
      <t>SCHC header compression Rules <bcp14>MUST</bcp14> remain tightly coupled between the compressor and the decompressor. If the compression Rules get out of sync, a Compression Residue might be decompressed differently at the receiver, thus yielding a result different than the initial message submitted to compression procedures. Accordingly, any time the context Rules are updated on an OSCORE endpoint, that endpoint <bcp14>MUST</bcp14> trigger OSCORE key re-establishment, e.g., by running the lightweight key update protocol KUDOS <xref target="I-D.ietf-core-oscore-key-update"/>. Similar procedures may be appropriate to signal Rule updates when other message-protection mechanisms are in use.</t>
      <section anchor="sec-security-considerations-yang-module">
        <name>YANG Module</name>
        <t>The YANG data model defined in <xref target="sec-yang-module"/> extends the ietf-schc module defined in <xref target="RFC9363"/>.</t>
        <t>Therefore, all the security considerations compiled in <xref section="8" sectionFormat="of" target="RFC9363"/> also apply to the resulting extended YANG data model.</t>
      </section>
    </section>
    <section anchor="iana-considerations">
      <name>IANA Considerations</name>
      <t>This document has the following actions for IANA.</t>
      <t>Note to RFC Editor: Please replace all occurrences of "[RFC-XXXX]" with the RFC number of this specification and delete this paragraph.</t>
      <section anchor="ietf-xml">
        <name>IETF XML</name>
        <t>IANA is asked to register the following entry in the "IETF XML" registry <xref target="RFC3688"/>.</t>
        <ul spacing="normal">
          <li>
            <t>URI: urn:ietf:params:xml:ns:yang:ietf-schc-coap</t>
          </li>
          <li>
            <t>Registrant Contact: The IESG.</t>
          </li>
          <li>
            <t>XML: N/A; the requested URI is an XML namespace.</t>
          </li>
        </ul>
      </section>
      <section anchor="yang-module-names">
        <name>YANG Module Names</name>
        <t>IANA is asked to register the following entry in the "YANG Module Names" registry <xref target="RFC6020"/><xref target="RFC8407"/> within the "YANG Parameters" registry group.</t>
        <ul spacing="normal">
          <li>
            <t>Name: ietf-schc-coap</t>
          </li>
          <li>
            <t>Namespace: urn:ietf:params:xml:ns:yang:ietf-schc-coap</t>
          </li>
          <li>
            <t>Prefix: schc-coap</t>
          </li>
          <li>
            <t>Reference: [RFC-XXXX]</t>
          </li>
        </ul>
      </section>
      <section anchor="sec-iana-coap-fields">
        <name>SCHC Compression of CoAP Fields</name>
        <t>IANA is asked to establish the "SCHC Compression of CoAP Fields" IANA registry.</t>
        <t>As registration policy, the registry uses "Specification Required" per <xref section="4.6" sectionFormat="of" target="RFC8126"/>. Expert Review guidelines are provided in <xref target="sec-iana-expert-review"/>.</t>
        <section anchor="intended-use">
          <name>Intended Use</name>
          <t>The objective of this registry is to collect a list of CoAP fields and subfields, for which it has been defined how to perform SCHC compression.</t>
          <t>Such a definition does not necessarily have to be in the same documentation that defines the CoAP fields and subfields in question. While that can be the case, it is also possible to provide that definition in a separate specification.</t>
          <t>Each entry of the registry is intended to include references to the documentation that defines the associated CoAP field or subfield, as well as references to the specifications that define the SCHC compression of that CoAP field or subfield.</t>
          <t>When a specification defines how to perform SCHC compression of a CoAP field, the following applies.</t>
          <ul spacing="normal">
            <li>
              <t>If a registry entry for the CoAP field does not already exist, it is strongly encouraged to register an associated new entry.</t>
            </li>
            <li>
              <t>If a registry entry for the CoAP field already exists, it is strongly encouraged to update its list of references. The update is intended to add references to the specification that provides the new or updated SCHC compression of the CoAP field, as well as to any documentation that updates the definition of the CoAP field itself.</t>
            </li>
          </ul>
          <t>If the defined SCHC compression considers the CoAP field as composed of subfields, it is strongly encouraged that the same as above is also performed for each subfield and the associated registry entry.</t>
        </section>
        <section anchor="structure-of-entries">
          <name>Structure of Entries</name>
          <t>The columns of this registry are:</t>
          <ul spacing="normal">
            <li>
              <t>Field: a unique identifier of the CoAP field or subfield associated with this entry. This identifier is used as FID in a Field Descriptor of a SCHC compression Rule for compressing/decompressing CoAP messages.  </t>
              <t>
This identifier has two possible formats:  </t>
              <ul spacing="normal">
                <li>
                  <t>"CoAP.X", where X is the name of the CoAP field.</t>
                </li>
                <li>
                  <t>"CoAP.X.Y", where X is the name of the CoAP field and Y is the name of a subfield of X.</t>
                </li>
              </ul>
              <t>
If the CoAP field in question is specifically a CoAP option, then X has the format "option(N)", where N is the option number of the CoAP option. The value N is taken from the "Number" column of the corresponding entry in the "CoAP Option Numbers" IANA registry <xref target="CoAP.Option.Numbers"/>.  </t>
              <t>
Within the YANG data model originally specified in <xref section="6" sectionFormat="of" target="RFC9363"/>, this identifier must have a corresponding item or set of items for the CoAP field or subfield associated with this entry.</t>
            </li>
            <li>
              <t>Description: a short description of the CoAP field or subfield associated with this entry, together with public references to the resources that define it.</t>
            </li>
            <li>
              <t>Reference: public references to the resources that define how a SCHC compression Rule works for the CoAP field or subfield associated with this entry.</t>
            </li>
          </ul>
          <t>This registry has been initially populated with the values in <xref target="_table-coap-fields"/>. The "Reference" column for all these entries refers to this document.</t>
        </section>
      </section>
      <section anchor="sec-iana-expert-review">
        <name>Expert Review Instructions</name>
        <t>The IANA registry established in this document is defined as "Specification Required". This section gives some general guidelines for what the experts should be looking for, but they are being designated as experts for a reason so they should be given substantial latitude.</t>
        <t>Expert reviewers should take into consideration the following points:</t>
        <ul spacing="normal">
          <li>
            <t>Point squatting should be discouraged. Reviewers are encouraged to get sufficient information for registration requests to ensure that the usage is not going to duplicate one that is already registered and that the point is likely to be used in deployments.  </t>
            <t>
Specifically, for every CoAP field, only one corresponding registry entry is allowed. Also, for every CoAP subfield, only one corresponding registry entry is allowed.</t>
          </li>
          <li>
            <t>Consistent with the "Specification Required" registration policy, specifications should exist, but early assignment before a specification is available is considered to be permissible. When specifications are not provided, the description provided needs to have sufficient information to identify what the point is being used for.</t>
          </li>
        </ul>
        <t>If the expert becomes aware of a definition for SCHC compression of CoAP fields and subfields that is deployed and in use, the expert may also initiate a registration or update an existing one on their own, if they deem important that the definition in question gains visibility through the registry entry.</t>
      </section>
    </section>
  </middle>
  <back>
    <references anchor="sec-combined-references">
      <name>References</name>
      <references anchor="sec-normative-references">
        <name>Normative References</name>
        <reference anchor="RFC3688">
          <front>
            <title>The IETF XML Registry</title>
            <author fullname="M. Mealling" initials="M." surname="Mealling"/>
            <date month="January" year="2004"/>
            <abstract>
              <t>This document describes an IANA maintained registry for IETF standards which use Extensible Markup Language (XML) related items such as Namespaces, Document Type Declarations (DTDs), Schemas, and Resource Description Framework (RDF) Schemas.</t>
            </abstract>
          </front>
          <seriesInfo name="BCP" value="81"/>
          <seriesInfo name="RFC" value="3688"/>
          <seriesInfo name="DOI" value="10.17487/RFC3688"/>
        </reference>
        <reference anchor="RFC5116">
          <front>
            <title>An Interface and Algorithms for Authenticated Encryption</title>
            <author fullname="D. McGrew" initials="D." surname="McGrew"/>
            <date month="January" year="2008"/>
            <abstract>
              <t>This document defines algorithms for Authenticated Encryption with Associated Data (AEAD), and defines a uniform interface and a registry for such algorithms. The interface and registry can be used as an application-independent set of cryptoalgorithm suites. This approach provides advantages in efficiency and security, and promotes the reuse of crypto implementations. [STANDARDS-TRACK]</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="5116"/>
          <seriesInfo name="DOI" value="10.17487/RFC5116"/>
        </reference>
        <reference anchor="RFC6020">
          <front>
            <title>YANG - A Data Modeling Language for the Network Configuration Protocol (NETCONF)</title>
            <author fullname="M. Bjorklund" initials="M." role="editor" surname="Bjorklund"/>
            <date month="October" year="2010"/>
            <abstract>
              <t>YANG is a data modeling language used to model configuration and state data manipulated by the Network Configuration Protocol (NETCONF), NETCONF remote procedure calls, and NETCONF notifications. [STANDARDS-TRACK]</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="6020"/>
          <seriesInfo name="DOI" value="10.17487/RFC6020"/>
        </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="RFC7641">
          <front>
            <title>Observing Resources in the Constrained Application Protocol (CoAP)</title>
            <author fullname="K. Hartke" initials="K." surname="Hartke"/>
            <date month="September" year="2015"/>
            <abstract>
              <t>The Constrained Application Protocol (CoAP) is a RESTful application protocol for constrained nodes and networks. The state of a resource on a CoAP server can change over time. This document specifies a simple protocol extension for CoAP that enables CoAP clients to "observe" resources, i.e., to retrieve a representation of a resource and keep this representation updated by the server over a period of time. The protocol follows a best-effort approach for sending new representations to clients and provides eventual consistency between the state observed by each client and the actual resource state at the server.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="7641"/>
          <seriesInfo name="DOI" value="10.17487/RFC7641"/>
        </reference>
        <reference anchor="RFC7959">
          <front>
            <title>Block-Wise Transfers in the Constrained Application Protocol (CoAP)</title>
            <author fullname="C. Bormann" initials="C." surname="Bormann"/>
            <author fullname="Z. Shelby" initials="Z." role="editor" surname="Shelby"/>
            <date month="August" year="2016"/>
            <abstract>
              <t>The Constrained Application Protocol (CoAP) is a RESTful transfer protocol for constrained nodes and networks. Basic CoAP messages work well for small payloads from sensors and actuators; however, applications will need to transfer larger payloads occasionally -- for instance, for firmware updates. In contrast to HTTP, where TCP does the grunt work of segmenting and resequencing, CoAP is based on datagram transports such as UDP or Datagram Transport Layer Security (DTLS). These transports only offer fragmentation, which is even more problematic in constrained nodes and networks, limiting the maximum size of resource representations that can practically be transferred.</t>
              <t>Instead of relying on IP fragmentation, this specification extends basic CoAP with a pair of "Block" options for transferring multiple blocks of information from a resource representation in multiple request-response pairs. In many important cases, the Block options enable a server to be truly stateless: the server can handle each block transfer separately, with no need for a connection setup or other server-side memory of previous block transfers. Essentially, the Block options provide a minimal way to transfer larger representations in a block-wise fashion.</t>
              <t>A CoAP implementation that does not support these options generally is limited in the size of the representations that can be exchanged, so there is an expectation that the Block options will be widely used in CoAP implementations. Therefore, this specification updates RFC 7252.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="7959"/>
          <seriesInfo name="DOI" value="10.17487/RFC7959"/>
        </reference>
        <reference anchor="RFC7967">
          <front>
            <title>Constrained Application Protocol (CoAP) Option for No Server Response</title>
            <author fullname="A. Bhattacharyya" initials="A." surname="Bhattacharyya"/>
            <author fullname="S. Bandyopadhyay" initials="S." surname="Bandyopadhyay"/>
            <author fullname="A. Pal" initials="A." surname="Pal"/>
            <author fullname="T. Bose" initials="T." surname="Bose"/>
            <date month="August" year="2016"/>
            <abstract>
              <t>There can be machine-to-machine (M2M) scenarios where server responses to client requests are redundant. This kind of open-loop exchange (with no response path from the server to the client) may be desired to minimize resource consumption in constrained systems while updating many resources simultaneously or performing high-frequency updates. CoAP already provides Non-confirmable (NON) messages that are not acknowledged by the recipient. However, the request/response semantics still require the server to respond with a status code indicating "the result of the attempt to understand and satisfy the request", per RFC 7252.</t>
              <t>This specification introduces a CoAP option called 'No-Response'. Using this option, the client can explicitly express to the server its disinterest in all responses against the particular request. This option also provides granular control to enable expression of disinterest to a particular response class or a combination of response classes. The server MAY decide to suppress the response by not transmitting it back to the client according to the value of the No-Response option in the request. This option may be effective for both unicast and multicast requests. This document also discusses a few examples of applications that benefit from this option.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="7967"/>
          <seriesInfo name="DOI" value="10.17487/RFC7967"/>
        </reference>
        <reference anchor="RFC8126">
          <front>
            <title>Guidelines for Writing an IANA Considerations Section in RFCs</title>
            <author fullname="M. Cotton" initials="M." surname="Cotton"/>
            <author fullname="B. Leiba" initials="B." surname="Leiba"/>
            <author fullname="T. Narten" initials="T." surname="Narten"/>
            <date month="June" year="2017"/>
            <abstract>
              <t>Many protocols make use of points of extensibility that use constants to identify various protocol parameters. To ensure that the values in these fields do not have conflicting uses and to promote interoperability, their allocations are often coordinated by a central record keeper. For IETF protocols, that role is filled by the Internet Assigned Numbers Authority (IANA).</t>
              <t>To make assignments in a given registry prudently, guidance describing the conditions under which new values should be assigned, as well as when and how modifications to existing values can be made, is needed. This document defines a framework for the documentation of these guidelines by specification authors, in order to assure that the provided guidance for the IANA Considerations is clear and addresses the various issues that are likely in the operation of a registry.</t>
              <t>This is the third edition of this document; it obsoletes RFC 5226.</t>
            </abstract>
          </front>
          <seriesInfo name="BCP" value="26"/>
          <seriesInfo name="RFC" value="8126"/>
          <seriesInfo name="DOI" value="10.17487/RFC8126"/>
        </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="RFC8407">
          <front>
            <title>Guidelines for Authors and Reviewers of Documents Containing YANG Data Models</title>
            <author fullname="A. Bierman" initials="A." surname="Bierman"/>
            <date month="October" year="2018"/>
            <abstract>
              <t>This memo provides guidelines for authors and reviewers of specifications containing YANG modules. Recommendations and procedures are defined, which are intended to increase interoperability and usability of Network Configuration Protocol (NETCONF) and RESTCONF protocol implementations that utilize YANG modules. This document obsoletes RFC 6087.</t>
            </abstract>
          </front>
          <seriesInfo name="BCP" value="216"/>
          <seriesInfo name="RFC" value="8407"/>
          <seriesInfo name="DOI" value="10.17487/RFC8407"/>
        </reference>
        <reference anchor="RFC8613">
          <front>
            <title>Object Security for Constrained RESTful Environments (OSCORE)</title>
            <author fullname="G. Selander" initials="G." surname="Selander"/>
            <author fullname="J. Mattsson" initials="J." surname="Mattsson"/>
            <author fullname="F. Palombini" initials="F." surname="Palombini"/>
            <author fullname="L. Seitz" initials="L." surname="Seitz"/>
            <date month="July" year="2019"/>
            <abstract>
              <t>This document defines Object Security for Constrained RESTful Environments (OSCORE), a method for application-layer protection of the Constrained Application Protocol (CoAP), using CBOR Object Signing and Encryption (COSE). OSCORE provides end-to-end protection between endpoints communicating using CoAP or CoAP-mappable HTTP. OSCORE is designed for constrained nodes and networks supporting a range of proxy operations, including translation between different transport protocols.</t>
              <t>Although an optional functionality of CoAP, OSCORE alters CoAP options processing and IANA registration. Therefore, this document updates RFC 7252.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="8613"/>
          <seriesInfo name="DOI" value="10.17487/RFC8613"/>
        </reference>
        <reference anchor="RFC8724">
          <front>
            <title>SCHC: Generic Framework for Static Context Header Compression and Fragmentation</title>
            <author fullname="A. Minaburo" initials="A." surname="Minaburo"/>
            <author fullname="L. Toutain" initials="L." surname="Toutain"/>
            <author fullname="C. Gomez" initials="C." surname="Gomez"/>
            <author fullname="D. Barthel" initials="D." surname="Barthel"/>
            <author fullname="JC. Zuniga" initials="JC." surname="Zuniga"/>
            <date month="April" year="2020"/>
            <abstract>
              <t>This document defines the Static Context Header Compression and fragmentation (SCHC) framework, which provides both a header compression mechanism and an optional fragmentation mechanism. SCHC has been designed with Low-Power Wide Area Networks (LPWANs) in mind.</t>
              <t>SCHC compression is based on a common static context stored both in the LPWAN device and in the network infrastructure side. This document defines a generic header compression mechanism and its application to compress IPv6/UDP headers.</t>
              <t>This document also specifies an optional fragmentation and reassembly mechanism. It can be used to support the IPv6 MTU requirement over the LPWAN technologies. Fragmentation is needed for IPv6 datagrams that, after SCHC compression or when such compression was not possible, still exceed the Layer 2 maximum payload size.</t>
              <t>The SCHC header compression and fragmentation mechanisms are independent of the specific LPWAN technology over which they are used. This document defines generic functionalities and offers flexibility with regard to parameter settings and mechanism choices. This document standardizes the exchange over the LPWAN between two SCHC entities. Settings and choices specific to a technology or a product are expected to be grouped into profiles, which are specified in other documents. Data models for the context and profiles are out of scope.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="8724"/>
          <seriesInfo name="DOI" value="10.17487/RFC8724"/>
        </reference>
        <reference anchor="RFC8768">
          <front>
            <title>Constrained Application Protocol (CoAP) Hop-Limit Option</title>
            <author fullname="M. Boucadair" initials="M." surname="Boucadair"/>
            <author fullname="T. Reddy.K" initials="T." surname="Reddy.K"/>
            <author fullname="J. Shallow" initials="J." surname="Shallow"/>
            <date month="March" year="2020"/>
            <abstract>
              <t>The presence of Constrained Application Protocol (CoAP) proxies may lead to infinite forwarding loops, which is undesirable. To prevent and detect such loops, this document specifies the Hop-Limit CoAP option.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="8768"/>
          <seriesInfo name="DOI" value="10.17487/RFC8768"/>
        </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="RFC8974">
          <front>
            <title>Extended Tokens and Stateless Clients in the Constrained Application Protocol (CoAP)</title>
            <author fullname="K. Hartke" initials="K." surname="Hartke"/>
            <author fullname="M. Richardson" initials="M." surname="Richardson"/>
            <date month="January" year="2021"/>
            <abstract>
              <t>This document provides considerations for alleviating Constrained Application Protocol (CoAP) clients and intermediaries of keeping per-request state. To facilitate this, this document additionally introduces a new, optional CoAP protocol extension for extended token lengths.</t>
              <t>This document updates RFCs 7252 and 8323 with an extended definition of the "TKL" field in the CoAP message header.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="8974"/>
          <seriesInfo name="DOI" value="10.17487/RFC8974"/>
        </reference>
        <reference anchor="RFC9175">
          <front>
            <title>Constrained Application Protocol (CoAP): Echo, Request-Tag, and Token Processing</title>
            <author fullname="C. Amsüss" initials="C." surname="Amsüss"/>
            <author fullname="J. Preuß Mattsson" initials="J." surname="Preuß Mattsson"/>
            <author fullname="G. Selander" initials="G." surname="Selander"/>
            <date month="February" year="2022"/>
            <abstract>
              <t>This document specifies enhancements to the Constrained Application Protocol (CoAP) that mitigate security issues in particular use cases. The Echo option enables a CoAP server to verify the freshness of a request or to force a client to demonstrate reachability at its claimed network address. The Request-Tag option allows the CoAP server to match block-wise message fragments belonging to the same request. This document updates RFC 7252 with respect to the following: processing requirements for client Tokens, forbidding non-secure reuse of Tokens to ensure response-to-request binding when CoAP is used with a security protocol, and amplification mitigation (where the use of the Echo option is now recommended).</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="9175"/>
          <seriesInfo name="DOI" value="10.17487/RFC9175"/>
        </reference>
        <reference anchor="RFC9177">
          <front>
            <title>Constrained Application Protocol (CoAP) Block-Wise Transfer Options Supporting Robust Transmission</title>
            <author fullname="M. Boucadair" initials="M." surname="Boucadair"/>
            <author fullname="J. Shallow" initials="J." surname="Shallow"/>
            <date month="March" year="2022"/>
            <abstract>
              <t>This document specifies alternative Constrained Application Protocol (CoAP) block-wise transfer options: Q-Block1 and Q-Block2.</t>
              <t>These options are similar to, but distinct from, the CoAP Block1 and Block2 options defined in RFC 7959. The Q-Block1 and Q-Block2 options are not intended to replace the Block1 and Block2 options but rather have the goal of supporting Non-confirmable (NON) messages for large amounts of data with fewer packet interchanges. Also, the Q-Block1 and Q-Block2 options support faster recovery should any of the blocks get lost in transmission.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="9177"/>
          <seriesInfo name="DOI" value="10.17487/RFC9177"/>
        </reference>
        <reference anchor="RFC9363">
          <front>
            <title>A YANG Data Model for Static Context Header Compression (SCHC)</title>
            <author fullname="A. Minaburo" initials="A." surname="Minaburo"/>
            <author fullname="L. Toutain" initials="L." surname="Toutain"/>
            <date month="March" year="2023"/>
            <abstract>
              <t>This document describes a YANG data model for the Static Context Header Compression (SCHC) compression and fragmentation Rules.</t>
              <t>This document formalizes the description of the Rules for better interoperability between SCHC instances either to exchange a set of Rules or to modify the parameters of some Rules.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="9363"/>
          <seriesInfo name="DOI" value="10.17487/RFC9363"/>
        </reference>
        <reference anchor="RFC9668">
          <front>
            <title>Using Ephemeral Diffie-Hellman Over COSE (EDHOC) with the Constrained Application Protocol (CoAP) and Object Security for Constrained RESTful Environments (OSCORE)</title>
            <author fullname="F. Palombini" initials="F." surname="Palombini"/>
            <author fullname="M. Tiloca" initials="M." surname="Tiloca"/>
            <author fullname="R. Höglund" initials="R." surname="Höglund"/>
            <author fullname="S. Hristozov" initials="S." surname="Hristozov"/>
            <author fullname="G. Selander" initials="G." surname="Selander"/>
            <date month="November" year="2024"/>
            <abstract>
              <t>The lightweight authenticated key exchange protocol Ephemeral Diffie-Hellman Over COSE (EDHOC) can be run over the Constrained Application Protocol (CoAP) and used by two peers to establish a Security Context for the security protocol Object Security for Constrained RESTful Environments (OSCORE). This document details this use of the EDHOC protocol by specifying a number of additional and optional mechanisms, including an optimization approach for combining the execution of EDHOC with the first OSCORE transaction. This combination reduces the number of round trips required to set up an OSCORE Security Context and to complete an OSCORE transaction using that Security Context.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="9668"/>
          <seriesInfo name="DOI" value="10.17487/RFC9668"/>
        </reference>
        <reference anchor="I-D.ietf-core-oscore-groupcomm">
          <front>
            <title>Group Object Security for Constrained RESTful Environments (Group OSCORE)</title>
            <author fullname="Marco Tiloca" initials="M." surname="Tiloca">
              <organization>RISE AB</organization>
            </author>
            <author fullname="Göran Selander" initials="G." surname="Selander">
              <organization>Ericsson AB</organization>
            </author>
            <author fullname="Francesca Palombini" initials="F." surname="Palombini">
              <organization>Ericsson AB</organization>
            </author>
            <author fullname="John Preuß Mattsson" initials="J. P." surname="Mattsson">
              <organization>Ericsson AB</organization>
            </author>
            <author fullname="Rikard Höglund" initials="R." surname="Höglund">
              <organization>RISE AB</organization>
            </author>
            <date day="12" month="September" year="2025"/>
            <abstract>
              <t>   This document defines the security protocol Group Object Security for
   Constrained RESTful Environments (Group OSCORE), providing end-to-end
   security of messages exchanged with the Constrained Application
   Protocol (CoAP) between members of a group, e.g., sent over IP
   multicast.  In particular, the described protocol defines how OSCORE
   is used in a group communication setting to provide source
   authentication for CoAP group requests, sent by a client to multiple
   servers, and for protection of the corresponding CoAP responses.
   Group OSCORE also defines a pairwise mode where each member of the
   group can efficiently derive a symmetric pairwise key with each other
   member of the group for pairwise OSCORE communication.  Group OSCORE
   can be used between endpoints communicating with CoAP or CoAP-
   mappable HTTP.

              </t>
            </abstract>
          </front>
          <seriesInfo name="Internet-Draft" value="draft-ietf-core-oscore-groupcomm-27"/>
        </reference>
        <reference anchor="I-D.ietf-core-oscore-key-update">
          <front>
            <title>Key Update for OSCORE (KUDOS)</title>
            <author fullname="Rikard Höglund" initials="R." surname="Höglund">
              <organization>RISE AB</organization>
            </author>
            <author fullname="Marco Tiloca" initials="M." surname="Tiloca">
              <organization>RISE AB</organization>
            </author>
            <date day="7" month="July" year="2025"/>
            <abstract>
              <t>   Communications with the Constrained Application Protocol (CoAP) can
   be protected end-to-end at the application-layer by using the
   security protocol Object Security for Constrained RESTful
   Environments (OSCORE).  Under some circumstances, two CoAP endpoints
   need to update their OSCORE keying material before communications can
   securely continue, e.g., due to approaching key usage limits.  This
   document defines Key Update for OSCORE (KUDOS), a lightweight key
   update procedure that two CoAP endpoints can use to update their
   OSCORE keying material by establishing a new OSCORE Security Context.
   Accordingly, this document updates the use of the OSCORE flag bits in
   the CoAP OSCORE Option as well as the protection of CoAP response
   messages with OSCORE.  Also, it deprecates the key update procedure
   specified in Appendix B.2 of RFC 8613.  Therefore, this document
   updates RFC 8613.

              </t>
            </abstract>
          </front>
          <seriesInfo name="Internet-Draft" value="draft-ietf-core-oscore-key-update-11"/>
        </reference>
        <reference anchor="I-D.ietf-core-href">
          <front>
            <title>Constrained Resource Identifiers</title>
            <author fullname="Carsten Bormann" initials="C." surname="Bormann">
              <organization>Universität Bremen TZI</organization>
            </author>
            <author fullname="Henk Birkholz" initials="H." surname="Birkholz">
              <organization>Fraunhofer SIT</organization>
            </author>
            <date day="16" month="October" year="2025"/>
            <abstract>
              <t>   The Constrained Resource Identifier (CRI) is a complement to the
   Uniform Resource Identifier (URI) that represents the URI components
   in Concise Binary Object Representation (CBOR) rather than as a
   sequence of characters.  This approach simplifies parsing,
   comparison, and reference resolution in environments with severe
   limitations on processing power, code size, and memory size.

   This RFC updates RFC 7595 by adding a column on the "URI Schemes"
   registry as well as a note on how that registry cooperates with the
   "CRI Scheme Numbers for Certain Unregistered Scheme Names" registry
   created by the present RFC.


   // (This "cref" paragraph will be removed by the RFC editor:) The
   // present revision -26 is taking on the results from the 2025-10-09
   // IESG telechat (issue #140), by integrating the CRI scheme number
   // column into the URI scheme registry created by RFC 7595 and
   // keeping the URI-Scheme registration process essentially unchanged
   // from the point of view of a registrant that does not have any
   // special requirements on the CRI scheme number assigned.  Also, the
   // cri'' application-extension syntax has been moved to draft-ietf-
   // cbor-edn-literals, which is currently lagging behind in the
   // approval process.

              </t>
            </abstract>
          </front>
          <seriesInfo name="Internet-Draft" value="draft-ietf-core-href-26"/>
        </reference>
        <reference anchor="CoAP.Option.Numbers" target="https://www.iana.org/assignments/core-parameters/core-parameters.xhtml#option-numbers">
          <front>
            <title>CoAP Option Numbers</title>
            <author>
              <organization>IANA</organization>
            </author>
            <date/>
          </front>
        </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="RFC8824">
          <front>
            <title>Static Context Header Compression (SCHC) for the Constrained Application Protocol (CoAP)</title>
            <author fullname="A. Minaburo" initials="A." surname="Minaburo"/>
            <author fullname="L. Toutain" initials="L." surname="Toutain"/>
            <author fullname="R. Andreasen" initials="R." surname="Andreasen"/>
            <date month="June" year="2021"/>
            <abstract>
              <t>This document defines how to compress Constrained Application Protocol (CoAP) headers using the Static Context Header Compression and fragmentation (SCHC) framework. SCHC defines a header compression mechanism adapted for Constrained Devices. SCHC uses a static description of the header to reduce the header's redundancy and size. While RFC 8724 describes the SCHC compression and fragmentation framework, and its application for IPv6/UDP headers, this document applies SCHC to CoAP headers. The CoAP header structure differs from IPv6 and UDP, since CoAP uses a flexible header with a variable number of options, themselves of variable length. The CoAP message format is asymmetric: the request messages have a header format different from the format in the response messages. This specification gives guidance on applying SCHC to flexible headers and how to leverage the asymmetry for more efficient compression Rules.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="8824"/>
          <seriesInfo name="DOI" value="10.17487/RFC8824"/>
        </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="RFC9528">
          <front>
            <title>Ephemeral Diffie-Hellman Over COSE (EDHOC)</title>
            <author fullname="G. Selander" initials="G." surname="Selander"/>
            <author fullname="J. Preuß Mattsson" initials="J." surname="Preuß Mattsson"/>
            <author fullname="F. Palombini" initials="F." surname="Palombini"/>
            <date month="March" year="2024"/>
            <abstract>
              <t>This document specifies Ephemeral Diffie-Hellman Over COSE (EDHOC), a very compact and lightweight authenticated Diffie-Hellman key exchange with ephemeral keys. EDHOC provides mutual authentication, forward secrecy, and identity protection. EDHOC is intended for usage in constrained scenarios, and a main use case is to establish an Object Security for Constrained RESTful Environments (OSCORE) security context. By reusing CBOR Object Signing and Encryption (COSE) for cryptography, Concise Binary Object Representation (CBOR) for encoding, and Constrained Application Protocol (CoAP) for transport, the additional code size can be kept very low.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="9528"/>
          <seriesInfo name="DOI" value="10.17487/RFC9528"/>
        </reference>
        <reference anchor="I-D.ietf-core-groupcomm-bis">
          <front>
            <title>Group Communication for the Constrained Application Protocol (CoAP)</title>
            <author fullname="Esko Dijk" initials="E." surname="Dijk">
              <organization>IoTconsultancy.nl</organization>
            </author>
            <author fullname="Marco Tiloca" initials="M." surname="Tiloca">
              <organization>RISE AB</organization>
            </author>
            <date day="25" month="September" year="2025"/>
            <abstract>
              <t>   The Constrained Application Protocol (CoAP) is a web transfer
   protocol for constrained devices and constrained networks.  In a
   number of use cases, constrained devices often naturally operate in
   groups (e.g., in a building automation scenario, all lights in a
   given room may need to be switched on/off as a group).  This document
   specifies the use of CoAP for group communication, including the use
   of UDP/IP multicast as the default underlying data transport.  Both
   unsecured and secured CoAP group communication are specified.
   Security is achieved by use of the Group Object Security for
   Constrained RESTful Environments (Group OSCORE) protocol.  The target
   application area of this specification is any group communication use
   cases that involve resource-constrained devices or networks that
   support CoAP.  This document replaces and obsoletes RFC 7390, while
   it updates RFC 7252 and RFC 7641.

              </t>
            </abstract>
          </front>
          <seriesInfo name="Internet-Draft" value="draft-ietf-core-groupcomm-bis-15"/>
        </reference>
        <reference anchor="I-D.ietf-schc-universal-option">
          <front>
            <title>Options representation in SCHC YANG Data Models</title>
            <author fullname="Quentin Lampin" initials="Q." surname="Lampin">
              <organization>Orange</organization>
            </author>
            <author fullname="Ana Minaburo" initials="A." surname="Minaburo">
              <organization>Consultant</organization>
            </author>
            <author fullname="Marco Tiloca" initials="M." surname="Tiloca">
              <organization>RISE AB</organization>
            </author>
            <author fullname="Laurent Toutain" initials="L." surname="Toutain">
              <organization>IMT Atlantique</organization>
            </author>
            <date day="17" month="October" year="2025"/>
            <abstract>
              <t>   The idea of keeping option identifiers in SCHC Rules simplifies the
   interoperability and the evolution of SCHC compression, when the
   protocol introduces new options, that can be unknown from the current
   SCHC implementation.  This document discuss the augmentation of the
   current YANG Data Model, in order to add in the Rule options
   identifiers used by the protocol.

              </t>
            </abstract>
          </front>
          <seriesInfo name="Internet-Draft" value="draft-ietf-schc-universal-option-01"/>
        </reference>
      </references>
    </references>
    <?line 2189?>

<section anchor="sec-yang-module">
      <name>YANG Data Model</name>
      <t>This appendix defines the ietf-schc-coap module, which extends the ietf-schc module defined in <xref target="RFC9363"/> to include the new CoAP options as defined in the present document.</t>
      <figure anchor="fig-yang-data-model">
        <name>SCHC CoAP Extension YANG Data Model.</name>
        <sourcecode type="yang" name="ietf-schc-coap@2025-10-20.yang" markers="true"><![CDATA[
module ietf-schc-coap {
  yang-version 1.1;
  namespace "urn:ietf:params:xml:ns:yang:ietf-schc-coap";
  prefix schc-coap;

  import ietf-schc {
      prefix schc;
  }

  organization
    "IETF Static Context Header Compression (schc) Working Group";
  contact
    "WG Web:   <https://datatracker.ietf.org/wg/schc/about/>
     WG List:  <mailto:schc@ietf.org>
     Editor:   Marco Tiloca
       <mailto:marco.tiloca@ri.se>";
  description
    "Copyright (c) 2021 IETF Trust and the persons identified as
     authors of the code.  All rights reserved.
     Redistribution and use in source and binary forms, with or
     without modification, is permitted pursuant to, and subject to
     the license terms contained in, the Simplified BSD License set
     forth in Section 4.c of the IETF Trust's Legal Provisions
     Relating to IETF Documents
     (https://trustee.ietf.org/license-info).
     This version of this YANG module is part of RFC XXXX
     (https://www.rfc-editor.org/info/rfcXXXX); see the RFC itself
     for full legal notices.
     The key words 'MUST', 'MUST NOT', 'REQUIRED', 'SHALL', 'SHALL
     NOT', 'SHOULD', 'SHOULD NOT', 'RECOMMENDED', 'NOT RECOMMENDED',
     'MAY', and 'OPTIONAL' in this document are to be interpreted as
     described in BCP 14 (RFC 2119) (RFC 8174) when, and only when,
     they appear in all capitals, as shown here.
     ****************************************************************

     This module extends the ietf-schc module defined in RFC 9363 to
     include the new CoAP options as defined in RFC YYYY.";

  revision 2025-10-20 {
    description
      "New CoAP extensions and extended OSCORE fields.";
    reference
      "RFC YYYY Static Context Header Compression (SCHC) for the
                Constrained Application Protocol (CoAP) (see
                Sections 5 and 6)";
  }

  // Field ID

  identity fid-coap-option-proxy-cri {
    base "schc:fid-coap-option";
    description
      "Proxy-Cri option.";
    reference
      "RFC XXXX Constrained Resource Identifiers";
  }

  identity fid-coap-option-proxy-scheme-number {
    base "schc:fid-coap-option";
    description
      "Proxy-Scheme-Number option.";
    reference
      "RFC XXXX Constrained Resource Identifiers";
  }

  identity fid-coap-option-hop-limit {
    base "schc:fid-coap-option";
    description
      "Hop Limit option to avoid infinite forwarding loops.";
    reference
      "RFC 8768 Constrained Application Protocol (CoAP)
                Hop-Limit Option";
  }

  identity fid-coap-option-echo {
    base "schc:fid-coap-option";
    description
      "Echo option.";
    reference
      "RFC 9175 Constrained Application Protocol (CoAP):
                Echo, Request-Tag, and Token Processing";
  }

  identity fid-coap-option-request-tag {
    base "schc:fid-coap-option";
    description
      "Request-Tag option.";
    reference
      "RFC 9175 Constrained Application Protocol (CoAP):
                Echo, Request-Tag, and Token Processing";
  }

  identity fid-coap-option-q-block1 {
    base "schc:fid-coap-option";
    description
      "Q-Block1 option.";
    reference
      "RFC 9177 Constrained Application Protocol (CoAP)
                Block-Wise Transfer Options Supporting
                Robust Transmission";
  }

  identity fid-coap-option-q-block2 {
    base "schc:fid-coap-option";
    description
      "Q-Block2 option.";
    reference
      "RFC 9177 Constrained Application Protocol (CoAP)
                Block-Wise Transfer Options Supporting
                Robust Transmission";
  }

  identity fid-coap-option-edhoc {
    base "schc:fid-coap-option";
    description
      "EDHOC option.";
    reference
      "RFC 9668 Using Ephemeral Diffie-Hellman Over COSE (EDHOC)
                with the Constrained Application Protocol (CoAP)
                and Object Security for Constrained RESTful
                Environments (OSCORE)";
  }

  identity fid-coap-option-oscore-x {
       base "schc:fid-coap-option";
       description
         "CoAP option OSCORE x field.";
       reference
         "RFC YYYY Static Context Header Compression (SCHC) for the
                   Constrained Application Protocol (CoAP) (see
                   Section 6.4)
          RFC XXXX Key Update for OSCORE (KUDOS)";
  }

  identity fid-coap-option-oscore-nonce {
       base "schc:fid-coap-option";
       description
         "CoAP option OSCORE nonce field.";
       reference
         "RFC YYYY Static Context Header Compression (SCHC) for the
                   Constrained Application Protocol (CoAP) (see
                   Section 6.4)
          RFC XXXX Key Update for OSCORE (KUDOS)";
  }

  // Function Length

  identity fl-oscore-oscore-piv-length {
       base "schc:fl-base-type";
       description
         "Size in bytes of the OSCORE Partial IV corresponding to n.";
       reference
         "RFC YYYY Static Context Header Compression (SCHC) for the
                   Constrained Application Protocol (CoAP) (see
                   Section 6.4)";
  }

  identity fl-oscore-oscore-nonce-length {
       base "schc:fl-base-type";
       description
         "Size in bytes of the OSCORE nonce corresponding to m+1.";
       reference
         "RFC YYYY Static Context Header Compression (SCHC) for the
                   Constrained Application Protocol (CoAP) (see
                   Section 6.4)
          RFC XXXX Key Update for OSCORE (KUDOS)";
  }
}

]]></sourcecode>
      </figure>
    </section>
    <section anchor="sec-document-updates" removeInRFC="true">
      <name>Document Updates</name>
      <section anchor="sec-05-06">
        <name>Version -05 to -06</name>
        <ul spacing="normal">
          <li>
            <t>Generalized the Token Length field, the Token field, and the "tkl" function to comply with RFC 8974.</t>
          </li>
          <li>
            <t>Clarified use of the FL for variable-length fields.</t>
          </li>
          <li>
            <t>Explicit definition and use of "var" in the FL of a Field Descriptor.</t>
          </li>
          <li>
            <t>Consistent use of "var" in the examples of Rules.</t>
          </li>
          <li>
            <t>More robust reference to the YANG data model of RFC 9363.</t>
          </li>
          <li>
            <t>Editorial fixes in the examples.</t>
          </li>
          <li>
            <t>Minor clarifications and editorial improvements.</t>
          </li>
        </ul>
      </section>
      <section anchor="sec-04-05">
        <name>Version -04 to -05</name>
        <ul spacing="normal">
          <li>
            <t>Compression of CoAP options:
            </t>
            <ul spacing="normal">
              <li>
                <t>Clarified definition of Field Descriptors in SCHC Rules.</t>
              </li>
              <li>
                <t>Description of Option Value as possibly composed of sub-fields.</t>
              </li>
              <li>
                <t>Both the syntactic approach and the semantics approach are possible (see draft-ietf-schc-universal-option).</t>
              </li>
              <li>
                <t>Updated the FIDs to be consistent with the semantic approach.</t>
              </li>
            </ul>
          </li>
          <li>
            <t>Compression of OSCORE Option:
            </t>
            <ul spacing="normal">
              <li>
                <t>Revised semantics of the x sub-field related to KUDOS.</t>
              </li>
              <li>
                <t>Removed moot sub-fields related to KUDOS.</t>
              </li>
            </ul>
          </li>
          <li>
            <t>Clarified OSCORE compression when using the group mode of Group OSCORE.</t>
          </li>
          <li>
            <t>Updated YANG data model.</t>
          </li>
          <li>
            <t>Updated author's contact information.</t>
          </li>
          <li>
            <t>Fixes and editorial improvements.</t>
          </li>
        </ul>
      </section>
      <section anchor="sec-03-04">
        <name>Version -03 to -04</name>
        <ul spacing="normal">
          <li>
            <t>Clarified the rationale for using the "tkl" function.</t>
          </li>
          <li>
            <t>Added the "osc.piv" function to determine the length of the OSCORE piv field.</t>
          </li>
          <li>
            <t>Consistent formulation of "tkl", "osc.x.m", and "osc.y.w".</t>
          </li>
          <li>
            <t>Explicitly stated that Field Descriptors have to be ordered in a determistic way.</t>
          </li>
          <li>
            <t>Fixed format of TV in Rule Descriptors for CoAP MID.</t>
          </li>
          <li>
            <t>Fixed order of OSCORE-related Field Descriptors in example Rules.</t>
          </li>
          <li>
            <t>Use "bit" instead of "b" as symbol for bit (per ISO/IEC 80000-13).</t>
          </li>
          <li>
            <t>Made YANG extractable.</t>
          </li>
          <li>
            <t>Updated references.</t>
          </li>
          <li>
            <t>Fixes and editorial improvements.</t>
          </li>
        </ul>
      </section>
      <section anchor="sec-02-03">
        <name>Version -02 to -03</name>
        <ul spacing="normal">
          <li>
            <t>Consistent representation of "CoAP Version" 1 in example Rules.</t>
          </li>
          <li>
            <t>Split the compression of Token Length and Token into two sections.</t>
          </li>
          <li>
            <t>Disambiguated example of Rule on eliding a Uri-Path option.</t>
          </li>
          <li>
            <t>Fixed compression examples with OSCORE.</t>
          </li>
          <li>
            <t>Inherited security considerations on the YANG module from RFC 9363.</t>
          </li>
          <li>
            <t>Fixes and editorial improvements.</t>
          </li>
        </ul>
      </section>
      <section anchor="sec-01-02">
        <name>Version -01 to -02</name>
        <ul spacing="normal">
          <li>
            <t>Added compression for the CoAP options Proxy-Cri and Proxy-Scheme-Number.</t>
          </li>
          <li>
            <t>Defined new IANA registry "SCHC Compression of CoAP Fields".</t>
          </li>
          <li>
            <t>Updated the YANG data model.</t>
          </li>
          <li>
            <t>Fixes and editorial improvements.</t>
          </li>
        </ul>
      </section>
      <section anchor="sec-00-01">
        <name>Version -00 to -01</name>
        <ul spacing="normal">
          <li>
            <t>Fixed an example, as per the erratum with Errata ID 7623.</t>
          </li>
          <li>
            <t>Clarified building of Field Descriptor for CoAP options.</t>
          </li>
          <li>
            <t>Clarified what SCHC compression considers for CoAP options.</t>
          </li>
          <li>
            <t>Revised SCHC compression of the ETag and If-Match CoAP option.</t>
          </li>
          <li>
            <t>Revised SCHC compression of the If-None-Match CoAP option.</t>
          </li>
          <li>
            <t>Added YANG data model for the YANG module.</t>
          </li>
          <li>
            <t>Added IANA considerations.</t>
          </li>
          <li>
            <t>Fixes and editorial improvements.</t>
          </li>
        </ul>
      </section>
    </section>
    <section numbered="false" anchor="acknowledgments">
      <name>Acknowledgments</name>
      <t>The authors sincerely thank <contact fullname="Christian Amsüss"/>, <contact fullname="Quentin Lampin"/>, <contact fullname="John Preuß Mattsson"/>, <contact fullname="Carles Gomez Montenegro"/>, <contact fullname="Göran Selander"/>, <contact fullname="Pascal Thubert"/>, and <contact fullname="Éric Vyncke"/> 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 projects SIFIS-Home (Grant agreement 952652) and ARCADIAN-IoT (Grant agreement 101020259).</t>
    </section>
  </back>
  <!-- ##markdown-source:
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
UdY3v2D2uhrUkV53eDg6GvYPh8Oe52Lwy0oriU7CaLw37u8f9qLusH/i00oq
Mz9q2SUdxV5tdTG9fUtdedTMjzmq1ZQXkRXXVmDKzpJloUhuLI8dZM7WXnpA
+yjinLoctth1yp2Eh0qOc8N2jbMDN/hOhXS0DU0Xuy73Bq99yBWaQVOxXcOu
/pEHN1EScRqbFkSVQK2eaalkPbvXtGv/xeJhVt5UUrH75uw/tqRMcShZZX4t
je42DhsiSySlgPQGH8zFF13xsPNo3IipiGZ5qbJ8KV3w6cqKuncBfUrqt+ZC
o8a/VPEpreVPcn4+ub81lRj95Pmt7gP6sKaUaGlTff3bkuKixgfDfhfH1eMl
M/7ync3zk/PHa3L8PPOTz6vvf/Qx85vCoaVBzW+lUqLlQ3jU/JaHrzTosTs/
wf/p97/y/AT/w2Pvo4+Y31NGVM166MxfX76Uy5b2+uisLJUqha/gp2n+ugSZ
T0HxceqZ/7h6BXj+A2o7XZn/+rriIvK5Wk926S9uZMpvWpAw9+++e+KZ/xHw
X3l+Ov/B11/7QPVk86PIqwaVzlPl/dfBf98P/3fws9n8X2L/qk1rHf157vnv
rUFL9/+zzM+NHIIvtn9sgagGvQ2z/0A918W/w73D4eEJT3F4cBgddRX+7Xvp
zx/hZ7P5S/t/SvwzMReWRKjTD1zJvSbmArQelpG9ARe2KvKuHHTtCVOTWMM+
x6mdHHdPuvsMaYLx/nhcdRJt7fSV2lUKQuyvH4RIQW+Ob78f7GBVldWjEE+O
g/KyjR9LhSKeqCREHYeIJN19y1Lngdr/HldIzYpxEdxR1XOok+BjELg2he4+
NV51n3OWR71Xl8bfNfnnvEpnnU6mdU6NEaiieSyJ8E05iHITjDrs7e8LRnXH
4yYVHnCp58ElHGCD0Eh8qt6AfUzBkfuqOs8aCGY88k3oFOxEs3nxsLvCya5o
1Vj9kMvGhRUO2huEqbpnWV2V83TmyVNS0ZOoNS/yCMDdCjhdiat8s7fOVMyW
mEv0vWFdGixcPU6zuzAbOU3P4lxsEBg4qbsOctXpsbW2vCVdzcj9leiOiaCQ
clC5qXmOqqkEg6tGUbrhdR6iW5VWxU37yLW5mFItoluqlERt7eJpXDw4pZgE
IPhoY2O4SYp9+ch2kcOIGXncEjjHhaobbPyE4tXCxmuweqsbir1kLBVOMybI
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
afZ1jjnp0WnwXTTGmhrzxUDtpYXWnXGczXAggJZkkXNGfJBwsngQ5nk6jMPC
Pl5aPj+Xi+f3PItpJ7YfuM0J53q9BP/L9otOHBXjNiHSJIvGRADSIEryBRWd
4sN4oJLhZH/KiVrJ7FgSPItu8MNMbTwKtj157tvyXIZ66ic+MB+z+ATnng+z
mF9+op/GYk0r1HFa/0eXNfCVZeKvggnJw4x5gXrun/98//L8qH/QBxRdd488
o68Akm9Gem7j6ZwZPeWOvDOS3vOKGGuwA2/t2vPTr8cnR/v1S9Ez+goL+Wak
555kjzhS53wKF3CFGXcUCQnojd11luDO+CIqwthUtlhhRn5jnSn1jL5SSb4Z
LdV2M9gazPEURvpkEWRBmfWwpHFGVSfdDg3/ZNPQ4HLcfo0JCY/Cm+qMe/Uz
aj/n0864Xz/jxXV488jZfDMeNEL1TZpEjwVtecbD+hnfDkgikrkO93ubbbM8
41HzOb5Ls6c+x+P6GV+lLD1wFYkng+pJA1RZdeFreNjbwxvpShEilX6MHtqL
+QhkFd9qqjN27FJcnhkNhaMHd9ddgmdGu+hV44zwoDPfplDt2CWuGmeUB9ec
1TOjXdCqcUaaa+2T9Mxol69qnJEeXHtWP1RX2yM8+ATn2LOZh4cCPOoq+mfs
184o5oP2S9DUws0pT2XG/doZX4f37bObx4lVvhkPGqH6p0WUPTxuzsqMh7Uz
/pDO26/iWSwAPT46PH6SGY9qZzwbDqP5YzmHZ8aT2hn/1P5umg4/9njOk97R
0ZPgar9bO6PmVo87zMqM9ffx4sUPb89lg4ebnaF3xr3aGQmmfdnbycGJklj3
+ivTG++M9Zhjn+JTznhcO+NV/I/I2eLqszTNuFd/joKr/SfG1b16msOmE6A8
T0tz9urvoxO0v/mkFQm5/j7iOfYerwZUb4cFVt8ezwmqPtvTxjOeNM/omsA2
mLsy40G/bsaL4STVeHrwZLpV/+C4bsY3aVt7D+RWHm5wQSozntTuUeJM21qN
3GyrXHizYp11mlWyaddXDPMr01bxXCLjiL3kbMzHEvaqwI2YL2wDLtp2K6aN
PEiT6UMQjscUgleQYRtfgUnZgC5+fHkpTsYkd5EZvG6muMij6TgYpRGZf+Gl
YRZho8eUI0Lp98KqkzONbqMpOS7V/mRWp35+J9AljoZpkmDYAEymZ8Hth2YE
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

-->

</rfc>
