<?xml version='1.0' encoding='utf-8'?>
<!DOCTYPE rfc [
  <!ENTITY nbsp    "&#160;">
  <!ENTITY zwsp   "&#8203;">
  <!ENTITY nbhy   "&#8209;">
  <!ENTITY wj     "&#8288;">
]>
<?xml-stylesheet type="text/xsl" href="rfc2629.xslt" ?>
<!-- generated by https://github.com/cabo/kramdown-rfc version 1.7.29 (Ruby 3.3.8) -->
<rfc xmlns:xi="http://www.w3.org/2001/XInclude" ipr="trust200902" docName="draft-ietf-core-multicast-notifications-proxy-01" category="info" submissionType="IETF" tocInclude="true" sortRefs="true" symRefs="true" version="3">
  <!-- xml2rfc v2v3 conversion 3.31.0 -->
  <front>
    <title abbrev="Proxies for Observe Multicast Notifications">Using Proxies for Observe Notifications as CoAP Multicast Responses</title>
    <seriesInfo name="Internet-Draft" value="draft-ietf-core-multicast-notifications-proxy-01"/>
    <author initials="M." surname="Tiloca" fullname="Marco Tiloca">
      <organization>RISE AB</organization>
      <address>
        <postal>
          <street>Isafjordsgatan 22</street>
          <city>Kista</city>
          <code>164 40</code>
          <country>Sweden</country>
        </postal>
        <email>marco.tiloca@ri.se</email>
      </address>
    </author>
    <author initials="R." surname="Höglund" fullname="Rikard Höglund">
      <organization>RISE AB</organization>
      <address>
        <postal>
          <street>Isafjordsgatan 22</street>
          <city>Kista</city>
          <code>164 40</code>
          <country>Sweden</country>
        </postal>
        <email>rikard.hoglund@ri.se</email>
      </address>
    </author>
    <author initials="C." surname="Amsüss" fullname="Christian Amsüss">
      <organization/>
      <address>
        <postal>
          <street>Hollandstr. 12/4</street>
          <city>Vienna</city>
          <code>1020</code>
          <country>Austria</country>
        </postal>
        <email>christian@amsuess.com</email>
      </address>
    </author>
    <author initials="F." surname="Palombini" fullname="Francesca Palombini">
      <organization>Ericsson AB</organization>
      <address>
        <postal>
          <street>Torshamnsgatan 23</street>
          <city>Kista</city>
          <code>164 40</code>
          <country>Sweden</country>
        </postal>
        <email>francesca.palombini@ericsson.com</email>
      </address>
    </author>
    <date year="2026" month="April" day="22"/>
    <area>WIT</area>
    <workgroup>CoRE Working Group</workgroup>
    <keyword>Internet-Draft</keyword>
    <abstract>
      <?line 80?>

<t>The Constrained Application Protocol (CoAP) allows clients to "observe" resources at a server and to receive notifications as unicast responses upon changes of the resource state. Instead of sending a distinct unicast notification to each different client, a server can alternatively send a single notification as a response message over multicast, to all the clients observing the same target resource. When doing so, the security protocol Group Object Security for Constrained RESTful Environments (Group OSCORE) can be used to protect multicast notifications end-to-end between the server and the observer clients. This document describes how multicast notifications can be used in network setups that leverage a proxy, e.g., in order to accommodate clients that are not able to directly listen to multicast traffic.</t>
    </abstract>
    <note removeInRFC="true">
      <name>Discussion Venues</name>
      <t>Discussion of this document takes place on the
    Constrained RESTful Environments Working Group mailing list (core@ietf.org),
    which is archived at <eref target="https://mailarchive.ietf.org/arch/browse/core/"/>.</t>
      <t>Source for this draft and an issue tracker can be found at
    <eref target="https://github.com/core-wg/multicast-notifications-proxy"/>.</t>
    </note>
  </front>
  <middle>
    <?line 84?>

<section anchor="intro">
      <name>Introduction</name>
      <t>The Constrained Application Protocol (CoAP) <xref target="RFC7252"/> has been extended with a number of mechanisms, including resource Observation <xref target="RFC7641"/>. This enables CoAP clients to register at a CoAP server as "observers" of a resource, and hence being automatically notified with an unsolicited response upon changes of the resource state.</t>
      <t>CoAP supports group communication <xref target="I-D.ietf-core-groupcomm-bis"/>, e.g., over IP multicast. This includes support for Observe registration requests over multicast, in order for clients to efficiently register as observers of a resource hosted at multiple servers.</t>
      <t>In a number of use cases, it is conversely desirable that a server sends observe notifications for the same target resource to multiple observers at once. In general, this is beneficial when several CoAP clients observe the same target resource at a CoAP server, and thus they could all be notified at once by means of a single response message.</t>
      <t>To this end, <xref target="I-D.ietf-core-observe-multicast-notifications"/> defines a method that a server can use to deliver observe notifications as CoAP responses addressed to multiple clients, e.g., over IP multicast. Also, it defines how to use the security protocol Group Object Security for Constrained RESTful Environments (Group OSCORE) <xref target="I-D.ietf-core-oscore-groupcomm"/> to protect multicast notifications end-to-end between the server and the observer clients.</t>
      <t>This document describes how the method specified in <xref target="I-D.ietf-core-observe-multicast-notifications"/> can be used in network setups that leverage a proxy, e.g., in order to accommodate clients that are not able to directly listen to multicast traffic.</t>
      <section anchor="terminology">
        <name>Terminology</name>
        <t>The key words "<bcp14>MUST</bcp14>", "<bcp14>MUST NOT</bcp14>", "<bcp14>REQUIRED</bcp14>", "<bcp14>SHALL</bcp14>", "<bcp14>SHALL
NOT</bcp14>", "<bcp14>SHOULD</bcp14>", "<bcp14>SHOULD NOT</bcp14>", "<bcp14>RECOMMENDED</bcp14>", "<bcp14>NOT RECOMMENDED</bcp14>",
"<bcp14>MAY</bcp14>", and "<bcp14>OPTIONAL</bcp14>" in this document are to be interpreted as
described in BCP 14 <xref target="RFC2119"/> <xref target="RFC8174"/> when, and only when, they
appear in all capitals, as shown here.</t>
        <?line -18?>

<t>Readers are expected to be familiar with terms and concepts described in CoAP <xref target="RFC7252"/>, group communication for CoAP <xref target="I-D.ietf-core-groupcomm-bis"/>, Observe <xref target="RFC7641"/>, Concise Data Definition Language (CDDL) <xref target="RFC8610"/>, Concise Binary Object Representation (CBOR) <xref target="RFC8949"/>, Object Security for Constrained RESTful Environments (OSCORE) <xref target="RFC8613"/>, Group OSCORE <xref target="I-D.ietf-core-oscore-groupcomm"/>, and Constrained Resource Identifiers (CRIs) <xref target="I-D.ietf-core-href"/>.</t>
        <t>Readers are also expected to be familiar with terms and concepts described in <xref target="I-D.ietf-core-observe-multicast-notifications"/>, particularly with the terms "traditional observation", "group observation", "phantom request", and "informative response".</t>
      </section>
    </section>
    <section anchor="sec-variants">
      <name>High-Level Overview of Available Variants</name>
      <t>Building on what is specified in <xref target="I-D.ietf-core-observe-multicast-notifications"/>, this document considers network setups where proxies are deployed, which is expected if (some of) the clients participating in the group observation are not capable to listen to multicast traffic. In such setups, a proxy directly receives multicast notifications from the server and relays them back to the clients.</t>
      <t>Therefore, with respect to <xref target="I-D.ietf-core-observe-multicast-notifications"/>, this document introduces additional variants to enforce a group observation. As a complement to <xref section="3" sectionFormat="of" target="I-D.ietf-core-observe-multicast-notifications"/>, the rest of this section provides an overview of such additional variants, which differ as to whether exchanged messages are protected end-to-end between the observer clients and the server.</t>
      <ul spacing="normal">
        <li>
          <t>Variant with proxy and without end-to-end security - Messages pertaining to the group observation are not protected end-to-end between the clients and the server. This basic case is defined in <xref target="intermediaries"/>. An example is provided in <xref target="intermediaries-example"/>.</t>
        </li>
        <li>
          <t>Variant with proxy and with end-to-end security - Messages pertaining to the group observation are protected end-to-end between the clients and the server, by using the security protocol Group OSCORE <xref target="I-D.ietf-core-oscore-groupcomm"/>. In particular, the clients separately provide the proxy with the obtained phantom request, thus enabling the proxy to receive the multicast notifications from the server. This case is defined in <xref target="intermediaries-e2e-security"/>. An example is provided in <xref target="intermediaries-example-e2e-security"/>.  </t>
          <t>
If the participating endpoints using Group OSCORE also support the concept of Deterministic Client <xref target="I-D.ietf-core-cacheable-oscore"/>, the same advantages mentioned in <xref section="3" sectionFormat="of" target="I-D.ietf-core-observe-multicast-notifications"/> for the case without a proxy apply (see <xref section="D" sectionFormat="of" target="I-D.ietf-core-observe-multicast-notifications"/>). In addition, this allows for a more efficient setup and enforcement of the group observation, by reducing the amount of message exchanges and allowing the proxy to effectively serve protected multicast notifications from its cache. An example is provided in <xref target="intermediaries-example-e2e-security-det-exchange"/>.</t>
        </li>
      </ul>
    </section>
    <section anchor="intermediaries">
      <name>Setup with Proxies</name>
      <t>This section specifies how the approach presented in Sections <xref target="I-D.ietf-core-observe-multicast-notifications" section="4" sectionFormat="bare"/> and <xref target="I-D.ietf-core-observe-multicast-notifications" section="5" sectionFormat="bare"/> of <xref target="I-D.ietf-core-observe-multicast-notifications"/> works when a proxy is used between the clients and the server. In addition to what is specified in <xref section="5.7" sectionFormat="of" target="RFC7252"/> and <xref section="5" sectionFormat="of" target="RFC7641"/>, the following applies.</t>
      <t>A client sends its original observation request to the proxy. If the proxy is not already registered at the server for that target resource, the proxy forwards the observation request to the server, hence registering itself as an observer. If the server has an ongoing group observation for the target resource or decides to start one, the server considers the proxy as taking part in the group observation and replies to the proxy with an informative response see <xref section="4.2" sectionFormat="of" target="I-D.ietf-core-observe-multicast-notifications"/>.</t>
      <t>Upon receiving an informative response, the proxy performs as specified for the client in  <xref section="5" sectionFormat="of" target="I-D.ietf-core-observe-multicast-notifications"/>, with the peculiarity that "consuming" the last notification (if present) means populating the proxy's cache.</t>
      <t>In particular, by using the information retrieved from the informative response, the proxy configures an observation of the target resource at the origin server, acting as a client directly taking part in the group observation.</t>
      <t>As a consequence, the proxy listens to the IP multicast address and port number indicated by the server, i.e., per the CRI <xref target="I-D.ietf-core-href"/> specified by a dedicated element of 'tpi_details' within the 'tp_info' parameter, in the informative response. In particular, when transporting CoAP over UDP, the CRI is conveyed by the element 'tpi_client' (see <xref section="4.2.1.1" sectionFormat="of" target="I-D.ietf-core-observe-multicast-notifications"/>).</t>
      <t>Furthermore, multicast notifications will match the phantom request stored at the proxy, based on the Token value specified by a dedicated element of 'tpi_details' within the 'tp_info' parameter, in the informative response. In particular, when transporting CoAP over UDP, the Token value is specified by the element 'tpi_token' (see <xref section="4.2.1.1" sectionFormat="of" target="I-D.ietf-core-observe-multicast-notifications"/>).</t>
      <t>Then, the proxy performs the following actions.</t>
      <ul spacing="normal">
        <li>
          <t>If the 'last_notif' field is not present, the proxy replies to the client with an Empty Acknowledgement (if elicited by the message type of the original observation request, and if the proxy has not already done so).</t>
        </li>
        <li>
          <t>If the 'last_notif' field is present, the proxy rebuilds the latest multicast notification, as defined in <xref section="5" sectionFormat="of" target="I-D.ietf-core-observe-multicast-notifications"/>. Then, the proxy replies to the client, by forwarding back the latest multicast notification.</t>
        </li>
      </ul>
      <t>When responding to an observation request from a client, the proxy also adds that client (and its Token) to the list of its registered observers for the target resource, next to the older observations.</t>
      <t>Upon receiving a multicast notification from the server, the proxy forwards it back separately to each observer client over unicast. Note that the notification forwarded back to a certain client has the same Token value of the original observation request sent by that client to the proxy.</t>
      <t>Note that the proxy configures the observation of the target resource at the server only once, when receiving the informative response associated with a (newly started) group observation for that target resource.</t>
      <t>After that, when receiving an observation request from a following new client to be added to the same group observation, the proxy does not take any further action with the server. Instead, the proxy replies to the client either with the latest multicast notification if available from its cache, or with an Empty Acknowledgement otherwise, as defined above.</t>
      <t>As a result, the observer counter at the server (see <xref section="4" sectionFormat="of" target="I-D.ietf-core-observe-multicast-notifications"/>) is not incremented when a new origin client behind the proxy registers as an observer at the proxy. Instead, the observer counter takes into account only the proxy, which has registered as an observer at the server and has received the informative response from the server.</t>
      <t>An example is provided in <xref target="intermediaries-example"/>.</t>
      <t>In the general case with a chain of two or more proxies, every proxy in the chain takes the role of client with the (next hop towards the) origin server. Note that the proxy adjacent to the origin server is the only one in the chain that receives informative responses and that listens to an IP multicast address and port number to receive notifications for the group observation. Furthermore, every proxy in the chain takes the role of server with the (previous hop towards the) origin client.</t>
    </section>
    <section anchor="intermediaries-e2e-security">
      <name>Setup with Proxies and with Group OSCORE</name>
      <t>As defined in <xref section="9" sectionFormat="of" target="I-D.ietf-core-observe-multicast-notifications"/>, the security protocol Group OSCORE <xref target="I-D.ietf-core-oscore-groupcomm"/> can be used to protect multicast notifications end-to-end between the origin server and the origin clients.</t>
      <t>Since the informative responses from the origin server are protected specifically end-to-end by using OSCORE or Group OSCORE, additional actions are required in the presence of a proxy.</t>
      <t>In fact, the proxy adjacent to the origin server is not able to access the encrypted payload of such informative responses. Hence, the proxy cannot retrieve the 'ph_req' and 'tp_info' parameters necessary to correctly receive multicast notifications and forward them back to the clients.</t>
      <t>Consequently, differently from what is defined in <xref section="11" sectionFormat="of" target="I-D.ietf-core-observe-multicast-notifications"/>, a proxy that receives an informative response simply forwards it back to the (previous hop towards the) origin client that has sent the corresponding observation request. Note that the proxy does not even realize that the message is an informative response, since the outer Code field is set to 2.05 (Content).</t>
      <t>Upon receiving the informative response, the origin client does not configure an observation of the target resource yet. Instead, the origin client performs a new observe registration request, by transmitting the re-built phantom request as intended to reach the proxy adjacent to the origin server. In particular, the origin client includes the new CoAP option Listen-To-Multicast-Responses defined in <xref target="ltmr-option"/>, to provide that proxy with the transport-specific information required for receiving multicast notifications for the group observation.</t>
      <t>As a result, the observer counter at the server (see <xref section="4" sectionFormat="of" target="I-D.ietf-core-observe-multicast-notifications"/>) is incremented when, after having received the original observation request from a new origin client, the origin server replies with the informative response. In particular, the observer counter at the server reliably takes into account new, different origin clients behind the proxy, which the server distinguishes through their security identity specified by the pair (OSCORE Sender ID, OSCORE ID Context) in the OSCORE Option value of their original observation request. Note that this does not hold anymore if the origin endpoints use phantom observation requests as Deterministic Requests (see <xref section="D" sectionFormat="of" target="I-D.ietf-core-observe-multicast-notifications"/>).</t>
      <t>Details on the additional message exchange and processing are defined in <xref target="intermediaries-e2e-security-processing"/>.</t>
      <section anchor="ltmr-option">
        <name>Listen-To-Multicast-Responses Option</name>
        <t>In order to allow a proxy to listen to multicast notifications sent by a server, a new CoAP option is defined. This option <bcp14>MUST</bcp14> be supported by clients that are interested to take part in group observations through intermediaries and by proxies that collect multicast notifications and forward them back to the observer clients.</t>
        <t>The option is called Listen-To-Multicast-Response, is intended only for requests, and has the properties summarized in <xref target="ltmr-table"/>, which extends Table 4 of <xref target="RFC7252"/>. The option is critical and not Safe-to-Forward. Since the option is not Safe-to-Forward, the 'N' column indicates a dash for "not applicable".</t>
        <table align="center" anchor="ltmr-table">
          <name>The Listen-To-Multicast-Responses Option. C=Critical, U=Unsafe, N=NoCacheKey, R=Repeatable</name>
          <thead>
            <tr>
              <th align="left">No.</th>
              <th align="left">C</th>
              <th align="left">U</th>
              <th align="left">N</th>
              <th align="left">R</th>
              <th align="left">Name</th>
              <th align="left">Format</th>
              <th align="left">Length</th>
              <th align="left">Default</th>
            </tr>
          </thead>
          <tbody>
            <tr>
              <td align="left">TBD47</td>
              <td align="left">x</td>
              <td align="left">x</td>
              <td align="left">-</td>
              <td align="left"> </td>
              <td align="left">Listen-To-<br/>Multicast-Responses</td>
              <td align="left">(*)</td>
              <td align="left">3-1024</td>
              <td align="left">(none)</td>
            </tr>
          </tbody>
        </table>
        <t>Note to RFC Editor: In the table above, please replace TBD47 with the registered option number. Then, please delete this paragraph.</t>
        <t>The value of the Listen-To-Multicast-Responses Option is the byte serialization of a CBOR array. The content of the array specifies transport-specific message information that is required for listening to the multicast notifications of a group observation and is intended to the proxy adjacent to the origin server sending those notifications. In particular, the serialized CBOR array has the same format specified in <xref section="4.2.1" sectionFormat="of" target="I-D.ietf-core-observe-multicast-notifications"/> for the 'tp_info' parameter of the informative response defined in <xref section="4.2" sectionFormat="of" target="I-D.ietf-core-observe-multicast-notifications"/>.</t>
        <t>The Listen-To-Multicast-Responses Option is of class U for OSCORE <xref target="RFC8613"/><xref target="I-D.ietf-core-oscore-groupcomm"/>.</t>
      </section>
      <section anchor="intermediaries-e2e-security-processing">
        <name>Message Processing</name>
        <t>Compared to <xref target="intermediaries"/>, the following additions apply when informative responses are protected end-to-end with Group OSCORE between the origin server and the origin clients.</t>
        <t>After the origin server sends an informative response, each proxy simply forwards it back to the (previous hop towards the) origin client that has sent the observation request.</t>
        <t>Once received the informative response, the origin client proceeds in a different way than the one defined in <xref section="9.3.1" sectionFormat="of" target="I-D.ietf-core-observe-multicast-notifications"/>:</t>
        <ul spacing="normal">
          <li>
            <t>The client performs all the additional decryption and verification steps of <xref section="9.3.1" sectionFormat="of" target="I-D.ietf-core-observe-multicast-notifications"/> on the phantom request specified in the 'ph_req' parameter and on the last notification specified in the 'last_notif' parameter (if present).</t>
          </li>
          <li>
            <t>The client builds a ticket request (see <xref section="C" sectionFormat="of" target="I-D.ietf-core-cacheable-oscore"/>), as intended to reach the proxy adjacent to the origin server. The ticket request is formatted as follows.  </t>
            <ul spacing="normal">
              <li>
                <t>The Token is chosen as the client sees fit. In fact, there is no reason for this Token to be the same as the phantom request's.</t>
              </li>
              <li>
                <t>The outer Code field, the outer CoAP options, and the encrypted payload (protecting the inner Code, the inner CoAP options, and the possible plain CoAP payload) concatenated with the countersignature are the same as those of the phantom request used for the group observation. That is, they are as specified in the 'ph_req' parameter of the received informative response.</t>
              </li>
              <li>
                <t>An outer Observe Option is included and set to 0 (register). This is meant to be set in the phantom request already.</t>
              </li>
              <li>
                <t>The client includes: the outer option Proxy-Uri or Proxy-Cri <xref target="I-D.ietf-core-href"/>; or the outer options (Uri-Host, Uri-Port), together with the outer option Proxy-Scheme or Proxy-Scheme-Number <xref target="I-D.ietf-core-href"/>. These options are set in order to specify the same request URI of the original registration request sent by the client.</t>
              </li>
              <li>
                <t>The new option Listen-To-Multicast-Responses is included as an outer option. The value of the option is set to the byte serialization of the CBOR array specified by the 'tp_info' parameter of the informative response.      </t>
                <t>
Note that, except for transport-specific information such as the Token and Message ID values, every different client participating in the same group observation (hence rebuilding the same phantom request) will build the same ticket request.      </t>
                <t>
Note also that, identically to the phantom request, the ticket request is still protected with Group OSCORE, i.e., it has the same OSCORE Option, encrypted payload, and countersignature.</t>
              </li>
            </ul>
          </li>
        </ul>
        <t>Then, the client sends the ticket request to the next hop towards the origin server. Every proxy in the chain forwards the ticket request to the next hop towards the origin server, until the last proxy in the chain is reached. This last proxy, adjacent to the origin server, proceeds as follows.</t>
        <ul spacing="normal">
          <li>
            <t>The proxy <bcp14>MUST NOT</bcp14> further forward the ticket request to the origin server.</t>
          </li>
          <li>
            <t>The proxy removes the option Proxy-Uri, or Proxy-Scheme, or Proxy-Cri, or Proxy-Scheme-Number from the ticket request.</t>
          </li>
          <li>
            <t>The proxy removes the Listen-To-Multicast-Responses Option from the ticket request and extracts the transport-specific information specified within the option value.</t>
          </li>
          <li>
            <t>The proxy rebuilds the phantom request associated with the group observation, by using the ticket request as directly providing the required transport-independent information. This includes the outer Code field, the outer CoAP options, and the encrypted payload concatenated with the countersignature.</t>
          </li>
          <li>
            <t>The proxy configures an observation of the target resource at the origin server, acting as a client directly taking part in the group observation. To this end, the proxy uses the rebuilt phantom request and the transport-specific information retrieved from the Listen-To-Multicast-Responses Option. The particular way to achieve this is implementation specific.</t>
          </li>
        </ul>
        <t>After that, the proxy listens to the IP multicast address and port number indicated in the Listen-To-Multicast-Responses Option, i.e., per the CRI specified by a dedicated element of 'tpi_details' within the serialized CBOR array conveyed in the option value. In particular, when transporting CoAP over UDP, the CRI is conveyed by the element 'tpi_client' (see <xref section="4.2.1.1" sectionFormat="of" target="I-D.ietf-core-observe-multicast-notifications"/>).</t>
        <t>The multicast notifications of the group observation in question will match the phantom request stored at the proxy, based on the Token value specified by a dedicated element of 'tpi_details' within the serialized CBOR array conveyed in the value of the Listen-To-Multicast-Responses Option. In particular, when transporting CoAP over UDP, the Token value is specified by the element 'tpi_token' (see <xref section="4.2.1.1" sectionFormat="of" target="I-D.ietf-core-observe-multicast-notifications"/>).</t>
        <t>An example is provided in <xref target="intermediaries-example-e2e-security"/>.</t>
      </section>
    </section>
    <section anchor="impact-on-counting">
      <name>Impact from Proxies on Rough Counting of Clients in the Group Observation</name>
      <t><xref target="intermediaries"/> specifies how the approach defined in Sections <xref target="I-D.ietf-core-observe-multicast-notifications" section="4" sectionFormat="bare"/> and <xref target="I-D.ietf-core-observe-multicast-notifications" section="5" sectionFormat="bare"/> of <xref target="I-D.ietf-core-observe-multicast-notifications"/> works when a proxy is used between the origin clients and the origin server.</t>
      <t>That is, the clients register as observers at the proxy, which in turn registers as a participant to the group observation at the server, receives the multicast notifications from the server, and forwards those to the clients.</t>
      <t>With reference to the method defined in <xref section="8" sectionFormat="of" target="I-D.ietf-core-observe-multicast-notifications"/>, this has an impact on the rough counting that the server performs to keep an estimate of still active and interested clients. In particular, the following applies.</t>
      <ul spacing="normal">
        <li>
          <t>Since the Feedback-Divider Option defined in <xref section="8.1" sectionFormat="of" target="I-D.ietf-core-observe-multicast-notifications"/> is not Safe-to-Forward, the proxy needs to recognize and understand the option in order to participate to the rough counting process.  </t>
          <t>
If the proxy receives a request that includes the Feedback-Divider Option but the proxy does not recognize and understand the option, then the proxy stops processing the request and sends a 4.02 (Bad Option) response to the observer client (see <xref section="5.7.1" sectionFormat="of" target="RFC7252"/>). This results in the client terminating its observation at the proxy, after which the client stops receiving notifications for the group observation.  </t>
          <t>
If the proxy receives a multicast notification that includes the Feedback-Divider Option but the proxy does not recognize and understand the option, then the proxy stops processing the received multicast notification and sends a 5.02 (Bad Gateway) response to each of the observer clients (see <xref section="5.7.1" sectionFormat="of" target="RFC7252"/>). This results in all the observer clients terminating their observation at the proxy, after which they stop receiving notifications for the group observation. Consequently, the proxy may decide to forget about its participation to the group observation at the server.  </t>
          <t>
This is not an issue if communications between the origin endpoints are protected end-to-end, i.e., both for the requests from the origin clients by using OSCORE or Group OSCORE, as well as for the multicast notifications from the origin server by using Group OSCORE (see <xref section="9" sectionFormat="of" target="I-D.ietf-core-observe-multicast-notifications"/> and <xref target="intermediaries-e2e-security"/> of the present document). In fact, in such a case, the Feedback-Divider Option is protected end-to-end as well, and is thus hidden from the proxy.  </t>
          <t>
Therefore, if the server uses the rough counting process defined in <xref section="8" sectionFormat="of" target="I-D.ietf-core-observe-multicast-notifications"/> but communications are not protected end-to-end between the origin endpoints, then it is practically required that the proxy recognizes and understands the Feedback-Divider Option. If that is not the case, then every execution of the rough counting process will effectively prevent the clients from receiving further notifications for the group observation, until they register again as observers at the proxy.</t>
        </li>
        <li>
          <t>The following holds when the proxy receives a multicast notification including the Feedback-Divider Option.  </t>
          <ul spacing="normal">
            <li>
              <t>If the multicast notification is not protected end-to-end by using Group OSCORE (see <xref target="intermediaries"/>), then the Feedback-Divider Option is visible to the proxy.      </t>
              <t>
