<?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  (Ruby 3.1.2) -->
<rfc xmlns:xi="http://www.w3.org/2001/XInclude" ipr="trust200902" docName="draft-tiloca-schc-8824-update-02" category="std" consensus="true" submissionType="IETF" obsoletes="8824" tocInclude="true" sortRefs="true" symRefs="true" version="3">
  <!-- xml2rfc v2v3 conversion 3.18.1 -->
  <front>
    <title abbrev="SCHC for CoAP">Static Context Header Compression (SCHC) for the Constrained Application Protocol (CoAP)</title>
    <seriesInfo name="Internet-Draft" value="draft-tiloca-schc-8824-update-02"/>
    <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="Martinez" fullname="Ivan Martinez">
      <organization>Nokia Bell Labs</organization>
      <address>
        <postal>
          <street>12 Rue Jean Bart</street>
          <city>Massy</city>
          <code>91300</code>
          <country>France</country>
        </postal>
        <email>ivan.martinez_bolivar@nokia-bell-labs.com</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="2023" month="October" day="23"/>
    <area>Internet</area>
    <workgroup>SCHC Working Group</workgroup>
    <keyword>Internet-Draft</keyword>
    <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. 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://gitlab.com/crimson84/draft-tiloca-schc-8824-update"/>.</t>
    </note>
  </front>
  <middle>
    <section anchor="intro">
      <name>Introduction</name>
      <t>The Constrained Application Protocol (CoAP) <xref target="RFC7252"/> is a command/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 this document's scope.</t>
      <t>CoAP is an application protocol, so CoAP compression 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"/>). Thereby, each description contains the Field ID (FID), Field Length (FL), and Field Position (FP), as well as a Direction Indicator (DI) (upstream, downstream, and bidirectional) and some associated Target Values (TVs). The DI is used for compression to give the best TV to the FID when these values differ in their transmission direction. Therefore, a field may be described several times in the same Rule.</t>
      <t>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 SCHC compression for the CoAP options Size1, Size2, Proxy-Uri, and Proxy-Scheme (see <xref target="ssec-size1-size2-proxy-uri-proxy-scheme-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"/>), in the light of recent developments related to the security protocol 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 "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL
NOT", "SHOULD", "SHOULD NOT", "RECOMMENDED", "NOT RECOMMENDED",
"MAY", and "OPTIONAL" in this document are to be interpreted as
described in BCP 14 <xref target="RFC2119"/> <xref target="RFC8174"/> when, and only when, they
appear in all capitals, as shown here.</t>
        <t>Readers are expected to be familiar with the terms and concepts related to the SCHC framework <xref target="RFC8724"/>, the web-transfer protocol CoAP <xref target="RFC7252"/>, and the security protocols OSCORE <xref target="RFC8613"/> and 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 MAY 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"/>.</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 C/D (SCHC Compression/Decompression, 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">
              <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">
              <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 Object Security for Constrained RESTful Environments (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 the OSCORE mechanism. Then, a second Rule compresses the Outer header, including the CoAP Option OSCORE.</t>
      <figure anchor="fig-applicability-to-coap-3">
        <name>OSCORE Compression/Decompression</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">
              <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 applies the same description and compression/decompression techniques as the technique used for IP and UDP, 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 MAY define both request/response headers and TVs in the same Rule, using the DI to indicate the header type.</t>
      <t>As for other header compression protocols, when the compressor does not find a correct Rule to compress the header, the packet MUST be sent uncompressed using the RuleID dedicated to this purpose, and where 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 or a response. 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, 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. For instance, if a client sends only Confirmable (CON) requests <xref target="RFC7252"/>, the Type can be elided by compression, 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. On the other hand, some CoAP header fields have variable lengths, and the Rule description specifies it. For example, the size of the Token field may vary from 0 to 8 bytes, 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>
When doing SCHC compression of a variable-length field, <xref section="7.4.2" sectionFormat="of" target="RFC8724"/> makes it possible to define a function for the Field Length in the Field Descriptor, in order to determine the length before compression. If the Field Length is unknown, the Rule will set it as a variable, and SCHC will send the compressed field's length in the Compression Residue.</t>
          </li>
          <li>
            <t>A field can appear several times in the CoAP headers. This is typically the case for elements of a URI (path or queries). 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, thereby removing the MO's ambiguity.</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, building on what is specified in <xref section="7.1" sectionFormat="of" target="RFC8724"/>.</t>
      <section anchor="ssec-coap-version-field">
        <name>CoAP Version Field</name>
        <t>The CoAP version is bidirectional and MUST be elided during SCHC compression, since it always contains the same value. In the future, or if a new version of CoAP is defined, new Rules will be needed to avoid ambiguities between versions.</t>
      </section>
      <section anchor="ssec-coap-type-field">
        <name>CoAP Type Field</name>
        <t>CoAP <xref target="RFC7252"/> has four types of messages: Confirmable (CON), Non-confirmable (NON), Acknowledgement (ACK), and Reset (RST).</t>
        <t>The SCHC compression scheme SHOULD 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-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 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>CoAP defines the Token using two CoAP fields: Token Length in the mandatory header and Token Value directly following the mandatory CoAP header.</t>
        <t>SCHC processes the Token Length as it would process any header field. If the value does not change, the size can be stored in the TV and elided during the transmission. Otherwise, SCHC will send the Token Length in the Compression Residue.</t>
        <t>For the Token Value, SCHC MUST NOT send it as variable-size data in the Compression Residue, to avoid ambiguity with the Token Length. Therefore, SCHC MUST use the Token Length value to define the size of the Compression Residue. SCHC designates a specific function, "tkl", that the Rule MUST use to complete the Field Descriptor. During the decompression, this function returns the value contained in the Token Length field.</t>
      </section>
    </section>
    <section anchor="sec-coap-options">
      <name>Compression of CoAP Options</name>
      <t>CoAP defines options placed after the mandatory header and the Token field, ordered by option number (see <xref section="3" sectionFormat="of" target="RFC7252"/>). Each option instance in a message uses the format Delta-Type (D-T), Length (L), Value (V). The SCHC Rule builds the description of each option as follows:</t>
      <ul spacing="normal">
        <li>
          <t>in the FID: an identifier of the option with option number built from the D-T;</t>
        </li>
        <li>
          <t>in the FL: the option length, consistent with what is specified in Sections <xref target="RFC8724" section="7.4.1" sectionFormat="bare"/> and <xref target="RFC8724" section="7.4.2" sectionFormat="bare"/> of <xref target="RFC8724"/>; and</t>
        </li>
        <li>
          <t>in the TV: the option value.</t>
        </li>
      </ul>
      <t>When the Option Length has a well-known size, the Rule may keep the length value. Therefore, SCHC compression does not send it. Otherwise, SCHC compression carries the length of the Compression Residue, in addition to the Compression Residue value. Note that the length coding differs between CoAP options and SCHC variable size Compression Residue.</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.</t>
      <t>If the use of an additional CoAP option is later introduced, the SCHC Rules MAY be updated, in which case a new FID description MUST 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 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. Otherwise, if the client expects several possible values, a "match-mapping" MO SHOULD 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. 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</name>
          <thead>
            <tr>
              <th align="left">Field</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">Uri-Path</td>
              <td align="left"> </td>
              <td align="left">1</td>
              <td align="left">Up</td>
              <td align="left">
                <tt>["/a/b",</tt> <br/> <tt>"/c/d"]</tt></td>
              <td align="left">
                <tt>match-</tt> <br/> <tt>mapping</tt></td>
              <td align="left">mapping-sent</td>
            </tr>
            <tr>
              <td align="left">Uri-Path</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 MUST 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 MUST 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 with the length (i.e., 0x2 "X6") followed by the query option with the length (i.e., 0x4 "eth0").</t>
        <table align="center" anchor="_table-CoMicompress">
          <name>CORECONF URI compression</name>
          <thead>
            <tr>
              <th align="left">Field</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">Uri-Path</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">Uri-Path</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">Uri-Query</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 SHOULD 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 SCHC Rule description MAY define sending some field values by not setting the TV, while setting the MO to "ignore" and the CDA to "value-sent". A Rule MAY also use a "match-mapping" MO when there are different options 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-etag-if-match-none-match-location-path-location-query-option">
        <name>CoAP Option ETag, If-Match, If-None-Match, Location-Path, and Location-Query Fields</name>
        <t>A Rule entry cannot store these fields' values. Therefore, SCHC compression MUST 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="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 packet uses the Hop-Limit Option, SCHC compression SHOULD 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 MAY 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 packet uses the Echo Option, SCHC compression SHOULD 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 MAY 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 packet uses the Request-Tag Option, SCHC compression MAY 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 MAY use a "match-mapping" MO when there are different options 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="I-D.ietf-core-oscore-edhoc"/> that a client can include in a CoAP request, in order to perform an optimized, shortened execution of the authenticated key establishment protocol EDHOC <xref target="I-D.ietf-lake-edhoc"/>. 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 MUST 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>
      <section anchor="ssec-coap-extensions-block">
        <name>Block</name>
        <t>When a packet uses a Block1 or Block2 Option <xref target="RFC7959"/> or a Q-Block1 or Q-Block2 Option <xref target="RFC9177"/>, SCHC compression MUST 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". 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 MAY limit the delta between two consecutive values or a proxy can modify the increment.</t>
        <t>Since the client MAY use a RST message to inform a server that the Observe response is not required, a specific SCHC Rule SHOULD 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 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 option. 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 piv (Partial Initialization Vector) field in bytes. When n = 0, no piv is present.</t>
          </li>
        </ul>
        <t>Assuming the presence of a single flag byte, this is followed by the piv 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</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)      |