In this case, the proxy proceeds like defined in <xref section="8.2" sectionFormat="of" target="I-D.ietf-core-observe-multicast-notifications"/> for an origin client, i.e., by answering on its own to the server if it picks a random number I equal to 0. When doing so, the proxy will be counted by the server as a single client.      </t>
              <t>
Furthermore, the proxy <bcp14>MUST</bcp14> remove the option before forwarding the notification to (the previous hop towards) any of the origin clients.      </t>
              <t>
The proxy would have to rely on separate means for verifying whether the origin clients are still interested in the observation, e.g., by regularly forwarding notifications to the clients as unicast separate responses that are specifically Confirmable messages.      </t>
              <t>
When no interested origin clients remain, the proxy can simply forget about being part of the group observation for the target resource at the server, like an origin client would do (see <xref section="5.4" sectionFormat="of" target="I-D.ietf-core-observe-multicast-notifications"/>).</t>
            </li>
            <li>
              <t>If the multicast notification is protected end-to-end by using Group OSCORE (see <xref section="9" sectionFormat="of" target="I-D.ietf-core-observe-multicast-notifications"/> and <xref target="intermediaries-e2e-security"/> of this document), then the Feedback-Divider Option is protected end-to-end as well, and is thus hidden from the proxy. As a consequence, the proxy forwards the notification to (the previous hop towards) any of the origin clients, each of which answers to the server if it picks a random number I equal to 0.</t>
            </li>
          </ul>
        </li>
      </ul>
    </section>
    <section anchor="intermediaries-example">
      <name>Example with a Proxy</name>
      <t>This section provides an example where a proxy P is used between the clients and the server. The same assumptions and notation used in <xref section="7" sectionFormat="of" target="I-D.ietf-core-observe-multicast-notifications"/> are used for this example. In addition, the proxy has address PRX_ADDR and listens to the port number PRX_PORT.</t>
      <t>Unless explicitly indicated, all messages transmitted on the wire are sent over unicast.</t>
      <figure anchor="example-proxy-no-oscore">
        <name>Example of Group Observation with a Proxy</name>
        <artset>
          <artwork type="svg"><svg xmlns="http://www.w3.org/2000/svg" version="1.1" height="1664" width="576" viewBox="0 0 576 1664" class="diagram" text-anchor="middle" font-family="monospace" font-size="13px" stroke-linecap="round">
              <path d="M 8,48 L 8,992" fill="none" stroke="black"/>
              <path d="M 8,1056 L 8,1232" fill="none" stroke="black"/>
              <path d="M 8,1296 L 8,1600" fill="none" stroke="black"/>
              <path d="M 64,48 L 64,88" fill="none" stroke="black"/>
              <path d="M 64,104 L 64,920" fill="none" stroke="black"/>
              <path d="M 64,936 L 64,992" fill="none" stroke="black"/>
              <path d="M 64,1056 L 64,1232" fill="none" stroke="black"/>
              <path d="M 64,1296 L 64,1448" fill="none" stroke="black"/>
              <path d="M 64,1464 L 64,1600" fill="none" stroke="black"/>
              <path d="M 120,48 L 120,992" fill="none" stroke="black"/>
              <path d="M 120,1056 L 120,1232" fill="none" stroke="black"/>
              <path d="M 120,1296 L 120,1600" fill="none" stroke="black"/>
              <path d="M 192,48 L 192,992" fill="none" stroke="black"/>
              <path d="M 192,1056 L 192,1232" fill="none" stroke="black"/>
              <path d="M 192,1296 L 192,1600" fill="none" stroke="black"/>
              <path d="M 8,96 L 112,96" fill="none" stroke="black"/>
              <path d="M 120,160 L 184,160" fill="none" stroke="black"/>
              <path d="M 144,336 L 192,336" fill="none" stroke="black"/>
              <path d="M 144,384 L 184,384" fill="none" stroke="black"/>
              <path d="M 128,576 L 192,576" fill="none" stroke="black"/>
              <path d="M 16,928 L 120,928" fill="none" stroke="black"/>
              <path d="M 64,1072 L 112,1072" fill="none" stroke="black"/>
              <path d="M 72,1168 L 120,1168" fill="none" stroke="black"/>
              <path d="M 128,1376 L 192,1376" fill="none" stroke="black"/>
              <path d="M 16,1456 L 120,1456" fill="none" stroke="black"/>
              <path d="M 72,1536 L 120,1536" fill="none" stroke="black"/>
              <path d="M 132,360 L 144,384" fill="none" stroke="black"/>
              <path d="M 132,360 L 144,336" fill="none" stroke="black"/>
              <polygon class="arrowhead" points="192,384 180,378.4 180,389.6" fill="black" transform="rotate(0,184,384)"/>
              <polygon class="arrowhead" points="192,160 180,154.4 180,165.6" fill="black" transform="rotate(0,184,160)"/>
              <polygon class="arrowhead" points="136,1376 124,1370.4 124,1381.6" fill="black" transform="rotate(180,128,1376)"/>
              <polygon class="arrowhead" points="136,576 124,570.4 124,581.6" fill="black" transform="rotate(180,128,576)"/>
              <polygon class="arrowhead" points="120,1072 108,1066.4 108,1077.6" fill="black" transform="rotate(0,112,1072)"/>
              <polygon class="arrowhead" points="120,96 108,90.4 108,101.6" fill="black" transform="rotate(0,112,96)"/>
              <polygon class="arrowhead" points="80,1536 68,1530.4 68,1541.6" fill="black" transform="rotate(180,72,1536)"/>
              <polygon class="arrowhead" points="80,1168 68,1162.4 68,1173.6" fill="black" transform="rotate(180,72,1168)"/>
              <polygon class="arrowhead" points="24,1456 12,1450.4 12,1461.6" fill="black" transform="rotate(180,16,1456)"/>
              <polygon class="arrowhead" points="24,928 12,922.4 12,933.6" fill="black" transform="rotate(180,16,928)"/>
              <g class="text">
                <text x="12" y="36">C1</text>
                <text x="68" y="36">C2</text>
                <text x="120" y="36">P</text>
                <text x="192" y="36">S</text>
                <text x="228" y="68">(The</text>
                <text x="272" y="68">value</text>
                <text x="308" y="68">of</text>
                <text x="336" y="68">the</text>
                <text x="388" y="68">resource</text>
                <text x="436" y="68">/r</text>
                <text x="460" y="68">is</text>
                <text x="504" y="68">"1234")</text>
                <text x="236" y="100">Token:</text>
                <text x="284" y="100">0x4a</text>
                <text x="32" y="116">GET</text>
                <text x="244" y="116">Observe:</text>
                <text x="288" y="116">0</text>
                <text x="340" y="116">(register)</text>
                <text x="252" y="132">Proxy-Uri:</text>
                <text x="400" y="132">"coap://sensor.example/r"</text>
                <text x="236" y="164">Token:</text>
                <text x="284" y="164">0x5e</text>
                <text x="144" y="180">GET</text>
                <text x="244" y="180">Observe:</text>
                <text x="288" y="180">0</text>
                <text x="340" y="180">(register)</text>
                <text x="248" y="196">Uri-Host:</text>
                <text x="356" y="196">"sensor.example"</text>
                <text x="248" y="212">Uri-Path:</text>
                <text x="304" y="212">"r"</text>
                <text x="220" y="244">(S</text>
                <text x="272" y="244">allocates</text>
                <text x="328" y="244">the</text>
                <text x="384" y="244">available</text>
                <text x="448" y="244">Token</text>
                <text x="496" y="244">value</text>
                <text x="544" y="244">0x7b)</text>
                <text x="220" y="276">(S</text>
                <text x="256" y="276">sends</text>
                <text x="292" y="276">to</text>
                <text x="332" y="276">itself</text>
                <text x="368" y="276">a</text>
                <text x="408" y="276">phantom</text>
                <text x="488" y="276">observation</text>
                <text x="240" y="292">request</text>
                <text x="300" y="292">PH_REQ</text>
                <text x="340" y="292">as</text>
                <text x="380" y="292">coming</text>
                <text x="428" y="292">from</text>
                <text x="464" y="292">the</text>
                <text x="220" y="308">IP</text>
                <text x="272" y="308">multicast</text>
                <text x="344" y="308">address</text>
                <text x="416" y="308">GRP_ADDR)</text>
                <text x="236" y="388">Token:</text>
                <text x="284" y="388">0x7b</text>
                <text x="168" y="404">GET</text>
                <text x="244" y="404">Observe:</text>
                <text x="288" y="404">0</text>
                <text x="340" y="404">(register)</text>
                <text x="248" y="420">Uri-Host:</text>
                <text x="356" y="420">"sensor.example"</text>
                <text x="248" y="436">Uri-Path:</text>
                <text x="304" y="436">"r"</text>
                <text x="220" y="468">(S</text>
                <text x="264" y="468">creates</text>
                <text x="304" y="468">a</text>
                <text x="336" y="468">group</text>
                <text x="408" y="468">observation</text>
                <text x="468" y="468">of</text>
                <text x="496" y="468">/r)</text>
                <text x="220" y="500">(S</text>
                <text x="276" y="500">increments</text>
                <text x="336" y="500">the</text>
                <text x="388" y="500">observer</text>
                <text x="456" y="500">counter</text>
                <text x="224" y="516">for</text>
                <text x="256" y="516">the</text>
                <text x="296" y="516">group</text>
                <text x="368" y="516">observation</text>
                <text x="428" y="516">of</text>
                <text x="456" y="516">/r)</text>
                <text x="236" y="580">Token:</text>
                <text x="284" y="580">0x5e</text>
                <text x="148" y="596">5.03</text>
                <text x="272" y="596">Content-Format:</text>
                <text x="388" y="596">application/</text>
                <text x="336" y="612">informative-response+cbor</text>
                <text x="244" y="628">Max-Age:</text>
                <text x="288" y="628">0</text>
                <text x="236" y="644">&lt;Other</text>
                <text x="300" y="644">options&gt;</text>
                <text x="244" y="660">Payload:</text>
                <text x="288" y="660">{</text>
                <text x="232" y="676">/</text>
                <text x="272" y="676">tp_info</text>
                <text x="312" y="676">/</text>
                <text x="352" y="676">0</text>
                <text x="368" y="676">:</text>
                <text x="384" y="676">[</text>
                <text x="416" y="692">cri'coap://SRV_ADDR:SRV_PORT/',</text>
                <text x="432" y="708">cri'coap://GRP_ADDR:GRP_PORT/',</text>
                <text x="348" y="724">0x7b],</text>
                <text x="232" y="740">/</text>
                <text x="284" y="740">last_notif</text>
                <text x="336" y="740">/</text>
                <text x="352" y="740">2</text>
                <text x="368" y="740">:</text>
                <text x="416" y="740">bstr(0x45</text>
                <text x="464" y="740">|</text>
                <text x="488" y="740">OPT</text>
                <text x="512" y="740">|</text>
                <text x="540" y="740">0xff</text>
                <text x="568" y="740">|</text>
                <text x="452" y="756">PAYLOAD)</text>
                <text x="216" y="772">}</text>
                <text x="244" y="804">(PAYLOAD</text>
                <text x="292" y="804">in</text>
                <text x="356" y="804">'last_notif'</text>
                <text x="416" y="804">:</text>
                <text x="456" y="804">"1234")</text>
                <text x="228" y="852">(The</text>
                <text x="272" y="852">proxy</text>
                <text x="324" y="852">starts</text>
                <text x="392" y="852">listening</text>
                <text x="444" y="852">to</text>
                <text x="472" y="852">the</text>
                <text x="252" y="868">GRP_ADDR</text>
                <text x="320" y="868">address</text>
                <text x="368" y="868">and</text>
                <text x="400" y="868">the</text>
                <text x="452" y="868">GRP_PORT</text>
                <text x="516" y="868">port.)</text>
                <text x="228" y="900">(The</text>
                <text x="272" y="900">proxy</text>
                <text x="316" y="900">adds</text>
                <text x="348" y="900">C1</text>
                <text x="372" y="900">to</text>
                <text x="400" y="900">its</text>
                <text x="436" y="900">list</text>
                <text x="468" y="900">of</text>
                <text x="528" y="900">observers.)</text>
                <text x="236" y="932">Token:</text>
                <text x="284" y="932">0x4a</text>
                <text x="36" y="948">2.05</text>
                <text x="244" y="948">Observe:</text>
                <text x="304" y="948">54120</text>
                <text x="236" y="964">&lt;Other</text>
                <text x="300" y="964">options&gt;</text>
                <text x="244" y="980">Payload:</text>
                <text x="308" y="980">"1234"</text>
                <text x="16" y="1028">...</text>
                <text x="64" y="1028">...</text>
                <text x="120" y="1028">...</text>
                <text x="184" y="1028">...</text>
                <text x="236" y="1076">Token:</text>
                <text x="284" y="1076">0x01</text>
                <text x="88" y="1092">GET</text>
                <text x="244" y="1092">Observe:</text>
                <text x="288" y="1092">0</text>
                <text x="340" y="1092">(register)</text>
                <text x="252" y="1108">Proxy-Uri:</text>
                <text x="400" y="1108">"coap://sensor.example/r"</text>
                <text x="228" y="1140">(The</text>
                <text x="272" y="1140">proxy</text>
                <text x="312" y="1140">has</text>
                <text x="336" y="1140">a</text>
                <text x="368" y="1140">fresh</text>
                <text x="416" y="1140">cache</text>
                <text x="504" y="1140">representation)</text>
                <text x="236" y="1172">Token:</text>
                <text x="284" y="1172">0x01</text>
                <text x="92" y="1188">2.05</text>
                <text x="244" y="1188">Observe:</text>
                <text x="304" y="1188">54120</text>
                <text x="236" y="1204">&lt;Other</text>
                <text x="300" y="1204">options&gt;</text>
                <text x="244" y="1220">Payload:</text>
                <text x="308" y="1220">"1234"</text>
                <text x="16" y="1268">...</text>
                <text x="64" y="1268">...</text>
                <text x="120" y="1268">...</text>
                <text x="184" y="1268">...</text>
                <text x="228" y="1316">(The</text>
                <text x="272" y="1316">value</text>
                <text x="308" y="1316">of</text>
                <text x="336" y="1316">the</text>
                <text x="388" y="1316">resource</text>
                <text x="220" y="1332">/r</text>
                <text x="264" y="1332">changes</text>
                <text x="308" y="1332">to</text>
                <text x="356" y="1332">"5678".)</text>
                <text x="152" y="1364">(#)</text>
                <text x="236" y="1380">Token:</text>
                <text x="284" y="1380">0x7b</text>
                <text x="148" y="1396">2.05</text>
                <text x="244" y="1396">Observe:</text>
                <text x="292" y="1396">11</text>
                <text x="236" y="1412">&lt;Other</text>
                <text x="300" y="1412">options&gt;</text>
                <text x="244" y="1428">Payload:</text>
                <text x="308" y="1428">"5678"</text>
                <text x="236" y="1460">Token:</text>
                <text x="284" y="1460">0x4a</text>
                <text x="36" y="1476">2.05</text>
                <text x="244" y="1476">Observe:</text>
                <text x="304" y="1476">54123</text>
                <text x="236" y="1492">&lt;Other</text>
                <text x="300" y="1492">options&gt;</text>
                <text x="244" y="1508">Payload:</text>
                <text x="308" y="1508">"5678"</text>
                <text x="236" y="1540">Token:</text>
                <text x="284" y="1540">0x01</text>
                <text x="92" y="1556">2.05</text>
                <text x="244" y="1556">Observe:</text>
                <text x="304" y="1556">54123</text>
                <text x="236" y="1572">&lt;Other</text>
                <text x="300" y="1572">options&gt;</text>
                <text x="244" y="1588">Payload:</text>
                <text x="308" y="1588">"5678"</text>
                <text x="16" y="1652">(#)</text>
                <text x="52" y="1652">Sent</text>
                <text x="92" y="1652">over</text>
                <text x="124" y="1652">IP</text>
                <text x="176" y="1652">multicast</text>
                <text x="228" y="1652">to</text>
                <text x="332" y="1652">GROUP_ADDR:GROUP_PORT.</text>
              </g>
            </svg>
          </artwork>
          <artwork type="ascii-art"><![CDATA[
C1     C2     P        S
|      |      |        |
|      |      |        |  (The value of the resource /r is "1234")
|      |      |        |
+------------>|        |  Token: 0x4a
| GET  |      |        |  Observe: 0 (register)
|      |      |        |  Proxy-Uri: "coap://sensor.example/r"
|      |      |        |
|      |      +------->|  Token: 0x5e
|      |      | GET    |  Observe: 0 (register)
|      |      |        |  Uri-Host: "sensor.example"
|      |      |        |  Uri-Path: "r"
|      |      |        |
|      |      |        |  (S allocates the available Token value 0x7b)
|      |      |        |
|      |      |        |  (S sends to itself a phantom observation
|      |      |        |  request PH_REQ as coming from the
|      |      |        |  IP multicast address GRP_ADDR)
|      |      |        |
|      |      |  .-----+
|      |      | /      |
|      |      | \      |
|      |      |  `---->|  Token: 0x7b
|      |      |    GET |  Observe: 0 (register)
|      |      |        |  Uri-Host: "sensor.example"
|      |      |        |  Uri-Path: "r"
|      |      |        |
|      |      |        |  (S creates a group observation of /r)
|      |      |        |
|      |      |        |  (S increments the observer counter
|      |      |        |  for the group observation of /r)
|      |      |        |
|      |      |        |
|      |      |        |
|      |      |<-------+  Token: 0x5e
|      |      | 5.03   |  Content-Format: application/
|      |      |        |     informative-response+cbor
|      |      |        |  Max-Age: 0
|      |      |        |  <Other options>
|      |      |        |  Payload: {
|      |      |        |    / tp_info /    0 : [
|      |      |        |            cri'coap://SRV_ADDR:SRV_PORT/',
|      |      |        |              cri'coap://GRP_ADDR:GRP_PORT/',
|      |      |        |                0x7b],
|      |      |        |    / last_notif / 2 : bstr(0x45 | OPT | 0xff |
|      |      |        |                            PAYLOAD)
|      |      |        |  }
|      |      |        |
|      |      |        |  (PAYLOAD in 'last_notif' : "1234")
|      |      |        |
|      |      |        |
|      |      |        |  (The proxy starts listening to the
|      |      |        |   GRP_ADDR address and the GRP_PORT port.)
|      |      |        |
|      |      |        |  (The proxy adds C1 to its list of observers.)
|      |      |        |
|<------------+        |  Token: 0x4a
| 2.05 |      |        |  Observe: 54120
|      |      |        |  <Other options>
|      |      |        |  Payload: "1234"
|      |      |        |

...   ...    ...     ...

|      |      |        |
|      +----->|        |  Token: 0x01
|      | GET  |        |  Observe: 0 (register)
|      |      |        |  Proxy-Uri: "coap://sensor.example/r"
|      |      |        |
|      |      |        |  (The proxy has a fresh cache representation)
|      |      |        |
|      |<-----+        |  Token: 0x01
|      | 2.05 |        |  Observe: 54120
|      |      |        |  <Other options>
|      |      |        |  Payload: "1234"
|      |      |        |

...   ...    ...     ...

|      |      |        |
|      |      |        |  (The value of the resource
|      |      |        |  /r changes to "5678".)
|      |      |        |
|      |      |  (#)   |
|      |      |<-------+  Token: 0x7b
|      |      | 2.05   |  Observe: 11
|      |      |        |  <Other options>
|      |      |        |  Payload: "5678"
|      |      |        |
|<------------+        |  Token: 0x4a
| 2.05 |      |        |  Observe: 54123
|      |      |        |  <Other options>
|      |      |        |  Payload: "5678"
|      |      |        |
|      |<-----+        |  Token: 0x01
|      | 2.05 |        |  Observe: 54123
|      |      |        |  <Other options>
|      |      |        |  Payload: "5678"
|      |      |        |


(#) Sent over IP multicast to GROUP_ADDR:GROUP_PORT.
]]></artwork>
        </artset>
      </figure>
      <t>Note that the proxy has all the information to understand the observation request from C2 and can immediately start to serve the still fresh values.</t>
      <t>This behavior is mandated by <xref section="5" sectionFormat="of" target="RFC7641"/>, i.e., the proxy registers itself only once with the next hop and fans out the notifications that it receives to all the registered clients.</t>
    </section>
    <section anchor="intermediaries-example-e2e-security">
      <name>Example with a Proxy and with Group OSCORE</name>
      <t>This section provides an example where a proxy P is used between the clients and the server, and Group OSCORE is used to protect multicast notifications end-to-end between the server and the clients.</t>
      <t>The same assumptions and notation used in <xref section="10" sectionFormat="of" target="I-D.ietf-core-observe-multicast-notifications"/> are used for this example. In addition, the proxy has address PRX_ADDR and listens to the port number PRX_PORT.</t>
      <t>Unless explicitly indicated, all messages transmitted on the wire are sent over unicast and protected with OSCORE end-to-end between a client and the server.</t>
      <figure anchor="example-proxy-oscore">
        <name>Example of Group Observation with a Proxy and Group OSCORE</name>
        <artset>
          <artwork type="svg"><svg xmlns="http://www.w3.org/2000/svg" version="1.1" height="4416" width="576" viewBox="0 0 576 4416" class="diagram" text-anchor="middle" font-family="monospace" font-size="13px" stroke-linecap="round">
              <path d="M 8,48 L 8,2112" fill="none" stroke="black"/>
              <path d="M 8,2176 L 8,3632" fill="none" stroke="black"/>
              <path d="M 8,3696 L 8,4288" fill="none" stroke="black"/>
              <path d="M 72,48 L 72,88" fill="none" stroke="black"/>
              <path d="M 72,104 L 72,1528" fill="none" stroke="black"/>
              <path d="M 72,1544 L 72,1656" fill="none" stroke="black"/>
              <path d="M 72,1672 L 72,2088" fill="none" stroke="black"/>
              <path d="M 72,2176 L 72,3632" fill="none" stroke="black"/>
              <path d="M 72,3696 L 72,4008" fill="none" stroke="black"/>
              <path d="M 72,4024 L 72,4288" fill="none" stroke="black"/>
              <path d="M 136,48 L 136,2112" fill="none" stroke="black"/>
              <path d="M 136,2176 L 136,3632" fill="none" stroke="black"/>
              <path d="M 136,3696 L 136,4288" fill="none" stroke="black"/>
              <path d="M 216,48 L 216,2112" fill="none" stroke="black"/>
              <path d="M 216,2176 L 216,3632" fill="none" stroke="black"/>
              <path d="M 216,3696 L 216,4288" fill="none" stroke="black"/>
              <path d="M 8,96 L 128,96" fill="none" stroke="black"/>
              <path d="M 136,320 L 208,320" fill="none" stroke="black"/>
              <path d="M 160,656 L 216,656" fill="none" stroke="black"/>
              <path d="M 160,704 L 208,704" fill="none" stroke="black"/>
              <path d="M 432,960 L 448,960" fill="none" stroke="black"/>
              <path d="M 144,1088 L 216,1088" fill="none" stroke="black"/>
              <path d="M 16,1536 L 136,1536" fill="none" stroke="black"/>
              <path d="M 8,1664 L 128,1664" fill="none" stroke="black"/>
              <path d="M 16,2096 L 136,2096" fill="none" stroke="black"/>
              <path d="M 72,2192 L 128,2192" fill="none" stroke="black"/>
              <path d="M 136,2416 L 208,2416" fill="none" stroke="black"/>
              <path d="M 144,2672 L 216,2672" fill="none" stroke="black"/>
              <path d="M 80,3120 L 136,3120" fill="none" stroke="black"/>
              <path d="M 72,3232 L 128,3232" fill="none" stroke="black"/>
              <path d="M 80,3600 L 136,3600" fill="none" stroke="black"/>
              <path d="M 144,3776 L 216,3776" fill="none" stroke="black"/>
              <path d="M 16,4016 L 136,4016" fill="none" stroke="black"/>
              <path d="M 80,4160 L 136,4160" fill="none" stroke="black"/>
              <path d="M 148,680 L 160,704" fill="none" stroke="black"/>
              <path d="M 148,680 L 160,656" fill="none" stroke="black"/>
              <polygon class="arrowhead" points="440,960 428,954.4 428,965.6" fill="black" transform="rotate(180,432,960)"/>
              <polygon class="arrowhead" points="216,2416 204,2410.4 204,2421.6" fill="black" transform="rotate(0,208,2416)"/>
              <polygon class="arrowhead" points="216,704 204,698.4 204,709.6" fill="black" transform="rotate(0,208,704)"/>
              <polygon class="arrowhead" points="216,320 204,314.4 204,325.6" fill="black" transform="rotate(0,208,320)"/>
              <polygon class="arrowhead" points="152,3776 140,3770.4 140,3781.6" fill="black" transform="rotate(180,144,3776)"/>
              <polygon class="arrowhead" points="152,2672 140,2666.4 140,2677.6" fill="black" transform="rotate(180,144,2672)"/>
              <polygon class="arrowhead" points="152,1088 140,1082.4 140,1093.6" fill="black" transform="rotate(180,144,1088)"/>
              <polygon class="arrowhead" points="136,3232 124,3226.4 124,3237.6" fill="black" transform="rotate(0,128,3232)"/>
              <polygon class="arrowhead" points="136,2192 124,2186.4 124,2197.6" fill="black" transform="rotate(0,128,2192)"/>
              <polygon class="arrowhead" points="136,1664 124,1658.4 124,1669.6" fill="black" transform="rotate(0,128,1664)"/>
              <polygon class="arrowhead" points="136,96 124,90.4 124,101.6" fill="black" transform="rotate(0,128,96)"/>
              <polygon class="arrowhead" points="88,4160 76,4154.4 76,4165.6" fill="black" transform="rotate(180,80,4160)"/>
              <polygon class="arrowhead" points="88,3600 76,3594.4 76,3605.6" fill="black" transform="rotate(180,80,3600)"/>
              <polygon class="arrowhead" points="88,3120 76,3114.4 76,3125.6" fill="black" transform="rotate(180,80,3120)"/>
              <polygon class="arrowhead" points="24,4016 12,4010.4 12,4021.6" fill="black" transform="rotate(180,16,4016)"/>
              <polygon class="arrowhead" points="24,2096 12,2090.4 12,2101.6" fill="black" transform="rotate(180,16,2096)"/>
              <polygon class="arrowhead" points="24,1536 12,1530.4 12,1541.6" fill="black" transform="rotate(180,16,1536)"/>
              <g class="text">
                <text x="12" y="36">C1</text>
                <text x="76" y="36">C2</text>
                <text x="136" y="36">P</text>
                <text x="216" y="36">S</text>
                <text x="252" y="68">(The</text>
                <text x="296" y="68">value</text>
                <text x="332" y="68">of</text>
                <text x="360" y="68">the</text>
                <text x="412" y="68">resource</text>
                <text x="460" y="68">/r</text>
                <text x="484" y="68">is</text>
                <text x="528" y="68">"1234")</text>
                <text x="260" y="100">Token:</text>
                <text x="308" y="100">0x4a</text>
                <text x="40" y="116">FETCH</text>
                <text x="268" y="116">Observe:</text>
                <text x="312" y="116">0</text>
                <text x="364" y="116">(register)</text>
                <text x="264" y="132">OSCORE:</text>
                <text x="340" y="132">[kid:0x01,</text>
                <text x="416" y="132">Partial</text>
                <text x="484" y="132">IV:0x65]</text>
                <text x="272" y="148">Uri-Host:</text>
                <text x="380" y="148">"sensor.example"</text>
                <text x="288" y="164">Proxy-Scheme:</text>
                <text x="372" y="164">"coap"</text>
                <text x="260" y="180">&lt;Other</text>
                <text x="312" y="180">class</text>
                <text x="352" y="180">U/I</text>
                <text x="404" y="180">options&gt;</text>
                <text x="252" y="196">0xff</text>
                <text x="304" y="212">Encrypted_payload</text>
                <text x="384" y="212">{</text>
                <text x="268" y="228">0x01</text>
                <text x="316" y="228">(GET),</text>
                <text x="284" y="244">Observe:</text>
                <text x="328" y="244">0</text>
                <text x="384" y="244">(register),</text>
                <text x="288" y="260">Uri-Path:</text>
                <text x="348" y="260">"r",</text>
                <text x="276" y="276">&lt;Other</text>
                <text x="328" y="276">class</text>
                <text x="360" y="276">E</text>
                <text x="404" y="276">options&gt;</text>
                <text x="240" y="292">}</text>
                <text x="260" y="324">Token:</text>
                <text x="308" y="324">0x5e</text>
                <text x="168" y="340">FETCH</text>
                <text x="268" y="340">Observe:</text>
                <text x="312" y="340">0</text>
                <text x="364" y="340">(register)</text>
                <text x="264" y="356">OSCORE:</text>
                <text x="340" y="356">[kid:0x01,</text>
                <text x="416" y="356">Partial</text>
                <text x="484" y="356">IV:0x65]</text>
                <text x="272" y="372">Uri-Host:</text>
                <text x="380" y="372">"sensor.example"</text>
                <text x="260" y="388">&lt;Other</text>
                <text x="312" y="388">class</text>
                <text x="352" y="388">U/I</text>
                <text x="404" y="388">options&gt;</text>
                <text x="252" y="404">0xff</text>
                <text x="304" y="420">Encrypted_payload</text>
                <text x="384" y="420">{</text>
                <text x="268" y="436">0x01</text>
                <text x="316" y="436">(GET),</text>
                <text x="284" y="452">Observe:</text>
                <text x="328" y="452">0</text>
                <text x="384" y="452">(register),</text>
                <text x="288" y="468">Uri-Path:</text>
                <text x="348" y="468">"r",</text>
                <text x="276" y="484">&lt;Other</text>
                <text x="328" y="484">class</text>
                <text x="360" y="484">E</text>
                <text x="404" y="484">options&gt;</text>
                <text x="240" y="500">}</text>
                <text x="244" y="548">(S</text>
                <text x="296" y="548">allocates</text>
                <text x="352" y="548">the</text>
                <text x="408" y="548">available</text>
                <text x="264" y="564">Token</text>
                <text x="312" y="564">value</text>
                <text x="356" y="564">0x7b</text>
                <text x="388" y="564">.)</text>
                <text x="244" y="596">(S</text>
                <text x="280" y="596">sends</text>
                <text x="316" y="596">to</text>
                <text x="356" y="596">itself</text>
                <text x="392" y="596">a</text>
                <text x="432" y="596">phantom</text>
                <text x="512" y="596">observation</text>
                <text x="264" y="612">request</text>
                <text x="324" y="612">PH_REQ</text>
                <text x="364" y="612">as</text>
                <text x="404" y="612">coming</text>
                <text x="452" y="612">from</text>
                <text x="488" y="612">the</text>
                <text x="244" y="628">IP</text>
                <text x="296" y="628">multicast</text>
                <text x="368" y="628">address</text>
                <text x="440" y="628">GRP_ADDR)</text>
                <text x="184" y="644">(#)</text>
                <text x="260" y="708">Token:</text>
                <text x="308" y="708">0x7b</text>
                <text x="184" y="724">FETCH</text>
                <text x="268" y="724">Observe:</text>
                <text x="312" y="724">0</text>
                <text x="364" y="724">(register)</text>
                <text x="264" y="740">OSCORE:</text>
                <text x="340" y="740">[kid:0x05,</text>
                <text x="416" y="740">Partial</text>
                <text x="492" y="740">IV:0x01f5,</text>
                <text x="320" y="756">kid</text>
                <text x="408" y="756">context:0x57ab2e]</text>
                <text x="272" y="772">Uri-Host:</text>
                <text x="380" y="772">"sensor.example"</text>
                <text x="260" y="788">&lt;Other</text>
                <text x="312" y="788">class</text>
                <text x="352" y="788">U/I</text>
                <text x="404" y="788">options&gt;</text>
                <text x="252" y="804">0xff</text>
                <text x="304" y="820">Encrypted_payload</text>
                <text x="384" y="820">{</text>
                <text x="268" y="836">0x01</text>
                <text x="316" y="836">(GET),</text>
                <text x="284" y="852">Observe:</text>
                <text x="328" y="852">0</text>
                <text x="384" y="852">(register),</text>
                <text x="288" y="868">Uri-Path:</text>
                <text x="348" y="868">"r",</text>
                <text x="276" y="884">&lt;Other</text>
                <text x="328" y="884">class</text>
                <text x="360" y="884">E</text>
                <text x="404" y="884">options&gt;</text>
                <text x="240" y="900">}</text>
                <text x="308" y="916">&lt;Countersignature&gt;</text>
                <text x="244" y="948">(S</text>
                <text x="280" y="948">steps</text>
                <text x="324" y="948">SN_5</text>
                <text x="356" y="948">in</text>
                <text x="384" y="948">the</text>
                <text x="424" y="948">Group</text>
                <text x="476" y="948">OSCORE</text>
                <text x="276" y="964">Security</text>
                <text x="348" y="964">Context:</text>
                <text x="404" y="964">SN_5</text>
                <text x="476" y="964">502)</text>
                <text x="244" y="996">(S</text>
                <text x="288" y="996">creates</text>
                <text x="328" y="996">a</text>
                <text x="360" y="996">group</text>
                <text x="432" y="996">observation</text>
                <text x="492" y="996">of</text>
                <text x="520" y="996">/r)</text>
                <text x="244" y="1044">(S</text>
                <text x="300" y="1044">increments</text>
                <text x="360" y="1044">the</text>
                <text x="412" y="1044">observer</text>
                <text x="480" y="1044">counter</text>
                <text x="256" y="1060">for</text>
                <text x="288" y="1060">the</text>
                <text x="328" y="1060">group</text>
                <text x="400" y="1060">observation</text>
                <text x="460" y="1060">of</text>
                <text x="488" y="1060">/r)</text>
                <text x="260" y="1092">Token:</text>
                <text x="308" y="1092">0x5e</text>
                <text x="164" y="1108">2.05</text>
                <text x="264" y="1108">OSCORE:</text>
                <text x="304" y="1108">-</text>
                <text x="344" y="1108">(empty)</text>
                <text x="268" y="1124">Max-Age:</text>
                <text x="312" y="1124">0</text>
                <text x="260" y="1140">&lt;Other</text>
                <text x="312" y="1140">class</text>
                <text x="352" y="1140">U/I</text>
                <text x="404" y="1140">options&gt;</text>
                <text x="252" y="1156">0xff</text>
                <text x="304" y="1172">Encrypted_payload</text>
                <text x="384" y="1172">{</text>
                <text x="268" y="1188">5.03</text>
                <text x="324" y="1188">(Service</text>
                <text x="416" y="1188">Unavailable),</text>
                <text x="312" y="1204">Content-Format:</text>
                <text x="428" y="1204">application/</text>
                <text x="380" y="1220">informative-response+cbor,</text>
                <text x="276" y="1236">&lt;Other</text>
                <text x="328" y="1236">class</text>
                <text x="360" y="1236">E</text>
                <text x="408" y="1236">options&gt;,</text>
                <text x="272" y="1252">0xff,</text>
                <text x="280" y="1268">Payload</text>
                <text x="320" y="1268">{</text>
                <text x="272" y="1284">/</text>
                <text x="312" y="1284">tp_info</text>
                <text x="352" y="1284">/</text>
                <text x="392" y="1284">0</text>
                <text x="408" y="1284">:</text>
                <text x="424" y="1284">[</text>
                <text x="432" y="1300">cri'coap://SRV_ADDR:SRV_PORT/',</text>
                <text x="448" y="1316">cri'coap://GRP_ADDR:GRP_PORT/',</text>
                <text x="364" y="1332">0x7b],</text>
                <text x="272" y="1348">/</text>
                <text x="308" y="1348">ph_req</text>
                <text x="344" y="1348">/</text>
                <text x="392" y="1348">1</text>
                <text x="408" y="1348">:</text>
                <text x="456" y="1348">bstr(0x05</text>
                <text x="504" y="1348">|</text>
                <text x="440" y="1364">OPT</text>
                <text x="464" y="1364">|</text>
                <text x="492" y="1364">0xff</text>
                <text x="520" y="1364">|</text>
                <text x="456" y="1380">PAYLOAD</text>
                <text x="496" y="1380">|</text>
                <text x="532" y="1380">SIGN),</text>
                <text x="272" y="1396">/</text>
                <text x="324" y="1396">last_notif</text>
                <text x="376" y="1396">/</text>
                <text x="392" y="1396">2</text>
                <text x="408" y="1396">:</text>
                <text x="456" y="1396">bstr(0x45</text>
                <text x="504" y="1396">|</text>
                <text x="440" y="1412">OPT</text>
                <text x="464" y="1412">|</text>
                <text x="492" y="1412">0xff</text>
                <text x="520" y="1412">|</text>
                <text x="456" y="1428">PAYLOAD</text>
                <text x="496" y="1428">|</text>
                <text x="532" y="1428">SIGN),</text>
                <text x="272" y="1444">/</text>
                <text x="316" y="1444">join_uri</text>
                <text x="360" y="1444">/</text>
                <text x="392" y="1444">4</text>
                <text x="408" y="1444">:</text>
                <text x="472" y="1444">"coap://myGM/</text>
                <text x="496" y="1460">ace-group/myGroup",</text>
                <text x="272" y="1476">/</text>
                <text x="308" y="1476">sec_gp</text>
                <text x="344" y="1476">/</text>
                <text x="392" y="1476">5</text>
                <text x="408" y="1476">:</text>
                <text x="456" y="1476">"myGroup"</text>
                <text x="256" y="1492">}</text>
                <text x="240" y="1508">}</text>
                <text x="260" y="1540">Token:</text>
                <text x="308" y="1540">0x4a</text>
                <text x="36" y="1556">2.05</text>
                <text x="264" y="1556">OSCORE:</text>
                <text x="304" y="1556">-</text>
                <text x="344" y="1556">(empty)</text>
                <text x="268" y="1572">Max-Age:</text>
                <text x="312" y="1572">0</text>
                <text x="260" y="1588">&lt;Other</text>
                <text x="312" y="1588">class</text>
                <text x="352" y="1588">U/I</text>
                <text x="404" y="1588">options&gt;</text>
                <text x="252" y="1604">0xff</text>
                <text x="256" y="1620">(Same</text>
                <text x="356" y="1620">Encrypted_payload)</text>
                <text x="40" y="1652">(#)</text>
                <text x="260" y="1668">Token:</text>
                <text x="308" y="1668">0x4b</text>
                <text x="40" y="1684">FETCH</text>
                <text x="268" y="1684">Observe:</text>
                <text x="312" y="1684">0</text>
                <text x="364" y="1684">(register)</text>
                <text x="264" y="1700">OSCORE:</text>
                <text x="340" y="1700">[kid:0x05,</text>
                <text x="416" y="1700">Partial</text>
                <text x="492" y="1700">IV:0x01f5,</text>
                <text x="320" y="1716">kid</text>
                <text x="408" y="1716">context:0x57ab2e]</text>
                <text x="272" y="1732">Uri-Host:</text>
                <text x="380" y="1732">"sensor.example"</text>
                <text x="288" y="1748">Proxy-Scheme:</text>
                <text x="372" y="1748">"coap"</text>
                <text x="356" y="1764">Listen-To-Multicast-Responses:</text>
                <text x="488" y="1764">{</text>
                <text x="380" y="1780">[cri'coap://SRV_ADDR:SRV_PORT/',</text>
                <text x="400" y="1796">cri'coap://GRP_ADDR:GRP_PORT/',</text>
                <text x="312" y="1812">0x7b]</text>
                <text x="240" y="1828">}</text>
                <text x="260" y="1844">&lt;Other</text>
                <text x="312" y="1844">class</text>
                <text x="352" y="1844">U/I</text>
                <text x="404" y="1844">options&gt;</text>
                <text x="252" y="1860">0xff</text>
                <text x="304" y="1876">Encrypted_payload</text>
                <text x="384" y="1876">{</text>
                <text x="268" y="1892">0x01</text>
                <text x="316" y="1892">(GET),</text>
                <text x="284" y="1908">Observe:</text>
                <text x="328" y="1908">0</text>
                <text x="384" y="1908">(register),</text>
                <text x="288" y="1924">Uri-Path:</text>
                <text x="348" y="1924">"r",</text>
                <text x="276" y="1940">&lt;Other</text>
                <text x="328" y="1940">class</text>
                <text x="360" y="1940">E</text>
                <text x="404" y="1940">options&gt;</text>
                <text x="240" y="1956">}</text>
                <text x="308" y="1972">&lt;Countersignature&gt;</text>
                <text x="252" y="2004">(The</text>
                <text x="296" y="2004">proxy</text>
                <text x="348" y="2004">starts</text>
                <text x="416" y="2004">listening</text>
                <text x="468" y="2004">to</text>
                <text x="496" y="2004">the</text>
                <text x="276" y="2020">GRP_ADDR</text>
                <text x="344" y="2020">address</text>
                <text x="392" y="2020">and</text>
                <text x="424" y="2020">the</text>
                <text x="476" y="2020">GRP_PORT</text>
                <text x="540" y="2020">port.)</text>
                <text x="252" y="2052">(The</text>
                <text x="296" y="2052">proxy</text>
                <text x="340" y="2052">adds</text>
                <text x="372" y="2052">C1</text>
                <text x="396" y="2052">to</text>
                <text x="256" y="2068">its</text>
                <text x="292" y="2068">list</text>
                <text x="324" y="2068">of</text>
                <text x="384" y="2068">observers.)</text>
                <text x="72" y="2116">|</text>
                <text x="104" y="2116">ACK</text>
                <text x="16" y="2148">...</text>
                <text x="72" y="2148">...</text>
                <text x="136" y="2148">...</text>
                <text x="208" y="2148">...</text>
                <text x="260" y="2196">Token:</text>
                <text x="308" y="2196">0x01</text>
                <text x="104" y="2212">FETCH</text>
                <text x="268" y="2212">Observe:</text>
                <text x="312" y="2212">0</text>
                <text x="364" y="2212">(register)</text>
                <text x="264" y="2228">OSCORE:</text>
                <text x="340" y="2228">[kid:0x02,</text>
                <text x="416" y="2228">Partial</text>
                <text x="484" y="2228">IV:0xc9]</text>
                <text x="272" y="2244">Uri-Host:</text>
                <text x="380" y="2244">"sensor.example"</text>
                <text x="288" y="2260">Proxy-Scheme:</text>
                <text x="372" y="2260">"coap"</text>
                <text x="260" y="2276">&lt;Other</text>
                <text x="312" y="2276">class</text>
                <text x="352" y="2276">U/I</text>
                <text x="404" y="2276">options&gt;</text>
                <text x="252" y="2292">0xff</text>
                <text x="304" y="2308">Encrypted_payload</text>
                <text x="384" y="2308">{</text>
                <text x="268" y="2324">0x01</text>
                <text x="316" y="2324">(GET),</text>
                <text x="284" y="2340">Observe:</text>
                <text x="328" y="2340">0</text>
                <text x="384" y="2340">(register),</text>
                <text x="288" y="2356">Uri-Path:</text>
                <text x="348" y="2356">"r",</text>
                <text x="276" y="2372">&lt;Other</text>
                <text x="328" y="2372">class</text>
                <text x="360" y="2372">E</text>
                <text x="404" y="2372">options&gt;</text>
                <text x="240" y="2388">}</text>
                <text x="260" y="2420">Token:</text>
                <text x="308" y="2420">0x5f</text>
                <text x="168" y="2436">FETCH</text>
                <text x="268" y="2436">Observe:</text>
                <text x="312" y="2436">0</text>
                <text x="364" y="2436">(register)</text>
                <text x="264" y="2452">OSCORE:</text>
                <text x="340" y="2452">[kid:0x02,</text>
                <text x="416" y="2452">Partial</text>
                <text x="484" y="2452">IV:0xc9]</text>
                <text x="272" y="2468">Uri-Host:</text>
                <text x="380" y="2468">"sensor.example"</text>
                <text x="260" y="2484">&lt;Other</text>
                <text x="312" y="2484">class</text>
                <text x="352" y="2484">U/I</text>
                <text x="404" y="2484">options&gt;</text>
                <text x="252" y="2500">0xff</text>
                <text x="304" y="2516">Encrypted_payload</text>
                <text x="384" y="2516">{</text>
                <text x="268" y="2532">0x01</text>
                <text x="316" y="2532">(GET),</text>
                <text x="284" y="2548">Observe:</text>
                <text x="328" y="2548">0</text>
                <text x="384" y="2548">(register),</text>
                <text x="288" y="2564">Uri-Path:</text>
                <text x="348" y="2564">"r",</text>
                <text x="276" y="2580">&lt;Other</text>
                <text x="328" y="2580">class</text>
                <text x="360" y="2580">E</text>
                <text x="404" y="2580">options&gt;</text>
                <text x="240" y="2596">}</text>
                <text x="244" y="2628">(S</text>
                <text x="300" y="2628">increments</text>
                <text x="360" y="2628">the</text>
                <text x="412" y="2628">observer</text>
                <text x="480" y="2628">counter</text>
                <text x="256" y="2644">for</text>
                <text x="288" y="2644">the</text>
                <text x="328" y="2644">group</text>
                <text x="400" y="2644">observation</text>
                <text x="460" y="2644">of</text>
                <text x="488" y="2644">/r)</text>
                <text x="260" y="2676">Token:</text>
                <text x="308" y="2676">0x5f</text>
                <text x="164" y="2692">2.05</text>
                <text x="264" y="2692">OSCORE:</text>
                <text x="304" y="2692">-</text>
                <text x="344" y="2692">(empty)</text>
                <text x="268" y="2708">Max-Age:</text>
                <text x="312" y="2708">0</text>
                <text x="260" y="2724">&lt;Other</text>
                <text x="312" y="2724">class</text>
                <text x="352" y="2724">U/I</text>
                <text x="404" y="2724">options&gt;</text>
                <text x="252" y="2740">0xff</text>
                <text x="304" y="2756">Encrypted_payload</text>
                <text x="384" y="2756">{</text>
                <text x="268" y="2772">5.03</text>
                <text x="324" y="2772">(Service</text>
                <text x="416" y="2772">Unavailable),</text>
                <text x="312" y="2788">Content-Format:</text>
                <text x="428" y="2788">application/</text>
                <text x="380" y="2804">informative-response+cbor,</text>
                <text x="276" y="2820">&lt;Other</text>
                <text x="328" y="2820">class</text>
                <text x="360" y="2820">E</text>
                <text x="408" y="2820">options&gt;,</text>
                <text x="272" y="2836">0xff,</text>
                <text x="280" y="2852">Payload</text>
                <text x="320" y="2852">{</text>
                <text x="272" y="2868">/</text>
                <text x="312" y="2868">tp_info</text>
                <text x="352" y="2868">/</text>
                <text x="392" y="2868">0</text>
                <text x="408" y="2868">:</text>
                <text x="424" y="2868">[</text>
                <text x="432" y="2884">cri'coap://SRV_ADDR:SRV_PORT/',</text>
                <text x="448" y="2900">cri'coap://GRP_ADDR:GRP_PORT/',</text>
                <text x="364" y="2916">0x7b],</text>
                <text x="272" y="2932">/</text>
                <text x="308" y="2932">ph_req</text>
                <text x="344" y="2932">/</text>
                <text x="392" y="2932">1</text>
                <text x="408" y="2932">:</text>
                <text x="456" y="2932">bstr(0x05</text>
                <text x="504" y="2932">|</text>
                <text x="440" y="2948">OPT</text>
                <text x="464" y="2948">|</text>
                <text x="492" y="2948">0xff</text>
                <text x="520" y="2948">|</text>
                <text x="456" y="2964">PAYLOAD</text>
                <text x="496" y="2964">|</text>
                <text x="532" y="2964">SIGN),</text>
                <text x="272" y="2980">/</text>
                <text x="324" y="2980">last_notif</text>
                <text x="376" y="2980">/</text>
                <text x="392" y="2980">2</text>
                <text x="408" y="2980">:</text>
                <text x="456" y="2980">bstr(0x45</text>
                <text x="504" y="2980">|</text>
                <text x="440" y="2996">OPT</text>
                <text x="464" y="2996">|</text>
                <text x="492" y="2996">0xff</text>
                <text x="520" y="2996">|</text>
                <text x="456" y="3012">PAYLOAD</text>
                <text x="496" y="3012">|</text>
                <text x="532" y="3012">SIGN),</text>
                <text x="272" y="3028">/</text>
                <text x="316" y="3028">join_uri</text>
                <text x="360" y="3028">/</text>
                <text x="392" y="3028">4</text>
                <text x="408" y="3028">:</text>
                <text x="472" y="3028">"coap://myGM/</text>
                <text x="496" y="3044">ace-group/myGroup",</text>
                <text x="272" y="3060">/</text>
                <text x="308" y="3060">sec_gp</text>
                <text x="344" y="3060">/</text>
                <text x="392" y="3060">5</text>
                <text x="408" y="3060">:</text>
                <text x="456" y="3060">"myGroup"</text>
                <text x="256" y="3076">}</text>
                <text x="240" y="3092">}</text>
                <text x="260" y="3124">Token:</text>
                <text x="308" y="3124">0x01</text>
                <text x="100" y="3140">2.05</text>
                <text x="264" y="3140">OSCORE:</text>
                <text x="304" y="3140">-</text>
                <text x="344" y="3140">(empty)</text>
                <text x="268" y="3156">Max-Age:</text>
                <text x="312" y="3156">0</text>
                <text x="260" y="3172">&lt;Other</text>
                <text x="312" y="3172">class</text>
                <text x="352" y="3172">U/I</text>
                <text x="404" y="3172">options&gt;</text>
                <text x="252" y="3188">0xff</text>
                <text x="256" y="3204">(Same</text>
                <text x="356" y="3204">Encrypted_payload)</text>
                <text x="104" y="3220">(#)</text>
                <text x="260" y="3236">Token:</text>
                <text x="308" y="3236">0x02</text>
                <text x="104" y="3252">FETCH</text>
                <text x="268" y="3252">Observe:</text>
                <text x="312" y="3252">0</text>
                <text x="364" y="3252">(register)</text>
                <text x="264" y="3268">OSCORE:</text>
                <text x="340" y="3268">[kid:0x05,</text>
                <text x="416" y="3268">Partial</text>
                <text x="492" y="3268">IV:0x01f5,</text>
                <text x="320" y="3284">kid</text>
                <text x="408" y="3284">context:0x57ab2e]</text>
                <text x="272" y="3300">Uri-Host:</text>
                <text x="380" y="3300">"sensor.example"</text>
                <text x="288" y="3316">Proxy-Scheme:</text>
                <text x="372" y="3316">"coap"</text>
                <text x="356" y="3332">Listen-To-Multicast-Responses:</text>
                <text x="488" y="3332">{</text>
                <text x="380" y="3348">[cri'coap://SRV_ADDR:SRV_PORT/',</text>
                <text x="400" y="3364">cri'coap://GRP_ADDR:GRP_PORT/',</text>
                <text x="312" y="3380">0x7b]</text>
                <text x="240" y="3396">}</text>
                <text x="260" y="3412">&lt;Other</text>
                <text x="312" y="3412">class</text>
                <text x="352" y="3412">U/I</text>
                <text x="404" y="3412">options&gt;</text>
                <text x="252" y="3428">0xff</text>
                <text x="304" y="3444">Encrypted_payload</text>
                <text x="384" y="3444">{</text>
                <text x="268" y="3460">0x01</text>
                <text x="316" y="3460">(GET),</text>
                <text x="284" y="3476">Observe:</text>
                <text x="328" y="3476">0</text>
                <text x="384" y="3476">(register),</text>
                <text x="288" y="3492">Uri-Path:</text>
                <text x="348" y="3492">"r",</text>
                <text x="276" y="3508">&lt;Other</text>
                <text x="328" y="3508">class</text>
                <text x="360" y="3508">E</text>
                <text x="404" y="3508">options&gt;</text>
                <text x="240" y="3524">}</text>
                <text x="308" y="3540">&lt;Countersignature&gt;</text>
                <text x="252" y="3572">(The</text>
                <text x="296" y="3572">proxy</text>
                <text x="340" y="3572">adds</text>
                <text x="372" y="3572">C2</text>
                <text x="396" y="3572">to</text>
                <text x="256" y="3588">its</text>
                <text x="292" y="3588">list</text>
                <text x="324" y="3588">of</text>
                <text x="384" y="3588">observers.)</text>
                <text x="104" y="3620">ACK</text>
                <text x="16" y="3668">...</text>
                <text x="72" y="3668">...</text>
                <text x="136" y="3668">...</text>
                <text x="208" y="3668">...</text>
                <text x="252" y="3716">(The</text>
                <text x="296" y="3716">value</text>
                <text x="332" y="3716">of</text>
                <text x="360" y="3716">the</text>
                <text x="412" y="3716">resource</text>
                <text x="252" y="3732">/r</text>
                <text x="296" y="3732">changes</text>
                <text x="340" y="3732">to</text>
                <text x="388" y="3732">"5678".)</text>
                <text x="180" y="3764">(##)</text>
                <text x="260" y="3780">Token:</text>
                <text x="308" y="3780">0x7b</text>
                <text x="164" y="3796">2.05</text>
                <text x="268" y="3796">Observe:</text>
                <text x="316" y="3796">11</text>
                <text x="264" y="3812">OSCORE:</text>
                <text x="340" y="3812">[kid:0x05,</text>
                <text x="416" y="3812">Partial</text>
                <text x="492" y="3812">IV:0x01f6]</text>
                <text x="268" y="3828">Max-Age:</text>
                <text x="312" y="3828">0</text>
                <text x="260" y="3844">&lt;Other</text>
                <text x="312" y="3844">class</text>
                <text x="352" y="3844">U/I</text>
                <text x="404" y="3844">options&gt;</text>
                <text x="252" y="3860">0xff</text>
                <text x="304" y="3876">Encrypted_payload</text>
                <text x="384" y="3876">{</text>
                <text x="268" y="3892">2.05</text>
                <text x="332" y="3892">(Content),</text>
                <text x="284" y="3908">Observe:</text>
                <text x="328" y="3908">-</text>
                <text x="372" y="3908">(empty),</text>
                <text x="276" y="3924">&lt;Other</text>
                <text x="328" y="3924">class</text>
                <text x="360" y="3924">E</text>
                <text x="408" y="3924">options&gt;,</text>
                <text x="272" y="3940">0xff,</text>
                <text x="284" y="3956">Payload:</text>
                <text x="348" y="3956">"5678"</text>
                <text x="240" y="3972">}</text>
                <text x="308" y="3988">&lt;Countersignature&gt;</text>
                <text x="40" y="4004">(#)</text>
                <text x="260" y="4020">Token:</text>
                <text x="308" y="4020">0x4b</text>
                <text x="36" y="4036">2.05</text>
                <text x="268" y="4036">Observe:</text>
                <text x="328" y="4036">54123</text>
                <text x="264" y="4052">OSCORE:</text>
                <text x="340" y="4052">[kid:0x05,</text>
                <text x="416" y="4052">Partial</text>
                <text x="492" y="4052">IV:0x01f6]</text>
                <text x="268" y="4068">Max-Age:</text>
                <text x="312" y="4068">0</text>
                <text x="260" y="4084">&lt;Other</text>
                <text x="312" y="4084">class</text>
                <text x="352" y="4084">U/I</text>
                <text x="404" y="4084">options&gt;</text>
                <text x="252" y="4100">0xff</text>
                <text x="256" y="4116">(Same</text>
                <text x="352" y="4116">Encrypted_payload</text>
                <text x="256" y="4132">and</text>
                <text x="344" y="4132">Countersignature)</text>
                <text x="104" y="4148">(#)</text>
                <text x="260" y="4164">Token:</text>
                <text x="308" y="4164">0x02</text>
                <text x="100" y="4180">2.05</text>
                <text x="268" y="4180">Observe:</text>
                <text x="328" y="4180">54123</text>
                <text x="264" y="4196">OSCORE:</text>
                <text x="340" y="4196">[kid:0x05,</text>
                <text x="416" y="4196">Partial</text>
                <text x="492" y="4196">IV:0x01f6]</text>
                <text x="268" y="4212">Max-Age:</text>
                <text x="312" y="4212">0</text>
                <text x="260" y="4228">&lt;Other</text>
                <text x="312" y="4228">class</text>
                <text x="352" y="4228">U/I</text>
                <text x="404" y="4228">options&gt;</text>
                <text x="252" y="4244">0xff</text>
                <text x="256" y="4260">(Same</text>
                <text x="352" y="4260">Encrypted_payload</text>
                <text x="256" y="4276">and</text>
                <text x="344" y="4276">Countersignature)</text>
                <text x="16" y="4340">(#)</text>
                <text x="60" y="4340">Sent</text>
                <text x="100" y="4340">over</text>
                <text x="156" y="4340">unicast,</text>
                <text x="208" y="4340">and</text>
                <text x="264" y="4340">protected</text>
                <text x="324" y="4340">with</text>
                <text x="368" y="4340">Group</text>
                <text x="420" y="4340">OSCORE</text>
                <text x="492" y="4340">end-to-end</text>
                <text x="72" y="4356">between</text>
                <text x="120" y="4356">the</text>
                <text x="164" y="4356">server</text>
                <text x="208" y="4356">and</text>
                <text x="240" y="4356">the</text>
                <text x="292" y="4356">clients.</text>
                <text x="20" y="4388">(##)</text>
                <text x="60" y="4388">Sent</text>
                <text x="100" y="4388">over</text>
                <text x="132" y="4388">IP</text>
                <text x="184" y="4388">multicast</text>
                <text x="236" y="4388">to</text>
                <text x="340" y="4388">GROUP_ADDR:GROUP_PORT,</text>
                <text x="472" y="4388">protected</text>
                <text x="84" y="4404">end-to-end</text>
                <text x="148" y="4404">with</text>
                <text x="192" y="4404">Group</text>
                <text x="244" y="4404">OSCORE</text>
                <text x="304" y="4404">between</text>
                <text x="352" y="4404">the</text>
                <text x="396" y="4404">server</text>
                <text x="440" y="4404">and</text>
                <text x="472" y="4404">the</text>
                <text x="524" y="4404">clients.</text>
              </g>
            </svg>
          </artwork>
          <artwork type="ascii-art"><![CDATA[
C1      C2      P         S
|       |       |         |
|       |       |         |  (The value of the resource /r is "1234")
|       |       |         |
+-------------->|         |  Token: 0x4a
| FETCH |       |         |  Observe: 0 (register)
|       |       |         |  OSCORE: [kid:0x01, Partial IV:0x65]
|       |       |         |  Uri-Host: "sensor.example"
|       |       |         |  Proxy-Scheme: "coap"
|       |       |         |  <Other class U/I options>
|       |       |         |  0xff
|       |       |         |  Encrypted_payload {
|       |       |         |    0x01 (GET),
|       |       |         |    Observe: 0 (register),
|       |       |         |    Uri-Path: "r",
|       |       |         |    <Other class E options>
|       |       |         |  }
|       |       |         |
|       |       +-------->|  Token: 0x5e
|       |       | FETCH   |  Observe: 0 (register)
|       |       |         |  OSCORE: [kid:0x01, Partial IV:0x65]
|       |       |         |  Uri-Host: "sensor.example"
|       |       |         |  <Other class U/I options>
|       |       |         |  0xff
|       |       |         |  Encrypted_payload {
|       |       |         |    0x01 (GET),
|       |       |         |    Observe: 0 (register),
|       |       |         |    Uri-Path: "r",
|       |       |         |    <Other class E options>
|       |       |         |  }
|       |       |         |
|       |       |         |
|       |       |         |  (S allocates the available
|       |       |         |   Token value 0x7b .)
|       |       |         |
|       |       |         |  (S sends to itself a phantom observation
|       |       |         |  request PH_REQ as coming from the
|       |       |         |  IP multicast address GRP_ADDR)
|       |       |    (#)  |
|       |       |  .------+
|       |       | /       |
|       |       | \       |
|       |       |  `----->|  Token: 0x7b
|       |       |   FETCH |  Observe: 0 (register)
|       |       |         |  OSCORE: [kid:0x05, Partial IV:0x01f5,
|       |       |         |           kid context:0x57ab2e]
|       |       |         |  Uri-Host: "sensor.example"
|       |       |         |  <Other class U/I options>
|       |       |         |  0xff
|       |       |         |  Encrypted_payload {
|       |       |         |    0x01 (GET),
|       |       |         |    Observe: 0 (register),
|       |       |         |    Uri-Path: "r",
|       |       |         |    <Other class E options>
|       |       |         |  }
|       |       |         |  <Countersignature>
|       |       |         |
|       |       |         |  (S steps SN_5 in the Group OSCORE
|       |       |         |   Security Context: SN_5 <-- 502)
|       |       |         |
|       |       |         |  (S creates a group observation of /r)
|       |       |         |
|       |       |         |
|       |       |         |  (S increments the observer counter
|       |       |         |   for the group observation of /r)
|       |       |         |
|       |       |<--------+  Token: 0x5e
|       |       | 2.05    |  OSCORE: - (empty)
|       |       |         |  Max-Age: 0
|       |       |         |  <Other class U/I options>
|       |       |         |  0xff
|       |       |         |  Encrypted_payload {
|       |       |         |    5.03 (Service Unavailable),
|       |       |         |    Content-Format: application/
|       |       |         |       informative-response+cbor,
|       |       |         |    <Other class E options>,
|       |       |         |    0xff,
|       |       |         |    Payload {
|       |       |         |      / tp_info /    0 : [
|       |       |         |           cri'coap://SRV_ADDR:SRV_PORT/',
|       |       |         |             cri'coap://GRP_ADDR:GRP_PORT/',
|       |       |         |               0x7b],
|       |       |         |      / ph_req /     1 : bstr(0x05 |
|       |       |         |                          OPT | 0xff |
|       |       |         |                          PAYLOAD | SIGN),
|       |       |         |      / last_notif / 2 : bstr(0x45 |
|       |       |         |                          OPT | 0xff |
|       |       |         |                          PAYLOAD | SIGN),
|       |       |         |      / join_uri /   4 : "coap://myGM/
|       |       |         |                         ace-group/myGroup",
|       |       |         |      / sec_gp /     5 : "myGroup"
|       |       |         |    }
|       |       |         |  }
|       |       |         |
|<--------------+         |  Token: 0x4a
| 2.05  |       |         |  OSCORE: - (empty)
|       |       |         |  Max-Age: 0
|       |       |         |  <Other class U/I options>
|       |       |         |  0xff
|       |       |         |  (Same Encrypted_payload)
|       |       |         |
|  (#)  |       |         |
+-------------->|         |  Token: 0x4b
| FETCH |       |         |  Observe: 0 (register)
|       |       |         |  OSCORE: [kid:0x05, Partial IV:0x01f5,
|       |       |         |           kid context:0x57ab2e]
|       |       |         |  Uri-Host: "sensor.example"
|       |       |         |  Proxy-Scheme: "coap"
|       |       |         |  Listen-To-Multicast-Responses: {
|       |       |         |    [cri'coap://SRV_ADDR:SRV_PORT/',
|       |       |         |       cri'coap://GRP_ADDR:GRP_PORT/',
|       |       |         |         0x7b]
|       |       |         |  }
|       |       |         |  <Other class U/I options>
|       |       |         |  0xff
|       |       |         |  Encrypted_payload {
|       |       |         |    0x01 (GET),
|       |       |         |    Observe: 0 (register),
|       |       |         |    Uri-Path: "r",
|       |       |         |    <Other class E options>
|       |       |         |  }
|       |       |         |  <Countersignature>
|       |       |         |
|       |       |         |  (The proxy starts listening to the
|       |       |         |   GRP_ADDR address and the GRP_PORT port.)
|       |       |         |
|       |       |         |  (The proxy adds C1 to
|       |       |         |   its list of observers.)
|       |       |         |
|<--------------+         |
|       |  ACK  |         |

...    ...     ...      ...

|       |       |         |
|       +------>|         |  Token: 0x01
|       | FETCH |         |  Observe: 0 (register)
|       |       |         |  OSCORE: [kid:0x02, Partial IV:0xc9]
|       |       |         |  Uri-Host: "sensor.example"
|       |       |         |  Proxy-Scheme: "coap"
|       |       |         |  <Other class U/I options>
|       |       |         |  0xff
|       |       |         |  Encrypted_payload {
|       |       |         |    0x01 (GET),
|       |       |         |    Observe: 0 (register),
|       |       |         |    Uri-Path: "r",
|       |       |         |    <Other class E options>
|       |       |         |  }
|       |       |         |
|       |       +-------->|  Token: 0x5f
|       |       | FETCH   |  Observe: 0 (register)
|       |       |         |  OSCORE: [kid:0x02, Partial IV:0xc9]
|       |       |         |  Uri-Host: "sensor.example"
|       |       |         |  <Other class U/I options>
|       |       |         |  0xff
|       |       |         |  Encrypted_payload {
|       |       |         |    0x01 (GET),
|       |       |         |    Observe: 0 (register),
|       |       |         |    Uri-Path: "r",
|       |       |         |    <Other class E options>
|       |       |         |  }
|       |       |         |
|       |       |         |  (S increments the observer counter
|       |       |         |   for the group observation of /r)
|       |       |         |
|       |       |<--------+  Token: 0x5f
|       |       | 2.05    |  OSCORE: - (empty)
|       |       |         |  Max-Age: 0
|       |       |         |  <Other class U/I options>
|       |       |         |  0xff
|       |       |         |  Encrypted_payload {
|       |       |         |    5.03 (Service Unavailable),
|       |       |         |    Content-Format: application/
|       |       |         |       informative-response+cbor,
|       |       |         |    <Other class E options>,
|       |       |         |    0xff,
|       |       |         |    Payload {
|       |       |         |      / tp_info /    0 : [
|       |       |         |           cri'coap://SRV_ADDR:SRV_PORT/',
|       |       |         |             cri'coap://GRP_ADDR:GRP_PORT/',
|       |       |         |               0x7b],
|       |       |         |      / ph_req /     1 : bstr(0x05 |
|       |       |         |                          OPT | 0xff |
|       |       |         |                          PAYLOAD | SIGN),
|       |       |         |      / last_notif / 2 : bstr(0x45 |
|       |       |         |                          OPT | 0xff |
|       |       |         |                          PAYLOAD | SIGN),
|       |       |         |      / join_uri /   4 : "coap://myGM/
|       |       |         |                         ace-group/myGroup",
|       |       |         |      / sec_gp /     5 : "myGroup"
|       |       |         |    }
|       |       |         |  }
|       |       |         |
|       |<------+         |  Token: 0x01
|       | 2.05  |         |  OSCORE: - (empty)
|       |       |         |  Max-Age: 0
|       |       |         |  <Other class U/I options>
|       |       |         |  0xff
|       |       |         |  (Same Encrypted_payload)
|       |  (#)  |         |
|       +------>|         |  Token: 0x02
|       | FETCH |         |  Observe: 0 (register)
|       |       |         |  OSCORE: [kid:0x05, Partial IV:0x01f5,
|       |       |         |           kid context:0x57ab2e]
|       |       |         |  Uri-Host: "sensor.example"
|       |       |         |  Proxy-Scheme: "coap"
|       |       |         |  Listen-To-Multicast-Responses: {
|       |       |         |    [cri'coap://SRV_ADDR:SRV_PORT/',
|       |       |         |       cri'coap://GRP_ADDR:GRP_PORT/',
|       |       |         |         0x7b]
|       |       |         |  }
|       |       |         |  <Other class U/I options>
|       |       |         |  0xff
|       |       |         |  Encrypted_payload {
|       |       |         |    0x01 (GET),
|       |       |         |    Observe: 0 (register),
|       |       |         |    Uri-Path: "r",
|       |       |         |    <Other class E options>
|       |       |         |  }
|       |       |         |  <Countersignature>
|       |       |         |
|       |       |         |  (The proxy adds C2 to
|       |       |         |   its list of observers.)
|       |<------+         |
|       |  ACK  |         |
|       |       |         |

...    ...     ...      ...

|       |       |         |
|       |       |         |  (The value of the resource
|       |       |         |   /r changes to "5678".)
|       |       |         |
|       |       |   (##)  |
|       |       |<--------+  Token: 0x7b
|       |       | 2.05    |  Observe: 11
|       |       |         |  OSCORE: [kid:0x05, Partial IV:0x01f6]
|       |       |         |  Max-Age: 0
|       |       |         |  <Other class U/I options>
|       |       |         |  0xff
|       |       |         |  Encrypted_payload {
|       |       |         |    2.05 (Content),
|       |       |         |    Observe: - (empty),
|       |       |         |    <Other class E options>,
|       |       |         |    0xff,
|       |       |         |    Payload: "5678"
|       |       |         |  }
|       |       |         |  <Countersignature>
|  (#)  |       |         |
|<--------------+         |  Token: 0x4b
| 2.05  |       |         |  Observe: 54123
|       |       |         |  OSCORE: [kid:0x05, Partial IV:0x01f6]
|       |       |         |  Max-Age: 0
|       |       |         |  <Other class U/I options>
|       |       |         |  0xff
|       |       |         |  (Same Encrypted_payload
|       |       |         |   and Countersignature)
|       |  (#)  |         |
|       |<------+         |  Token: 0x02
|       | 2.05  |         |  Observe: 54123
|       |       |         |  OSCORE: [kid:0x05, Partial IV:0x01f6]
|       |       |         |  Max-Age: 0
|       |       |         |  <Other class U/I options>
|       |       |         |  0xff
|       |       |         |  (Same Encrypted_payload
|       |       |         |   and Countersignature)
|       |       |         |


(#)  Sent over unicast, and protected with Group OSCORE end-to-end
     between the server and the clients.

(##) Sent over IP multicast to GROUP_ADDR:GROUP_PORT, protected
     end-to-end with Group OSCORE between the server and the clients.
]]></artwork>
        </artset>
      </figure>
      <t>Unlike in the unprotected example in <xref target="intermediaries-example"/>, the proxy does not have all the information to perform request deduplication and can only recognize the identical request once the client sends the ticket request.</t>
    </section>
    <section anchor="intermediaries-example-e2e-security-det">
      <name>Example with a Proxy and with Deterministic Requests</name>
      <t>This section provides an example where a proxy P is used between the clients and the server, and Group OSCORE is used to protect multicast notifications end-to-end between the server and the clients.</t>
      <t>In addition, the phantom request is especially a Deterministic Request (see <xref section="D" sectionFormat="of" target="I-D.ietf-core-observe-multicast-notifications"/>), which is protected with the pairwise mode of Group OSCORE as defined in <xref target="I-D.ietf-core-cacheable-oscore"/>.</t>
      <t>Since the server replies to such a Deterministic Request with an informative response that is not protected (see <xref section="D" sectionFormat="of" target="I-D.ietf-core-observe-multicast-notifications"/>), the proxy is able to retrieve from the informative response everything needed to set itself as an observer in the group observation and to start listening to multicast notifications.</t>
      <t>In particular, each client sends the Deterministic Request to the proxy as a ticket request (see <xref target="intermediaries-e2e-security"/>). However, differently from what is defined in <xref target="intermediaries-e2e-security"/> where the ticket request is not a Deterministic Request, the clients do not include a Listen-to-Multicast-Responses Option. This results in the proxy forwarding the ticket request (i.e., the phantom observation request) to the server and obtaining the information required to listen to multicast notifications, unless the proxy has already set itself to do so. Also, the proxy will be able to serve multicast notifications from its cache as per <xref target="I-D.ietf-core-cacheable-oscore"/>.</t>
      <t><xref section="D" sectionFormat="of" target="I-D.ietf-core-observe-multicast-notifications"/> discusses how, when using a Deterministic Request as a phantom observation request, the observer counter at the server (see <xref section="4" sectionFormat="of" target="I-D.ietf-core-observe-multicast-notifications"/>) is not reliably incremented when new clients start participating in the group observation. The same applies also if a proxy is deployed.</t>
      <t>That is, the origin server increments its observer counter after having sent the informative response to the proxy, as a reply to the Deterministic Request forwarded to the origin server on behalf of the first origin client that contacted the proxy. After that, the same Deterministic Request sent by any origin client will not be forwarded to the origin server, but will instead produce a cache hit at the proxy that will serve the client accordingly. Hence, the observer counter at the server is not further incremented as additional, new origin clients start participating in the group observation through the proxy.</t>
      <t>Also in this case, the security identity associated with the sender of any Deterministic Request in the OSCORE group is exactly the same one, i.e., the pair (SID, OSCORE ID Context), where SID is the OSCORE Sender ID of the Deterministic Client in the OSCORE group, which all the clients in the group rely on to produce Deterministic Requests.</t>
      <section anchor="intermediaries-example-e2e-security-det-intro">
        <name>Assumptions and Walkthrough</name>
        <t>The example provided in this appendix as reflected by the message exchange shown in <xref target="intermediaries-example-e2e-security-det-exchange"/> assumes the following.</t>
        <ol spacing="normal" type="1"><li>
            <t>The OSCORE group supports Deterministic Requests. Thus, the server creates the phantom request as a Deterministic Request <xref target="I-D.ietf-core-cacheable-oscore"/>, stores it locally as one of its issued phantom requests, and starts the corresponding group observation.</t>
          </li>
          <li>
            <t>The server makes the phantom request available through other means (e.g., a pub-sub broker), together with the transport-specific information for listening to multicast notifications bound to the phantom request (see <xref section="A" sectionFormat="of" target="I-D.ietf-core-observe-multicast-notifications"/>).</t>
          </li>
          <li>
            <t>Since the phantom request is a Deterministic Request, the server can more efficiently make it available in its smaller, plain version. The clients can obtain it from the particular alternative source and protect it as per <xref section="3" sectionFormat="of" target="I-D.ietf-core-cacheable-oscore"/>, thus all computing the same Deterministic Request to be used as phantom observation request.</t>
          </li>
          <li>
            <t>If a client does not rely on a proxy between itself and the server, it simply sets the group observation and starts listening to multicast notifications. Building on Step 2 above, the same would happen if the phantom request was not specifically a Deterministic Request.</t>
          </li>
          <li>
            <t>If a client relies on a proxy between itself and the server, it uses the phantom request as a ticket request (see <xref target="intermediaries-e2e-security"/>). However, unlike for the case in <xref target="intermediaries-e2e-security"/> where the ticket request is not a Deterministic Request, the client does not include a Listen-to-Multicast-Responses Option in the phantom request sent to the proxy.</t>
          </li>
          <li>
            <t>Unlike for the case in <xref target="intermediaries-e2e-security"/>, the proxy does not know that the request is exactly a ticket request for subscribing to multicast notifications. Thus, the proxy simply forwards the ticket request to the server like it normally would.</t>
          </li>
          <li>
            <t>The server receives the ticket request, which is a deviation from the case where the ticket request is not a Deterministic Request and stops at the proxy (see <xref target="intermediaries-e2e-security"/>). Then, the server recognizes the phantom request among the stored ones, through a byte-by-byte comparison of the incoming message minus the transport-related fields (see <xref section="D" sectionFormat="of" target="I-D.ietf-core-observe-multicast-notifications"/>). Consequently, the server does not perform any Group OSCORE processing on it.</t>
          </li>
          <li>
            <t>The server replies with an unprotected informative response (see <xref section="4.2" sectionFormat="of" target="I-D.ietf-core-observe-multicast-notifications"/>), including: the transport-specific information, (optionally) the phantom request, and (optionally) the latest notification.  </t>
            <t>
Note that the phantom request can be omitted, since it is the deterministic phantom request from the client, and thus "in terms of transport-independent information, identical to the registration request from the client" (see <xref section="4.2" sectionFormat="of" target="I-D.ietf-core-observe-multicast-notifications"/>).</t>
          </li>
          <li>
            <t>From the received informative response, the proxy retrieves everything needed to set itself as an observer in the group observation and it starts listening to multicast notifications. If the informative response includes a latest notification, the proxy caches it and forwards it back to the client. Otherwise, the proxy replies with an empty ACK (if it has not done it already and the request from the client was a Confirmable message).</t>
          </li>
          <li>
            <t>Like for the case with a non-deterministic phantom request in <xref target="intermediaries-e2e-security"/>, the proxy fans out the multicast notifications to the origin clients as they come. Also, as new clients following the first one contact the proxy, the latter does not have to contact the server again as in <xref target="intermediaries-e2e-security"/>, since the deterministic phantom request would produce a cache hit as per <xref target="I-D.ietf-core-cacheable-oscore"/>. Thus, the proxy can serve such clients with the latest fresh multicast notification from its cache.</t>
          </li>
        </ol>
      </section>
      <section anchor="intermediaries-example-e2e-security-det-exchange">
        <name>Message Exchange</name>
        <t>The same assumptions and notation used in <xref section="10" sectionFormat="of" target="I-D.ietf-core-observe-multicast-notifications"/> are used for this example. As a recap of some specific values:</t>
        <ul spacing="normal">
          <li>
            <t>Two clients C1 and C2 register to observe a resource /r at a server S, which has address SRV_ADDR and listens to the port number SRV_PORT. Before the following exchanges occur, no clients are observing the resource /r , which has value "1234".</t>
          </li>
          <li>
            <t>The server S sends multicast notifications to the IP multicast address GRP_ADDR and port number GRP_PORT, and starts the group observation already after creating the deterministic phantom request to early disseminate.</t>
          </li>
          <li>
            <t>S is a member of the OSCORE group with 'kid context' = 0x57ab2e as Group ID. In the OSCORE group, S has 'kid' = 0x05 as Sender ID and SN_5 = 501 (i.e., 0x01f5) as Sender Sequence Number.</t>
          </li>
        </ul>
        <t>In addition:</t>
        <ul spacing="normal">
          <li>
            <t>The proxy has address PRX_ADDR and listens to the port number PRX_PORT.</t>
          </li>
          <li>
            <t>The deterministic client in the OSCORE group has 'kid' = 0x09 as Sender ID.</t>
          </li>
        </ul>
        <t>Unless explicitly indicated, all messages transmitted on the wire are sent over unicast and protected with Group OSCORE end-to-end between a client and the server.</t>
        <figure anchor="example-proxy-oscore-det-request">
          <name>Example of Group Observation with a Proxy and Group OSCORE, where the Phantom Request is a Deterministic Request</name>
          <artset>
            <artwork type="svg"><svg xmlns="http://www.w3.org/2000/svg" version="1.1" height="3664" width="576" viewBox="0 0 576 3664" class="diagram" text-anchor="middle" font-family="monospace" font-size="13px" stroke-linecap="round">
                <path d="M 8,48 L 8,2224" fill="none" stroke="black"/>
                <path d="M 8,2288 L 8,2832" fill="none" stroke="black"/>
                <path d="M 8,2896 L 8,3552" fill="none" stroke="black"/>
                <path d="M 72,48 L 72,680" fill="none" stroke="black"/>
                <path d="M 72,696 L 72,2008" fill="none" stroke="black"/>
                <path d="M 72,2024 L 72,2224" fill="none" stroke="black"/>
                <path d="M 72,2288 L 72,2832" fill="none" stroke="black"/>
                <path d="M 72,2896 L 72,3272" fill="none" stroke="black"/>
                <path d="M 72,3288 L 72,3552" fill="none" stroke="black"/>
                <path d="M 136,48 L 136,2224" fill="none" stroke="black"/>
                <path d="M 136,2288 L 136,2832" fill="none" stroke="black"/>
                <path d="M 136,2896 L 136,3552" fill="none" stroke="black"/>
                <path d="M 216,48 L 216,2224" fill="none" stroke="black"/>
                <path d="M 216,2288 L 216,2832" fill="none" stroke="black"/>
                <path d="M 216,2896 L 216,3552" fill="none" stroke="black"/>
                <path d="M 512,1200 L 512,1208" fill="none" stroke="black"/>
                <path d="M 160,240 L 216,240" fill="none" stroke="black"/>
                <path d="M 160,288 L 208,288" fill="none" stroke="black"/>
                <path d="M 8,688 L 128,688" fill="none" stroke="black"/>
                <path d="M 136,944 L 208,944" fill="none" stroke="black"/>
                <path d="M 144,1648 L 216,1648" fill="none" stroke="black"/>
                <path d="M 16,2016 L 136,2016" fill="none" stroke="black"/>
                <path d="M 72,2336 L 128,2336" fill="none" stroke="black"/>
                <path d="M 80,2624 L 136,2624" fill="none" stroke="black"/>
                <path d="M 144,2976 L 216,2976" fill="none" stroke="black"/>
                <path d="M 16,3280 L 136,3280" fill="none" stroke="black"/>
                <path d="M 80,3424 L 136,3424" fill="none" stroke="black"/>
                <path d="M 148,264 L 160,288" fill="none" stroke="black"/>
                <path d="M 148,264 L 160,240" fill="none" stroke="black"/>
                <polygon class="arrowhead" points="216,944 204,938.4 204,949.6" fill="black" transform="rotate(0,208,944)"/>
                <polygon class="arrowhead" points="216,288 204,282.4 204,293.6" fill="black" transform="rotate(0,208,288)"/>
                <polygon class="arrowhead" points="152,2976 140,2970.4 140,2981.6" fill="black" transform="rotate(180,144,2976)"/>
                <polygon class="arrowhead" points="152,1648 140,1642.4 140,1653.6" fill="black" transform="rotate(180,144,1648)"/>
                <polygon class="arrowhead" points="136,2336 124,2330.4 124,2341.6" fill="black" transform="rotate(0,128,2336)"/>
                <polygon class="arrowhead" points="136,688 124,682.4 124,693.6" fill="black" transform="rotate(0,128,688)"/>
                <polygon class="arrowhead" points="88,3424 76,3418.4 76,3429.6" fill="black" transform="rotate(180,80,3424)"/>
                <polygon class="arrowhead" points="88,2624 76,2618.4 76,2629.6" fill="black" transform="rotate(180,80,2624)"/>
                <polygon class="arrowhead" points="24,3280 12,3274.4 12,3285.6" fill="black" transform="rotate(180,16,3280)"/>
                <polygon class="arrowhead" points="24,2016 12,2010.4 12,2021.6" fill="black" transform="rotate(180,16,2016)"/>
                <g class="text">
                  <text x="12" y="36">C1</text>
                  <text x="76" y="36">C2</text>
                  <text x="136" y="36">P</text>
                  <text x="216" y="36">S</text>
                  <text x="252" y="68">(The</text>
                  <text x="296" y="68">value</text>
                  <text x="332" y="68">of</text>
                  <text x="360" y="68">the</text>
                  <text x="412" y="68">resource</text>
                  <text x="460" y="68">/r</text>
                  <text x="484" y="68">is</text>
                  <text x="528" y="68">"1234")</text>
                  <text x="244" y="100">(S</text>
                  <text x="296" y="100">allocates</text>
                  <text x="352" y="100">the</text>
                  <text x="408" y="100">available</text>
                  <text x="264" y="116">Token</text>
                  <text x="312" y="116">value</text>
                  <text x="356" y="116">0x7b</text>
                  <text x="388" y="116">.)</text>
                  <text x="244" y="148">(S</text>
                  <text x="280" y="148">sends</text>
                  <text x="316" y="148">to</text>
                  <text x="356" y="148">itself</text>
                  <text x="392" y="148">a</text>
                  <text x="432" y="148">phantom</text>
                  <text x="512" y="148">observation</text>
                  <text x="272" y="164">request</text>
                  <text x="332" y="164">PH_REQ</text>
                  <text x="372" y="164">as</text>
                  <text x="412" y="164">coming</text>
                  <text x="460" y="164">from</text>
                  <text x="496" y="164">the</text>
                  <text x="252" y="180">IP</text>
                  <text x="304" y="180">multicast</text>
                  <text x="376" y="180">address</text>
                  <text x="448" y="180">GRP_ADDR.</text>
                  <text x="256" y="196">The</text>
                  <text x="296" y="196">Group</text>
                  <text x="348" y="196">OSCORE</text>
                  <text x="420" y="196">processing</text>
                  <text x="492" y="196">occurs</text>
                  <text x="532" y="196">as</text>
                  <text x="280" y="212">specified</text>
                  <text x="336" y="212">for</text>
                  <text x="360" y="212">a</text>
                  <text x="424" y="212">Deterministic</text>
                  <text x="516" y="212">Request)</text>
                  <text x="260" y="292">Token:</text>
                  <text x="308" y="292">0x7b</text>
                  <text x="184" y="308">FETCH</text>
                  <text x="272" y="308">Uri-Host:</text>
                  <text x="380" y="308">"sensor.example"</text>
                  <text x="268" y="324">Observe:</text>
                  <text x="312" y="324">0</text>
                  <text x="364" y="324">(register)</text>
                  <text x="264" y="340">OSCORE:</text>
                  <text x="340" y="340">[kid:0x09,</text>
                  <text x="416" y="340">Partial</text>
                  <text x="464" y="340">IV:</text>
                  <text x="504" y="340">0x00,</text>
                  <text x="320" y="356">kid</text>
                  <text x="408" y="356">context:0x57ab2e]</text>
                  <text x="288" y="372">Request-Hash:</text>
                  <text x="388" y="372">0x4a086e65</text>
                  <text x="448" y="372">...</text>
                  <text x="260" y="388">&lt;Other</text>
                  <text x="312" y="388">class</text>
                  <text x="352" y="388">U/I</text>
                  <text x="404" y="388">options&gt;</text>
                  <text x="252" y="404">0xff</text>
                  <text x="304" y="420">Encrypted_payload</text>
                  <text x="384" y="420">{</text>
                  <text x="268" y="436">0x01</text>
                  <text x="316" y="436">(GET),</text>
                  <text x="284" y="452">Observe:</text>
                  <text x="328" y="452">0</text>
                  <text x="384" y="452">(register),</text>
                  <text x="288" y="468">Uri-Path:</text>
                  <text x="348" y="468">"r",</text>
                  <text x="276" y="484">&lt;Other</text>
                  <text x="328" y="484">class</text>
                  <text x="360" y="484">E</text>
                  <text x="404" y="484">options&gt;</text>
                  <text x="240" y="500">}</text>
                  <text x="244" y="532">(S</text>
                  <text x="288" y="532">creates</text>
                  <text x="328" y="532">a</text>
                  <text x="360" y="532">group</text>
                  <text x="432" y="532">observation</text>
                  <text x="492" y="532">of</text>
                  <text x="520" y="532">/r)</text>
                  <text x="252" y="564">(The</text>
                  <text x="300" y="564">server</text>
                  <text x="348" y="564">does</text>
                  <text x="384" y="564">not</text>
                  <text x="432" y="564">respond</text>
                  <text x="476" y="564">to</text>
                  <text x="520" y="564">PH_REQ.</text>
                  <text x="256" y="580">The</text>
                  <text x="300" y="580">server</text>
                  <text x="356" y="580">stores</text>
                  <text x="412" y="580">PH_REQ</text>
                  <text x="472" y="580">locally</text>
                  <text x="520" y="580">and</text>
                  <text x="264" y="596">makes</text>
                  <text x="300" y="596">it</text>
                  <text x="352" y="596">available</text>
                  <text x="404" y="596">at</text>
                  <text x="428" y="596">an</text>
                  <text x="476" y="596">external</text>
                  <text x="544" y="596">source)</text>
                  <text x="248" y="644">(C1</text>
                  <text x="296" y="644">obtains</text>
                  <text x="356" y="644">PH_REQ</text>
                  <text x="400" y="644">and</text>
                  <text x="440" y="644">sends</text>
                  <text x="476" y="644">it</text>
                  <text x="500" y="644">to</text>
                  <text x="524" y="644">P)</text>
                  <text x="260" y="692">Token:</text>
                  <text x="308" y="692">0x4a</text>
                  <text x="40" y="708">FETCH</text>
                  <text x="272" y="708">Uri-Host:</text>
                  <text x="380" y="708">"sensor.example"</text>
                  <text x="268" y="724">Observe:</text>
                  <text x="312" y="724">0</text>
                  <text x="364" y="724">(register)</text>
                  <text x="264" y="740">OSCORE:</text>
                  <text x="340" y="740">[kid:0x09,</text>
                  <text x="416" y="740">Partial</text>
                  <text x="464" y="740">IV:</text>
                  <text x="504" y="740">0x00,</text>
                  <text x="320" y="756">kid</text>
                  <text x="408" y="756">context:0x57ab2e]</text>
                  <text x="288" y="772">Proxy-Scheme:</text>
                  <text x="372" y="772">"coap"</text>
                  <text x="288" y="788">Request-Hash:</text>
                  <text x="388" y="788">0x4a086e65</text>
                  <text x="448" y="788">...</text>
                  <text x="260" y="804">&lt;Other</text>
                  <text x="312" y="804">class</text>
                  <text x="352" y="804">U/I</text>
                  <text x="404" y="804">options&gt;</text>
                  <text x="252" y="820">0xff</text>
                  <text x="304" y="836">Encrypted_payload</text>
                  <text x="384" y="836">{</text>
                  <text x="268" y="852">0x01</text>
                  <text x="316" y="852">(GET),</text>
                  <text x="284" y="868">Observe:</text>
                  <text x="328" y="868">0</text>
                  <text x="384" y="868">(register),</text>
                  <text x="288" y="884">Uri-Path:</text>
                  <text x="348" y="884">"r",</text>
                  <text x="276" y="900">&lt;Other</text>
                  <text x="328" y="900">class</text>
                  <text x="360" y="900">E</text>
                  <text x="404" y="900">options&gt;</text>
                  <text x="240" y="916">}</text>
                  <text x="260" y="948">Token:</text>
                  <text x="308" y="948">0x5e</text>
                  <text x="168" y="964">FETCH</text>
                  <text x="272" y="964">Uri-Host:</text>
                  <text x="380" y="964">"sensor.example"</text>
                  <text x="268" y="980">Observe:</text>
                  <text x="312" y="980">0</text>
                  <text x="364" y="980">(register)</text>
                  <text x="264" y="996">OSCORE:</text>
                  <text x="340" y="996">[kid:0x09,</text>
                  <text x="416" y="996">Partial</text>
                  <text x="464" y="996">IV:</text>
                  <text x="504" y="996">0x00,</text>
                  <text x="320" y="1012">kid</text>
                  <text x="408" y="1012">context:0x57ab2e]</text>
                  <text x="288" y="1028">Request-Hash:</text>
                  <text x="388" y="1028">0x4a086e65</text>
                  <text x="448" y="1028">...</text>
                  <text x="260" y="1044">&lt;Other</text>
                  <text x="312" y="1044">class</text>
                  <text x="352" y="1044">U/I</text>
                  <text x="404" y="1044">options&gt;</text>
                  <text x="252" y="1060">0xff</text>
                  <text x="304" y="1076">Encrypted_payload</text>
                  <text x="384" y="1076">{</text>
                  <text x="268" y="1092">0x01</text>
                  <text x="316" y="1092">(GET),</text>
                  <text x="284" y="1108">Observe:</text>
                  <text x="328" y="1108">0</text>
                  <text x="384" y="1108">(register),</text>
                  <text x="288" y="1124">Uri-Path:</text>
                  <text x="348" y="1124">"r",</text>
                  <text x="276" y="1140">&lt;Other</text>
                  <text x="328" y="1140">class</text>
                  <text x="360" y="1140">E</text>
                  <text x="404" y="1140">options&gt;</text>
                  <text x="240" y="1156">}</text>
                  <text x="244" y="1188">(S</text>
                  <text x="300" y="1188">recognizes</text>
                  <text x="372" y="1188">PH_REQ</text>
                  <text x="432" y="1188">through</text>
                  <text x="516" y="1188">byte-by-byte</text>
                  <text x="284" y="1204">comparison</text>
                  <text x="360" y="1204">against</text>
                  <text x="408" y="1204">the</text>
                  <text x="452" y="1204">stored</text>
                  <text x="496" y="1204">one</text>
                  <text x="536" y="1204">and</text>
                  <text x="264" y="1220">skips</text>
                  <text x="304" y="1220">any</text>
                  <text x="344" y="1220">Group</text>
                  <text x="396" y="1220">OSCORE</text>
                  <text x="472" y="1220">processing)</text>
                  <text x="244" y="1268">(S</text>
                  <text x="292" y="1268">prepares</text>
                  <text x="344" y="1268">the</text>
                  <text x="384" y="1268">"last</text>
                  <text x="464" y="1268">notification"</text>
                  <text x="276" y="1284">response</text>
                  <text x="344" y="1284">defined</text>
                  <text x="404" y="1284">below)</text>
                  <text x="252" y="1316">0x45</text>
                  <text x="296" y="1316">(2.05</text>
                  <text x="356" y="1316">Content)</text>
                  <text x="268" y="1332">Observe:</text>
                  <text x="316" y="1332">10</text>
                  <text x="264" y="1348">OSCORE:</text>
                  <text x="340" y="1348">[kid:0x05,</text>
                  <text x="416" y="1348">Partial</text>
                  <text x="492" y="1348">IV:0x01f5]</text>
                  <text x="268" y="1364">Max-Age:</text>
                  <text x="324" y="1364">3000</text>
                  <text x="260" y="1380">&lt;Other</text>
                  <text x="312" y="1380">class</text>
                  <text x="352" y="1380">U/I</text>
                  <text x="404" y="1380">options&gt;</text>
                  <text x="252" y="1396">0xff</text>
                  <text x="304" y="1412">Encrypted_payload</text>
                  <text x="384" y="1412">{</text>
                  <text x="268" y="1428">0x45</text>
                  <text x="312" y="1428">(2.05</text>
                  <text x="376" y="1428">Content),</text>
                  <text x="284" y="1444">Observe:</text>
                  <text x="328" y="1444">-</text>
                  <text x="372" y="1444">(empty),</text>
                  <text x="284" y="1460">Max-Age:</text>
                  <text x="344" y="1460">3000,</text>
                  <text x="284" y="1476">Payload:</text>
                  <text x="348" y="1476">"1234"</text>
                  <text x="240" y="1492">}</text>
                  <text x="308" y="1508">&lt;Countersignature&gt;</text>
                  <text x="244" y="1540">(S</text>
                  <text x="300" y="1540">increments</text>
                  <text x="360" y="1540">the</text>
                  <text x="412" y="1540">observer</text>
                  <text x="480" y="1540">counter</text>
                  <text x="248" y="1556">for</text>
                  <text x="280" y="1556">the</text>
                  <text x="320" y="1556">group</text>
                  <text x="392" y="1556">observation</text>
                  <text x="452" y="1556">of</text>
                  <text x="480" y="1556">/r)</text>
                  <text x="244" y="1588">(S</text>
                  <text x="292" y="1588">responds</text>
                  <text x="340" y="1588">to</text>
                  <text x="368" y="1588">the</text>
                  <text x="408" y="1588">proxy</text>
                  <text x="452" y="1588">with</text>
                  <text x="484" y="1588">an</text>
                  <text x="288" y="1604">unprotected</text>
                  <text x="384" y="1604">informative</text>
                  <text x="472" y="1604">response)</text>
                  <text x="176" y="1636">(#)</text>
                  <text x="260" y="1652">Token:</text>
                  <text x="308" y="1652">0x5e</text>
                  <text x="164" y="1668">5.03</text>
                  <text x="296" y="1668">Content-Format:</text>
                  <text x="412" y="1668">application/</text>
                  <text x="352" y="1684">informative-response+cbor</text>
                  <text x="268" y="1700">Max-Age:</text>
                  <text x="312" y="1700">0</text>
                  <text x="252" y="1716">0xff</text>
                  <text x="264" y="1732">Payload</text>
                  <text x="304" y="1732">{</text>
                  <text x="256" y="1748">/</text>
                  <text x="296" y="1748">tp_info</text>
                  <text x="336" y="1748">/</text>
                  <text x="376" y="1748">0</text>
                  <text x="392" y="1748">:</text>
                  <text x="408" y="1748">[</text>
                  <text x="432" y="1764">cri'coap://SRV_ADDR:SRV_PORT/',</text>
                  <text x="448" y="1780">cri'coap://GRP_ADDR:GRP_PORT/',</text>
                  <text x="364" y="1796">0x7b],</text>
                  <text x="256" y="1812">/</text>
                  <text x="308" y="1812">last_notif</text>
                  <text x="360" y="1812">/</text>
                  <text x="376" y="1812">2</text>
                  <text x="392" y="1812">:</text>
                  <text x="424" y="1812">&lt;this</text>
                  <text x="480" y="1812">conveys</text>
                  <text x="384" y="1828">the</text>
                  <text x="424" y="1828">"last</text>
                  <text x="504" y="1828">notification"</text>
                  <text x="404" y="1844">response</text>
                  <text x="476" y="1844">prepared</text>
                  <text x="540" y="1844">above&gt;</text>
                  <text x="240" y="1860">}</text>
                  <text x="244" y="1892">(P</text>
                  <text x="292" y="1892">extracts</text>
                  <text x="356" y="1892">PH_REQ</text>
                  <text x="400" y="1892">and</text>
                  <text x="444" y="1892">starts</text>
                  <text x="512" y="1892">listening</text>
                  <text x="252" y="1908">to</text>
                  <text x="304" y="1908">multicast</text>
                  <text x="400" y="1908">notifications</text>
                  <text x="476" y="1908">with</text>
                  <text x="520" y="1908">Token</text>
                  <text x="260" y="1924">0x7b</text>
                  <text x="292" y="1924">at</text>
                  <text x="380" y="1924">GRP_ADDR:GRP_PORT)</text>
                  <text x="244" y="1956">(P</text>
                  <text x="292" y="1956">extracts</text>
                  <text x="344" y="1956">the</text>
                  <text x="384" y="1956">"last</text>
                  <text x="464" y="1956">notification"</text>
                  <text x="280" y="1972">response,</text>
                  <text x="348" y="1972">caches</text>
                  <text x="392" y="1972">it,</text>
                  <text x="424" y="1972">and</text>
                  <text x="476" y="1972">forwards</text>
                  <text x="252" y="1988">it</text>
                  <text x="284" y="1988">back</text>
                  <text x="316" y="1988">to</text>
                  <text x="344" y="1988">C1)</text>
                  <text x="260" y="2020">Token:</text>
                  <text x="308" y="2020">0x4a</text>
                  <text x="36" y="2036">2.05</text>
                  <text x="268" y="2036">Observe:</text>
                  <text x="328" y="2036">54120</text>
                  <text x="264" y="2052">OSCORE:</text>
                  <text x="340" y="2052">[kid:0x05,</text>
                  <text x="416" y="2052">Partial</text>
                  <text x="492" y="2052">IV:0x01f5]</text>
                  <text x="268" y="2068">Max-Age:</text>
                  <text x="324" y="2068">2995</text>
                  <text x="260" y="2084">&lt;Other</text>
                  <text x="312" y="2084">class</text>
                  <text x="352" y="2084">U/I</text>
                  <text x="404" y="2084">options&gt;</text>
                  <text x="252" y="2100">0xff</text>
                  <text x="304" y="2116">Encrypted_payload</text>
                  <text x="384" y="2116">{</text>
                  <text x="268" y="2132">0x45</text>
                  <text x="312" y="2132">(2.05</text>
                  <text x="376" y="2132">Content),</text>
                  <text x="284" y="2148">Observe:</text>
                  <text x="328" y="2148">-</text>
                  <text x="372" y="2148">(empty),</text>
                  <text x="284" y="2164">Max-Age:</text>
                  <text x="344" y="2164">3000,</text>
                  <text x="284" y="2180">Payload:</text>
                  <text x="348" y="2180">"1234"</text>
                  <text x="240" y="2196">}</text>
                  <text x="308" y="2212">&lt;Countersignature&gt;</text>
                  <text x="16" y="2260">...</text>
                  <text x="72" y="2260">...</text>
                  <text x="136" y="2260">...</text>
                  <text x="208" y="2260">...</text>
                  <text x="248" y="2308">(C2</text>
                  <text x="296" y="2308">obtains</text>
                  <text x="356" y="2308">PH_REQ</text>
                  <text x="400" y="2308">and</text>
                  <text x="440" y="2308">sends</text>
                  <text x="476" y="2308">it</text>
                  <text x="500" y="2308">to</text>
                  <text x="524" y="2308">P)</text>
                  <text x="260" y="2340">Token:</text>
                  <text x="308" y="2340">0x01</text>
                  <text x="104" y="2356">FETCH</text>
                  <text x="272" y="2356">Uri-Host:</text>
                  <text x="380" y="2356">"sensor.example"</text>
                  <text x="268" y="2372">Observe:</text>
                  <text x="312" y="2372">0</text>
                  <text x="364" y="2372">(register)</text>
                  <text x="264" y="2388">OSCORE:</text>
                  <text x="340" y="2388">[kid:0x09,</text>
                  <text x="416" y="2388">Partial</text>
                  <text x="464" y="2388">IV:</text>
                  <text x="504" y="2388">0x00,</text>
                  <text x="320" y="2404">kid</text>
                  <text x="408" y="2404">context:0x57ab2e]</text>
                  <text x="288" y="2420">Proxy-Scheme:</text>
                  <text x="372" y="2420">"coap"</text>
                  <text x="288" y="2436">Request-Hash:</text>
                  <text x="388" y="2436">0x4a086e65</text>
                  <text x="448" y="2436">...</text>
                  <text x="260" y="2452">&lt;Other</text>
                  <text x="312" y="2452">class</text>
                  <text x="352" y="2452">U/I</text>
                  <text x="404" y="2452">options&gt;</text>
                  <text x="252" y="2468">0xff</text>
                  <text x="304" y="2484">Encrypted_payload</text>
                  <text x="384" y="2484">{</text>
                  <text x="268" y="2500">0x01</text>
                  <text x="316" y="2500">(GET),</text>
                  <text x="284" y="2516">Observe:</text>
                  <text x="328" y="2516">0</text>
                  <text x="384" y="2516">(register),</text>
                  <text x="288" y="2532">Uri-Path:</text>
                  <text x="348" y="2532">"r",</text>
                  <text x="276" y="2548">&lt;Other</text>
                  <text x="328" y="2548">class</text>
                  <text x="360" y="2548">E</text>
                  <text x="404" y="2548">options&gt;</text>
                  <text x="240" y="2564">}</text>
                  <text x="244" y="2596">(P</text>
                  <text x="284" y="2596">serves</text>
                  <text x="324" y="2596">C2</text>
                  <text x="356" y="2596">from</text>
                  <text x="388" y="2596">it</text>
                  <text x="428" y="2596">cache)</text>
                  <text x="260" y="2628">Token:</text>
                  <text x="308" y="2628">0x01</text>
                  <text x="100" y="2644">2.05</text>
                  <text x="268" y="2644">Observe:</text>
                  <text x="328" y="2644">54120</text>
                  <text x="264" y="2660">OSCORE:</text>
                  <text x="340" y="2660">[kid:0x05,</text>
                  <text x="416" y="2660">Partial</text>
                  <text x="492" y="2660">IV:0x01f5]</text>
                  <text x="268" y="2676">Max-Age:</text>
                  <text x="324" y="2676">1800</text>
                  <text x="260" y="2692">&lt;Other</text>
                  <text x="312" y="2692">class</text>
                  <text x="352" y="2692">U/I</text>
                  <text x="404" y="2692">options&gt;</text>
                  <text x="252" y="2708">0xff</text>
                  <text x="304" y="2724">Encrypted_payload</text>
                  <text x="384" y="2724">{</text>
                  <text x="268" y="2740">0x45</text>
                  <text x="312" y="2740">(2.05</text>
                  <text x="376" y="2740">Content),</text>
                  <text x="284" y="2756">Observe:</text>
                  <text x="328" y="2756">-</text>
                  <text x="372" y="2756">(empty),</text>
                  <text x="284" y="2772">Max-Age:</text>
                  <text x="344" y="2772">3000,</text>
                  <text x="284" y="2788">Payload:</text>
                  <text x="348" y="2788">"1234"</text>
                  <text x="240" y="2804">}</text>
                  <text x="308" y="2820">&lt;Countersignature&gt;</text>
                  <text x="16" y="2868">...</text>
                  <text x="72" y="2868">...</text>
                  <text x="136" y="2868">...</text>
                  <text x="208" y="2868">...</text>
                  <text x="252" y="2916">(The</text>
                  <text x="296" y="2916">value</text>
                  <text x="332" y="2916">of</text>
                  <text x="360" y="2916">the</text>
                  <text x="412" y="2916">resource</text>
                  <text x="252" y="2932">/r</text>
                  <text x="296" y="2932">changes</text>
                  <text x="340" y="2932">to</text>
                  <text x="388" y="2932">"5678".)</text>
                  <text x="180" y="2964">(##)</text>
                  <text x="260" y="2980">Token:</text>
                  <text x="308" y="2980">0x7b</text>
                  <text x="164" y="2996">2.05</text>
                  <text x="268" y="2996">Observe:</text>
                  <text x="316" y="2996">11</text>
                  <text x="264" y="3012">OSCORE:</text>
                  <text x="340" y="3012">[kid:0x05,</text>
                  <text x="416" y="3012">Partial</text>
                  <text x="492" y="3012">IV:0x01f6]</text>
                  <text x="268" y="3028">Max-Age:</text>
                  <text x="324" y="3028">3000</text>
                  <text x="260" y="3044">&lt;Other</text>
                  <text x="312" y="3044">class</text>
                  <text x="352" y="3044">U/I</text>
                  <text x="404" y="3044">options&gt;</text>
                  <text x="252" y="3060">0xff</text>
                  <text x="304" y="3076">Encrypted_payload</text>
                  <text x="384" y="3076">{</text>
                  <text x="268" y="3092">0x45</text>
                  <text x="312" y="3092">(2.05</text>
                  <text x="376" y="3092">Content),</text>
                  <text x="284" y="3108">Observe:</text>
                  <text x="328" y="3108">-</text>
                  <text x="372" y="3108">(empty),</text>
                  <text x="284" y="3124">Max-Age:</text>
                  <text x="344" y="3124">3000,</text>
                  <text x="276" y="3140">&lt;Other</text>
                  <text x="328" y="3140">class</text>
                  <text x="360" y="3140">E</text>
                  <text x="408" y="3140">options&gt;,</text>
                  <text x="272" y="3156">0xff,</text>
                  <text x="284" y="3172">Payload:</text>
                  <text x="348" y="3172">"5678"</text>
                  <text x="240" y="3188">}</text>
                  <text x="308" y="3204">&lt;Countersignature&gt;</text>
                  <text x="244" y="3236">(P</text>
                  <text x="288" y="3236">updates</text>
                  <text x="336" y="3236">its</text>
                  <text x="376" y="3236">cache</text>
                  <text x="424" y="3236">entry</text>
                  <text x="260" y="3252">with</text>
                  <text x="300" y="3252">this</text>
                  <text x="376" y="3252">notification)</text>
                  <text x="260" y="3284">Token:</text>
                  <text x="308" y="3284">0x4a</text>
                  <text x="36" y="3300">2.05</text>
                  <text x="268" y="3300">Observe:</text>
                  <text x="328" y="3300">54123</text>
                  <text x="264" y="3316">OSCORE:</text>
                  <text x="340" y="3316">[kid:0x05,</text>
                  <text x="416" y="3316">Partial</text>
                  <text x="492" y="3316">IV:0x01f6]</text>
                  <text x="268" y="3332">Max-Age:</text>
                  <text x="324" y="3332">2998</text>
                  <text x="260" y="3348">&lt;Other</text>
                  <text x="312" y="3348">class</text>
                  <text x="352" y="3348">U/I</text>
                  <text x="404" y="3348">options&gt;</text>
                  <text x="252" y="3364">0xff</text>
                  <text x="256" y="3380">(Same</text>
                  <text x="352" y="3380">Encrypted_payload</text>
                  <text x="256" y="3396">and</text>
                  <text x="344" y="3396">Countersignature)</text>
                  <text x="260" y="3428">Token:</text>
                  <text x="308" y="3428">0x01</text>
                  <text x="100" y="3444">2.05</text>
                  <text x="268" y="3444">Observe:</text>
                  <text x="328" y="3444">54123</text>
                  <text x="264" y="3460">OSCORE:</text>
                  <text x="340" y="3460">[kid:0x05,</text>
                  <text x="416" y="3460">Partial</text>
                  <text x="492" y="3460">IV:0x01f6]</text>
                  <text x="268" y="3476">Max-Age:</text>
                  <text x="324" y="3476">2996</text>
                  <text x="260" y="3492">&lt;Other</text>
                  <text x="312" y="3492">class</text>
                  <text x="352" y="3492">U/I</text>
                  <text x="404" y="3492">options&gt;</text>
                  <text x="252" y="3508">0xff</text>
                  <text x="256" y="3524">(Same</text>
                  <text x="352" y="3524">Encrypted_payload</text>
                  <text x="256" y="3540">and</text>
                  <text x="344" y="3540">Countersignature)</text>
                  <text x="16" y="3604">(#)</text>
                  <text x="60" y="3604">Sent</text>
                  <text x="100" y="3604">over</text>
                  <text x="152" y="3604">unicast</text>
                  <text x="200" y="3604">and</text>
                  <text x="268" y="3604">unprotected.</text>
                  <text x="20" y="3636">(##)</text>
                  <text x="60" y="3636">Sent</text>
                  <text x="100" y="3636">over</text>
                  <text x="132" y="3636">IP</text>
                  <text x="184" y="3636">multicast</text>
                  <text x="236" y="3636">to</text>
                  <text x="340" y="3636">GROUP_ADDR:GROUP_PORT,</text>
                  <text x="472" y="3636">protected</text>
                  <text x="84" y="3652">end-to-end</text>
                  <text x="148" y="3652">with</text>
                  <text x="192" y="3652">Group</text>
                  <text x="244" y="3652">OSCORE</text>
                  <text x="304" y="3652">between</text>
                  <text x="352" y="3652">the</text>
                  <text x="396" y="3652">server</text>
                  <text x="440" y="3652">and</text>
                  <text x="472" y="3652">the</text>
                  <text x="524" y="3652">clients.</text>
                </g>
              </svg>
            </artwork>
            <artwork type="ascii-art"><![CDATA[
C1      C2      P         S
|       |       |         |
|       |       |         |  (The value of the resource /r is "1234")
|       |       |         |
|       |       |         |  (S allocates the available
|       |       |         |   Token value 0x7b .)
|       |       |         |
|       |       |         |  (S sends to itself a phantom observation
|       |       |         |   request PH_REQ as coming from the
|       |       |         |   IP multicast address GRP_ADDR.
|       |       |         |   The Group OSCORE processing occurs as
|       |       |         |   specified for a Deterministic Request)
|       |       |         |
|       |       |  .------+
|       |       | /       |
|       |       | \       |
|       |       |  `----->|  Token: 0x7b
|       |       |   FETCH |  Uri-Host: "sensor.example"
|       |       |         |  Observe: 0 (register)
|       |       |         |  OSCORE: [kid:0x09, Partial IV: 0x00,
|       |       |         |           kid context:0x57ab2e]
|       |       |         |  Request-Hash: 0x4a086e65 ...
|       |       |         |  <Other class U/I options>
|       |       |         |  0xff
|       |       |         |  Encrypted_payload {
|       |       |         |    0x01 (GET),
|       |       |         |    Observe: 0 (register),
|       |       |         |    Uri-Path: "r",
|       |       |         |    <Other class E options>
|       |       |         |  }
|       |       |         |
|       |       |         |  (S creates a group observation of /r)
|       |       |         |
|       |       |         |  (The server does not respond to PH_REQ.
|       |       |         |   The server stores PH_REQ locally and
|       |       |         |   makes it available at an external source)
|       |       |         |
|       |       |         |
|       |       |         |  (C1 obtains PH_REQ and sends it to P)
|       |       |         |
|       |       |         |
+-------------->|         |  Token: 0x4a
| FETCH |       |         |  Uri-Host: "sensor.example"
|       |       |         |  Observe: 0 (register)
|       |       |         |  OSCORE: [kid:0x09, Partial IV: 0x00,
|       |       |         |           kid context:0x57ab2e]
|       |       |         |  Proxy-Scheme: "coap"
|       |       |         |  Request-Hash: 0x4a086e65 ...
|       |       |         |  <Other class U/I options>
|       |       |         |  0xff
|       |       |         |  Encrypted_payload {
|       |       |         |    0x01 (GET),
|       |       |         |    Observe: 0 (register),
|       |       |         |    Uri-Path: "r",
|       |       |         |    <Other class E options>
|       |       |         |  }
|       |       |         |
|       |       +-------->|  Token: 0x5e
|       |       | FETCH   |  Uri-Host: "sensor.example"
|       |       |         |  Observe: 0 (register)
|       |       |         |  OSCORE: [kid:0x09, Partial IV: 0x00,
|       |       |         |           kid context:0x57ab2e]
|       |       |         |  Request-Hash: 0x4a086e65 ...
|       |       |         |  <Other class U/I options>
|       |       |         |  0xff
|       |       |         |  Encrypted_payload {
|       |       |         |    0x01 (GET),
|       |       |         |    Observe: 0 (register),
|       |       |         |    Uri-Path: "r",
|       |       |         |    <Other class E options>
|       |       |         |  }
|       |       |         |
|       |       |         |  (S recognizes PH_REQ through byte-by-byte
|       |       |         |   comparison against the stored one, and
|       |       |         |   skips any Group OSCORE processing)
|       |       |         |
|       |       |         |
|       |       |         |  (S prepares the "last notification"
|       |       |         |   response defined below)
|       |       |         |
|       |       |         |  0x45 (2.05 Content)
|       |       |         |  Observe: 10
|       |       |         |  OSCORE: [kid:0x05, Partial IV:0x01f5]
|       |       |         |  Max-Age: 3000
|       |       |         |  <Other class U/I options>
|       |       |         |  0xff
|       |       |         |  Encrypted_payload {
|       |       |         |    0x45 (2.05 Content),
|       |       |         |    Observe: - (empty),
|       |       |         |    Max-Age: 3000,
|       |       |         |    Payload: "1234"
|       |       |         |  }
|       |       |         |  <Countersignature>
|       |       |         |
|       |       |         |  (S increments the observer counter
|       |       |         |  for the group observation of /r)
|       |       |         |
|       |       |         |  (S responds to the proxy with an
|       |       |         |   unprotected informative response)
|       |       |         |
|       |       |   (#)   |
|       |       |<--------+  Token: 0x5e
|       |       | 5.03    |  Content-Format: application/
|       |       |         |    informative-response+cbor
|       |       |         |  Max-Age: 0
|       |       |         |  0xff
|       |       |         |  Payload {
|       |       |         |    / tp_info /    0 : [
|       |       |         |           cri'coap://SRV_ADDR:SRV_PORT/',
|       |       |         |             cri'coap://GRP_ADDR:GRP_PORT/',
|       |       |         |               0x7b],
|       |       |         |    / last_notif / 2 : <this conveys
|       |       |         |                   the "last notification"
|       |       |         |                   response prepared above>
|       |       |         |  }
|       |       |         |
|       |       |         |  (P extracts PH_REQ and starts listening
|       |       |         |   to multicast notifications with Token
|       |       |         |   0x7b at GRP_ADDR:GRP_PORT)
|       |       |         |
|       |       |         |  (P extracts the "last notification"
|       |       |         |   response, caches it, and forwards
|       |       |         |   it back to C1)
|       |       |         |
|<--------------+         |  Token: 0x4a
| 2.05  |       |         |  Observe: 54120
|       |       |         |  OSCORE: [kid:0x05, Partial IV:0x01f5]
|       |       |         |  Max-Age: 2995
|       |       |         |  <Other class U/I options>
|       |       |         |  0xff
|       |       |         |  Encrypted_payload {
|       |       |         |    0x45 (2.05 Content),
|       |       |         |    Observe: - (empty),
|       |       |         |    Max-Age: 3000,
|       |       |         |    Payload: "1234"
|       |       |         |  }
|       |       |         |  <Countersignature>
|       |       |         |

...    ...     ...      ...

|       |       |         |
|       |       |         |  (C2 obtains PH_REQ and sends it to P)
|       |       |         |
|       +------>|         |  Token: 0x01
|       | FETCH |         |  Uri-Host: "sensor.example"
|       |       |         |  Observe: 0 (register)
|       |       |         |  OSCORE: [kid:0x09, Partial IV: 0x00,
|       |       |         |           kid context:0x57ab2e]
|       |       |         |  Proxy-Scheme: "coap"
|       |       |         |  Request-Hash: 0x4a086e65 ...
|       |       |         |  <Other class U/I options>
|       |       |         |  0xff
|       |       |         |  Encrypted_payload {
|       |       |         |    0x01 (GET),
|       |       |         |    Observe: 0 (register),
|       |       |         |    Uri-Path: "r",
|       |       |         |    <Other class E options>
|       |       |         |  }
|       |       |         |
|       |       |         |  (P serves C2 from it cache)
|       |       |         |
|       |<------+         |  Token: 0x01
|       | 2.05  |         |  Observe: 54120
|       |       |         |  OSCORE: [kid:0x05, Partial IV:0x01f5]
|       |       |         |  Max-Age: 1800
|       |       |         |  <Other class U/I options>
|       |       |         |  0xff
|       |       |         |  Encrypted_payload {
|       |       |         |    0x45 (2.05 Content),
|       |       |         |    Observe: - (empty),
|       |       |         |    Max-Age: 3000,
|       |       |         |    Payload: "1234"
|       |       |         |  }
|       |       |         |  <Countersignature>
|       |       |         |

...    ...     ...      ...

|       |       |         |
|       |       |         |  (The value of the resource
|       |       |         |   /r changes to "5678".)
|       |       |         |
|       |       |   (##)  |
|       |       |<--------+  Token: 0x7b
|       |       | 2.05    |  Observe: 11
|       |       |         |  OSCORE: [kid:0x05, Partial IV:0x01f6]
|       |       |         |  Max-Age: 3000
|       |       |         |  <Other class U/I options>
|       |       |         |  0xff
|       |       |         |  Encrypted_payload {
|       |       |         |    0x45 (2.05 Content),
|       |       |         |    Observe: - (empty),
|       |       |         |    Max-Age: 3000,
|       |       |         |    <Other class E options>,
|       |       |         |    0xff,
|       |       |         |    Payload: "5678"
|       |       |         |  }
|       |       |         |  <Countersignature>
|       |       |         |
|       |       |         |  (P updates its cache entry
|       |       |         |   with this notification)
|       |       |         |
|<--------------+         |  Token: 0x4a
| 2.05  |       |         |  Observe: 54123
|       |       |         |  OSCORE: [kid:0x05, Partial IV:0x01f6]
|       |       |         |  Max-Age: 2998
|       |       |         |  <Other class U/I options>
|       |       |         |  0xff
|       |       |         |  (Same Encrypted_payload
|       |       |         |   and Countersignature)
|       |       |         |
|       |<------+         |  Token: 0x01
|       | 2.05  |         |  Observe: 54123
|       |       |         |  OSCORE: [kid:0x05, Partial IV:0x01f6]
|       |       |         |  Max-Age: 2996
|       |       |         |  <Other class U/I options>
|       |       |         |  0xff
|       |       |         |  (Same Encrypted_payload
|       |       |         |   and Countersignature)
|       |       |         |


(#)  Sent over unicast and unprotected.

(##) Sent over IP multicast to GROUP_ADDR:GROUP_PORT, protected
     end-to-end with Group OSCORE between the server and the clients.
]]></artwork>
          </artset>
        </figure>
      </section>
    </section>
    <section anchor="intermediaries-example-e2e-security-det-rev-proxy">
      <name>Example with a Reverse-Proxy and with Deterministic Requests</name>
      <t>This section describes an example where specifically a reverse-proxy PRX is used between the clients and the server (see <xref section="5.7.3" sectionFormat="of" target="RFC7252"/>).</t>
      <t>Like for the example in <xref target="intermediaries-example-e2e-security-det"/>, the phantom request is especially a Deterministic Request (see <xref section="D" sectionFormat="of" target="I-D.ietf-core-observe-multicast-notifications"/>), which is protected with the pairwise mode of Group OSCORE as defined in <xref target="I-D.ietf-core-cacheable-oscore"/>.</t>
      <t>The same assumptions compiled in <xref target="intermediaries-example-e2e-security-det-intro"/> apply in this scenario too, with the following differences:</t>
      <ul spacing="normal">
        <li>
          <t>Assumption (2): when the server makes the phantom request available through other means (see <xref section="A" sectionFormat="of" target="I-D.ietf-core-observe-multicast-notifications"/>), the accompanying group observation data does <em>not</em> specify client-side, transport-specific information for listening to multicast notifications bound to the phantom request.</t>
        </li>
        <li>
          <t>Assumption (4): this assumption does not apply, since all the clients rely on PRX, although they are not aware to communicate with a proxy.</t>
        </li>
      </ul>
      <t>Furthermore, the following assumptions apply to this scenario:</t>
      <ul spacing="normal">
        <li>
          <t>The proxy has address PRX_ADDR and listens to the port number PRX_PORT. In particular, PRX exposes PRX_ADDR and PRX_PORT to clients when acting as stand-in for the server.  </t>
          <t>
That is, a request sent with destination address PRX_ADDR and port number PRX_PORT will reach PRX, which forwards the request to the server.</t>
        </li>
        <li>
          <t>The server knows the address PRX_ADDR and port number PRX_PORT that PRX exposes to clients.</t>
        </li>
        <li>
          <t>When the server makes the phantom request available through other means (see <xref section="A" sectionFormat="of" target="I-D.ietf-core-observe-multicast-notifications"/>), the accompanying group observation data is such that:  </t>
          <ul spacing="normal">
            <li>
              <t>It provides server-side, transport-specific information, which consists of the address PRX_ADDR and port number PRX_PORT associated with PRX.</t>
            </li>
            <li>
              <t>It does not provide any client-side, transport-specific information.</t>
            </li>
          </ul>
          <t>
Assuming that the group information data has a format consistent with the 'tp_info' array of the informative response (see <xref section="4.2.1" sectionFormat="of" target="I-D.ietf-core-observe-multicast-notifications"/>), this means that the 'tp_info' array includes only the 'tpi_server' element specifying a CRI with addressing information PRX_ADDR and PRX_PORT (i.e., targeting PRX). That is, 'tp_info' does not include the 'tpi_details' element, regardless of what is expected as per the transport used.</t>
        </li>
      </ul>
      <section anchor="rev-proxy-main-process">
        <name>Taking Part in Group Observations</name>
        <t>The rest of this section describes how a client can take part in a group observation.</t>
        <t>If any of the following conditions does not hold, then the client first performs the initialization procedure described in <xref target="rev-proxy-client-pre-steps"/>.</t>
        <ul spacing="normal">
          <li>
            <t>The client has already obtained the group observation data specifying the deterministic phantom request, which the server has made available through other means (see <xref section="A" sectionFormat="of" target="I-D.ietf-core-observe-multicast-notifications"/>).</t>
          </li>
          <li>
            <t>The client is already a member of the correct OSCORE group.</t>
          </li>
        </ul>
        <t>The main process consists of the following steps.</t>
        <ol spacing="normal" type="1"><li>
            <t>From the group observation data, the client knows the deterministic phantom request PH_REQ, the address PRX_ADDR, and the port number PRX_PORT, but no client-side, transport-specific information.  </t>
            <t>
In such a particular situation, the client sends PH_REQ with destination address PRX_ADDR and port number PRX_PORT, i.e., to PRX.</t>
          </li>
          <li>
            <t>Upon receiving PH_REQ, PRX performs the same actions that are performed by the proxy in the scenario of <xref target="intermediaries-example-e2e-security-det"/>.  </t>
            <t>
That is, if PH_REQ results in a cache hit at PRX, then PRX replies to the client with the latest multicast notification for the target resource from its cache and takes no further actions.  </t>
            <t>
Otherwise, PRX forwards PH_REQ to the server. After recognizing PH_REQ byte-by-byte, the server replies to PRX with an unprotected informative response, where 'tp_info' also includes the 'tpi_details' element, specifying the information to receive multicast notifications for the target resource. Based on such information, PRX starts listening to multicast notifications. If the informative response includes a latest notification, then PRX caches that notification and forwards it to the client.</t>
          </li>
        </ol>
        <t>Editor's note: add a figure showing an example of message exchange.</t>
        <section anchor="rev-proxy-client-pre-steps">
          <name>Client Initialization Procedure</name>
          <t>The following early initialization procedure is performed by a client that does not have the group observation data and/or is not a member of the correct OSCORE group, before starting the main process described in <xref target="rev-proxy-main-process"/>.</t>
          <t>The client is minimally provided with the pair (PRX_ADDR, PRX_PORT) associated with PRX, which the client believes to be associated with the origin server.</t>
          <t>a. The client sends a traditional Observe registration request with destination address PRX_ADDR and port number PRX_PORT, i.e., to PRX. The request is protected with (Group) OSCORE, i.e., end-to-end between the client and the server.</t>
          <t>b. PRX receives the request and forwards it to the server, as usual.</t>
          <t>c. The server replies with a 5.03 (Service Unavailable) informative response. The response is protected with (Group) OSCORE, i.e., end-to-end between the client and the server. The payload of the response specifies the following parameters:</t>
          <ul spacing="normal">
            <li>
              <t>The 'tp_info' parameter, within which the 'tpi_server' element is a CRI with addressing information PRX_ADDR and PRX_PORT (i.e., targeting PRX). The 'tp_info' parameter does not include the 'tpi_details' element, regardless of what is expected as per the transport used.</t>
            </li>
            <li>
              <t>The 'ph_req' parameter, conveying the deterministic phantom request PH_REQ.</t>
            </li>
            <li>
              <t>Optionally, parameters conveying information that the client can use for joining the OSCORE group if that has not happened yet (see <xref section="9.1" sectionFormat="of" target="I-D.ietf-core-observe-multicast-notifications"/>), as well as the keying material used in the OSCORE group if the server is managing it (see <xref section="C" sectionFormat="of" target="I-D.ietf-core-observe-multicast-notifications"/>).</t>
            </li>
          </ul>
          <t>d. PRX receives the protected informative response and forwards it to the client, as usual.</t>
          <t>e. Upon receiving the protected informative response, the client takes its payload as the group observation data for the group observation of interest.</t>
          <t>Per the instructions specified in the response, the client takes the necessary steps to join the correct OSCORE group, if it is not already a member.</t>
        </section>
      </section>
    </section>
    <section anchor="sec-security-considerations">
      <name>Security Considerations</name>
      <t>In addition to the security considerations from <xref target="I-D.ietf-core-observe-multicast-notifications"/>, the following considerations hold for this document.</t>
      <section anchor="sec-security-considerations-ltmr">
        <name>Listen-To-Multicast-Responses Option</name>
        <t>The CoAP option Listen-To-Multicast-Responses defined in <xref target="ltmr-option"/> is of class U for OSCORE and Group OSCORE <xref target="RFC8613"/><xref target="I-D.ietf-core-oscore-groupcomm"/>.</t>
        <t>This allows the proxy adjacent to the origin server to access the option value conveyed in a ticket request (see <xref target="intermediaries-e2e-security-processing"/>) and to retrieve from it the transport-specific information about a phantom request. By doing so, the proxy becomes able to configure an observation of the target resource and to receive multicast notifications that match the phantom request.</t>
        <t>Any proxy in the chain, as well as further possible intermediaries or on-path active adversaries, are thus able to remove the option or alter its content, before the ticket request reaches the proxy adjacent to the origin server.</t>
        <t>Removing the option would result in the proxy adjacent to the origin server to not configure the group observation, if that has not happened yet. In such a case, the proxy would not receive the corresponding multicast notifications to be forwarded back to the clients.</t>
        <t>Altering the option content would result in the proxy adjacent to the origin server incorrectly configuring a group observation (e.g., as based on a wrong multicast IP address), hence preventing the correct reception of multicast notifications and their forwarding to the clients. Alternatively, it would result in the proxy configuring bogus group observations that are currently not active on the origin server.</t>
        <t>In order to prevent what is described above, the ticket requests conveying the Listen-To-Multicast-Responses Option can be additionally protected hop-by-hop, e.g., by using OSCORE (see <xref target="I-D.ietf-core-oscore-capable-proxies"/>) and/or DTLS <xref target="RFC9147"/>.</t>
      </section>
    </section>
    <section anchor="iana">
      <name>IANA Considerations</name>
      <t>This document has the following actions for IANA.</t>
      <t>Note to RFC Editor: Please replace all occurrences of "[RFC-XXXX]" with the RFC number of this specification and delete this paragraph.</t>
      <section anchor="iana-coap-options">
        <name>CoAP Option Numbers Registry</name>
        <t>IANA is asked to enter the following option number to the "CoAP Option Numbers" registry <xref target="CoAP.Option.Numbers"/> within the "Constrained RESTful Environments (CoRE) Parameters" registry group.</t>
        <table align="center">
          <name>Registrations in the CoAP Option Numbers Registry</name>
          <thead>
            <tr>
              <th align="left">Number</th>
              <th align="left">Name</th>
              <th align="left">Reference</th>
            </tr>
          </thead>
          <tbody>
            <tr>
              <td align="left">TBD47</td>
              <td align="left">Listen-To-Multicast-Responses</td>
              <td align="left">[RFC-XXXX]</td>
            </tr>
          </tbody>
        </table>
        <t>For the Listen-To-Multicast-Responses Option, the preferred value range is 0-255. In particular, 47 is the preferred option number.</t>
        <t>Note to RFC Editor: In the table above, please replace TBD47 with the registered option number. Then, please delete this paragraph and the previous paragraph.</t>
      </section>
    </section>
  </middle>
  <back>
    <references anchor="sec-combined-references">
      <name>References</name>
      <references anchor="sec-normative-references">
        <name>Normative References</name>
        <reference anchor="I-D.ietf-core-groupcomm-bis">
          <front>
            <title>Group Communication for the Constrained Application Protocol (CoAP)</title>
            <author fullname="Esko Dijk" initials="E." surname="Dijk">
              <organization>IoTconsultancy.nl</organization>
            </author>
            <author fullname="Marco Tiloca" initials="M." surname="Tiloca">
              <organization>RISE AB</organization>
            </author>
            <date day="10" month="February" year="2026"/>
            <abstract>
              <t>   The Constrained Application Protocol (CoAP) is a web transfer
   protocol for constrained devices and constrained networks.  In a
   number of use cases, constrained devices often naturally operate in
   groups (e.g., in a building automation scenario, all lights in a
   given room may need to be switched on/off as a group).  This document
   specifies the use of CoAP for group communication, including the use
   of UDP/IP multicast as the default underlying data transport.  Both
   unsecured and secured CoAP group communication are specified.
   Security is achieved by use of the Group Object Security for
   Constrained RESTful Environments (Group OSCORE) protocol.  The target
   application area of this specification is any group communication use
   cases that involve resource-constrained devices or networks that
   support CoAP.  This document replaces and obsoletes RFC 7390, while
   it updates RFC 7252 and RFC 7641.

              </t>
            </abstract>
          </front>
          <seriesInfo name="Internet-Draft" value="draft-ietf-core-groupcomm-bis-18"/>
        </reference>
        <reference anchor="I-D.ietf-core-oscore-groupcomm">
          <front>
            <title>Group Object Security for Constrained RESTful Environments (Group OSCORE)</title>
            <author fullname="Marco Tiloca" initials="M." surname="Tiloca">
              <organization>RISE AB</organization>
            </author>
            <author fullname="Göran Selander" initials="G." surname="Selander">
              <organization>Ericsson AB</organization>
            </author>
            <author fullname="Francesca Palombini" initials="F." surname="Palombini">
              <organization>Ericsson AB</organization>
            </author>
            <author fullname="John Preuß Mattsson" initials="J. P." surname="Mattsson">
              <organization>Ericsson AB</organization>
            </author>
            <author fullname="Rikard Höglund" initials="R." surname="Höglund">
              <organization>RISE AB</organization>
            </author>
            <date day="23" month="December" year="2025"/>
            <abstract>
              <t>   This document defines the security protocol Group Object Security for
   Constrained RESTful Environments (Group OSCORE), providing end-to-end
   security of messages exchanged with the Constrained Application
   Protocol (CoAP) between members of a group, e.g., sent over IP
   multicast.  In particular, the described protocol defines how OSCORE
   is used in a group communication setting to provide source
   authentication for CoAP group requests, sent by a client to multiple
   servers, and for protection of the corresponding CoAP responses.
   Group OSCORE also defines a pairwise mode where each member of the
   group can efficiently derive a symmetric pairwise key with each other
   member of the group for pairwise OSCORE communication.  Group OSCORE
   can be used between endpoints communicating with CoAP or CoAP-
   mappable HTTP.

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

   This RFC updates RFC 7595 by adding a column on the "URI Schemes"
   registry.


   // (This "cref" paragraph will be removed by the RFC editor:) After
   // approval of -28 and nit fixes in -29, the present revision -30
   // contains two more small fixes for nits that were uncovered in the
   // RPC intake process.

              </t>
            </abstract>
          </front>
          <seriesInfo name="Internet-Draft" value="draft-ietf-core-href-30"/>
        </reference>
        <reference anchor="I-D.ietf-core-observe-multicast-notifications">
          <front>
            <title>Observe Notifications as CoAP Multicast Responses</title>
            <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="Christian Amsüss" initials="C." surname="Amsüss">
         </author>
            <author fullname="Francesca Palombini" initials="F." surname="Palombini">
              <organization>Ericsson AB</organization>
            </author>
            <date day="22" month="April" year="2026"/>
            <abstract>
              <t>   The Constrained Application Protocol (CoAP) allows clients to
   "observe" resources at a server and to receive notifications as
   unicast responses upon changes of the resource state.  In some use
   cases, such as those based on publish-subscribe, it would be
   convenient for the server to send a single notification addressed to
   all the clients observing the same target resource.  This document
   updates RFC7252 and RFC7641, and it defines how a server sends
   observe notifications as response messages over multicast,
   synchronizing all the observers of the same resource on the same
   shared Token value.  Besides, this document defines how the security
   protocol Group Object Security for Constrained RESTful Environments
   (Group OSCORE) can be used to protect multicast notifications end-to-
   end between the server and the observer clients.

              </t>
            </abstract>
          </front>
          <seriesInfo name="Internet-Draft" value="draft-ietf-core-observe-multicast-notifications-14"/>
        </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="RFC8610">
          <front>
            <title>Concise Data Definition Language (CDDL): A Notational Convention to Express Concise Binary Object Representation (CBOR) and JSON Data Structures</title>
            <author fullname="H. Birkholz" initials="H." surname="Birkholz"/>
            <author fullname="C. Vigano" initials="C." surname="Vigano"/>
            <author fullname="C. Bormann" initials="C." surname="Bormann"/>
            <date month="June" year="2019"/>
            <abstract>
              <t>This document proposes a notational convention to express Concise Binary Object Representation (CBOR) data structures (RFC 7049). Its main goal is to provide an easy and unambiguous way to express structures for protocol messages and data formats that use CBOR or JSON.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="8610"/>
          <seriesInfo name="DOI" value="10.17487/RFC8610"/>
        </reference>
        <reference anchor="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="RFC8949">
          <front>
            <title>Concise Binary Object Representation (CBOR)</title>
            <author fullname="C. Bormann" initials="C." surname="Bormann"/>
            <author fullname="P. Hoffman" initials="P." surname="Hoffman"/>
            <date month="December" year="2020"/>
            <abstract>
              <t>The Concise Binary Object Representation (CBOR) is a data format whose design goals include the possibility of extremely small code size, fairly small message size, and extensibility without the need for version negotiation. These design goals make it different from earlier binary serializations such as ASN.1 and MessagePack.</t>
              <t>This document obsoletes RFC 7049, providing editorial improvements, new details, and errata fixes while keeping full compatibility with the interchange format of RFC 7049. It does not create a new version of the format.</t>
            </abstract>
          </front>
          <seriesInfo name="STD" value="94"/>
          <seriesInfo name="RFC" value="8949"/>
          <seriesInfo name="DOI" value="10.17487/RFC8949"/>
        </reference>
        <reference anchor="CoAP.Option.Numbers" target="https://www.iana.org/assignments/core-parameters/core-parameters.xhtml#option-numbers">
          <front>
            <title>CoAP Option Numbers</title>
            <author>
              <organization>IANA</organization>
            </author>
            <date/>
          </front>
        </reference>
        <reference anchor="RFC2119">
          <front>
            <title>Key words for use in RFCs to Indicate Requirement Levels</title>
            <author fullname="S. Bradner" initials="S." surname="Bradner"/>
            <date month="March" year="1997"/>
            <abstract>
              <t>In many standards track documents several words are used to signify the requirements in the specification. These words are often capitalized. This document defines these words as they should be interpreted in IETF documents. This document specifies an Internet Best Current Practices for the Internet Community, and requests discussion and suggestions for improvements.</t>
            </abstract>
          </front>
          <seriesInfo name="BCP" value="14"/>
          <seriesInfo name="RFC" value="2119"/>
          <seriesInfo name="DOI" value="10.17487/RFC2119"/>
        </reference>
        <reference anchor="RFC8174">
          <front>
            <title>Ambiguity of Uppercase vs Lowercase in RFC 2119 Key Words</title>
            <author fullname="B. Leiba" initials="B." surname="Leiba"/>
            <date month="May" year="2017"/>
            <abstract>
              <t>RFC 2119 specifies common key words that may be used in protocol specifications. This document aims to reduce the ambiguity by clarifying that only UPPERCASE usage of the key words have the defined special meanings.</t>
            </abstract>
          </front>
          <seriesInfo name="BCP" value="14"/>
          <seriesInfo name="RFC" value="8174"/>
          <seriesInfo name="DOI" value="10.17487/RFC8174"/>
        </reference>
      </references>
      <references anchor="sec-informative-references">
        <name>Informative References</name>
        <reference anchor="I-D.ietf-core-cacheable-oscore">
          <front>
            <title>End-to-End Protected and Cacheable Responses for the Constrained Application Protocol (CoAP) using Group Object Security for Constrained RESTful Environments (Group OSCORE)</title>
            <author fullname="Christian Amsüss" initials="C." surname="Amsüss">
         </author>
            <author fullname="Marco Tiloca" initials="M." surname="Tiloca">
              <organization>RISE AB</organization>
            </author>
            <date day="2" month="March" year="2026"/>
            <abstract>
              <t>   When using the Constrained Application Protocol (CoAP), exchanged
   messages can be protected end-to-end also across untrusted
   intermediary proxies.  This can be achieved with Object Security for
   Constrained RESTful Environments (OSCORE) or, in the case of group
   communication, with Group Object Security for Constrained RESTful
   Environments (Group OSCORE).  However, this sidesteps the proxies'
   abilities to cache responses from the origin server(s).  This
   document restores cacheability of end-end protected responses at
   proxies, by using Group OSCORE and introducing consensus requests,
   which any client in an OSCORE group can send to one server or
   multiple servers in the same group.

              </t>
            </abstract>
          </front>
          <seriesInfo name="Internet-Draft" value="draft-ietf-core-cacheable-oscore-01"/>
        </reference>
        <reference anchor="I-D.ietf-core-oscore-capable-proxies">
          <front>
            <title>OSCORE-capable Proxies</title>
            <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>
            <date day="2" month="March" year="2026"/>
            <abstract>
              <t>   When using the Constrained Application Protocol (CoAP), messages
   exchanged between two endpoints can be protected end-to-end at the
   application layer by means of Object Security for Constrained RESTful
   Environments (OSCORE), also in the presence of intermediaries such as
   proxies.  This document defines how to use OSCORE for protecting CoAP
   messages also between an origin application endpoint and an
   intermediary, or between two intermediaries.  Also, it defines rules
   to escalate the protection of a CoAP option, in order to encrypt and
   integrity-protect it whenever possible.  Finally, it defines how to
   secure a CoAP message by applying multiple, nested OSCORE
   protections, e.g., both end-to-end between origin application
   endpoints; and between an application endpoint and an intermediary or
   between two intermediaries.  Therefore, this document updates RFC
   8613.  Furthermore, this document updates RFC 8768, by explicitly
   defining the processing with OSCORE for the CoAP Hop-Limit Option.
   The approach defined in this document can be seamlessly employed also
   with Group OSCORE, for protecting CoAP messages when group
   communication is used in the presence of intermediaries.

              </t>
            </abstract>
          </front>
          <seriesInfo name="Internet-Draft" value="draft-ietf-core-oscore-capable-proxies-06"/>
        </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>
      </references>
    </references>
    <?line 1084?>

<section anchor="sec-document-updates" removeInRFC="true">
      <name>Document Updates</name>
      <section anchor="sec-00-01">
        <name>Version -00 to -01</name>
        <ul spacing="normal">
          <li>
            <t>Renamed the Multicast-Response-Feedback-Divider Option as Feedback-Divider.</t>
          </li>
          <li>
            <t>Fixes in the examples of message exchanges.</t>
          </li>
          <li>
            <t>Clarifications and editorial improvements.</t>
          </li>
        </ul>
      </section>
      <section anchor="sec-00">
        <name>Version -00</name>
        <ul spacing="normal">
          <li>
            <t>Imported content about proxies from draft-ietf-core-observe-multicast-notifications-12.</t>
          </li>
        </ul>
      </section>
    </section>
    <section numbered="false" anchor="acknowldegment">
      <name>Acknowledgments</name>
      <t>The authors sincerely thank <contact fullname="Carsten Bormann"/>, <contact fullname="Klaus Hartke"/>, <contact fullname="Jaime Jiménez"/>, <contact fullname="Matthias Kovatsch⁩"/>, <contact fullname="John Preuß Mattsson"/>, <contact fullname="Jim Schaad"/>, <contact fullname="Ludwig Seitz"/>, and <contact fullname="Göran Selander"/> for their comments and feedback.</t>
      <t>The work on this document has been partly supported by the Sweden's Innovation Agency VINNOVA and the Celtic-Next projects CRITISEC and CYPRESS; and by the H2020 project SIFIS-Home (Grant agreement 952652).</t>
    </section>
  </back>
  <!-- ##markdown-source:
H4sIAAAAAAAAA+1923LbSJbgO78iV45YS10kLcmWL5qqnpYluaxpXzSSXNUd
PR0ekEyJKJEABwAlq21txH7J7uv8wDzt0/af7JfsueQVSIDQxS67WoqwJYJA
IvPcz8lzTvZ6vc7ZpnjY6RRxMZGb4l0eJydiP0s/xDIXx2km3g5ymZ1J8SYt
4uN4GBVxmuQiysV2urUvXs8nBVzMC3Eg8xl8I/NONBhkEkYNjWLv98brjNJh
Ek1hAqMsOi56sSyOe8M0k72pfqCXuA/0ZjD4RW8SFTIvOp14lm2KIpvnxfrq
6rPV9U6UyWhT/Lx31Dk/2YSpHuyKn9PsFBf3Y5bOZ53T802xlxQyS2TR28GX
dmDoTREnx2knnw+mcZ7Di4qLGUxqb/foRaczTEfw/KaYw9yedjrRvBin2WZH
0E9P/RYwQr4pXvfFUTxJh5G5zMt7HWXDtPxVmsGoB3uHu2LrubmYF5mUMKG9
PDr+Jc1G+UlURIlYXzd3DOPiYlP8Mc4LOxTMEd5yuNtbe/xIPFp1rs+TIoPb
D8/lSCbmupxG8WRTTHFa/YKm9Ycs7ucyvKyDvnj59/86mcyTUWlhB/FplI2q
3/76a8toZv1xShNrWt12X2xN87//nzwvLW57nMFMYphi+XtcXmVZL9PJJEpG
8LEv1tYfPCqt6qdYJkl5WWur64EVbQFFZ3FUXtJQz+cP0TSfyzzvD9NpeE0v
+mI/mqTTQZzEpVW9yKJkKPNhFLiD0LabxcM8T5MQ6o7SLB9H00Sj7uHnQN2x
nmF/pmf4B6kmRUvuJGk2BYlwJhELe72dvpUcJ8jncNO0N4gBEPQRvolmlTvT
3H9A38zXK7ePM3m8KfD/6kgs5uqkFjAafMHX4NmDF9tP1jfWAZ88K/z8+NHa
plDD8KWnj9dW4ZbRaGI+P4Rb9NzwyrNHz+COQZrBZxTL/bczfF//zXw6kFnO
FOrLK0Lw3tabLfo8AjkK4I4mijWUNiARz2MJNRZ/HWUnSATjopjlmw8enJ+f
94Eaoz6M+iACwXmSTGVS5A8IKLMoA3oDUVv53P8wLqaTeym9oZeoN3RQBtei
dRgNxzIaTDTaYOGlK3X4HUYzumvGeknDUH9mWD5be/QEtFAxyddAK8IikJrh
q8PdVy82xdJf4Jben+Dnr0udTq/XE9EAOCIagg46GksAWIIf40SOxNZsNlGI
R1VYpMN0IpYRpCsimkzS81wMJzGCSRSpWFI4XxKZzNN5BmQvokJEgq5mAuQJ
3pbJoQSwiKSsjecJq9VMq2Exh98gKaLkBD6kx6KA+emxgY0B433QgHkhoxF+
ncsE1Ru8cYSyJRkWZkz3ZTgJCQCHu46PZQbTV6vo2rkOQSBEE9SthMPJBQ2O
38MLJv7kce6RmbWYgjCLTqRIcRzDRV18K8CM1qCBxgDDKePVHEhK0aVZZV/8
PJaJGKV4U552+UY5nGeAVDHTOCGDACyUXySs+VB/jVaLi86D3cOj4/lE7CZn
cZYyfYtl9ezh9tuD3RVa+ECKeS4JWfgGHNOso4Q2AEqvSHsIm4EsziXMlWdo
MQ4fFWFkeuFgWYzjHFY1nOMkxAgEZBYPAMnj9Lz2Xe7U4kSA1XMO9hC8q5jP
gADHQGsTCW9B4EeCrKuukP2TfhdvBx0NE0AkDFFApigvLPXiw2Bw4RsFchje
OIqBVAtA/QSoSRLZ2KkBTI9han1moWkMsk12OvfQIMvS0XxIhHFPfLwX44XL
q/HWx48k5S8vxRhoa4BQlR9gCiN47jwuxrA8ljRI9VOJHBLn0xzXOZzMiQcM
m7DZyu+BcRUqLi8VDmSCy1WmsMPMmTzBVWfMwfStRmpuOD3Ll3AGkXlbl1AO
FAsvHkjixXmRohwcAu1fKISaVSTAn3kKYIgLuGY4qAXbdzo8pflslmYwY9J2
AhFLHK9XazXm5aWmBeLLvX2LSwUJhh28UQ3qGf0MjowHzuR/gMWC/FticUNm
+KgDTImkgp8ABBawueGL3IcicEGOAIkU380mmqNyWPhe4qEf2AE4A6QlvL4Q
sI5hmuCdKLNgNXHG5Dx2JTHKMvP2Epfh1OukkWEBnJGdPAydJkOSxeJEJsCB
ExRUCFOk3kTi6qOJOEdRlhOLTnyC01OpfXGZCrtKtsyRd+UFWmGTEcnXgbRU
piYmBhfAJVGiwKxEeFlgA2iPUp42gKeL5GNNHWDFESwjQZUGD4AZMirBFKUT
4gIFh5zEeCkMYO13WjUXjUbwQUlcA18Fmway3ZqgRogLMzWUnjAETeMz6wnD
XGyBAHw+n7ZA4VmvLvARhZF8JoeM+Tip4O8rVR/37okjmU3jJJ2kJxfiHuqM
wl64JMVxCiR+jl6mWHr97vBoqcu/xZu39PfB7r++2zvY3cG/D19uvXpl/uio
Ow5fvn33asf+ZZ/cfvv69e6bHX4YrgrvUmfp9dafl5jblt7uH+29fbP1agkB
UngowcXDAgG+MUYkZpkkAZZ3NK4I5s+39//v/157BKj5b2CErq+tPQO88Ien
a08ewQcUEfy2NAHQ8Ufk8E40m8kow1GQy8EQjguw9bvITjmQQQJaJ0Me/t1f
EDJ/3RTfD4aztUe/Vxdwwd5FDTPvIsGseqXyMAMxcCnwGgNN73oJ0v58t/7s
fdZwdy5+/88TYFXRW3v6z7/vdDoHYAGTJAY0yA/ABQULE8DHcTSNJzFAjlQu
UlZO8B2iZJwB8XoYIslkzI9uUK+yuOD7fAWrtaVrZ3RRtAxjEEk74GaLHRRV
MY3zChT8HLlteXtn5xVbPWBGuY88j5Mou9AC60ACXYHuKngey9vP3x7wY+A3
8vuvI9gckaaFWVe40q4q7JhEvaG1ptoboccFQgjQsbx9sJfTwOhqg83lYwro
N70ZukoyrivAMQUJM59EGXIPDQHig4dZgrmOCPSgflNrFiLjM55LF2dggoH1
pu0dLQYc39YosSWUZOJlfDLuvQIhOhFvz9CzkeeocrfOonhCYvGnKAMnG1aB
Ug7UU+9MXQAD+fk8npDpCqg9R4EK8qVJoHdLIggglMcE25JoP0fJIJSLTIAf
ydkkvZCg5M/HMTiCqPI1GuJjsZynYIKkxyues8agjWewcJhkzKqrAjejBpSr
jmhtUgBoM+VzmANPtqtVj1Ufyl/Oa7XqcQY4KunRTE6iC7KNpmIQDU/x5c5i
SKUCVACRYLMTnSAmkXngxgWAjpWLw5aLJiiNSbJ3kULQaqvCB6wWNKFAooCN
Q8PRC4FlCXoPkV4qbyc6K9gVQKpQNwOgzmK02EGzpw69ETwDU9PoZr8fNQe8
G6gDXpABAbDHMdL2IJOKMmngco3xUrZWjBnDl1EjabJnQDN68S78mM4Ld2Rj
svXEaz2NmcwKEDIUJkgXUN3C6dbMkl2gQZTHQ/ImkCXYqlSsR2p9KkcgmoCL
0H3cQqc0QjTizQoXwbt76j4SgI3QuC1QXBMMXfQU5rkJyNTZzzVagZjZSuCu
96ZcYtCwQLdMwYq+5vUbSZ0OCtYnJdnbZV+HvHU9PX7UiaiRJdxOSCiEt0B1
T67LnobE9fBeHqKD4U12632hCliapTFCi5HggZu0pfbNCbKsEpHjdySbzBj2
G4ptAjkZBqW4qhYn5GNGozOAMdEVCiIAk15GvTQy7jFBTjOwltlgowJ6l3Mp
nUF2KoOsEKFoAaXEq4qn4vjgYaZoyOmoAesGolUlWUlwqshIhQOIijMJElpT
SjTFTQoOFnFwUks75gB6d4Ws4P24BBX9RLvOslUjmcVFzhHtGxNLbySLnp4r
Uc49sO4QGMQxentWxdlcAaV8Rq0qtCFhXUbAVZZiFFjZlCXc5+IRgWajSgJo
W+QczNCIj3P2K9tIWgf1rH+Cpo6mno3+E5qBigfiYM6X9JVjauN7jlONTSRH
WDJAbUvNRkV+EEFpFp/EJUtQSxstXGlxfcOreqnk5U4ysGRtOIujLY4VwoyC
1/xQTtcZC+45j9CrtYo0OA8tnTmwqF9JZliRy8kxReATo4rNjNVUxurr5ITC
6FWVoZm6HHWCyyPACpoYMJMcvsaAkuy6g1uz064LLYuIdupRvjXYimSpEZI8
kJvwaMjUFr54edRfr5AoYPzdjMCIioFIITyWiwzQrXgDBagsMRp5x/QDS6nQ
n2+tGVUGQ8zRk0EFSoSwhKCag5Q+WaIbJpWNmWUwvhU7rqiI3SydgS4tPOF0
X4sXCoa6CtdT32bBBIkCxMIZLkgrwkXwgNkexyfzTDq0xYMpwRuIURIdE2PZ
OOWQJk97RAqIxrRvQyTIvWwxw/yAKxKfhdi3MOTjBgh1XJHIjLSmihrHyQgh
jvLqwuOvuC/7XSQEugrOq3VdHZKAhyLgCz2GnBh1dL+Yxe9BZIO7l98nSlCr
gi/eI7zvC7Nz2tUrDuGhYkmRtAWfKclxIQg0ikBQUPTdzn7XTFgHwC/s6vQE
aXaMgvtlJQ1c1F/rrwVUdafzYp6hhzAlX6lO8Z3Hk4mAVQwV8fvmG8iO1BGR
KrgI5rbEQBddO0pPYYln0WQuvwVYu9P1tFcI6AXefCWYH+nAX1k4lTQc62py
K5TMv49i5T0NdV/AjCYjrbKUZHGHLQlfxZ9a+u5OZyC7toanSXo+kaMTXhEK
Kan3rNRqtVmFuVZaPDQpWI6kxK5eRSXlKtYRKBqRpyuL1xZc1wCjKbmSs5hh
VkO5FED1zP964Y5Og4+WIPxIDCvVjkji+MOiicA6aaubyXKkXLyS5NXsREI8
Mu9zNC86CSD3VExeIXSZoA1GD1Htip4uyk5cJH7j2DF2Y6vGLuiKRH4wxkk6
GZm9nkiTY1n91iy67JYFjaO4YBA6HqTOYCgFH5hHVc5DH/MT1c4fjuq/lwdH
ClbRIYAmO9d6LCRI4yu57N6CvtHOLJg5LBY8o7LT8WdX0bllk7BZ6Sow0KZB
SirynIlJY6BO+gH55+kwJumqttaXE3mOLg+ae3K0UmsvVm1b1NXHheQvK1No
pmUr1OD1DsgG6KiOOD5s0BHw+SwQR6lkUQLmBTycACmxBlPi0ppo1iWhHJrF
klHGNI4ZoJGjUb5FJvTre4ZdtK2b5WyKrzqP0ShzRFQ0ABrXNhHAHd7cLcXh
0NflxAWHMsq6p6p1tJqIk2FGM0CKYCcPMaLMOgWIgQR1O/LgxfIjL/kinsov
QboyZUQYJiKobUby2ZGiHZuBI5jIm67nFXylEw7m+ylKNKpnhXKMCKB8vRjf
nrJlORfAxkpQyIxRxCAzn6dIAxTpULH5rsD91wvtaCo3mh5gyFAkOJ2QCHJ1
NV5fJpk8TmdAssapXPGt8bJIVDpj9Es0dASU9wiumy6yZJGlaeFIJkAfAqr2
/3F32ZrqgK1WlnptupzWTIH4umeuXgGgar0WoGBXnMXpPK8FKqOgLihjYrpe
FK8aqvGjg8TZQXvkWc3WwFWjtLeU4uZTicldcCGDhsBhjCGLOpZz4rKl8bwg
trKuOYfKnY92d9VagSjctXfdTRBlKtPIqHrijAHMfIAW5FByfoxW0MDFx/BU
9yqs4iZAgAhDmiZvAGTqxQyXMosuJqlK18RtmiBU+uJl2c8FpOHY2o9nc3g2
fg9LuU/QD7g9uBOIU8AtZJgPoN/fUqtFOY6nLCR8Ud0W2rZ2yWHMrs0mhRcQ
VnVkL0jNa1W/x+79+WKlNg4UTzHcXLET1Tzb8i+/DTVEzp8kQ8qY4QGjJSxI
jeEBCMJbo0n8N+cm7STFtUvqYm6WYpd0jhpxOx1J6+nkkihvvb+6gamSIEaS
YqVqbTdHd/zFmzkb07NltOdCFmV17g1sw2lsPjQkEpLDRA73NC5MqCuTPXTi
ikosISITgbNBSUFEOuiwmEeDW1T+xE0eJDkNMHX2/jmF/hXpsN5R2jNlUD1T
NuVT+qSYZj1+jER16ux7RUV548vEG3pa2JXid0pioeKzmK7dhqhVj5/Lcixb
jcDM5AmMozNOx3WMr0bPSbkDFZOzGxC42kg3UGwV32mx5kxOYhDjFyGLFGbm
CLuSxqsYxtpidQbn5PyTeZyPicoARyd0Q5xZZR6PuHChGlmaRXCfStoBuyNB
73tvp6t14N6OIMnwoVjR6k19o6pAXCcWRmpChi/mKAdCSYtxiummyQWZr7Hr
EHubmDYQGBidXAV/5/JAf9NiD7HT2eHon44gOsq+vM3HhmWWojYkV5SSYNrt
+fbsc7wDd2+BFFBw/njPlQBkTtgkSvR1rboLp8j4LK0jCpGNrFekk1W2an9b
XacEQDD51O4x01IleZNgIHOVi0XOs47MV+SIpVsfcgTowYXJNuL4B7j2TRZm
o7kRzIaVzorRKoQpN+GkyxJK6QxyZViOMrV1jY+o2BbTLGLKhJ9OYVl/80R6
gfYd7fQQY3NhQi6OyOwj6WjyBylg6E4V6AmtWHofstFhdCzRmH3Bq+8Lay7b
pwI3shC7/+Y+wnY+TcyWBsr2UZSPaX1LZI1ynQVMDnPUPgFH94UQn8Q2/HsH
/97AvwP8jXGVxp9P4gUJV/jjlUxOQOR+wnTGCMAtPsHIR893Hj2Bax/Uvx78
w6csZr4fZL8Pccwnsfy7FX7Fw97a6vojvJKAtwkXP3U+bop7FvJc2PbDEkK2
DR/2xfYP2wruXfHuh3dJDrDsijc/vEm3MRTzRwlC+uCHAzmTEb1hCdgzPkl+
WEIrQmZLlzpWl2J1mdgFKZNmWHqs7CKcFIVlumI2kejro14CG0RBxGgnN8bK
2GU3V8eV1dMjOZEkdWNKuotOsmg2VmTvRSBbiSHlvw8uClJAMRqlxrCLBOaQ
Avdn0QUT65CtSv0K+sbJHgiYKcasdcyVQpn+ntnCMs7JXaqTBzSx8G5x7Nt+
bT0zXRlXjNO8FEoImgcaUPAWCyA/IsyLrUtboL2d+uyZgLOmIR50dYIuVM3O
d1vGQFhSHCkCJ/UdV/uYkIEOFlRzvEgBqoQ0jHVoldoY1nB1KPqNU1g2Y7Ca
WVfJ4lBqPVfpRRSTrAk11aW+VeMw1whl6NB2iLgaXDrJSTZIpJ/PYw0Zb53O
W04XWRD3DHpviC+JU0yonFRbu+cReecKbkkNZT7rPwxQ/ybu5B3ZYLr1EFVZ
qGPAjSQFTDTbA5htWB1Ie5aznm1+oTYMK5vRLs96gRTLjVyCoYL85cB+dQB3
Y9IO4uZz9EurVxuUEeiz4Sk51jy5kuW7jatqLp8GY7h7Q6cY51WaR5wrEceF
LIohc0pe7NEDvCeGZg1KVSoDdrZKYBnwUExBAhtHyyRbNDjB3OwkxWpnUu33
GBmrLTIff/fdSZTDJF0veGJM47xr+Loai1tWMsPGThI1Ztf7HBptloJUQwsA
NL6uH1HjrlCGJhhlid1d4+gSuZxYYh8VFHDJymtGLaX0QZl4KWzbEP4+YtXL
VUNcZpG3onhTaKrERdCXZsBvJQrCuuDFahQVPRkRgFS8alUsa9NnRReb5pTf
pHf48MY4zKwqH8BBeSlOs+lgXJlV+9RZ5l0WY0SYP4AJaJN5/kko+LlPgdMJ
T/RephiQwr/2wcxZwcDNCWfI2yTl6rsOgSWn0r6OP/e444JTAIMLyKV5I6JH
rd34hoyrC0sRGhLvDvYqe8+hcJqz+SztHoWGHgVW2gSzPGTyBpuzbpYZ/oa4
IQKF93q7E79xDKtKjOOK9hEtT9hgRRcdf0yNJj5pjqxxsQQLGhZCSLnawNnb
4TWavblyz4RwWUx4k1os6wTOga71MTeXyH6FE6roPnuTL6LdVVPeBy+dI0e8
V6JN5GoyfUje5wW+0xpQFatJZ8jFpewIL8DUrUrYrirh8uWel+bk5ecGpqdW
EtrkLCuz3bo9Py/d9rrjdwWsIp5YyyDwIvJ8UEvrOIy9sdusirvW8vJ0LpsO
/CpdzmnSGpzYSc2yfAj5w2Vymp7phJOS/OyWJVrXk6iVr7XAM7t6FYqte3Mr
j6VmWK4M+EBNXPI20XQrb5y8wdQJj1Ym6qSTVbcj/ASaoF4upeaW55/bnFje
JLCbIMqBtiuKwcaboaFHOtAsqtzFwTWDbmIctbNhSgD7WnKHhdfRwJrD81xv
/suaPSYFj4XbMpW06nYxKQKVCTqwW4VbDGO1ucsmUqyLBD2yHZbSrOyybpYM
raDYZgGhVOkbJe2GAy4mkznEol9TivRRczQrSJy4KCI2Tkn7WtKn22HiynHI
rzLL+jZK+e6JvekMBBVLAJ38Ay8+oO2RbRSUlEVwrOrycg1D3YzEUgQlB9Fo
vTTpDdWjl51ONUrWVNEVisncvJ6rtNFZCpMZ08L1P83N4aY/PjmrUnR42TxL
SvmE1sq2dlMgQOzu4XZtAknRwJ2VBGRnM0p74pXEl5+5YJwcgaH5XjVhCUbE
ngaTtwDMqjaLsa6ZmXfWNP6FySBRAUdbDJCKUymxMlKgHJliTxZMLCI7PqLa
RY6a250904EsEPUOVc79ztmSegF2KcYrezsxMkqmzbLwikMBuabdLKa8hGxf
zvtLTxJMoMEVzHGbOy8M0c20BDVus/XDDEJKYFQxaK/8Vpl3OtPI2s1Exa4t
Vbf4wTyYAtRi+rTsxHkYpPwsd7eptQWoLRIVaQaZtroulp+DdcaTWLE7BeFd
07JQ3Og/UejhjUodluG0ECOhdLiZduiVg2u6VXk8p30bMktsxoP26mhhNm2l
fbJKPaZqcq6/JsSpQFrNTF2EbhiE/gj0C9agj1GudTgOYbaSKtECtTreXhnK
RXTB2SFtUc1AuAaOhZ9FaIE6jS5U9SmCAAZAhyEaYL157Lcj4ULiFjqBCErH
H2lzHH31fE4pLF6Tnzyk+mxmS91Gk7aLB2kxNms26S7lXFeTM7QwjRXUs0SR
bgG5UJ/5e1TmFd4mWIl0qhnGqt66sSOCCVTzRofpk7LiRP5jHWejXPhuI1+y
JVbdw1NA6Op9YGoIMY5H4AjbVevcXUSz6e8Se9XQ1vcLqoe2+pvkR4lmWnch
KROUkijcwHCGcQwVwLP+v59qaqRUXhJTjTJPFYbz3jxVyIylxUiiQpzyA+DW
ddZrAEU+i9skAbcvTQqtom3CjJUKOmTVUjo4wTa3c+QJBtlqTUkTi7D2DKar
KRP3KsrEthNtAirH1pWeqhspbyCMJt4s2/0rjvJp4KCzmHelSjVnGC/eU73r
LCeqElMdeJzEpzX7uk8DGQfcsSMpJ2sqOYitbfJz7lWAM0Pr4dyIa503jyWI
YhYPT8kEAyoGmlHhiT0BHBBNaBsp2AxY59Fy60uOS5UKu9mFUG0vnQ0R4deK
2NEowsrRSdfcHJA8cUs78ctya+VlJQwrO/krVIvm7eA4PgVOxwbQzqmf5zg6
k2wLU/GNqYBUvQEQ8rQzfoFz0Y2cQr4abjORU+B4Ajqm4nIbt3uk9iknqoma
s1qfaX2vyG1gbaZpMzNMkqFXyrGNYcJsShlUuuuUAgVhOkndCZcWlWGHea/w
DwtbbIqFNRe4Ey9FCmuDMXUtMEo+JfFGmdoVtkZp1RYLZEu3lRdXlxW3oced
RmctRc1NlbVuiBZs7+Bt2dwGp3WNMc2mK4un/LoSCeM/uyqEpCr8aD8kkA6l
6gNLjXlmTg83HYvihn06FrN/pe46KEJUHkE+n+ptZk43ZcDpBrCWXp4E6CWT
bqYBNQikyVVaN7n1+zrGvH/wp/dbOzsH9OJSUNqNPeN9+28PjrCEJZngk/LD
jFoLTC5sYLpLDovpSmcKRWzw8zxWWRR5pQi80/kf9kdEUX520tleo3zW7XX6
ta/zWw87n3Siq/tLUHJr+Ashlo/K0VAjOh5QRdjS2vrDR0sr9WN/13N+fu+O
TdHPTbH64VEEj/+4exScgcrB2PTSLBpmbDb3NrEjTTTbfPAAwJanWV+h+EG2
1BYS3znTNrPdkJXHae7Xmq1OyYDJ+rOsnyM/tB8VY3io/Vo8rB5Sij5nVFNs
1dRxuyHp1Q9PBg2YbRxf7XSnpoVTqFSiYQgdF9p/+f5g919R4IIzQia2Eq8N
zwY3hn482CemvcqC+oT97ypfPKh74t9qh/r3Ch09GYRmgqT0LdHRMJMqL79q
dIDEeNAw6+aBTcWV2yvCVjQ1PFzrbl17Qq2/+F4JjO+a5cVGf/Uhf1ZVjj0u
PdjU5Qw42wcNSxTCTRTqaUP0Ozphp/6x19GH3tYJUlXDTd+/JTtb7Z3/vknU
8h76pvjYONUHQqU7Md+sik3xl+a1qZ9hFt9XIvzw4Cfi3k38A3Xqg/vdVmN4
o2gZsIl/XG0UQRz71+bbHwibKAsf1mGlePjOMqi4Dbjj7T7y9uqH4+NG4q//
2d/686u3WztNguDyWuymBka7ycv13Vys36/zOusIUheWvFI70QQdjURvy582
HBVSyQbrX0/u2JlRlyEwpViFmWZCJibT+ILvXaPnO+cFvs1Dlc6BaRjpv/Fo
bf2WeZURWj/3Tr+PFVT8v/6FvzsLAfpdg423umYfd009f72/go1Xg36y98HY
kPmYW9pg1ZPTnr4FeX1fj30XGi4RfMvYr4Nn0HtoeAj8Ct28Fk8d23j85OnS
lbh5+d5K6IuQbg7YYIQOHw9ra7eMBFrTFxIfD7/w3D1o35D4v/DcOx0knUPj
ZHt+BNDijwdv3xkDAv9k597xwKmYU+fSkCDpJamqY9GVnTqeAhxRTZFxgyy2
MtPfHCHRpPY4varEtLKfW9eAYHudU5YpNYOCONR3jlvgYpK+NMc1UVyV5SCn
iuvzegYSmx+kFAWYwmi642hD/2KOmrtbFDoLRnmJpsGbTcU0KcuUuUKnPM2r
He9UCDZ2+qo4B/I5lak2Il0T2Qr3NaqLd5W7G33G4BcHG71Z6Ydv7Wwmvwj9
qoG2tdXfbqRNt1hwawcUFgKgNfm8ldMiasN1Ol5nA3Y2YifKvx1JG/ru6nG7
4Bu80J1r2FVV0Yvdo+2X4ak0Gnc1jxBgwU08jUebqDC6IMSzAg+Z2/sJLjze
+GvzAIvDIeHn3GR/ZVsueEKpIVVm/GCvopDCj6ET2HzHrk5Vf69T1T82PyBI
tYplsK5XuotuDSJl4VNewGjh3R5odlsC5vJKNP+dS5uBiIszCFPoN0eRd/T1
a9JXe3lbG1FfsIpyvF30m2XyollcKe4eHqV16D38eLvou/8suWzBxfV7fgze
+e5BA1D+rQlg/14VGdYR9CZm1NotiIyNkshYXTveWEjj6geG4NYlHwp4cuNJ
NFiXdwLH/evbFDgw5nap1KxxuMXsT80jDt+83yiVYRAxLligOVhRdVjb5IHA
lRcbq+s3k0vt94luXTC33EmqAUrb3aR2UzORnfAOkTOIikO5kqQnliX20l4g
eKq7PF8/p9OO2PIhwDYGF+VdYtTnYh5us4XWIF5r99GuKw4WPocAXHjTflvI
Ne+vLdArLXfYFozSeo9t4TjlXbamRXOLD2UFrNmtNgwoXuGFzk9of+5qI+h9
tE/icO/HN4tpd9GW4be0jl/SOHkP+oMw8kjYrZnpxY+v23Bi9ScaSu7PhWPg
78U6GmeSy+H7k5mijA2ciX580dMLlPUC5+F7P17ynftoIHIffse3JuyXDzFK
WBH5C/Uim/yB71pGnQafPer0jRjsV49ZNRY0by5WOX+5udq4DYVBquJmxvdX
ZAHd+Tql+1sEuFvlkNSs8KppJDeaok0mWTCrBakmV9U77nNb23/0n+tUd/mF
/qPTatnfNYpou88ryqL6tkT0eklED599NUL2TrZ8QdnSdmMgBNrb3Rj4YhR5
R1+/Jn35gv5biDGFsH4XY7qLMd3FmBoWfRdj+rrWcRdj0n993xRj8ixvP9b0
TQr7NjEmL54k2jsp65/dSbmLI9Ws8S6OdGeLXwvcnyeOxEGa9VsI0lSFc2Mg
pmnyNw/S1C+7sTKjZu3N1RmtJ7J8rybjJ+i8BLNzXOelWqlxbdH8eIEo+NWV
4TVkgn+iZnu5YOyDr8JPKRdw3KLsqN2Marmnh/TZtKcXLGr57ZJojb22AM8Y
gC9jp52Jt8Aadk28kDV8h53bwE75GVVO5dRTqVKKbqiWwqtrsRUV1CypXcUK
qZQrFm917TT4Ta0P1aqbRnMx2DUrwSqVP1ga9i6hbk0qzW+eOI2KdNPn+kbP
+hyyUndQ6shVU1um2vKa9OCRHM1NFMyUk1EFl20ySuPoEzvMo6luubvgWIwW
VVo1B6y2qtfqjWTxW6rZqhZUlfqsY/UVdSij9mRRGHgtDqc13azzMhvTW6M4
O49zKaZ4MoMlbl5/VGpBGTjvC5ZiuzKXzkLG4kRutRmePFNJzZHqbm9IO/E2
67W8gsebq9aD5rR60/Ir+FZqO4kN6E+o/TPjno5FUin6zikSdGJBXa/XhJ+k
Ik1vt7uGgJgk3DbY1ByswnRhSPrnT9Yf5dbYdW2lL16m55JYwZwthA3sEGLn
Ch1tjyrGZu7EilVJYTrehhfjt2sfpXSvaqMMz6hARrHoUItqC2mvjVvN8SfL
Ttlr/XHRK6UebXRC36CI4qRy5r17YHqbw5WxzSgVRZZriOnoMZcUYQwATp72
xdYk3IFS0z5XCDe26UU3mVsnwMtmfE5YkNmbeA+PEx/O85wPAlDnKnCPwDoR
wB316yF9i8fCc0dtdZh6+Yx4OotM0xxzbfA0reApd7r6ljvV8wFY8bF7gsEI
JGJ6IUflQwn8zsjOxqTtbe6u2j3G3py3GZaejkDoMpRRKptjuMLYULxhD7T1
50d9R8cR1n5zHOI4zvIidCAohkEjEthmFkCmpYNiCGjhiZgTxrF3ot/fEmkb
UTmQC6bbpbbI59xqFLguIjt2NMdOmorWx3HhtevlydMjtqpeVwcPgQdQbExg
KS9tc8gFtKkITzcbdumOa6fVMaNdPg3P7yt6FUIU+hR0C/FOZ4tIsdJlVwtp
Ze4VF8GTo1Dp8GF3iIYwotRslL3Ak+K6cT4ZSaM5TaTXUgDMDvBt9na6+tG9
HV3JQhYLag74Wh8ZrW465Bnt7WgC9Ce1rU9jrMxJG0HaXNYA9oCpW9uytUeE
ErZY+eDhrVKx/c/R5FTjoLVJ24P7svSSa/i1Deue/kKYA8mCp0Z/QJLJ5PGE
bSHVWFgfei0/cLBP5GPsa9z25BiahX4WmwDgslRhpOlaDSteY0nnYTqfzzDx
Lq+DEzwxz7suO+jSopDFS1IqTGZBbdTls4jo7GIs5yQ7OaejgNNjkqDUUH9U
fpE6Y0ylIhI5pBlLTjILQoc/rCs5z6uYRqd1azDNGTUppMT33CV5mZsag2KY
D3r5fCAGWXqKcfzAyZ4LjvuqnGJep94HIJbsAeWl6ZY051awRfDDvnPwSsBN
abTjNN7BasbW1tikHWQZG5YIRkSeBVrMfbnzKSCTTiCkk2wxZG9UrWZdcmDJ
5sIhbCNfe5JZNIFZJawYdQtlG8ygF2tbRwPgIZ9WESA16hqM4mOYTmdzcz5v
gw7j42TJf8T31Ns4AOJH1A7fnixnTwBhkaRNCe1aam+k5MDCklTTabAT8wbX
JJSGW+eYiOf6hFB4+LCQM7GOzazPpKPFdY9wlFP6jIMypZxHvCav7XYN7QBI
NnyQoOXGh1m1h4U5XiEoaW7oIc05pKPTwVC5fiGnyJLH1byiumONc+cEUG04
PO6Ld9daYDBUdZrQuWDKMnIjHMpOqGAD3woCMh9m8WARfVolEz7aPgBs333j
2ByOm02JKomcAQpPPKnvHeLlD+gEWfCQu7NYCWktlQh410S9Ylg81sezVVsS
7JE519YuQ5/XEeSNaaplG5/0B/qUwMvqLKJjlHuDix4dp4zSEF6c2xM6gCa5
A4G2S+DDvHwUKnAz2Zp0FGjl3KBAVCd0No9aj6EyHfREa9ULYzmnIdHBD4DZ
pyXMsuemA1JugDboXlUP9gsFosyZHZstNHpXLPOmAVLgSgg1bLZU7kJIlpiC
Dy4o9SMr4Rn1J+inlJsqdfFMiqFUx77g/SOPFstPW8pWh2yw+AVEL6GUkXgk
HBLEoqNinTOizVFpoXPES+9baoUBAMOzvnihH208Tt5vdcaxwvxWw4GonK+i
dvfqDxm3p4pFIfT7B1GALUMmsneaIHzGMxT8kzP6graxMB7sg8PnDtpmpsyI
ZT6cYKw0+whNb3yTClZplVyDRLIIotDJG4i5tdU+aLWyAlIbC0ma9JoJ9Gqa
yutVV2dJ+0EG57CRAo8EAqkndSgO4eHEk+zhP07QJJE6SuJGahRDF65c00ev
uLfrwKM+fqjNcnNjxDeDjo25YKykKTZY0cN0BgqFUWgXQEPDeDiKcrlfYc3h
I35wkh3v10qx7GqHt723bfzcL9I0b4vDbsNoRkdhAoEY41f1Z9yk86HOUwOc
7TXevF23R0wB5pWAodFsZzg8xkYTwqG2QNyOfDpPb1FHPp3GB6Y+Hyvk+f4m
sAAcMgRYdvEsHPc4H56dPWvQztCdFCcwcSs7cyyWnr3a4FjAeY3diiqnSevU
woq3HxDPWmBRhJJiFHo5zaxCByLi0USjOM8lHVjI548fsik4lTQVZRp5sRNi
g/tOzuh98YPQaaPIaWzC7O30+ZisckDrkKCKA/CDqxv4kI2Q4aKpJcwPYgOz
DDn4xhmtK86th+qoG/GGwOZvTW76Z6nfsN0jD+VDdFgbsyuv75m3vi/bPbIm
4+E31kNyQSbKb6dr2k3bpjVLov4igIxlvX+CEhaNigVj2OPH6cy7sOd4ZTh/
JQ3crpsVfwv5/8+8HDEUO6ufMf1f4an3MsrH3G9k9elj+XiDEoZ/nYSzuyz2
6tcLRdLna5imJHs51KF2K1AKsghrI3PUIGrTRIk+s3GSLEoq5E0PL1wfFZx6
RXH2iQqyf67mcKA3Od5v5m6PrY7JFNu//qtvp33yP4zgunr90Z2o+zZF3fW6
Nv/DMMIdWX+bZO2rlkN3U0QpF73h4W53LJi4sxlCgbm8KO2jdFuo2fw0xp2e
+j2Mz9d8dZbhacnKvVualOMwi6qlTXRa54gO5CQ9v4HpQzXvy1QFouuhWoqP
tQX1Gm3KftuWhjxcXf2GyssCMP0cNWYedK5QNOYdeXUNRr/1Js03ahZzu71i
SjNTPkDubd3rTZoFEF+0wXmdItGV8Hftuyirkzbxyk16uCw8bHMBPy9g5sVc
2bpVyz9go5ZAe5PvOTk1Tc7kxaKwV/nneoqq/GMUl1KAI85v+owGxz46zVk0
LHxftrQ9vGAZDUl/JAWI2xaMQQFZcOMryL+JbHJWdzNLomu3r7ve/vWC553d
7e21azdkvEoj4OAxkJ/f9lh/9mzjzvYoPfLN2B6fq1/E9votRcpu1jP0HyYI
cBcN+8cMG+xzSJ0a0ahEFVZYLZXnzfqC/UoqZ+3pnbt7p3LKrFCbfrAAFnct
iu7CSA2PXI2vvvHGRnX3L9RC89mItp9tETfgI7tYsCKVh8nFB8Y1++Le0hds
4gPe0tNficW+VB+fsuC7BdviyyLo8W8cQXWNlmgoJyz7TTVJotxqkxN704ZJ
XadSal+l9h3YUqmaZDdss1RpQHSABRy57LVrRHTvCpnkmTxjEJSbEo0kFa2F
uhKVKh8zNTnVqujgT1doVlSuf9noP+mr4lXwPrn2xaueaNFnqtpv6fJbb00U
TPLHbdp4UtfDprlQ/5K2Ii5MZX4+lAk8mAJDpl07d5s8rxvpDFWyv+0aAObT
yiY3H3Hweu3S8oWV3IxLbGMxnUXJRbDSXYAhEXGaGcbo3yuSvVBU2MvjEZYG
fYHS9H4ZWI9WNlUzBHvR5MMRUnSFS7nJgy6iBg7DvPBirNtkXFACOD1/jn9R
jc10ShK5MDJEl8S+4BYeWMXeLSHZKyGZmTYrDn3cZiK9KDWKQskhP8xSrPT1
BtNP0MJ09Q3SWzQseNq45QAKIk6MnDCJ65gzqDrVRH6pMMEFxFyB5Q5UPhFa
SWjq3Folo85WhA3mf69SN1iiWy4YwYJilYXe+t1UCenCykKFhv/5K+REpCCs
ncK5byJOfif2Ctv3jmfaiis1rIdAozEqO+Wnt4dfuUUMfNE3U7JFuDw3SmC5
gtCgkYjdufBGFa2qhjKOcCGwEPsIvqhXZCgTn7uvNlbvA4dn0YWtTW5Vy9tf
C+MMsMEoNvMrv8fUZVJrRXVH/J7xdF/ICaUSaKnKjbG2D/aUqGFUcJMfu+Iw
S+tGZVF2IomZ4Ruq9lY8a2dW6RZgpgVqDQg5N/PqYtEZMCKV1QAEdM83YBjW
zar+zytmJouFC/OOolOaCTYtApFSMfvYwjKWU28axUlPJTapirxMcqvuImxS
jdNzW2uD9YUFthCZqRcG0q+xnIn7F+mWVUZoD7HdC0/LllqmkxFxp2t7qYpN
VV6eK0qK0cWJ/xbpTpRDOQLj38xVWRd2sYoZZmAt08HfZJ/8zmlp4vV54/0b
1T+rRjg4VLSwUk2zvyPf8HXTaCRvLM7K64jtMsoVcNRoZ1h4dV7KTENi0Flu
FSllsUaw43ZEprA7DB+vZYZVGM0Ffbxf1g2Kxq6xwUPykduNmdLI9lIP1blq
k+k0r8njYu4Uc3t9INWm3vX1sGnFlSopvt4X72ZUbo8l8sTEChCoMD3KZ3N6
qAozUUKg6aRusV2pVOs7pVG1lQzovIL3weAxIi0+1it3GjuWWrmRVUH8ixN3
GpG6ZeelAuS60mNlEbGItfV05X6JSBNkKgDudZs3BR9egFNUj5My1o5ONPUM
HdUlT+ejWlR4iailhh5mlTh+2yYW2s12dBh3i1MqrEFNlCRPqfmw6rNQ33Ay
DNi+eB7lXKBJ7OAZL7iwL9k9gelHZZ8QlXu0Ue6l4LdR6HR2QbOk2X1SKnIT
GRPtlfgENQS2ZyPNb8MDwBblLm6kUe/plnZ7vrrZN+rGV6gVHcOi1SnlpmLl
WuUV5z4jG1VLECg1JKhXTACdB2lm29os1gEgPLnynHCs6cpTCbWK1bMitNNv
VRGKeu7qY9rqeSEGsWzlu5aPKyFj11WhavgBNqU6Y9YbyGATRa8lJUwucruY
KXkeoZrQjSB18DXcB+XWZL44GnudmEoBmGUy3lZMRI6frWlyXVf7POgrKez0
TTI+VJiDTCtujITNowmMMmxo1dNwTmCQ9fWytSD4HOtmN19tpNndUH6jrtst
9VdEzQ96FcPI5OYJNqisaDbfc5AJKMoSY9DFoEDpLbsWwQl9Kf/CAoUP+vNg
wtmj7Xo26IJJHvGt6abUdZDgDOgpN+33OR4ITI80Gh53pyfgt0M95ud0lxzu
kgervZCVIOmzsOsJT57LyUT1mhGnPDOYlMxwn0U3Kgm/2m1FO42S6IRWVXn1
dtCwHwVYeEFvrEbd6HG2rFidi4f3zOFClaTmht+iuhYfpJga8/HJLOXII1DG
vqJDrOLJ5srctVX3CtoNs8ILiUSlFGUX7LYgKJBMGtQgN1TSmrPkRdERC4e6
dy82RAN1ljmuNZjP1oQeet9fen09rLhVg/k3s4378aNHDuWgZ+kRdJ1tD5xR
OpxP2RYCK6bx8DndnXDRCnqTYpopi2Y73dpXW38LBvc2CXCEHj92eYlQBrSr
rUSaut5bKJ8DAZDQmwrwJ6HK32Ugl3eiXUx9RNkv0dBprej30oaL0XCoG72r
pXAGDcsenvM12lRqWwhwhJ3P1UkE/vkHceEL2XAgPxpgS6yoEpoXz7G3I3nj
Xt/5gcQmWPbMhSF29iKb1zRJM9wW8qzMVJv9B5KmMEWl/qobB1vJhe9/gkkd
J54Y1Y7aLAVAcedZF6CALPBDerMIdeeQBFA0wt06+rZLLi93hDXHS0xTZRQr
XKaqAS27ipwjY8xcWr2PWIqKy9YEBMs8wHdqqaneyr272D/2zz1YSI4ocSzG
gmKy26jM+k4kw/YaV2VJNC9uXcDYNTLQ9F1u6P7kNXuvNq7LqdU5akMfGgrs
14YK9rIkKT25MKDhoG1Vg+jezjnMT7mxkTjPUm9he/vaFAOtPqa2SzPcBk6M
z6PVAoJpppmlDjLK8gQnxj3VwoeM2LJtkNHIiZvA4S5ykJ4AgVcW6gR9QN6o
I0JIWzGfqP5KZWLdQ44YMaWpJTtnimjXzukr7LNHXjLxWmkU1eLSNtlnJ1BZ
F+N0huEU+AUGPuEOPF4+rUKJfSVrdZIDggi4XwlV9HB3jl4d4g2jYpKvPSRd
cE/sbb3ZCinnGGwvnSyg1SPxka9WdWgN9REOBWNyI89UHLzYFhxZ2BT7E4n9
ENEditSeJ/UO4q1mJJqljx//++HuqxeXl0vWHcUhlGNoouw6K8FENkZgr1Pr
UPSPwCY+yaLZmDU5KV4FXm4YlosDdlQvxD29TEpCUIqWLA8ECW3dnnILTZkU
yr6yC1c8q2anqHgp8MIl7RpfAOzx+7469UV9j12W2UdSI6AJx9H0g93Do+P5
ROwmZzGwJtd1Lm+nB7sruG2hrH/nBTpC/Um9XMAfGABd8PMJgKK2/Skp6+j5
zqMneLmZbvXDBnPw8MdNQG58kvywNCSoLekEmwMnPmBOMmjCD2bIvFAWcBv+
0fIbV4JFcWydZNRyEZC52lvf2KhsRsMy47z0oIfZGnpWPe4K7ivDYmDm0zgD
0ZCyLiOovEC1PFZPB4nZRvJBFMXp3KfzXq9HSga5eUdz6juVZKmtVM3CPZV9
eQmYYisgTrLj4SWxy0/cuV70Vldxwb3VNWYSHGB1FT5e4t7JgUyiqdrrqaKj
90LKEU6ntxNj/CrT+AXRUf6KtmJexB+kIQgVYsxDMUbe994GvJV0iiSkoGsZ
TzFqxgXQ/cqSnLXQQvamaEzKkVG8bEEqwcmm5yiLjoteLIvjHklVVVHdMzqu
5+m43to6SdWtIW7hTOTohJkW3xzxtZGka4gARQJy9MNSki4pZyGaF+MU+ICy
QygZBDRYcgpc9nE7yug8pudo8ybgFICXA5f/OImAJF4CWZ9Kfe1fohj4/l/i
6d//M5F/01dfRwVQFmDijymox3w4/n//8z/NE+kYQ7Vy/vf/JfC+PE/NG2Ac
cQhYiEb6yqv56Dw+AfcuLnh0RARc//Hv/wUsB9cnEbY+hK+0GxtnlK5issOO
FTGoEOh5mp2yNi4rnAEGsJBp8aAAPsLDbtwcnsuRTO7nwJFJqmybrROQZBfi
p703b97+tGWYZ1siynpv5AfC8S8SKz63D/aO9g53tzk38s/7IHIP/4k+qBe8
XF9dX9X3i8O9F3uHvZfYG3X5R1go0MxJJjmG9Wxj/fHG+kq/8/8BuzhUdVke
AQA=

-->

</rfc>