+-+-+-+-+-+-+-+-+---------------------------------+
|               |                                 |
|<--   CoAP  -->|<------- CoAP OSCORE_piv ------> |
   OSCORE_flags

 <-- 1 byte --> <------ s bytes ----->
+--------------+----------------------+-----------------------+
|  s (if any)  | kid context (if any) | kid (if any)      ... |
+--------------+----------------------+-----------------------+
|                                     |                       |
|<-------- CoAP OSCORE_kidctx ------->|<-- CoAP OSCORE_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 option, 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 the specific behavior to adopt during the KUDOS execution.</t>
        <t>If the seventh least significant bit z of the x field is set, it indicates that two additional fields are included in the option, following the x and nonce fields. These two fields, namely y and old_nonce, are also used when running the key update protocol KUDOS, with y specifying the length of the old_nonce field in bytes.</t>
        <t><xref target="fig-oscore-option-kudos"/> provides the breakdown of the x field, where its four least significant bits form the sub-field m, which specifies the size of nonce in bytes, minus 1. Also, the figure provides the breakdown of the y field, where its four least significant bits form the sub-field w, which specifies the size of old_nonce in bytes, minus 1.</t>
        <figure anchor="fig-oscore-option-kudos">
          <name>OSCORE Option 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) |
+-+-+-+-+-+-+-+-+---+---+---+---+---+---+---+---+---------------------+
|                                               |                     |
|<------------------- CoAP -------------------->|<- CoAP OSCORE_piv ->|
                   OSCORE_flags

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


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


 <------ 1 byte ----->  <------ w + 1 bytes ------>
+---------------------+----------------------------+
|     y (if any)      |     old_nonce (if any)     |
+---------------------+----------------------------+
|<-- CoAP OSCORE_y -->|<-- CoAP OSCORE_oldnonce -->|
|                     |
|   0 1 2 3 4 5 6 7   |
|  +-+-+-+-+-+-+-+-+  |
|  |0|0|0|0|   w   |  |
|  +-+-+-+-+-+-+-+-+  |


+-----------------------+
|    kid (if any) ...   |
+-----------------------+
|                       |
|<-- CoAP OSCORE_kid -->|
]]></artwork>
        </figure>
        <t>To better perform OSCORE SCHC compression, the Rule description needs to identify the OSCORE Option and the fields it contains.</t>
        <t>Conceptually, it discerns up to eight distinct pieces of information within the OSCORE Option: the flag bits, the piv, the kid context prepended by its size, the x byte, the nonce, the y byte, the old_nonce, and the kid. The SCHC Rule splits the OSCORE Option into eight corresponding Field Descriptors in order to compress those pieces of information:</t>
        <ul spacing="normal">
          <li>
            <t>CoAP OSCORE_flags</t>
          </li>
          <li>
            <t>CoAP OSCORE_piv</t>
          </li>
          <li>
            <t>CoAP OSCORE_kidctx</t>
          </li>
          <li>
            <t>CoAP OSCORE_x</t>
          </li>
          <li>
            <t>CoAP OSCORE_nonce</t>
          </li>
          <li>
            <t>CoAP OSCORE_y</t>
          </li>
          <li>
            <t>CoAP OSCORE_oldnonce</t>
          </li>
          <li>
            <t>CoAP OSCORE_kid</t>
          </li>
        </ul>
        <t><xref target="fig-oscore-option"/> shows the original format of the OSCORE Option with the four fields OSCORE_flags, OSCORE_piv, OSCORE_kidctx, and OSCORE_kid superimposed on it. Also, <xref target="fig-oscore-option-kudos"/> shows the extended format of the OSCORE option with all the eight fields superimposed on it.</t>
        <t>If a field 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 field kid context is present, it directly includes the size octet, s.</t>
        <t>In addition, the following applies.</t>
        <ul spacing="normal">
          <li>
            <t>For the x field, 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 case where the x field is not present, and thus TV is set to b''; and the case where the two endpoints run KUDOS with a pre-agreed size of the nonce field as per the m sub-field of the x field, as well as with a pre-agreed combination of its modes of operation, as per the bits b and p of the x field.  </t>
            <t>
Otherwise, if the value changes over time, then 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". The Rule may also use a "match-mapping" MO to compress this field, in case the two endpoints pre-agree on a set of alternative ways to run KUDOS, with respect to the size of the nonce field and the combination of the KUDOS modes of operation to use.</t>
          </li>
          <li>
            <t>For the y field, 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 case where the y field is not present, and thus TV is set to b''; and the case where the two endpoints run KUDOS with a pre-agreed size of the old_nonce field as per the w sub-field of the y field.  </t>
            <t>
Otherwise, if the value changes over time, then 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". The Rule may also use a "match-mapping" MO to compress this field, in case the two endpoints pre-agree on a set of sizes of the old_nonce field.</t>
          </li>
          <li>
            <t>For the nonce field, if it is not present (i.e., the x field is not present in the first place), 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".  </t>
            <t>
Otherwise, if the nonce field 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". In such a case, for the value of the nonce field, SCHC MUST NOT send it as variable-length data in the Compression Residue, to avoid ambiguity with the length of the nonce field encoded in the x field. Therefore, SCHC MUST use the m sub-field of the x field to define the size of the Compression Residue. SCHC designates a specific function, "osc.x.m", that the Rule MUST use to complete the Field Descriptor. During the decompression, this function returns the length of the nonce field in bytes, as the value of the m sub-field of the x field, plus 1.</t>
          </li>
          <li>
            <t>For the old_nonce field, if it is not present (i.e., the y field is not present in the first place), 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".  </t>
            <t>
Otherwise, if the old_nonce field 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". In such a case, for the value of the old_nonce field, SCHC MUST NOT send it as variable-length data in the Compression Residue, to avoid ambiguity with the length of the old_nonce field encoded in the y field. Therefore, SCHC MUST use the w sub-field of the y field to define the size of the Compression Residue. SCHC designates a specific function, "osc.y.w", that the Rule MUST use to complete the Field Descriptor. During the decompression, this function returns the length of the old_nonce field in bytes, as the value of the w sub-field of the y field, plus 1.</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 MUST NOT 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 MUST 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</name>
          <thead>
            <tr>
              <th align="left">Field</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">
                <tt>CoAP</tt> <br/> <tt>Version</tt></td>
              <td align="left">2</td>
              <td align="left">1</td>
              <td align="left">Bi</td>
              <td align="left">01</td>
              <td align="left">equal</td>
              <td align="left">not-sent</td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">CoAP 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 Type</td>
              <td align="left">2</td>
              <td align="left">1</td>
              <td align="left">Up</td>
              <td align="left">
                <tt>[ACK,</tt> <br/> <tt>RST]</tt></td>
              <td align="left">
                <tt>match-</tt> <br/> <tt>mapping</tt></td>
              <td align="left">
                <tt>mapping-</tt> <br/> <tt>sent</tt></td>
              <td align="left">T</td>
            </tr>
            <tr>
              <td align="left">
                <tt>CoAP</tt> <br/> <tt>TKL</tt></td>
              <td align="left">4</td>
              <td align="left">1</td>
              <td align="left">Bi</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 Code</td>
              <td align="left">8</td>
              <td align="left">1</td>
              <td align="left">Bi</td>
              <td align="left">
                <tt>[0.00,</tt> <br/> <tt>...</tt> <br/> <tt>5.05]</tt></td>
              <td align="left">
                <tt>match-</tt> <br/> <tt>mapping</tt></td>
              <td align="left">
                <tt>mapping-</tt> <br/> <tt>sent</tt></td>
              <td align="left">CC CCC</td>
            </tr>
            <tr>
              <td align="left">
                <tt>CoAP</tt> <br/> <tt>MID</tt></td>
              <td align="left">16</td>
              <td align="left">1</td>
              <td align="left">Bi</td>
              <td align="left">0000</td>
              <td align="left">MSB(7)</td>
              <td align="left">LSB</td>
              <td align="left">MID</td>
            </tr>
            <tr>
              <td align="left">
                <tt>CoAP</tt> <br/> <tt>Uri-Path</tt></td>
              <td align="left">var</td>
              <td align="left">1</td>
              <td align="left">Dw</td>
              <td align="left">path</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 indicated in the TV and elided with the CDA "not-sent".</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>OSCORE aims to solve the problem of end-to-end protection for CoAP messages. Therefore, the goal is to hide as much as possible of the 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 options moved to the Inner Plaintext.</t>
          </li>
          <li>
            <t>Class I: Integrity-protected options, included in the Additional Authenticated Data (AAD) when protecting the Plaintext, but otherwise left untouched in the Outer Message.</t>
          </li>
          <li>
            <t>Class U: Unprotected options, 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 Packet Split into OSCORE Outer Header and Plaintext</name>
          <artwork align="center"><![CDATA[
                    Original CoAP Message
                 +-+-+---+-------+---------------+
                 |v|t|TKL| code  | Message ID    |
                 +-+-+---+-------+---------------+....+
                 | Token                              |
                 +-------------------------------.....+
                 | Options (IEU)            |
                 .                          .
                 .                          .
                 +------+-------------------+
                 | 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>
        </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>
        <figure anchor="fig-full-oscore">
          <name>OSCORE Message</name>
          <artwork align="center"><![CDATA[
   Outer Header
+-+-+---+--------+---------------+
|v|t|TKL|new code| Message ID    |
+-+-+---+--------+---------------+....+
| Token                               |
+--------------------------------.....+
| Options (IU)             |
.                          .
. OSCORE Option            .
+------+-------------------+
| 0xFF |
+------+---------------------------+
|                                  |
| Ciphertext: Encrypted Inner      |
|             Header and Payload   |
|             + Authentication Tag |
|                                  |
+----------------------------------+
]]></artwork>
        </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="560" width="576" viewBox="0 0 576 560" class="diagram" text-anchor="middle" font-family="monospace" font-size="13px">
                <path d="M 8,48 L 8,136" fill="none" stroke="black"/>
                <path d="M 8,160 L 8,272" fill="none" stroke="black"/>
                <path d="M 24,48 L 24,80" fill="none" stroke="black"/>
                <path d="M 24,320 L 24,368" fill="none" stroke="black"/>
                <path d="M 24,416 L 24,544" fill="none" stroke="black"/>
                <path d="M 40,48 L 40,80" fill="none" stroke="black"/>
                <path d="M 64,176 L 64,208" fill="none" stroke="black"/>
                <path d="M 72,48 L 72,80" fill="none" stroke="black"/>
                <path d="M 72,280 L 72,312" fill="none" stroke="black"/>
                <path d="M 72,376 L 72,408" fill="none" stroke="black"/>
                <path d="M 104,416 L 104,448" fill="none" stroke="black"/>
                <path d="M 144,48 L 144,80" fill="none" stroke="black"/>
                <path d="M 168,208 L 168,272" fill="none" stroke="black"/>
                <path d="M 168,320 L 168,368" fill="none" stroke="black"/>
                <path d="M 208,448 L 208,544" fill="none" stroke="black"/>
                <path d="M 224,160 L 224,176" fill="none" stroke="black"/>
                <path d="M 232,416 L 232,448" fill="none" stroke="black"/>
                <path d="M 256,256 L 256,408" fill="none" stroke="black"/>
                <path d="M 272,48 L 272,80" fill="none" stroke="black"/>
                <path d="M 312,80 L 312,112" fill="none" stroke="black"/>
                <path d="M 336,416 L 336,448" fill="none" stroke="black"/>
                <path d="M 376,48 L 376,208" fill="none" stroke="black"/>
                <path d="M 376,272 L 376,320" fill="none" stroke="black"/>
                <path d="M 392,368 L 392,496" 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,216 L 440,264" fill="none" stroke="black"/>
                <path d="M 440,328 L 440,360" fill="none" stroke="black"/>
                <path d="M 480,368 L 480,400" fill="none" stroke="black"/>
                <path d="M 520,272 L 520,320" fill="none" stroke="black"/>
                <path d="M 552,80 L 552,112" fill="none" stroke="black"/>
                <path d="M 552,144 L 552,208" fill="none" stroke="black"/>
                <path d="M 568,400 L 568,496" fill="none" stroke="black"/>
                <path d="M 8,48 L 272,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 376,80 L 504,80" fill="none" stroke="black"/>
                <path d="M 8,112 L 272,112" fill="none" stroke="black"/>
                <path d="M 376,112 L 512,112" fill="none" stroke="black"/>
                <path d="M 376,144 L 552,144" fill="none" stroke="black"/>
                <path d="M 8,176 L 224,176" fill="none" stroke="black"/>
                <path d="M 8,208 L 168,208" fill="none" stroke="black"/>
                <path d="M 376,208 L 552,208" fill="none" stroke="black"/>
                <path d="M 176,240 L 248,240" fill="none" stroke="black"/>
                <path d="M 8,272 L 168,272" fill="none" stroke="black"/>
                <path d="M 376,272 L 520,272" fill="none" stroke="black"/>
                <path d="M 24,320 L 168,320" fill="none" stroke="black"/>
                <path d="M 376,320 L 520,320" fill="none" stroke="black"/>
                <path d="M 24,368 L 168,368" fill="none" stroke="black"/>
                <path d="M 392,368 L 480,368" fill="none" stroke="black"/>
                <path d="M 392,400 L 568,400" fill="none" stroke="black"/>
                <path d="M 24,416 L 104,416" fill="none" stroke="black"/>
                <path d="M 232,416 L 336,416" fill="none" stroke="black"/>
                <path d="M 352,432 L 376,432" fill="none" stroke="black"/>
                <path d="M 392,432 L 568,432" fill="none" stroke="black"/>
                <path d="M 24,448 L 208,448" fill="none" stroke="black"/>
                <path d="M 232,448 L 336,448" fill="none" stroke="black"/>
                <path d="M 24,480 L 208,480" fill="none" stroke="black"/>
                <path d="M 392,496 L 568,496" fill="none" stroke="black"/>
                <path d="M 24,544 L 208,544" fill="none" stroke="black"/>
                <polygon class="arrowhead" points="448,360 436,354.4 436,365.6" fill="black" transform="rotate(90,440,360)"/>
                <polygon class="arrowhead" points="448,264 436,258.4 436,269.6" fill="black" transform="rotate(90,440,264)"/>
                <polygon class="arrowhead" points="360,432 348,426.4 348,437.6" fill="black" transform="rotate(180,352,432)"/>
                <polygon class="arrowhead" points="184,240 172,234.4 172,245.6" fill="black" transform="rotate(180,176,240)"/>
                <polygon class="arrowhead" points="80,408 68,402.4 68,413.6" fill="black" transform="rotate(90,72,408)"/>
                <polygon class="arrowhead" points="80,312 68,306.4 68,317.6" fill="black" transform="rotate(90,72,312)"/>
                <g class="text">
                  <text x="48" y="36">Outer</text>
                  <text x="104" y="36">Message</text>
                  <text x="404" y="36">OSCORE</text>
                  <text x="472" 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="88" y="68">new</text>
                  <text x="124" y="68">code</text>
                  <text x="184" y="68">Message</text>
                  <text x="228" y="68">ID</text>
                  <text x="404" y="68">code</text>
                  <text x="296" 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="292" y="116">....</text>
                  <text x="532" 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="44" y="164">OSCORE</text>
                  <text x="100" y="164">Option</text>
                  <text x="416" y="180">Payload</text>
                  <text x="36" y="196">0xFF</text>
                  <text x="60" y="244">Ciphertext</text>
                  <text x="256" y="244">\</text>
                  <text x="424" y="292">Inner</text>
                  <text x="468" y="292">SCHC</text>
                  <text x="448" y="308">Compression</text>
                  <text x="72" y="340">Outer</text>
                  <text x="116" y="340">SCHC</text>
                  <text x="96" y="356">Compression</text>
                  <text x="428" y="388">RuleID</text>
                  <text x="448" y="420">Compression</text>
                  <text x="528" y="420">Residue</text>
                  <text x="64" y="436">RuleID'</text>
                  <text x="284" y="436">Encryption</text>
                  <text x="80" y="468">Compression</text>
                  <text x="164" y="468">Residue'</text>
                  <text x="432" y="468">Payload</text>
                  <text x="76" y="516">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    |
        v                      |              |   Compression   |
  +-----------------+          |              +-----------------+
  |   Outer SCHC    |          |                      |
  |   Compression   |          |                      v
  +-----------------+          |                +----------+
        |                      |                | RuleID   |
        v                      |                +----------+----------+
  +---------+               +------------+      | Compression Residue |
  | RuleID' |               | Encryption | <--- +---------------------+
  +---------+------------+  +------------+      |                     |
  | Compression Residue' |                      | Payload             |
  +----------------------+                      |                     |
  |                      |                      +---------------------+
  | 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 MUST NOT 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 MUST NOT 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 MUST 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 MUST 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 present in a regular CoAP message. The methods described in <xref target="sec-coap-fields-compression"/> apply to these fields. Table 4 provides an example.</t>
        <artwork><![CDATA[
 +----------+
 | RuleID 0 |
 +----------+
]]></artwork>
        <table align="center" anchor="_table-Inner-Rules">
          <name>Inner SCHC Rule</name>
          <thead>
            <tr>
              <th align="left">Field</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 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 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">
                <tt>match-</tt> <br/> <tt>mapping</tt></td>
              <td align="left">
                <tt>mapping-</tt> <br/> <tt>sent</tt></td>
              <td align="left">C</td>
            </tr>
            <tr>
              <td align="left">
                <tt>CoAP</tt> <br/> <tt>Uri-Path</tt></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="640" width="432" viewBox="0 0 432 640" class="diagram" text-anchor="middle" font-family="monospace" font-size="13px">
                <path d="M 8,40 L 8,200" fill="none" stroke="black"/>
                <path d="M 48,536 L 48,632" fill="none" stroke="black"/>
                <path d="M 120,312 L 120,440" fill="none" stroke="black"/>
                <path d="M 232,224 L 232,288" fill="none" stroke="black"/>
                <path d="M 232,464 L 232,512" fill="none" stroke="black"/>
                <path d="M 336,312 L 336,440" fill="none" stroke="black"/>
                <path d="M 424,40 L 424,200" fill="none" stroke="black"/>
                <path d="M 424,536 L 424,632" fill="none" stroke="black"/>
                <path d="M 8,40 L 424,40" fill="none" stroke="black"/>
                <path d="M 8,200 L 424,200" fill="none" stroke="black"/>
                <path d="M 120,312 L 336,312" fill="none" stroke="black"/>
                <path d="M 120,440 L 336,440" fill="none" stroke="black"/>
                <path d="M 48,536 L 424,536" fill="none" stroke="black"/>
                <path d="M 48,632 L 424,632" fill="none" stroke="black"/>
                <polygon class="arrowhead" points="240,512 228,506.4 228,517.6" fill="black" transform="rotate(90,232,512)"/>
                <polygon class="arrowhead" points="240,288 228,282.4 228,293.6" fill="black" transform="rotate(90,232,288)"/>
                <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="260">Inner</text>
                  <text x="308" y="260">SCHC</text>
                  <text x="376" y="260">Compression</text>
                  <text x="172" y="340">Compressed</text>
                  <text x="256" y="340">Plaintext</text>
                  <text x="148" y="372">0x00</text>
                  <text x="156" y="404">RuleID</text>
                  <text x="192" y="404">=</text>
                  <text x="220" y="404">0x00</text>
                  <text x="252" y="404">(1</text>
                  <text x="288" y="404">byte)</text>
                  <text x="144" y="420">(No</text>
                  <text x="208" y="420">Compression</text>
                  <text x="292" y="420">Residue)</text>
                  <text x="260" y="484">AEAD</text>
                  <text x="324" y="484">Encryption</text>
                  <text x="268" y="500">(piv</text>
                  <text x="296" y="500">=</text>
                  <text x="328" y="500">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 adding security to the 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 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="704" width="488" viewBox="0 0 488 704" class="diagram" text-anchor="middle" font-family="monospace" font-size="13px">
                <path d="M 8,40 L 8,216" fill="none" stroke="black"/>
                <path d="M 16,328 L 16,504" fill="none" stroke="black"/>
                <path d="M 16,600 L 16,696" fill="none" stroke="black"/>
                <path d="M 232,240 L 232,304" fill="none" stroke="black"/>
                <path d="M 232,528 L 232,576" fill="none" stroke="black"/>
                <path d="M 408,40 L 408,216" fill="none" stroke="black"/>
                <path d="M 408,328 L 408,504" fill="none" stroke="black"/>
                <path d="M 480,608 L 480,696" fill="none" stroke="black"/>
                <path d="M 8,40 L 408,40" fill="none" stroke="black"/>
                <path d="M 8,216 L 408,216" fill="none" stroke="black"/>
                <path d="M 16,328 L 408,328" fill="none" stroke="black"/>
                <path d="M 16,504 L 408,504" fill="none" stroke="black"/>
                <path d="M 12,600 L 468,600" fill="none" stroke="black"/>
                <path d="M 16,696 L 480,696" fill="none" stroke="black"/>
                <polygon class="arrowhead" points="240,576 228,570.4 228,581.6" fill="black" transform="rotate(90,232,576)"/>
                <polygon class="arrowhead" points="240,304 228,298.4 228,309.6" fill="black" transform="rotate(90,232,304)"/>
                <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="276">Inner</text>
                  <text x="308" y="276">SCHC</text>
                  <text x="376" y="276">Compression</text>
                  <text x="68" y="356">Compressed</text>
                  <text x="152" y="356">Plaintext</text>
                  <text x="84" y="388">0x001919902180</text>
                  <text x="156" y="388">(6</text>
                  <text x="196" y="388">bytes)</text>
                  <text x="52" y="420">00</text>
                  <text x="92" y="420">RuleID</text>
                  <text x="48" y="452">0b0</text>
                  <text x="76" y="452">(1</text>
                  <text x="104" y="452">bit</text>
                  <text x="176" y="452">match-mapping</text>
                  <text x="280" y="452">Compression</text>
                  <text x="364" y="452">Residue)</text>
                  <text x="116" y="468">0x32332043</text>
                  <text x="172" y="468">&gt;&gt;</text>
                  <text x="192" y="468">1</text>
                  <text x="236" y="468">(shifted</text>
                  <text x="308" y="468">payload)</text>
                  <text x="248" y="484">0b0000000</text>
                  <text x="320" y="484">Padding</text>
                  <text x="260" y="548">AEAD</text>
                  <text x="324" y="548">Encryption</text>
                  <text x="268" y="564">(piv</text>
                  <text x="296" y="564">=</text>
                  <text x="328" y="564">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</name>
          <thead>
            <tr>
              <th align="left">Field</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">
                <tt>CoAP</tt> <br/> <tt>Version</tt></td>
              <td align="left">2</td>
              <td align="left">1</td>
              <td align="left">Bi</td>
              <td align="left">01</td>
              <td align="left">equal</td>
              <td align="left">
                <tt>not-</tt> <br/> <tt>sent</tt></td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">
                <tt>CoAP</tt> <br/> <tt>Type</tt></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">
                <tt>not-</tt> <br/> <tt>sent</tt></td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">
                <tt>CoAP</tt> <br/> <tt>Type</tt></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">
                <tt>not-</tt> <br/> <tt>sent</tt></td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">
                <tt>CoAP</tt> <br/> <tt>TKL</tt></td>
              <td align="left">4</td>
              <td align="left">1</td>
              <td align="left">Bi</td>
              <td align="left">1</td>
              <td align="left">equal</td>
              <td align="left">
                <tt>not-</tt> <br/> <tt>sent</tt></td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">
                <tt>CoAP</tt> <br/> <tt>Code</tt></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">
                <tt>not-</tt> <br/> <tt>sent</tt></td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">
                <tt>CoAP</tt> <br/> <tt>Code</tt></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">
                <tt>not-</tt> <br/> <tt>sent</tt></td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">
                <tt>CoAP</tt> <br/> <tt>MID</tt></td>
              <td align="left">16</td>
              <td align="left">1</td>
              <td align="left">Bi</td>
              <td align="left">0000</td>
              <td align="left">MSB(12)</td>
              <td align="left">LSB</td>
              <td align="left">MMMM</td>
            </tr>
            <tr>
              <td align="left">
                <tt>CoAP</tt> <br/> <tt>Token</tt></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">
                <tt>CoAP</tt> <br/> <tt>OSCORE_flags</tt></td>
              <td align="left">var</td>
              <td align="left">1</td>
              <td align="left">Up</td>
              <td align="left">0x09</td>
              <td align="left">equal</td>
              <td align="left">
                <tt>not-</tt> <br/> <tt>sent</tt></td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">
                <tt>CoAP</tt> <br/> <tt>OSCORE_piv</tt></td>
              <td align="left">var</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">
                <tt>CoAP</tt> <br/> <tt>OSCORE_kid</tt></td>
              <td align="left">var</td>
              <td align="left">1</td>
              <td align="left">Up</td>
              <td align="left">0x636c69656e70</td>
              <td align="left">MSB(44)</td>
              <td align="left">LSB</td>
              <td align="left">KKKK</td>
            </tr>
            <tr>
              <td align="left">
                <tt>CoAP</tt> <br/> <tt>OSCORE_kidctx</tt></td>
              <td align="left">var</td>
              <td align="left">1</td>
              <td align="left">Bi</td>
              <td align="left">b''</td>
              <td align="left">equal</td>
              <td align="left">
                <tt>not-</tt> <br/> <tt>sent</tt></td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">
                <tt>CoAP</tt> <br/> <tt>OSCORE_x</tt></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">
                <tt>not-</tt> <br/> <tt>sent</tt></td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">
                <tt>CoAP</tt> <br/> <tt>OSCORE_nonce</tt></td>
              <td align="left">osc.x.m</td>
              <td align="left">1</td>
              <td align="left">Bi</td>
              <td align="left">b''</td>
              <td align="left">equal</td>
              <td align="left">
                <tt>not-</tt> <br/> <tt>sent</tt></td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">
                <tt>CoAP</tt> <br/> <tt>OSCORE_y</tt></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">
                <tt>not-</tt> <br/> <tt>sent</tt></td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">
                <tt>CoAP</tt> <br/> <tt>OSCORE_oldnonce</tt></td>
              <td align="left">osc.y.w</td>
              <td align="left">1</td>
              <td align="left">Bi</td>
              <td align="left">b''</td>
              <td align="left">equal</td>
              <td align="left">
                <tt>not-</tt> <br/> <tt>sent</tt></td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">
                <tt>CoAP</tt> <br/> <tt>OSCORE_flags</tt></td>
              <td align="left">var</td>
              <td align="left">1</td>
              <td align="left">Dw</td>
              <td align="left">b''</td>
              <td align="left">equal</td>
              <td align="left">
                <tt>not-</tt> <br/> <tt>sent</tt></td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">
                <tt>CoAP</tt> <br/> <tt>OSCORE_piv</tt></td>
              <td align="left">var</td>
              <td align="left">1</td>
              <td align="left">Dw</td>
              <td align="left">b''</td>
              <td align="left">equal</td>
              <td align="left">
                <tt>not-</tt> <br/> <tt>sent</tt></td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">
                <tt>CoAP</tt> <br/> <tt>OSCORE_kid</tt></td>
              <td align="left">var</td>
              <td align="left">1</td>
              <td align="left">Dw</td>
              <td align="left">b''</td>
              <td align="left">equal</td>
              <td align="left">
                <tt>not-</tt> <br/> <tt>sent</tt></td>
              <td align="left"> </td>
            </tr>
          </tbody>
        </table>
        <figure anchor="fig-Protected-Compressed-GET">
          <name>Protected and Inner SCHC Compressed GET Request</name>
          <artset>
            <artwork type="svg" align="center"><svg xmlns="http://www.w3.org/2000/svg" version="1.1" height="496" width="408" viewBox="0 0 408 496" class="diagram" text-anchor="middle" font-family="monospace" font-size="13px">
                <path d="M 8,46 L 144,46" fill="none" stroke="black"/>
                <path d="M 8,50 L 144,50" fill="none" stroke="black"/>
                <g class="text">
                  <text x="40" y="36">Protected</text>
                  <text x="116" y="36">message:</text>
                  <text x="204" y="68">0x4102000182980904636c69656e74ffa2c54fe1b434297b62</text>
                  <text x="16" y="84">(24</text>
                  <text x="60" y="84">bytes)</text>
                  <text x="32" y="116">Header:</text>
                  <text x="28" y="132">0x4102</text>
                  <text x="12" y="148">01</text>
                  <text x="56" y="148">Ver</text>
                  <text x="28" y="164">00</text>
                  <text x="72" y="164">CON</text>
                  <text x="52" y="180">0001</text>
                  <text x="104" y="180">TKL</text>
                  <text x="100" y="196">00000010</text>
                  <text x="184" y="196">Request</text>
                  <text x="236" y="196">Code</text>
                  <text x="264" y="196">2</text>
                  <text x="300" y="196">"POST"</text>
                  <text x="28" y="228">0x0001</text>
                  <text x="64" y="228">=</text>
                  <text x="88" y="228">mid</text>
                  <text x="20" y="244">0x82</text>
                  <text x="48" y="244">=</text>
                  <text x="80" y="244">token</text>
                  <text x="36" y="276">Options:</text>
                  <text x="20" y="308">0x98</text>
                  <text x="108" y="308">0904636c69656e74</text>
                  <text x="188" y="308">(9</text>
                  <text x="228" y="308">bytes)</text>
                  <text x="28" y="324">Option</text>
                  <text x="68" y="324">9:</text>
                  <text x="108" y="324">OSCORE</text>
                  <text x="24" y="340">Value</text>
                  <text x="56" y="340">=</text>
                  <text x="140" y="340">0x0904636c69656e74</text>
                  <text x="92" y="356">09</text>
                  <text x="112" y="356">=</text>
                  <text x="136" y="356">000</text>
                  <text x="160" y="356">0</text>
                  <text x="176" y="356">1</text>
                  <text x="200" y="356">001</text>
                  <text x="236" y="356">flag</text>
                  <text x="276" y="356">byte</text>
                  <text x="160" y="372">h</text>
                  <text x="176" y="372">k</text>
                  <text x="200" y="372">n</text>
                  <text x="108" y="388">04</text>
                  <text x="136" y="388">piv</text>
                  <text x="164" y="404">636c69656e74</text>
                  <text x="232" y="404">kid</text>
                  <text x="20" y="436">0xFF</text>
                  <text x="80" y="436">Payload</text>
                  <text x="140" y="436">marker</text>
                  <text x="36" y="468">Payload:</text>
                  <text x="84" y="484">0xa2c54fe1b434297b62</text>
                  <text x="180" y="484">(9</text>
                  <text x="220" y="484">bytes)</text>
                </g>
              </svg>
            </artwork>
            <artwork type="ascii-art"><![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 flag byte
                   h k  n
            04 piv
              636c69656e74 kid

0xFF  Payload marker

Payload:
0xa2c54fe1b434297b62 (9 bytes)
]]></artwork>
          </artset>
        </figure>
        <figure anchor="fig-Protected-Compressed-CONTENT">
          <name>Protected and Inner SCHC Compressed Content Response</name>
          <artset>
            <artwork type="svg" align="center"><svg xmlns="http://www.w3.org/2000/svg" version="1.1" height="432" width="496" viewBox="0 0 496 432" class="diagram" text-anchor="middle" font-family="monospace" font-size="13px">
                <path d="M 8,46 L 144,46" fill="none" stroke="black"/>
                <path d="M 8,50 L 144,50" fill="none" stroke="black"/>
                <g class="text">
                  <text x="40" y="36">Protected</text>
                  <text x="116" y="36">message:</text>
                  <text x="180" y="68">0x614400018290ff10c6d7c26cc1e9aef3f2461e0c29</text>
                  <text x="16" y="84">(21</text>
                  <text x="60" y="84">bytes)</text>
                  <text x="32" y="116">Header:</text>
                  <text x="28" y="132">0x6144</text>
                  <text x="12" y="148">01</text>
                  <text x="56" y="148">Ver</text>
                  <text x="28" y="164">10</text>
                  <text x="72" y="164">ACK</text>
                  <text x="52" y="180">0001</text>
                  <text x="104" y="180">TKL</text>
                  <text x="100" y="196">01000100</text>
                  <text x="196" y="196">Successful</text>
                  <text x="276" y="196">Response</text>
                  <text x="332" y="196">Code</text>
                  <text x="364" y="196">68</text>
                  <text x="400" y="196">"2.04</text>
                  <text x="460" y="196">Changed"</text>
                  <text x="28" y="228">0x0001</text>
                  <text x="64" y="228">=</text>
                  <text x="88" y="228">mid</text>
                  <text x="20" y="244">0x82</text>
                  <text x="48" y="244">=</text>
                  <text x="80" y="244">token</text>
                  <text x="36" y="276">Options:</text>
                  <text x="20" y="308">0x90</text>
                  <text x="52" y="308">(1</text>
                  <text x="88" y="308">byte)</text>
                  <text x="28" y="324">Option</text>
                  <text x="68" y="324">9:</text>
                  <text x="108" y="324">OSCORE</text>
                  <text x="24" y="340">Value</text>
                  <text x="56" y="340">=</text>
                  <text x="80" y="340">b''</text>
                  <text x="20" y="372">0xFF</text>
                  <text x="80" y="372">Payload</text>
                  <text x="140" y="372">marker</text>
                  <text x="36" y="404">Payload:</text>
                  <text x="124" y="420">0x10c6d7c26cc1e9aef3f2461e0c29</text>
                  <text x="264" y="420">(14</text>
                  <text x="308" y="420">bytes)</text>
                </g>
              </svg>
            </artwork>
            <artwork type="ascii-art"><![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 = b''

0xFF  Payload marker

Payload:
0x10c6d7c26cc1e9aef3f2461e0c29 (14 bytes)
]]></artwork>
          </artset>
        </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 OSCORE_kidctx field MAY be masked off with an LSB CDA. The rest of the OSCORE_kidctx 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 OSCORE_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:
==================
0x011489458a9fc3686852f6c4 (12 bytes)
0x01 RuleID
    1489 Compression Residue
        458a9fc3686852f6c4 Padded payload

Compression Residue:
0b 0001 010 0100 0100 (15 bits -> 2 bytes with padding)
    mid tkn piv  kid

Payload
0xa2c54fe1b434297b62 (9 bytes)

Compressed message length: 12 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  tkn

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)</name>
          <thead>
            <tr>
              <th align="left">Field</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">
                <tt>CoAP</tt> <br/> <tt>Version</tt></td>
              <td align="left">2</td>
              <td align="left">1</td>
              <td align="left">Bi</td>
              <td align="left">01</td>
              <td align="left">equal</td>
              <td align="left">
                <tt>not-sent</tt></td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">CoAP 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">
                <tt>not-sent</tt></td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">CoAP 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">
                <tt>not-sent</tt></td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">
                <tt>CoAP</tt> <br/> <tt>TKL</tt></td>
              <td align="left">4</td>
              <td align="left">1</td>
              <td align="left">Bi</td>
              <td align="left">1</td>
              <td align="left">equal</td>
              <td align="left">
                <tt>not-sent</tt></td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">CoAP 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">
                <tt>not-sent</tt></td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">CoAP 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">
                <tt>match-</tt> <br/> <tt>mapping</tt></td>
              <td align="left">
                <tt>mapping-</tt> <br/> <tt>sent</tt></td>
              <td align="left">C</td>
            </tr>
            <tr>
              <td align="left">
                <tt>CoAP</tt> <br/> <tt>MID</tt></td>
              <td align="left">16</td>
              <td align="left">1</td>
              <td align="left">Bi</td>
              <td align="left">0000</td>
              <td align="left">MSB(12)</td>
              <td align="left">LSB</td>
              <td align="left">MMMM</td>
            </tr>
            <tr>
              <td align="left">CoAP 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">
                <tt>CoAP</tt> <br/> <tt>Uri-Path</tt></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">
                <tt>not-sent</tt></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 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>In particular, 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</name>
          <thead>
            <tr>
              <th align="left">Field</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">
                <tt>CoAP</tt> <br/> <tt>Version</tt></td>
              <td align="left">2</td>
              <td align="left">1</td>
              <td align="left">Bi</td>
              <td align="left">01</td>
              <td align="left">equal</td>
              <td align="left">not-sent</td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">
                <tt>CoAP</tt> <br/> <tt>Type</tt></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">
                <tt>CoAP</tt> <br/> <tt>Type</tt></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">
                <tt>match-</tt> <br/> <tt>mapping</tt></td>
              <td align="left">
                <tt>mapping-</tt> <br/> <tt>sent</tt></td>
              <td align="left">T</td>
            </tr>
            <tr>
              <td align="left">
                <tt>CoAP</tt> <br/> <tt>TKL</tt></td>
              <td align="left">4</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">
                <tt>CoAP</tt> <br/> <tt>Code</tt></td>
              <td align="left">8</td>
              <td align="left">1</td>
              <td align="left">Up</td>
              <td align="left">
                <tt>[1, 2,</tt> <br/> <tt>3, 4]</tt></td>
              <td align="left">
                <tt>match-</tt> <br/> <tt>mapping</tt></td>
              <td align="left">
                <tt>mapping-</tt> <br/> <tt>sent</tt></td>
              <td align="left">CC</td>
            </tr>
            <tr>
              <td align="left">
                <tt>CoAP</tt> <br/> <tt>Code</tt></td>
              <td align="left">8</td>
              <td align="left">1</td>
              <td align="left">Dw</td>
              <td align="left">
                <tt>[65, 68,</tt> <br/> <tt>69, 132]</tt></td>
              <td align="left">
                <tt>match-</tt> <br/> <tt>mapping</tt></td>
              <td align="left">
                <tt>mapping-</tt> <br/> <tt>sent</tt></td>
              <td align="left">CC</td>
            </tr>
            <tr>
              <td align="left">
                <tt>CoAP</tt> <br/> <tt>MID</tt></td>
              <td align="left">16</td>
              <td align="left">1</td>
              <td align="left">Bi</td>
              <td align="left">0x00</td>
              <td align="left">MSB(12)</td>
              <td align="left">LSB</td>
              <td align="left">MMMM</td>
            </tr>
            <tr>
              <td align="left">
                <tt>CoAP</tt> <br/> <tt>Token</tt></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">
                <tt>CoAP</tt> <br/> <tt>Uri-Host</tt></td>
              <td align="left">
                <tt>var</tt> <br/> <tt>(B)</tt></td>
              <td align="left">1</td>
              <td align="left">Up</td>
              <td align="left"> </td>
              <td align="left">ignore</td>
              <td align="left">
                <tt>value-</tt> <br/> <tt>sent</tt></td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">
                <tt>CoAP</tt> <br/> <tt>Uri-Path</tt></td>
              <td align="left">var</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">
                <tt>CoAP</tt> <br/> <tt>Proxy-Scheme</tt></td>
              <td align="left">var</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</name>
          <thead>
            <tr>
              <th align="left">Field</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">
                <tt>CoAP</tt> <br/> <tt>Version</tt></td>
              <td align="left">2</td>
              <td align="left">1</td>
              <td align="left">Bi</td>
              <td align="left">01</td>
              <td align="left">equal</td>
              <td align="left">not-sent</td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">
                <tt>CoAP</tt> <br/> <tt>Type</tt></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">
                <tt>CoAP</tt> <br/> <tt>Type</tt></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">
                <tt>match-</tt> <br/> <tt>mapping</tt></td>
              <td align="left">
                <tt>mapping-</tt> <br/> <tt>sent</tt></td>
              <td align="left">T</td>
            </tr>
            <tr>
              <td align="left">
                <tt>CoAP</tt> <br/> <tt>TKL</tt></td>
              <td align="left">4</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">
                <tt>CoAP</tt> <br/> <tt>Code</tt></td>
              <td align="left">8</td>
              <td align="left">1</td>
              <td align="left">Up</td>
              <td align="left">
                <tt>[1, 2,</tt> <br/> <tt>3, 4]</tt></td>
              <td align="left">
                <tt>match-</tt> <br/> <tt>mapping</tt></td>
              <td align="left">
                <tt>mapping-</tt> <br/> <tt>sent</tt></td>
              <td align="left">CC</td>
            </tr>
            <tr>
              <td align="left">
                <tt>CoAP</tt> <br/> <tt>Code</tt></td>
              <td align="left">8</td>
              <td align="left">1</td>
              <td align="left">Dw</td>
              <td align="left">
                <tt>[65, 68,</tt> <br/> <tt>69, 132]</tt></td>
              <td align="left">
                <tt>match-</tt> <br/> <tt>mapping</tt></td>
              <td align="left">
                <tt>mapping-</tt> <br/> <tt>sent</tt></td>
              <td align="left">CC</td>
            </tr>
            <tr>
              <td align="left">
                <tt>CoAP</tt> <br/> <tt>MID</tt></td>
              <td align="left">16</td>
              <td align="left">1</td>
              <td align="left">Bi</td>
              <td align="left">0x00</td>
              <td align="left">MSB(12)</td>
              <td align="left">LSB</td>
              <td align="left">MMMM</td>
            </tr>
            <tr>
              <td align="left">
                <tt>CoAP</tt> <br/> <tt>Token</tt></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">
                <tt>CoAP</tt> <br/> <tt>Uri-Host</tt></td>
              <td align="left">
                <tt>var</tt> <br/> <tt>(B)</tt></td>
              <td align="left">1</td>
              <td align="left">Up</td>
              <td align="left"> </td>
              <td align="left">ignore</td>
              <td align="left">
                <tt>value-</tt> <br/> <tt>sent</tt></td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">
                <tt>CoAP</tt> <br/> <tt>Uri-Path</tt></td>
              <td align="left">var</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"/>, which 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 tkn  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"/>, which 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 tkn  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"/>, which 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"/>, which 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 tkn

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"/>, which 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 tkn

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"/>, which 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</name>
          <thead>
            <tr>
              <th align="left">Field</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">
                <tt>CoAP</tt> <br/> <tt>Code</tt></td>
              <td align="left">8</td>
              <td align="left">1</td>
              <td align="left">Up</td>
              <td align="left">
                <tt>[1, 2,</tt> <br/> <tt>3, 4]</tt></td>
              <td align="left">
                <tt>match-</tt> <br/> <tt>mapping</tt></td>
              <td align="left">
                <tt>mapping-</tt> <br/> <tt>sent</tt></td>
              <td align="left">CC</td>
            </tr>
            <tr>
              <td align="left">
                <tt>CoAP</tt> <br/> <tt>Code</tt></td>
              <td align="left">8</td>
              <td align="left">1</td>
              <td align="left">Dw</td>
              <td align="left">
                <tt>[65, 68,</tt> <br/> <tt>69, 132]</tt></td>
              <td align="left">
                <tt>match-</tt> <br/> <tt>mapping</tt></td>
              <td align="left">
                <tt>mapping-</tt> <br/> <tt>sent</tt></td>
              <td align="left">CC</td>
            </tr>
            <tr>
              <td align="left">
                <tt>CoAP</tt> <br/> <tt>Uri-Path</tt></td>
              <td align="left">var</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</name>
          <thead>
            <tr>
              <th align="left">Field</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">
                <tt>CoAP</tt> <br/> <tt>Version</tt></td>
              <td align="left">2</td>
              <td align="left">1</td>
              <td align="left">Bi</td>
              <td align="left">01</td>
              <td align="left">equal</td>
              <td align="left">not-sent</td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">
                <tt>CoAP</tt> <br/> <tt>Type</tt></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">
                <tt>CoAP</tt> <br/> <tt>Type</tt></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">
                <tt>match-</tt> <br/> <tt>mapping</tt></td>
              <td align="left">
                <tt>mapping-</tt> <br/> <tt>sent</tt></td>
              <td align="left">T</td>
            </tr>
            <tr>
              <td align="left">
                <tt>CoAP</tt> <br/> <tt>TKL</tt></td>
              <td align="left">4</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">
                <tt>CoAP</tt> <br/> <tt>Code</tt></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">
                <tt>CoAP</tt> <br/> <tt>Code</tt></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">
                <tt>CoAP</tt> <br/> <tt>MID</tt></td>
              <td align="left">16</td>
              <td align="left">1</td>
              <td align="left">Bi</td>
              <td align="left">0x00</td>
              <td align="left">MSB(12)</td>
              <td align="left">LSB</td>
              <td align="left">MMMM</td>
            </tr>
            <tr>
              <td align="left">
                <tt>CoAP</tt> <br/> <tt>Token</tt></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">
                <tt>CoAP</tt> <br/> <tt>Uri-Host</tt></td>
              <td align="left">
                <tt>var</tt> <br/> <tt>(B)</tt></td>
              <td align="left">1</td>
              <td align="left">Up</td>
              <td align="left"> </td>
              <td align="left">ignore</td>
              <td align="left">
                <tt>value-</tt> <br/> <tt>sent</tt></td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">
                <tt>CoAP</tt> <br/> <tt>OSCORE_flags</tt></td>
              <td align="left">var</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">
                <tt>CoAP</tt> <br/> <tt>OSCORE_piv</tt></td>
              <td align="left">var</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">
                <tt>CoAP</tt> <br/> <tt>OSCORE_kid</tt></td>
              <td align="left">var</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">
                <tt>CoAP</tt> <br/> <tt>OSCORE_kidctx</tt></td>
              <td align="left">var</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">
                <tt>CoAP</tt> <br/> <tt>OSCORE_x</tt></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">
                <tt>not-sent</tt></td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">
                <tt>CoAP</tt> <br/> <tt>OSCORE_nonce</tt></td>
              <td align="left">osc.x.m</td>
              <td align="left">1</td>
              <td align="left">Bi</td>
              <td align="left">b''</td>
              <td align="left">equal</td>
              <td align="left">
                <tt>not-sent</tt></td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">
                <tt>CoAP</tt> <br/> <tt>OSCORE_y</tt></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">
                <tt>not-sent</tt></td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">
                <tt>CoAP</tt> <br/> <tt>OSCORE_oldnonce</tt></td>
              <td align="left">osc.y.w</td>
              <td align="left">1</td>
              <td align="left">Bi</td>
              <td align="left">b''</td>
              <td align="left">equal</td>
              <td align="left">
                <tt>not-sent</tt></td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">
                <tt>CoAP</tt> <br/> <tt>OSCORE_flags</tt></td>
              <td align="left">var</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">
                <tt>CoAP</tt> <br/> <tt>OSCORE_piv</tt></td>
              <td align="left">var</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">
                <tt>CoAP</tt> <br/> <tt>OSCORE_kid</tt></td>
              <td align="left">var</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">
                <tt>CoAP</tt> <br/> <tt>Proxy-Scheme</tt></td>
              <td align="left">var</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</name>
          <thead>
            <tr>
              <th align="left">Field</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">
                <tt>CoAP</tt> <br/> <tt>Version</tt></td>
              <td align="left">2</td>
              <td align="left">1</td>
              <td align="left">Bi</td>
              <td align="left">01</td>
              <td align="left">equal</td>
              <td align="left">not-sent</td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">
                <tt>CoAP</tt> <br/> <tt>Type</tt></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">
                <tt>CoAP</tt> <br/> <tt>Type</tt></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">
                <tt>match-</tt> <br/> <tt>mapping</tt></td>
              <td align="left">
                <tt>mapping-</tt> <br/> <tt>sent</tt></td>
              <td align="left">T</td>
            </tr>
            <tr>
              <td align="left">
                <tt>CoAP</tt> <br/> <tt>TKL</tt></td>
              <td align="left">4</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">
                <tt>CoAP</tt> <br/> <tt>Code</tt></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">
                <tt>CoAP</tt> <br/> <tt>Code</tt></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">
                <tt>CoAP</tt> <br/> <tt>MID</tt></td>
              <td align="left">16</td>
              <td align="left">1</td>
              <td align="left">Bi</td>
              <td align="left">0x00</td>
              <td align="left">MSB(12)</td>
              <td align="left">LSB</td>
              <td align="left">MMMM</td>
            </tr>
            <tr>
              <td align="left">
                <tt>CoAP</tt> <br/> <tt>Token</tt></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">
                <tt>CoAP</tt> <br/> <tt>Uri-Host</tt></td>
              <td align="left">
                <tt>var</tt> <br/> <tt>(B)</tt></td>
              <td align="left">1</td>
              <td align="left">Up</td>
              <td align="left"> </td>
              <td align="left">ignore</td>
              <td align="left">
                <tt>value-</tt> <br/> <tt>sent</tt></td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">
                <tt>CoAP</tt> <br/> <tt>OSCORE_flags</tt></td>
              <td align="left">var</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">
                <tt>CoAP</tt> <br/> <tt>OSCORE_piv</tt></td>
              <td align="left">var</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">
                <tt>CoAP</tt> <br/> <tt>OSCORE_kid</tt></td>
              <td align="left">var</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">
                <tt>CoAP</tt> <br/> <tt>OSCORE_kidctx</tt></td>
              <td align="left">var</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">
                <tt>CoAP</tt> <br/> <tt>OSCORE_x</tt></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">
                <tt>not-sent</tt></td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">
                <tt>CoAP</tt> <br/> <tt>OSCORE_nonce</tt></td>
              <td align="left">osc.x.m</td>
              <td align="left">1</td>
              <td align="left">Bi</td>
              <td align="left">b''</td>
              <td align="left">equal</td>
              <td align="left">
                <tt>not-sent</tt></td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">
                <tt>CoAP</tt> <br/> <tt>OSCORE_y</tt></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">
                <tt>not-sent</tt></td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">
                <tt>CoAP</tt> <br/> <tt>OSCORE_oldnonce</tt></td>
              <td align="left">osc.y.w</td>
              <td align="left">1</td>
              <td align="left">Bi</td>
              <td align="left">b''</td>
              <td align="left">equal</td>
              <td align="left">
                <tt>not-sent</tt></td>
              <td align="left"> </td>
            </tr>
            <tr>
              <td align="left">
                <tt>CoAP</tt> <br/> <tt>OSCORE_flags</tt></td>
              <td align="left">var</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">
                <tt>CoAP</tt> <br/> <tt>OSCORE_piv</tt></td>
              <td align="left">var</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">
                <tt>CoAP</tt> <br/> <tt>OSCORE_kid</tt></td>
              <td align="left">var</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>
          <artwork 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>
        </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>
          <artwork 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>
        </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 flag byte
                   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"/>, which 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:
=================
0x03156caf0c2dae0d8ca5cc6deda8b459f8a9fc3686852f6c40 (25 bytes)
0x03 RuleID
    156caf0c2dae0d8ca5cc6deda8b459f8a9fc3686852f6c40 compression
                                                     residue and
                                                     padded payload


Compression Residue (107 bits -> 14 bytes with padding)
0b 0001 010    1011  |  0x6578616d706c652e636f6d  |  0b 0100 0101
    mid tkn  Uri-Host  (residue size and residue)        piv  kid

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 flag byte
                   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"/>, which 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:
=================
0x044b6caf0c2dae0d8ca5cc6deda8b459f8a9fc3686852f6c40 (25 bytes)
0x04 RuleID
    4b6caf0c2dae0d8ca5cc6deda8b459f8a9fc3686852f6c40 compression
                                                     residue and
                                                     padded payload


Compression Residue (107 bits -> 14 bytes with padding)
0b 0100 101    1011  |  0x6578616d706c652e636f6d  |  0b 0100 0101
    mid tkn  Uri-Host  (residue size and residue)        piv  kid

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"/>, which 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 = b''


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"/>, which 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 tkn

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 = b''


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"/>, which 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 tkn

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 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"/>, which the Device delivers to the application.</t>
      </section>
    </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 (OSCORE, DTLS, etc.), it is necessary to use a Layer 2 security mechanism to protect the SCHC messages.</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 REQUIRED. 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 uncompressible 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 MUST 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 MUST 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>
    <section anchor="iana-considerations">
      <name>IANA Considerations</name>
      <t>This document has no actions for IANA.</t>
    </section>
  </middle>
  <back>
    <references>
      <name>References</name>
      <references>
        <name>Normative References</name>
        <reference anchor="RFC2119">
          <front>
            <title>Key words for use in RFCs to Indicate Requirement Levels</title>
            <author fullname="S. Bradner" initials="S." surname="Bradner"/>
            <date month="March" year="1997"/>
            <abstract>
              <t>In many standards track documents several words are used to signify the requirements in the specification. These words are often capitalized. This document defines these words as they should be interpreted in IETF documents. This document specifies an Internet Best Current Practices for the Internet Community, and requests discussion and suggestions for improvements.</t>
            </abstract>
          </front>
          <seriesInfo name="BCP" value="14"/>
          <seriesInfo name="RFC" value="2119"/>
          <seriesInfo name="DOI" value="10.17487/RFC2119"/>
        </reference>
        <reference anchor="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="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="RFC8174">
          <front>
            <title>Ambiguity of Uppercase vs Lowercase in RFC 2119 Key Words</title>
            <author fullname="B. Leiba" initials="B." surname="Leiba"/>
            <date month="May" year="2017"/>
            <abstract>
              <t>RFC 2119 specifies common key words that may be used in protocol specifications. This document aims to reduce the ambiguity by clarifying that only UPPERCASE usage of the key words have the defined special meanings.</t>
            </abstract>
          </front>
          <seriesInfo name="BCP" value="14"/>
          <seriesInfo name="RFC" value="8174"/>
          <seriesInfo name="DOI" value="10.17487/RFC8174"/>
        </reference>
        <reference anchor="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="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="I-D.ietf-core-oscore-edhoc">
          <front>
            <title>Using EDHOC with CoAP and OSCORE</title>
            <author fullname="Francesca Palombini" initials="F." surname="Palombini">
              <organization>Ericsson</organization>
            </author>
            <author fullname="Marco Tiloca" initials="M." surname="Tiloca">
              <organization>RISE AB</organization>
            </author>
            <author fullname="Rikard Höglund" initials="R." surname="Höglund">
              <organization>RISE AB</organization>
            </author>
            <author fullname="Stefan Hristozov" initials="S." surname="Hristozov">
              <organization>Fraunhofer AISEC</organization>
            </author>
            <author fullname="Göran Selander" initials="G." surname="Selander">
              <organization>Ericsson</organization>
            </author>
            <date day="13" month="October" year="2023"/>
            <abstract>
              <t>   The lightweight authenticated key exchange protocol EDHOC can be run
   over CoAP and used by two peers to establish an OSCORE Security
   Context.  This document details this use of the EDHOC protocol, by
   specifying a number of additional and optional mechanisms.  These
   especially include 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="Internet-Draft" value="draft-ietf-core-oscore-edhoc-09"/>
        </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="Jiye Park" initials="J." surname="Park">
              <organization>Universitaet Duisburg-Essen</organization>
            </author>
            <date day="2" month="September" year="2023"/>
            <abstract>
              <t>   This document defines the security protocol Group Object Security for
   Constrained RESTful Environments (Group OSCORE), providing end-to-end
   security of CoAP messages exchanged 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 any 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-20"/>
        </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="23" month="October" year="2023"/>
            <abstract>
              <t>   This document defines Key Update for OSCORE (KUDOS), a lightweight
   procedure that two CoAP endpoints can use to update their keying
   material by establishing a new OSCORE Security Context.  Accordingly,
   it updates the use of the OSCORE flag bits in the CoAP OSCORE Option
   as well as the protection of CoAP response messages with OSCORE, and
   it deprecates the key update procedure specified in Appendix B.2 of
   RFC 8613.  Thus, this document updates RFC 8613.  Also, this document
   defines a procedure that two endpoints can use to update their OSCORE
   identifiers, run either stand-alone or during a KUDOS execution.

              </t>
            </abstract>
          </front>
          <seriesInfo name="Internet-Draft" value="draft-ietf-core-oscore-key-update-06"/>
        </reference>
      </references>
      <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="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="Chonggang Wang" initials="C." surname="Wang">
              <organization>InterDigital</organization>
            </author>
            <author fullname="Marco Tiloca" initials="M." surname="Tiloca">
              <organization>RISE AB</organization>
            </author>
            <date day="10" month="July" year="2023"/>
            <abstract>
              <t>   This document specifies the use of the Constrained Application
   Protocol (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 RFC 7390, while it updates RFC 7252 and RFC 7641.

              </t>
            </abstract>
          </front>
          <seriesInfo name="Internet-Draft" value="draft-ietf-core-groupcomm-bis-09"/>
        </reference>
        <reference anchor="I-D.ietf-lake-edhoc">
          <front>
            <title>Ephemeral Diffie-Hellman Over COSE (EDHOC)</title>
            <author fullname="Göran Selander" initials="G." surname="Selander">
              <organization>Ericsson AB</organization>
            </author>
            <author fullname="John Preuß Mattsson" initials="J. P." surname="Mattsson">
              <organization>Ericsson AB</organization>
            </author>
            <author fullname="Francesca Palombini" initials="F." surname="Palombini">
              <organization>Ericsson AB</organization>
            </author>
            <date day="25" month="August" year="2023"/>
            <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
   OSCORE security context.  By reusing COSE for cryptography, CBOR for
   encoding, and CoAP for transport, the additional code size can be
   kept very low.

              </t>
            </abstract>
          </front>
          <seriesInfo name="Internet-Draft" value="draft-ietf-lake-edhoc-22"/>
        </reference>
      </references>
    </references>
    <section anchor="yang-data-model">
      <name>YANG Data Model</name>
      <t>TBD</t>
    </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>The work on this document has been partly supported by the H2020 projects SIFIS-Home (Grant agreement 952652) and ARCADIAN-IoT (Grant agreement 101020259).</t>
    </section>
  </back>
  <!-- ##markdown-source:
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
t0XCSpdG6JS8utNwiS9sqzsYilCwXEvTpeWqoFso8VrRe+2yR8nv72wrZZb0
RU0H9MY4vvIvtNPDF5se0LvV9NCe0ltYS89AlRe+RsU1ZtNpDUDEaWL5fJSS
ikqOuXxCXcNcOMmWdoNz4UM2qvBVcUwoahOnevADkDT6Vrff/PDLjnJ9M/qf
f3vGzvN6k6wdsOgq+RkchyMS4SKhv+A00/Qg8Gj9NMaVkchQkwMe/w/zE4Rh
fn3VCrb5xZ3A/mHoG362gfR3Wq1vOvLzTdPDpR/zUutTwIQffNrgffPSQ8yP
dsjG88tL5fn1n41gufMTncn8AgV/ZH1QmV9eqp3/m/XnJ+ow89t/1s8vv9TP
r6byzq9/wfn59kfNz3/df/41188fbMMPTbwDP9aD/BT8oqLM1Ecdm5Fa/3gW
fNUgfQIKzPtuq94PI7cKvPbvU7zEz5ZbcK6SSOmEoGgm322hjhllW7/h3Vij
sCPxzPLNNow9hnQ4SK9hXjwLgr5SzcqC7YdfrCOEzg3lekVBk3RAjcuWFN0g
Llc+5eX2Z1m9RibXvXjJSmohyd9u8Jb/StFGxkuutoLEzKw1BnEXs304pCvW
BXmKrdFN6AcdAg2+727A3h2+fy27dQgEEOg3YSamODGi8lin+Lm6ugXpHGqn
prrQkSsXCYiI7WVqLyi7T0MvbjEkkZYvJCObEyYftYV9/k5BiGvWJrUBNgN1
/dYsJ0Y1wZjP1u577kcMIvm5r3O55dBHdI57MNr4jCZdoKIYxbl24QiuSPAT
EbbNkwKS7S5yVCDl5GNEs+pjnLvnZ20fJbBq4thDpOjqHWFchJYnLl+ASQLq
0dnlqws+xDEoCj1Jb1HHdkiaT1BiE6CzeD4RotMxVkg55+MgiaIR3sGKojeI
8IpQX5zZTljrTqlsVBof3XamYhb4RmiUFgXdgiSGHvkSeKcrgVg4Gao9BArd
6gL4uHERK/Ny+xUXMQiqv7OOYl/WluSJ40y8tG+g3SHMPTPdK4vZbplCv6sz
vvnd83vN+eWlh5ifaH/T+eWle8/fDYLFaA6fdTd437zU6uof/qby431f/+D8
8Rw1s64aGX/4I+uDyvzy0kPMj5H31vz2n/Xzyy/186/7fhBM5zcgIdT8/Nf9
519z/fzBZ1Xn+kqdu8A8BkpjYPZ9wULxBR0aNZpeg06HkhDEW7b50bnn0/je
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

-->

</rfc>
