<?xml version="1.0" encoding="UTF-8"?>
  <?xml-stylesheet type="text/xsl" href="rfc2629.xslt" ?>
  <!-- generated by https://github.com/cabo/kramdown-rfc version 1.6.17 (Ruby 3.0.2) -->


<!DOCTYPE rfc  [
  <!ENTITY nbsp    "&#160;">
  <!ENTITY zwsp   "&#8203;">
  <!ENTITY nbhy   "&#8209;">
  <!ENTITY wj     "&#8288;">

]>

<?rfc strict="yes"?>
<?rfc compact="yes"?>

<rfc ipr="trust200902" docName="draft-ietf-lpwan-schc-yang-data-model-16" category="std" consensus="true" tocInclude="true" sortRefs="true" symRefs="true">
  <front>
    <title abbrev="LPWAN SCHC YANG module">Data Model for Static Context Header Compression (SCHC)</title>

    <author initials="A." surname="Minaburo" fullname="Ana Minaburo">
      <organization>Acklio</organization>
      <address>
        <postal>
          <street>1137A avenue des Champs Blancs</street>
          <city>35510 Cesson-Sevigne Cedex</city>
          <country>France</country>
        </postal>
        <email>ana@ackl.io</email>
      </address>
    </author>
    <author initials="L." surname="Toutain" fullname="Laurent Toutain">
      <organization>Institut MINES TELECOM; IMT Atlantique</organization>
      <address>
        <postal>
          <street>2 rue de la Chataigneraie</street> <street>CS 17607</street>
          <city>35576 Cesson-Sevigne Cedex</city>
          <country>France</country>
        </postal>
        <email>Laurent.Toutain@imt-atlantique.fr</email>
      </address>
    </author>

    <date year="2022" month="August" day="25"/>

    
    <workgroup>lpwan Working Group</workgroup>
    

    <abstract>


<t>This document describes a YANG data model for the SCHC (Static Context Header Compression) 
compression and fragmentation rules.</t>

<t>This document formalizes the description of the rules for better interoperability between SCHC instances either 
to exchange a set of rules or to modify some rules parameters.</t>



    </abstract>



  </front>

  <middle>


<section anchor="Introduction"><name>Introduction</name>

<t>SCHC is a compression and fragmentation mechanism for constrained networks defined in <xref target="RFC8724"/>.
It is based on a static context shared by two entities at the boundary of the constrained network.
<xref target="RFC8724"/> provides a non formal representation of the rules used either for compression/decompression (or C/D)
or fragmentation/reassembly (or F/R). The goal of this document is to formalize the description of the rules to offer:</t>

<t><list style="symbols">
  <t>the same definition on both ends, even if the internal representation is different;</t>
  <t>an update of the other end to set up some specific values (e.g. IPv6 prefix, destination address,...).</t>
</list></t>

<t><xref target="I-D.ietf-lpwan-architecture"/> illustrates the exchange of rules using the YANG data model.</t>

<t>This document defines a YANG module <xref target="RFC7950"/> to represent both compression and fragmentation rules, which leads to common representation for values for all the rules elements.</t>

</section>
<section anchor="requirements-language"><name>Requirements Language</name>

<t>The key words "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL NOT", "SHOULD", "SHOULD NOT", "RECOMMENDED", "NOT RECOMMENDED",
"MAY", and "OPTIONAL" in this document are to be interpreted as described in BCP 14 <xref target="RFC2119"/> <xref target="RFC8174"/> when, and only when, they
appear in all capitals, as shown here.</t>

</section>
<section anchor="Term"><name>Terminology</name>

<t>This section defines the terminology and acronyms used in this document.
It extends the terminology of <xref target="RFC8376"/>.</t>

<t><list style="symbols">
  <t>App: LPWAN Application, as defined by <xref target="RFC8376"/>. An application sending/receiving packets to/from the Dev.</t>
  <t>Bi: Bidirectional. Characterizes a Field Descriptor that applies to headers of packets traveling in either direction (Up and Dw, see this glossary).</t>
  <t>CDA: Compression/Decompression Action. Describes the pair of actions that are performed at the compressor to compress a header field and at the decompressor to recover the original value of the header field.</t>
  <t>Context: A set of Rules used to compress/decompress headers.</t>
  <t>Dev: Device, as defined by <xref target="RFC8376"/>.</t>
  <t>DevIID: Device Interface Identifier. The IID that identifies the Dev interface.</t>
  <t>DI: Direction Indicator. This field tells which direction of packet travel (Up, Dw or Bi) a Field Description applies to. This allows for asymmetric processing, using the same Rule.</t>
  <t>Dw: Downlink direction for compression/decompression, from SCHC C/D in the network to SCHC C/D in the Dev.</t>
  <t>FID: Field Identifier. This identifies the protocol and field a Field Description applies to.</t>
  <t>FL: Field Length is the length of the original packet header field. It is expressed as a number of bits for header fields of fixed lengths or as a type (e.g., variable, token length, ...) for field lengths that are unknown at the time of Rule creation. The length of a header field is defined in the corresponding protocol specification (such as IPv6 or UDP).</t>
  <t>FP: when a Field is expected to appear multiple times in a header, Field Position specifies the occurrence this Field Description applies to
(for example, first uri-path option, second uri-path, etc. in a CoAP header), counting from 1. The value 0 is special and means "don't care", see <xref target="RFC8724"/> Section 7.2.</t>
  <t>IID: Interface Identifier. See the IPv6 addressing architecture <xref target="RFC7136"/>.</t>
  <t>L2 Word: this is the minimum subdivision of payload data that the L2 will carry. In most L2 technologies, the L2 Word is an octet.
In bit-oriented radio technologies, the L2 Word might be a single bit.
The L2 Word size is assumed to be constant over time for each device.</t>
  <t>MO: Matching Operator. An operator used to match a value contained in a header field with a value contained in a Rule.</t>
  <t>Rule ID (Rule Identifier): An identifier for a Rule. SCHC C/D on both sides share the same Rule ID for a given packet. A set of Rule IDs are used to support SCHC F/R functionality.</t>
  <t>TV: Target value. A value contained in a Rule that will be matched with the value of a header field.</t>
  <t>Up: Uplink direction for compression/decompression, from the Dev SCHC C/D to the network SCHC C/D.</t>
</list></t>

</section>
<section anchor="schc-rules"><name>SCHC rules</name>

<t>SCHC compression is generic, the main mechanism does not refer
to a specific protocol. Any header field is abstracted through an Field Identifier (FID), a position (FP), a direction (DI), and a value that can be a numerical
value or a string. <xref target="RFC8724"/> and <xref target="RFC8824"/> specify fields for IPv6 <xref target="RFC8200"/>, UDP<xref target="RFC0768"/>, CoAP <xref target="RFC7252"/> including options defined for no server response  <xref target="RFC7967"/> and OSCORE <xref target="RFC8613"/>. For the latter <xref target="RFC8824"/> splits this field into sub-fields.</t>

<t>SCHC fragmentation requires a set of common parameters that are included in a rule. These parameters are defined in <xref target="RFC8724"/>.</t>

<t>The YANG data model enables the compression and the fragmentation selection using the feature statement.</t>

<section anchor="comp_types"><name>Compression Rules</name>

<t><xref target="RFC8724"/> proposes a non formal representation of the compression rule.
A compression context for a device is composed of a set of rules. Each rule contains information to
describe a specific field in the header to be compressed.</t>

<figure title="Compression Decompression Context" anchor="Fig-ctxt"><artwork><![CDATA[
  +-----------------------------------------------------------------+
  |                      Rule N                                     |
 +-----------------------------------------------------------------+|
 |                    Rule i                                       ||
+-----------------------------------------------------------------+||
|  (FID)            Rule 1                                        |||
|+-------+--+--+--+------------+-----------------+---------------+|||
||Field 1|FL|FP|DI|Target Value|Matching Operator|Comp/Decomp Act||||
|+-------+--+--+--+------------+-----------------+---------------+|||
||Field 2|FL|FP|DI|Target Value|Matching Operator|Comp/Decomp Act||||
|+-------+--+--+--+------------+-----------------+---------------+|||
||...    |..|..|..|   ...      | ...             | ...           ||||
|+-------+--+--+--+------------+-----------------+---------------+||/
||Field N|FL|FP|DI|Target Value|Matching Operator|Comp/Decomp Act|||
|+-------+--+--+--+------------+-----------------+---------------+|/
|                                                                 |        
\-----------------------------------------------------------------/  

]]></artwork></figure>

</section>
<section anchor="identifier-generation"><name>Identifier generation</name>

<t>Identifiers used in the SCHC YANG data model are from the identityref statement to ensure global uniqueness and easy augmentation if needed.  The principle to define a new type based on a group of identityref is the following:</t>

<t><list style="symbols">
  <t>define a main identity ending with the keyword base-type.</t>
  <t>derive all the identities used in the Data Model from this base type.</t>
  <t>create a typedef from this base type.</t>
</list></t>

<t>The example (<xref target="Fig-identityref"/>) shows how an identityref is created for RCS (Reassembly Check Sequence) algorithms used during SCHC fragmentation.</t>

<figure title="Principle to define a type based on identityref." anchor="Fig-identityref"><artwork><![CDATA[
 // -- RCS algorithm types

  identity rcs-algorithm-base-type {
    description
      "Identify which algorithm is used to compute RCS.
       The algorithm also defines the size of the RCS field.";
  }

  identity rcs-RFC8724 {
    base rcs-algorithm-base-type;
    description
      "CRC 32 defined as default RCS in RFC8724. RCS is 4 bytes long";
  }

  typedef rcs-algorithm-type {
    type identityref {
      base rcs-algorithm-base-type;
    }
    description
      "type used in rules.";
  }
]]></artwork></figure>

</section>
<section anchor="convention-for-field-identifier"><name>Convention for Field Identifier</name>

<t>In the process of compression, the headers of the original packet are first parsed to create a list of fields. This list of fields is matched against the rules to find the appropriate rule and apply compression.  <xref target="RFC8724"/>  does not state how the field ID value is constructed. 
In examples, identification is done through a string indexed by the protocol name (e.g. IPv6.version, CoAP.version,...).</t>

<t>The current YANG data model includes fields definitions found in <xref target="RFC8724"/>, <xref target="RFC8824"/>.</t>

<t>Using the YANG data model, each field MUST be identified through a global YANG identityref.<br />
A YANG field ID for the protocol is always derived from the fid-base-type. Then an identity 
for each protocol is specified using the naming convention fid-&lt;&lt;protocol name&gt;&gt;-base-type. 
All possible fields for this protocol MUST derive from the protocol identity. The naming 
convention is "fid" followed by the protocol name and the field name. If a field has 
to be divided into sub-fields, the field identity serves as a base.</t>

<t>The full field-id definition is found in <xref target="annexA"/>. A type is defined for IPv6 protocol, and each 
field is based on it. Note that the DiffServ bits derive from the Traffic Class identity.</t>

</section>
<section anchor="convention-for-field-length"><name>Convention for Field length</name>

<t>Field length is either an integer giving the size of a field in bits or a specific function. <xref target="RFC8724"/> defines the
"var" function which allows variable length fields (whose length is expressed in bytes) and <xref target="RFC8824"/> defines the "tkl" function for managing the CoAP
Token length field.</t>

<t>The naming convention is "fl" followed by the function name.</t>

<t>The field length function can be defined as an identityref as described in <xref target="annexA"/>. Therefore, the type for field length is a union between an integer giving the size of the length in bits and the identityref.</t>

</section>
<section anchor="convention-for-field-position"><name>Convention for Field position</name>

<t>Field position is a positive integer which gives he occurrence times of a
specific field.  The default value is 1, and incremented at each repetition. 
Value 0 indicates that the position is not important and is not considered during the rule selection process.</t>

<t>Field position is a positive integer. The type is uint8.</t>

</section>
<section anchor="convention-for-direction-indicator"><name>Convention for Direction Indicator</name>

<t>The Direction Indicator (di) is used to tell if a field appears in both direction (Bi) or only uplink (Up) or Downlink (Dw). The naming convention is "di" followed by the Direction Indicator name.</t>

<t>The type is "di-type".</t>

</section>
<section anchor="target_value"><name>Convention for Target Value</name>

<t>The Target Value is a list of binary sequences of any length, aligned to the left. In the rule, the structure will be used as a list, with index as a key. The highest index value is used to compute the size of the index sent in residue for the match-mapping CDA (Compression Decompression Action). The index can specify several values:</t>

<t><list style="symbols">
  <t>For Equal and MSB, Target Value contains a single element. Therefore, the index is set to 0.</t>
  <t>For match-mapping, Target Value can contain several elements. Index values MUST start from 0 and MUST be contiguous.</t>
</list></t>

<t>If the header field contains a text, the binary sequence uses the same encoding.</t>

</section>
<section anchor="convention-for-matching-operator"><name>Convention for Matching Operator</name>

<t>Matching Operator (MO) is a function applied between a field value provided by the parsed header and the target value. <xref target="RFC8724"/> defines 4 MO.</t>

<t>The naming convention is "mo" followed by the MO name.</t>

<t>The type is "mo-type"</t>

<section anchor="matching-operator-arguments"><name>Matching Operator arguments</name>

<t>They are viewed as a list, built with a tv-struct (see <xref target="target_value"/>).</t>

</section>
</section>
<section anchor="convention-for-compression-decompression-actions"><name>Convention for Compression Decompression Actions</name>

<t>Compression Decompression Action (CDA) identifies the function to use for compression or decompression. 
<xref target="RFC8724"/> defines 6 CDA.</t>

<t>The naming convention is "cda" followed by the CDA name.</t>

<section anchor="compression-decompression-action-arguments"><name>Compression Decompression Action arguments</name>

<t>Currently no CDA requires arguments, but in the future some CDA may require one or several arguments.
They are viewed as a list, of target-value type.</t>

</section>
</section>
<section anchor="frag_types"><name>Fragmentation rule</name>

<t>Fragmentation is optional in the data model and depends on the presence of the "fragmentation" feature.</t>

<t>Most of the fragmentation parameters are listed in Annex D of <xref target="RFC8724"/>.</t>

<t>Since fragmentation rules work for a specific direction, they MUST contain a mandatory direction indicator.
The type is the same as the one used in compression entries, but bidirectional MUST NOT be used.</t>

<section anchor="fragmentation-mode"><name>Fragmentation mode</name>

<t><xref target="RFC8724"/> defines 3 fragmentation modes:</t>

<t><list style="symbols">
  <t>No Ack: this mode is unidirectional, no acknowledgment is sent back.</t>
  <t>Ack Always: each fragmentation window must be explicitly acknowledged before going to the next.</t>
  <t>Ack on Error:  A window is acknowledged only when the receiver detects some missing fragments.</t>
</list></t>

<t>The type is "fragmentation-mode-type". 
The naming convention is "fragmentation-mode" followed by the fragmentation mode name.</t>

</section>
<section anchor="fragmentation-header"><name>Fragmentation Header</name>

<t>A data fragment header, starting with the rule ID, can be sent in the fragmentation direction. 
<xref target="RFC8724"/> indicates that the SCHC header may be composed of (cf. <xref target="Fig-frag-header-8724"/>):</t>

<t><list style="symbols">
  <t>a Datagram Tag (Dtag) identifying the datagram being fragmented if the fragmentation applies concurrently on several datagrams. This field is optional and its length is defined by the rule.</t>
  <t>a Window (W) used in Ack-Always and Ack-on-Error modes. In Ack-Always, its size is 1. In Ack-on-Error, it depends on the rule. This field is not needed in No-Ack mode.</t>
  <t>a Fragment Compressed Number (FCN) indicating the fragment/tile position within the window. This field is mandatory on all modes defined in <xref target="RFC8724"/>, its size is defined by the rule.</t>
</list></t>

<figure title="Data fragment header from RFC8724" anchor="Fig-frag-header-8724"><artwork><![CDATA[
|-- SCHC Fragment Header ----|
         |-- T --|-M-|-- N --|
+-- ... -+- ... -+---+- ... -+--------...-------+~~~~~~~~~~~~~~~~~~~~
| RuleID | DTag  | W |  FCN  | Fragment Payload | padding (as needed)
+-- ... -+- ... -+---+- ... -+--------...-------+~~~~~~~~~~~~~~~~~~~~

]]></artwork></figure>

</section>
<section anchor="last-fragment-format"><name>Last fragment format</name>

<t>The last fragment of a datagram is sent with an RCS (Reassembly Check Sequence) field to detect residual 
transmission error and possible losses in the last window. <xref target="RFC8724"/> defines a single algorithm based on Ethernet 
CRC computation.</t>

<t>The naming convention is "rcs" followed by the algorithm name.</t>

<t>For Ack-on-Error mode, the All-1 fragment may just contain the RCS or can include a tile. The parameters defines the 
behavior:</t>

<t><list style="symbols">
  <t>all-1-data-no: the last fragment contains no data, just the RCS</t>
  <t>all-1-data-yes: the last fragment includes a single tile and the RCS</t>
  <t>all-1-data-sender-choice: the last fragment may or may not contain a single tile. The receiver can detect if a tile is present.</t>
</list></t>

<t>The naming convention is "all-1-data" followed by the behavior identifier.</t>

</section>
<section anchor="acknowledgment-behavior"><name>Acknowledgment behavior</name>

<t>The acknowledgment fragment header goes in the opposite direction of data. <xref target="RFC8724"/> defines the header, composed of (see <xref target="Fig-frag-ack"/>):</t>

<t><list style="symbols">
  <t>a Dtag (if present).</t>
  <t>a mandatory window as in the data fragment.</t>
  <t>a C bit giving the status of RCS validation.  In case of failure, a bitmap follows, indicating the received tile.</t>
</list></t>

<figure title="Acknowledgment fragment header for RFC8724" anchor="Fig-frag-ack"><artwork><![CDATA[
|--- SCHC ACK Header ----|
         |-- T --|-M-| 1 |
+-- ... -+- ... -+---+---+~~~~~~~~~~~~~~~~~~
| RuleID |  DTag | W |C=1| padding as needed                (success)
+-- ... -+- ... -+---+---+~~~~~~~~~~~~~~~~~~

+-- ... -+- ... -+---+---+------ ... ------+~~~~~~~~~~~~~~~
| RuleID |  DTag | W |C=0|Compressed Bitmap| pad. as needed (failure)
+-- ... -+- ... -+---+---+------ ... ------+~~~~~~~~~~~~~~~

]]></artwork></figure>

<t>For Ack-on-Error, SCHC defines when an acknowledgment can be sent. This can be at any time defined by the layer 2, at the end of a window (FCN all-0) 
or as a response to receiving the last fragment (FCN all-1). The naming convention is "ack-behavior" followed by the algorithm name.</t>

</section>
<section anchor="timer-values"><name>Timer values</name>

<t>The state machine requires some common values to handle fragmentation correctly.</t>

<t><list style="symbols">
  <t>retransmission-timer gives the duration before sending an ack request (cf. section 8.2.2.4. of <xref target="RFC8724"/>). If specified, value MUST be strictly positive.</t>
  <t>inactivity-timer gives  the duration before aborting a fragmentation session (cf. section 8.2.2.4. of <xref target="RFC8724"/>). The value 0 explicitly indicates that this timer is disabled.</t>
</list></t>

<t><xref target="RFC8724"/> do not specified any range for these timers. <xref target="RFC9011"/> recommends a duration of 12 hours. In fact, the value range should be between milliseconds for real time systems to several days. To allow a large range of applications, two parameters must be specified:</t>

<t><list style="symbols">
  <t>the duration of a tick. It is computed by this formula 2^tick-duration/10^6. When tick-duration is set to 0, the unit is the microsecond. The default value of 20 leads to a unit of 1.048575 second. A value of 32 leads to a tick duration of about 1 hour 11 minutes.</t>
  <t>the number of ticks in the predefined unit. With the default tick-duration value of 20, the timers can cover a range between 1.0 sec and 19 hours covering <xref target="RFC9011"/> recommendation.</t>
</list></t>

</section>
<section anchor="fragmentation-parameter"><name>Fragmentation Parameter</name>

<t>The SCHC fragmentation protocol specifies the  the number of attempts before aborting through the parameter:</t>

<t><list style="symbols">
  <t>max-ack-requests  (cf. section 8.2.2.4. of <xref target="RFC8724"/>).</t>
</list></t>

</section>
<section anchor="layer-2-parameters"><name>Layer 2 parameters</name>

<t>The data model includes two parameters needed for fragmentation:</t>

<t><list style="symbols">
  <t>l2-word-size: <xref target="RFC8724"/> base fragmentation, in bits,  on a layer 2 word which can be of any length. The default value is 8 and correspond 
to the default value for byte aligned layer 2. A value of 1 will indicate that there is no alignment and no need for padding.</t>
  <t>maximum-packet-size: defines the maximum size of a uncompressed datagram. By default, the value is set to 1280 bytes.</t>
</list></t>

<t>They are defined as unsigned integers, see <xref target="annexA"/>.</t>

</section>
</section>
</section>
<section anchor="rule-definition"><name>Rule definition</name>

<t>A rule is identified by a unique rule identifier (rule ID) comprising both a Rule ID value and a Rule ID length. 
The YANG grouping rule-id-type defines the structure used to represent a rule ID. A length of 0 is allowed to represent an implicit rule.</t>

<t>Three natures of rules are defined in <xref target="RFC8724"/>:</t>

<t><list style="symbols">
  <t>Compression: a compression rule is associated with the rule ID.</t>
  <t>No compression: this identifies the default rule used to send a packet integrally when no compression rule was found (see <xref target="RFC8724"/> section 6).</t>
  <t>Fragmentation: fragmentation parameters are associated with the rule ID. Fragmentation is optional and feature "fragmentation" should be set.</t>
</list></t>

<t>The YANG data model introduces repectively these three identities :</t>

<t><list style="symbols">
  <t>nature-compresion</t>
  <t>nature-no-compression</t>
  <t>nature-fragmentation</t>
</list></t>

<t>The naming convention is "nature" followed by the nature identifier.</t>

<t>To access a specific rule, the rule ID length and value are used as a key. The rule is either
a compression or a fragmentation rule.</t>

<section anchor="compression-rule"><name>Compression rule</name>

<t>A compression rule is composed of entries describing its processing. An entry  contains all the information defined in <xref target="Fig-ctxt"/> with the types defined above.</t>

<t>The compression rule described <xref target="Fig-ctxt"/> is defined by compression-content. It defines a list of
compression-rule-entry, indexed by their field id, position and direction. The compression-rule-entry 
element represent a line of the table <xref target="Fig-ctxt"/>. Their type reflects the identifier types defined in
<xref target="comp_types"/></t>

<t>Some checks are performed on the values:</t>

<t><list style="symbols">
  <t>target value MUST be present for MO different from ignore.</t>
  <t>when MSB MO is specified, the matching-operator-value must be present</t>
</list></t>

</section>
<section anchor="fragmentation-rule"><name>Fragmentation rule</name>

<t>A Fragmentation rule is composed of entries describing the protocol behavior. Some on them are numerical entries,
others are identifiers defined in <xref target="frag_types"/>.</t>

</section>
<section anchor="yang-tree"><name>YANG Tree</name>

<t>The YANG data model described in this document conforms to the
Network Management Datastore Architecture defined in <xref target="RFC8342"/>.</t>

<figure title="Overview of SCHC data model" anchor="Fig-model-overview"><artwork><![CDATA[
module: ietf-schc
  +--rw schc
     +--rw rule* [rule-id-value rule-id-length]
        +--rw rule-id-value                   uint32
        +--rw rule-id-length                  uint8
        +--rw rule-nature                     nature-type
        +--rw (nature)?
           +--:(fragmentation) {fragmentation}?
           |  +--rw fragmentation-mode
           |  |       schc:fragmentation-mode-type
           |  +--rw l2-word-size?             uint8
           |  +--rw direction                 schc:di-type
           |  +--rw dtag-size?                uint8
           |  +--rw w-size?                   uint8
           |  +--rw fcn-size                  uint8
           |  +--rw rcs-algorithm?            rcs-algorithm-type
           |  +--rw maximum-packet-size?      uint16
           |  +--rw window-size?              uint16
           |  +--rw max-interleaved-frames?   uint8
           |  +--rw inactivity-timer
           |  |  +--rw ticks-duration?   uint8
           |  |  +--rw ticks-numbers?    uint16
           |  +--rw retransmission-timer
           |  |  +--rw ticks-duration?   uint8
           |  |  +--rw ticks-numbers?    uint16
           |  +--rw max-ack-requests?         uint8
           |  +--rw (mode)?
           |     +--:(no-ack)
           |     +--:(ack-always)
           |     +--:(ack-on-error)
           |        +--rw tile-size?          uint8
           |        +--rw tile-in-all-1?      schc:all-1-data-type
           |        +--rw ack-behavior?       schc:ack-behavior-type
           +--:(compression) {compression}?
              +--rw entry*
                      [field-id field-position direction-indicator]
                 +--rw field-id                    schc:fid-type
                 +--rw field-length                schc:fl-type
                 +--rw field-position              uint8
                 +--rw direction-indicator         schc:di-type
                 +--rw target-value* [index]
                 |  +--rw index    uint16
                 |  +--rw value?   binary
                 +--rw matching-operator           schc:mo-type
                 +--rw matching-operator-value* [index]
                 |  +--rw index    uint16
                 |  +--rw value?   binary
                 +--rw comp-decomp-action          schc:cda-type
                 +--rw comp-decomp-action-value* [index]
                    +--rw index    uint16
                    +--rw value?   binary
]]></artwork></figure>

</section>
</section>
<section anchor="annexA"><name>YANG Module</name>

<figure anchor="Fig-schc"><artwork><![CDATA[
<CODE BEGINS> file "ietf-schc@2022-08-25.yang"
module ietf-schc {
  yang-version 1.1;
  namespace "urn:ietf:params:xml:ns:yang:ietf-schc";
  prefix schc;

  organization
    "IETF IPv6 over Low Power Wide-Area Networks (lpwan) working
     group";
  contact
    "WG Web:   <https://datatracker.ietf.org/wg/lpwan/about/>
     WG List:  <mailto:p-wan@ietf.org>
     Editor:   Laurent Toutain
       <mailto:laurent.toutain@imt-atlantique.fr>
     Editor:   Ana Minaburo
       <mailto:ana@ackl.io>";
  description
    "
     Copyright (c) 2022 IETF Trust and the persons identified as
     authors of the code.  All rights reserved.

     Redistribution and use in source and binary forms, with or
     without modification, is permitted pursuant to, and subject to
     the license terms contained in, the Revised BSD License set
     forth in Section 4.c of the IETF Trust's Legal Provisions
     Relating to IETF Documents
     (https://trustee.ietf.org/license-info).

     This version of this YANG module is part of RFC XXXX
     (https://www.rfc-editor.org/info/rfcXXXX); see the RFC itself
     for full legal notices.

     The key words 'MUST', 'MUST NOT', 'REQUIRED', 'SHALL', 'SHALL
     NOT', 'SHOULD', 'SHOULD NOT', 'RECOMMENDED', 'NOT RECOMMENDED',
     'MAY', and 'OPTIONAL' in this document are to be interpreted as
     described in BCP 14 (RFC 2119) (RFC 8174) when, and only when,
     they appear in all capitals, as shown here.

     ***************************************************************

     Generic Data model for Static Context Header Compression Rule
     for SCHC, based on RFC 8724 and RFC8824. Include compression,
     no compression and fragmentation rules.

     This module is a YANG model for SCHC rules (RFC 8724 and
     RFC8824). RFC 8724 describes compression rules in a abstract
     way through a table.

 |-----------------------------------------------------------------|
 |  (FID)            Rule 1                                        |
 |+-------+--+--+--+------------+-----------------+---------------+|
 ||Field 1|FL|FP|DI|Target Value|Matching Operator|Comp/Decomp Act||
 |+-------+--+--+--+------------+-----------------+---------------+|
 ||Field 2|FL|FP|DI|Target Value|Matching Operator|Comp/Decomp Act||
 |+-------+--+--+--+------------+-----------------+---------------+|
 ||...    |..|..|..|   ...      | ...             | ...           ||
 |+-------+--+--+--+------------+-----------------+---------------+|
 ||Field N|FL|FP|DI|Target Value|Matching Operator|Comp/Decomp Act||
 |+-------+--+--+--+------------+-----------------+---------------+|
 |-----------------------------------------------------------------|

     This module specifies a global data model that can be used for
     rule exchanges or modification. It specifies both the data model
     format and the global identifiers used to describe some
     operations in fields.
     This data model applies to both compression and fragmentation.";

  revision 2022-08-25 {
    description
      "Initial version from RFC XXXX.";
    reference
      "RFC XXX: Data Model for Static Context Header Compression
       (SCHC)";
  }

  feature compression {
    description
      "SCHC compression capabilities are taken into account.";
  }

  feature fragmentation {
    description
      "SCHC fragmentation capabilities are taken into account.";
  }

  // -------------------------
  //  Field ID type definition
  //--------------------------
  // generic value TV definition 

  identity fid-base-type {
    description
      "Field ID base type for all fields.";
  }

  identity fid-ipv6-base-type {
    base fid-base-type;
    description
      "Field ID base type for IPv6 headers described in RFC 8200.";
    reference
      "RFC 8200 Internet Protocol, Version 6 (IPv6) Specification";
  }

  identity fid-ipv6-version {
    base fid-ipv6-base-type;
    description
      "IPv6 version field from RFC 8200.";
    reference
      "RFC 8200 Internet Protocol, Version 6 (IPv6) Specification";
  }

  identity fid-ipv6-trafficclass {
    base fid-ipv6-base-type;
    description
      "IPv6 Traffic Class field from RFC 8200.";
    reference
      "RFC 8200 Internet Protocol, Version 6 (IPv6) Specification";
  }

  identity fid-ipv6-trafficclass-ds {
    base fid-ipv6-trafficclass;
    description
      "IPv6 Traffic Class field from RFC 8200,
       DiffServ field from RFC 3168.";
    reference
      "RFC 3168 The Addition of Explicit Congestion Notification
                (ECN) to IP";
  }

  identity fid-ipv6-trafficclass-ecn {
    base fid-ipv6-trafficclass;
    description
      "IPv6 Traffic Class field from RFC 8200,
       ECN field from RFC 3168.";
    reference
      "RFC 3168 The Addition of Explicit Congestion Notification
                (ECN) to IP";
  }

  identity fid-ipv6-flowlabel {
    base fid-ipv6-base-type;
    description
      "IPv6 Flow Label field from RFC8200.";
    reference
      "RFC 8200 Internet Protocol, Version 6 (IPv6) Specification";
  }

  identity fid-ipv6-payload-length {
    base fid-ipv6-base-type;
    description
      "IPv6 Payload Length field from RFC8200.";
    reference
      "RFC 8200 Internet Protocol, Version 6 (IPv6) Specification";
  }

  identity fid-ipv6-nextheader {
    base fid-ipv6-base-type;
    description
      "IPv6 Next Header field from RFC8200.";
    reference
      "RFC 8200 Internet Protocol, Version 6 (IPv6) Specification";
  }

  identity fid-ipv6-hoplimit {
    base fid-ipv6-base-type;
    description
      "IPv6 Next Header field from RFC8200.";
    reference
      "RFC 8200 Internet Protocol, Version 6 (IPv6) Specification";
  }

  identity fid-ipv6-devprefix {
    base fid-ipv6-base-type;
    description
      "Corresponds to either the source address or the destination
       address prefix of RFC 8200. Depending if it is
       respectively an uplink or a downlink message.";
    reference
      "RFC 8200 Internet Protocol, Version 6 (IPv6) Specification";
  }

  identity fid-ipv6-deviid {
    base fid-ipv6-base-type;
    description
      "Corresponds to either the source address or the destination
       address IID of RFC 8200. Depending if it is respectively
       an uplink or a downlink message.";
    reference
      "RFC 8200 Internet Protocol, Version 6 (IPv6) Specification";
  }

  identity fid-ipv6-appprefix {
    base fid-ipv6-base-type;
    description
      "Corresponds to either the source address or the destination
       address prefix of RFC 8200. Depending if it is respectively
       a downlink or an uplink message.";
    reference
      "RFC 8200 Internet Protocol, Version 6 (IPv6) Specification";
  }

  identity fid-ipv6-appiid {
    base fid-ipv6-base-type;
    description
      "Corresponds to either the source address or the destination
       address IID of RFC 8200. Depending if it is respectively
       a downlink or an uplink message.";
    reference
      "RFC 8200 Internet Protocol, Version 6 (IPv6) Specification";
  }

  identity fid-udp-base-type {
    base fid-base-type;
    description
      "Field ID base type for UDP headers described in RFC 768.";
    reference
      "RFC 768 User Datagram Protocol";
  }

  identity fid-udp-dev-port {
    base fid-udp-base-type;
    description
      "UDP source or destination port from RFC 768, if uplink or
       downlink communication, respectively.";
    reference
      "RFC 768 User Datagram Protocol";
  }

  identity fid-udp-app-port {
    base fid-udp-base-type;
    description
      "UDP destination or source port from RFC 768, if uplink or
       downlink communication, respectively.";
    reference
      "RFC 768 User Datagram Protocol";
  }

  identity fid-udp-length {
    base fid-udp-base-type;
    description
      "UDP length from RFC 768.";
    reference
      "RFC 768 User Datagram Protocol";
  }

  identity fid-udp-checksum {
    base fid-udp-base-type;
    description
      "UDP length from RFC 768.";
    reference
      "RFC 768 User Datagram Protocol";
  }

  identity fid-coap-base-type {
    base fid-base-type;
    description
      "Field ID base type for UDP headers described in RFC 7252.";
    reference
      "RFC 7252 The Constrained Application Protocol (CoAP)";
  }

  identity fid-coap-version {
    base fid-coap-base-type;
    description
      "CoAP version from RFC 7252.";
    reference
      "RFC 7252 The Constrained Application Protocol (CoAP)";
  }

  identity fid-coap-type {
    base fid-coap-base-type;
    description
      "CoAP type from RFC 7252.";
    reference
      "RFC 7252 The Constrained Application Protocol (CoAP)";
  }

  identity fid-coap-tkl {
    base fid-coap-base-type;
    description
      "CoAP token length from RFC 7252.";
    reference
      "RFC 7252 The Constrained Application Protocol (CoAP)";
  }

  identity fid-coap-code {
    base fid-coap-base-type;
    description
      "CoAP code from RFC 7252.";
    reference
      "RFC 7252 The Constrained Application Protocol (CoAP)";
  }

  identity fid-coap-code-class {
    base fid-coap-code;
    description
      "CoAP code class from RFC 7252.";
    reference
      "RFC 7252 The Constrained Application Protocol (CoAP)";
  }

  identity fid-coap-code-detail {
    base fid-coap-code;
    description
      "CoAP code detail from RFC 7252.";
    reference
      "RFC 7252 The Constrained Application Protocol (CoAP)";
  }

  identity fid-coap-mid {
    base fid-coap-base-type;
    description
      "CoAP message ID from RFC 7252.";
    reference
      "RFC 7252 The Constrained Application Protocol (CoAP)";
  }

  identity fid-coap-token {
    base fid-coap-base-type;
    description
      "CoAP token from RFC 7252.";
    reference
      "RFC 7252 The Constrained Application Protocol (CoAP)";
  }

  identity fid-coap-option-if-match {
    base fid-coap-base-type;
    description
      "CoAP option If-Match from RFC 7252.";
    reference
      "RFC 7252 The Constrained Application Protocol (CoAP)";
  }

  identity fid-coap-option-uri-host {
    base fid-coap-base-type;
    description
      "CoAP option URI-Host from RFC 7252.";
    reference
      "RFC 7252 The Constrained Application Protocol (CoAP)";
  }

  identity fid-coap-option-etag {
    base fid-coap-base-type;
    description
      "CoAP option Etag from RFC 7252.";
    reference
      "RFC 7252 The Constrained Application Protocol (CoAP)";
  }

  identity fid-coap-option-if-none-match {
    base fid-coap-base-type;
    description
      "CoAP option if-none-match from RFC 7252.";
    reference
      "RFC 7252 The Constrained Application Protocol (CoAP)";
  }

  identity fid-coap-option-observe {
    base fid-coap-base-type;
    description
      "CoAP option Observe from RFC 7641.";
    reference
      "RFC 7252 The Constrained Application Protocol (CoAP)";
  }

  identity fid-coap-option-uri-port {
    base fid-coap-base-type;
    description
      "CoAP option Uri-Port from RFC 7252.";
    reference
      "RFC 7252 The Constrained Application Protocol (CoAP)";
  }

  identity fid-coap-option-location-path {
    base fid-coap-base-type;
    description
      "CoAP option Location-Path from RFC 7252.";
    reference
      "RFC 7252 The Constrained Application Protocol (CoAP)";
  }

  identity fid-coap-option-uri-path {
    base fid-coap-base-type;
    description
      "CoAP option Uri-Path from RFC 7252.";
    reference
      "RFC 7252 The Constrained Application Protocol (CoAP)";
  }

  identity fid-coap-option-content-format {
    base fid-coap-base-type;
    description
      "CoAP option Content Format from RFC 7252.";
    reference
      "RFC 7252 The Constrained Application Protocol (CoAP)";
  }

  identity fid-coap-option-max-age {
    base fid-coap-base-type;
    description
      "CoAP option Max-Age from RFC 7252.";
    reference
      "RFC 7252 The Constrained Application Protocol (CoAP)";
  }

  identity fid-coap-option-uri-query {
    base fid-coap-base-type;
    description
      "CoAP option Uri-Query from RFC 7252.";
    reference
      "RFC 7252 The Constrained Application Protocol (CoAP)";
  }

  identity fid-coap-option-accept {
    base fid-coap-base-type;
    description
      "CoAP option Accept from RFC 7252.";
    reference
      "RFC 7252 The Constrained Application Protocol (CoAP)";
  }

  identity fid-coap-option-location-query {
    base fid-coap-base-type;
    description
      "CoAP option Location-Query from RFC 7252.";
    reference
      "RFC 7252 The Constrained Application Protocol (CoAP)";
  }

  identity fid-coap-option-block2 {
    base fid-coap-base-type;
    description
      "CoAP option Block2 from RFC 7959.";
    reference
      "RFC 7959 Block-Wise Transfers in the Constrained
                Application Protocol (CoAP)";
  }

  identity fid-coap-option-block1 {
    base fid-coap-base-type;
    description
      "CoAP option Block1 from RFC 7959.";
    reference
      "RFC 7959 Block-Wise Transfers in the Constrained
                Application Protocol (CoAP)";
  }

  identity fid-coap-option-size2 {
    base fid-coap-base-type;
    description
      "CoAP option size2 from RFC 7959.";
    reference
      "RFC 7959 Block-Wise Transfers in the Constrained
                Application Protocol (CoAP)";
  }

  identity fid-coap-option-proxy-uri {
    base fid-coap-base-type;
    description
      "CoAP option Proxy-Uri from RFC 7252.";
    reference
      "RFC 7252 The Constrained Application Protocol (CoAP)";
  }

  identity fid-coap-option-proxy-scheme {
    base fid-coap-base-type;
    description
      "CoAP option Proxy-scheme from RFC 7252.";
    reference
      "RFC 7252 The Constrained Application Protocol (CoAP)";
  }

  identity fid-coap-option-size1 {
    base fid-coap-base-type;
    description
      "CoAP option Size1 from RFC 7252.";
    reference
      "RFC 7252 The Constrained Application Protocol (CoAP)";
  }

  identity fid-coap-option-no-response {
    base fid-coap-base-type;
    description
      "CoAP option No response from RFC 7967.";
    reference
      "RFC 7967 Constrained Application Protocol (CoAP)
                Option for No Server Response";
  }

  identity fid-oscore-base-type {
    base fid-coap-type;
    description
      "OSCORE options (RFC8613) split by RFC 8824 in sub options.";
    reference
      "RFC 8824 Static Context Header Compression (SCHC) for the
                Constrained Application Protocol (CoAP)";
  }

  identity fid-coap-option-oscore-flags {
    base fid-oscore-base-type;
    description
      "CoAP option oscore flags (see RFC 8824, section 6.4).";
    reference
      "RFC 8824 Static Context Header Compression (SCHC) for the
                Constrained Application Protocol (CoAP)";
  }

  identity fid-coap-option-oscore-piv {
    base fid-oscore-base-type;
    description
      "CoAP option oscore flags (see RFC 8824, section 6.4).";
    reference
      "RFC 8824 Static Context Header Compression (SCHC) for the
                Constrained Application Protocol (CoAP)";
  }

  identity fid-coap-option-oscore-kid {
    base fid-oscore-base-type;
    description
      "CoAP option oscore flags (see RFC 8824, section 6.4).";
    reference
      "RFC 8824 Static Context Header Compression (SCHC) for the
                Constrained Application Protocol (CoAP)";
  }

  identity fid-coap-option-oscore-kidctx {
    base fid-oscore-base-type;
    description
      "CoAP option oscore flags (see RFC 8824, section 6.4).";
    reference
      "RFC 8824 Static Context Header Compression (SCHC) for the
                Constrained Application Protocol (CoAP)";
  }

  //----------------------------------
  // Field Length type definition
  //----------------------------------

  identity fl-base-type {
    description
      "Used to extend field length functions.";
  }

  identity fl-variable {
    base fl-base-type;
    description
      "Residue length in Byte is sent as defined
       for CoAP in RFC 8824 (cf. 5.3).";
    reference
      "RFC 8824 Static Context Header Compression (SCHC) for the
                Constrained Application Protocol (CoAP)";
  }

  identity fl-token-length {
    base fl-base-type;
    description
      "Residue length in Byte is sent as defined
       for CoAP in RFC 8824 (cf. 4.5).";
    reference
      "RFC 8824 Static Context Header Compression (SCHC) for the
                Constrained Application Protocol (CoAP)";
  }

  //---------------------------------
  // Direction Indicator type
  //---------------------------------

  identity di-base-type {
    description
      "Used to extend direction indicators.";
  }

  identity di-bidirectional {
    base di-base-type;
    description
      "Direction Indication of bidirectionality in
       RFC 8724 (cf. 7.1).";
    reference
      "RFC 8724 SCHC: Generic Framework for Static Context
                Header Compression and Fragmentation";
  }

  identity di-up {
    base di-base-type;
    description
      "Direction Indication of uplink defined in
       RFC 8724 (cf. 7.1).";
    reference
      "RFC 8724 SCHC: Generic Framework for Static Context
                Header Compression and Fragmentation";
  }

  identity di-down {
    base di-base-type;
    description
      "Direction Indication of downlink defined in
       RFC 8724 (cf. 7.1).";
    reference
      "RFC 8724 SCHC: Generic Framework for Static Context
                Header Compression and Fragmentation";
  }

  //----------------------------------
  // Matching Operator type definition
  //----------------------------------

  identity mo-base-type {
    description
      "Matching Operator: used in the rule selection process
       defined in RFC 8724 (cf. 7.2) to check is a Target Value
       matches the field's value.";
    reference
      "RFC 8724 SCHC: Generic Framework for Static Context
                Header Compression and Fragmentation";
  }

  identity mo-equal {
    base mo-base-type;
    description
      "equal MO as defined in RFC 8724 (cf. 7.3).";
    reference
      "RFC 8724 SCHC: Generic Framework for Static Context
                Header Compression and Fragmentation";
  }

  identity mo-ignore {
    base mo-base-type;
    description
      "ignore MO as defined in RFC 8724 (cf. 7.3).";
    reference
      "RFC 8724 SCHC: Generic Framework for Static Context
                Header Compression and Fragmentation";
  }

  identity mo-msb {
    base mo-base-type;
    description
      "MSB MO as defined in RFC 8724 (cf. 7.3).";
    reference
      "RFC 8724 SCHC: Generic Framework for Static Context
                Header Compression and Fragmentation";
  }

  identity mo-match-mapping {
    base mo-base-type;
    description
      "match-mapping MO as defined in RFC 8724 (cf. 7.3).";
    reference
      "RFC 8724 SCHC: Generic Framework for Static Context
                Header Compression and Fragmentation";
  }

  //------------------------------
  // CDA type definition
  //------------------------------

  identity cda-base-type {
    description
      "Compression Decompression Actions. Specify the action to
       be applied to the field's value in a specific rule as
       defined in RFC8724 (cf. 7.2)";
    reference
      "RFC 8724 SCHC: Generic Framework for Static Context
                Header Compression and Fragmentation";
  }

  identity cda-not-sent {
    base cda-base-type;
    description
      "not-sent CDA as defined in RFC 8724 (cf. 7.4).";
    reference
      "RFC 8724 SCHC: Generic Framework for Static Context
                Header Compression and Fragmentation";
  }

  identity cda-value-sent {
    base cda-base-type;
    description
      "value-sent CDA as defined in RFC 8724 (cf. 7.4).";
  }

  identity cda-lsb {
    base cda-base-type;
    description
      "LSB CDA as defined in RFC 8724 (cf. 7.4).";
    reference
      "RFC 8724 SCHC: Generic Framework for Static Context
                Header Compression and Fragmentation";
  }

  identity cda-mapping-sent {
    base cda-base-type;
    description
      "mapping-sent CDA as defined in RFC 8724 (cf. 7.4).";
    reference
      "RFC 8724 SCHC: Generic Framework for Static Context
                Header Compression and Fragmentation";
  }

  identity cda-compute {
    base cda-base-type;
    description
      "compute-* CDA as defined in RFC 8724 (cf. 7.4).";
    reference
      "RFC 8724 SCHC: Generic Framework for Static Context
                Header Compression and Fragmentation";
  }

  identity cda-deviid {
    base cda-base-type;
    description
      "DevIID CDA as defined in RFC 8724 (cf. 7.4).";
    reference
      "RFC 8724 SCHC: Generic Framework for Static Context
                Header Compression and Fragmentation";
  }

  identity cda-appiid {
    base cda-base-type;
    description
      "AppIID CDA as defined in RFC 8724 (cf. 7.4).";
    reference
      "RFC 8724 SCHC: Generic Framework for Static Context
                Header Compression and Fragmentation";
  }

  // -- type definition

  typedef fid-type {
    type identityref {
      base fid-base-type;
    }
    description
      "Field ID generic type.";
    reference
      "RFC 8724 SCHC: Generic Framework for Static Context Header
                Compression and Fragmentation";
  }

  typedef fl-type {
    type union {
      type uint64; /* positive integer, expressing length in bits */
      type identityref { /* function */
        base fl-base-type;
      }
    }
    description
      "Field length either a positive integer expressing the size in
       bits or a function defined through an identityref.";
    reference
      "RFC 8724 SCHC: Generic Framework for Static Context Header
                Compression and Fragmentation";
  }

  typedef di-type {
    type identityref {
      base di-base-type;
    }
    description
      "Direction in LPWAN network, up when emitted by the device,
       down when received by the device, bi when emitted or
       received by the device.";
    reference
      "RFC 8724 SCHC: Generic Framework for Static Context Header
                Compression and Fragmentation";
  }

  typedef mo-type {
    type identityref {
      base mo-base-type;
    }
    description
      "Matching Operator (MO) to compare fields values with
       target values.";
    reference
      "RFC 8724 SCHC: Generic Framework for Static Context Header
                Compression and Fragmentation";
  }

  typedef cda-type {
    type identityref {
      base cda-base-type;
    }
    description
      "Compression Decompression Action to compression or
       decompress a field.";
    reference
      "RFC 8724 SCHC: Generic Framework for Static Context Header
                Compression and Fragmentation";
  }

  // -- FRAGMENTATION TYPE
  // -- fragmentation modes

  identity fragmentation-mode-base-type {
    description
      "Define the fragmentation mode.";
    reference
      "RFC 8724 SCHC: Generic Framework for Static Context Header
                Compression and Fragmentation";
  }

  identity fragmentation-mode-no-ack {
    base fragmentation-mode-base-type;
    description
      "No-ACK of RFC8724.";
    reference
      "RFC 8724 SCHC: Generic Framework for Static Context Header
                Compression and Fragmentation";
  }

  identity fragmentation-mode-ack-always {
    base fragmentation-mode-base-type;
    description
      "ACK-Always of RFC8724.";
    reference
      "RFC 8724 SCHC: Generic Framework for Static Context Header
                Compression and Fragmentation";
  }

  identity fragmentation-mode-ack-on-error {
    base fragmentation-mode-base-type;
    description
      "ACK-on-Error of RFC8724.";
    reference
      "RFC 8724 SCHC: Generic Framework for Static Context Header
                Compression and Fragmentation";
  }

  typedef fragmentation-mode-type {
    type identityref {
      base fragmentation-mode-base-type;
    }
    description
      "Define the type used for fragmentation mode in rules.";
  }

  // -- Ack behavior 

  identity ack-behavior-base-type {
    description
      "Define when to send an Acknowledgment .";
    reference
      "RFC 8724 SCHC: Generic Framework for Static Context Header
                Compression and Fragmentation";
  }

  identity ack-behavior-after-all-0 {
    base ack-behavior-base-type;
    description
      "Fragmentation expects Ack after sending All-0 fragment.";
  }

  identity ack-behavior-after-all-1 {
    base ack-behavior-base-type;
    description
      "Fragmentation expects Ack after sending All-1 fragment.";
  }

  identity ack-behavior-by-layer2 {
    base ack-behavior-base-type;
    description
      "Layer 2 defines when to send an Ack.";
  }

  typedef ack-behavior-type {
    type identityref {
      base ack-behavior-base-type;
    }
    description
      "Define the type used for Ack behavior in rules.";
  }

  // -- All-1 with data types

  identity all-1-data-base-type {
    description
      "Type to define when to send an Acknowledgment message.";
    reference
      "RFC 8724 SCHC: Generic Framework for Static Context Header
                Compression and Fragmentation";
  }

  identity all-1-data-no {
    base all-1-data-base-type;
    description
      "All-1 contains no tiles.";
  }

  identity all-1-data-yes {
    base all-1-data-base-type;
    description
      "All-1 MUST contain a tile.";
  }

  identity all-1-data-sender-choice {
    base all-1-data-base-type;
    description
      "Fragmentation process chooses to send tiles or not in All-1.";
  }

  typedef all-1-data-type {
    type identityref {
      base all-1-data-base-type;
    }
    description
      "Define the type used for All-1 format in rules.";
  }

  // -- RCS algorithm types

  identity rcs-algorithm-base-type {
    description
      "Identify which algorithm is used to compute RCS.
       The algorithm also defines the size of the RCS field.";
    reference
      "RFC 8724 SCHC: Generic Framework for Static Context Header
                Compression and Fragmentation";
  }

  identity rcs-RFC8724 {
    base rcs-algorithm-base-type;
    description
      "CRC 32 defined as default RCS in RFC8724. This RCS is
       4 bytes long.";
    reference
      "RFC 8724 SCHC: Generic Framework for Static Context Header
                Compression and Fragmentation";
  }

  typedef rcs-algorithm-type {
    type identityref {
      base rcs-algorithm-base-type;
    }
    description
      "Define the type for RCS algorithm in rules.";
  }

  // --------- TIMER DURATION -------------------

  grouping timer-duration {
    leaf ticks-duration {
      type uint8;
      default "20";
      description
        "Duration of one tick in micro-seconds:
            2^ticks-duration/10^6 = 1.048s.";
    }
    leaf ticks-numbers {
      type uint16;
      description
        "Timer duration = ticks-numbers * 2^ticks-duration / 10^6.";
    }
    description
      "Used by inactivity and retransmission timer. Allows a
       precision from micro-second to year by sending the
       tick-duration value.
       For instance:

       tick-duration /  smallest value          highest value
       v
       20: 00y 000d 00h 00m 01s.048575<->00y 000d 19h 05m 18s.428159
       21: 00y 000d 00h 00m 02s.097151<->00y 001d 14h 10m 36s.856319
       22: 00y 000d 00h 00m 04s.194303<->00y 003d 04h 21m 13s.712639
       23: 00y 000d 00h 00m 08s.388607<->00y 006d 08h 42m 27s.425279
       24: 00y 000d 00h 00m 16s.777215<->00y 012d 17h 24m 54s.850559
       25: 00y 000d 00h 00m 33s.554431<->00y 025d 10h 49m 49s.701119

       Note that the smallest value is also the incrementation step,
       so the timer precision.
      ";
    reference
      "RFC 8724 SCHC: Generic Framework for Static Context Header
                Compression and Fragmentation";
  }

  // --------  RULE ENTRY DEFINITION ------------

  grouping tv-struct {
    description
      "Defines the target value element. If the header field
       contains a text, the binary sequence uses the same encoding.
       field-id allows the conversion to the appropriate type.";
    leaf index {
      type uint16;
      description
        "Index gives the position in the matching-list. If only one
         element is present, index is 0. Otherwise, index is the
         the order in the matching list, starting at 0.";
    }
    leaf value {
      type binary;
      description
        "Target Value content as a untyped binary value.";
    }
    reference
      "RFC 8724 SCHC: Generic Framework for Static Context Header
                Compression and Fragmentation";
  }

  grouping compression-rule-entry {
    description
      "These entries defines a compression entry (i.e. a line)
       as defined in RFC 8724.

   +-------+--+--+--+------------+-----------------+---------------+
   |Field 1|FL|FP|DI|Target Value|Matching Operator|Comp/Decomp Act|
   +-------+--+--+--+------------+-----------------+---------------+

       An entry in a compression rule is composed of 7 elements:
       - Field ID: The header field to be compressed.
       - Field Length : Either a positive integer of a function.
       - Field Position: A positive (and possibly equal to 0)
         integer.
       - Direction Indicator: An indication in which direction
         compression and decompression process is effective.
       - Target value: A value against which the header Field is
         compared.
       - Matching Operator: The comparison operation and optional
         associate parameters.
       - Comp./Decomp. Action: The compression or decompression
         action, and optional parameters.
      ";
    leaf field-id {
      type schc:fid-type;
      mandatory true;
      description
        "Field ID, identify a field in the header with a YANG
         identity reference.";
    }
    leaf field-length {
      type schc:fl-type;
      mandatory true;
      description
        "Field Length, expressed in number of bits if the length is
         known when the Rule is created or through a specific
         function if the length is variable.";
    }
    leaf field-position {
      type uint8;
      mandatory true;
      description
        "Field position in the header is an integer. Position 1
         matches the first occurrence of a field in the header,
         while incremented position values match subsequent
         occurrences.
         Position 0 means that this entry matches a field
         irrespective of its position of occurrence in the
         header.
         Be aware that the decompressed header may have
         position-0 fields ordered differently than they
         appeared in the original packet.";
    }
    leaf direction-indicator {
      type schc:di-type;
      mandatory true;
      description
        "Direction Indicator, indicate if this field must be
         consider for rule selection or ignored based on the
         direction (bi directionnal, only uplink, or only
         downlink).";
    }
    list target-value {
      key "index";
      uses tv-struct;
      description
        "A list of value to compare with the header field value.
         If target value is a singleton, position must be 0.
         For use as a matching list for the mo-match-mapping matching
         operator, index should take consecutive values starting
         from 0.";
    }
    leaf matching-operator {
      type schc:mo-type;
      must "../target-value or derived-from-or-self(., 
                                                   'mo-ignore')" {
        error-message
          "mo-equal, mo-msb and mo-match-mapping need target-value";
        description
          "target-value is not required for mo-ignore.";
      }
      must "not (derived-from-or-self(., 'mo-msb')) or
            ../matching-operator-value" {
        error-message "mo-msb requires length value";
      }
      mandatory true;
      description
        "MO: Matching Operator (cf. Section 7.3 of RFC 8724).";
    }
    list matching-operator-value {
      key "index";
      uses tv-struct;
      description
        "Matching Operator Arguments, based on TV structure to allow
         several arguments.
         In RFC 8724, only the MSB matching operator needs arguments
         (a single argument, which is the number of most significant
         bits to be matched).";
    }
    leaf comp-decomp-action {
      type schc:cda-type;
      mandatory true;
      description
        "CDA: Compression Decompression Action (cf. Section 7.4 of 
         RFC 8724).";
    }
    list comp-decomp-action-value {
      key "index";
      uses tv-struct;
      description
        "CDA arguments, based on a TV structure, in order to allow
         for several arguments. The CDAs specified in RFC 8724
         require no argument.";
    }
    reference
      "RFC 8724 SCHC: Generic Framework for Static Context Header
                Compression and Fragmentation";
  }

  // --Rule nature

  identity nature-base-type {
    description
      "A rule, identified by its RuleID, are used for a single
       purpose. RFC 8724 Section 6. defines 2 natures: 
       compression, no compression and fragmentation.";
    reference
      "RFC 8724 SCHC: Generic Framework for Static Context Header
                Compression and Fragmentation";
  }

  identity nature-compression {
    base nature-base-type;
    description
      "Identify a compression rule, as defined in section 6 of
        RFC 8724.";
    reference
      "RFC 8724 SCHC: Generic Framework for Static Context Header
                Compression and Fragmentation";
  }

  identity nature-no-compression {
    base nature-base-type;
    description
      "Identify a no compression rule, as defined in section 6 of
        RFC 8724.";
    reference
      "RFC 8724 SCHC: Generic Framework for Static Context Header
                Compression and Fragmentation";
  }

  identity nature-fragmentation {
    base nature-base-type;
    description
      "Identify a fragmentation rule, as defined in section 6 of
        RFC 8724.";
    reference
      "RFC 8724 SCHC: Generic Framework for Static Context Header
                Compression and Fragmentation";
  }

  typedef nature-type {
    type identityref {
      base nature-base-type;
    }
    description
      "defines the type to indicate the nature of the rule.";
  }

  grouping compression-content {
    list entry {
      must "derived-from-or-self(../rule-nature,
                                        'nature-compression')" {
        error-message "Rule nature must be compression";
      }
      key "field-id field-position direction-indicator";
      uses compression-rule-entry;
      description
        "A compression rule is a list of rule entries, each
         describing a header field. An entry is identified
         through a field-id, its position in the packet, and
         its direction.";
    }
    description
      "Define a compression rule composed of a list of entries.";
    reference
      "RFC 8724 SCHC: Generic Framework for Static Context Header
                Compression and Fragmentation";
  }

  grouping fragmentation-content {
    description
      "This grouping defines the fragmentation parameters for
       all the modes (No-ACK, ACK-Always and ACK-on-Error) specified
       in RFC 8724.";
    leaf fragmentation-mode {
      type schc:fragmentation-mode-type;
      must "derived-from-or-self(../rule-nature,
                                        'nature-fragmentation')" {
        error-message "Rule nature must be fragmentation";
      }
      mandatory true;
      description
        "Which fragmentation mode is used (No-Ack, ACK-Always,
         ACK-on-Error).";
    }
    leaf l2-word-size {
      type uint8;
      default "8";
      description
        "Size, in bits, of the layer 2 word.";
    }
    leaf direction {
      type schc:di-type;
      must "derived-from-or-self(., 'di-up') or
            derived-from-or-self(., 'di-down')" {
        error-message
          "Direction for fragmentation rules are up or down.";
      }
      mandatory true;
      description
        "MUST be up or down, bidirectional MUST NOT be used.";
    }
    // SCHC Frag header format 
    leaf dtag-size {
      type uint8;
      default "0";
      description
        "Size, in bits, of the DTag field (T variable from
         RFC8724).";
    }
    leaf w-size {
      when "derived-from-or-self(../fragmentation-mode,
                                'fragmentation-mode-ack-on-error')
            or
            derived-from-or-self(../fragmentation-mode,
                                'fragmentation-mode-ack-always') ";
      type uint8;
      description
        "Size, in bits, of the window field (M variable from
         RFC8724).";
    }
    leaf fcn-size {
      type uint8;
      mandatory true;
      description
        "Size, in bits, of the FCN field (N variable from RFC8724).";
    }
    leaf rcs-algorithm {
      type rcs-algorithm-type;
      default "schc:rcs-RFC8724";
      description
        "Algorithm used for RCS. The algorithm specifies the RCS
         size.";
    }
    // SCHC fragmentation protocol parameters
    leaf maximum-packet-size {
      type uint16;
      default "1280";
      description
        "When decompression is done, packet size must not
         strictly exceed this limit, expressed in bytes.";
    }
    leaf window-size {
      type uint16;
      description
        "By default, if not specified 2^w-size - 1. Should not exceed
         this value. Possible FCN values are between 0 and
         window-size - 1.";
    }
    leaf max-interleaved-frames {
      type uint8;
      default "1";
      description
        "Maximum of simultaneously fragmented frames. Maximum value
         is 2^dtag-size. All DTAG values can be used, but more than
         max-interleaved-frames MUST NOT be active at any time";
    }
    container inactivity-timer {
      uses timer-duration;
      description
        "Duration is seconds of the inactivity timer, 0 indicates
         that the timer is disabled.";
    }
    container retransmission-timer {
      uses timer-duration;
      when "derived-from-or-self(../fragmentation-mode,
                                'fragmentation-mode-ack-on-error')
            or
            derived-from-or-self(../fragmentation-mode,
                                'fragmentation-mode-ack-always') ";
      description
        "Duration in seconds of the retransmission timer.";
    }
    leaf max-ack-requests {
      when "derived-from-or-self(../fragmentation-mode,
                                'fragmentation-mode-ack-on-error')
            or
            derived-from-or-self(../fragmentation-mode,
                                'fragmentation-mode-ack-always') ";
      type uint8 {
        range "1..max";
      }
      description
        "The maximum number of retries for a specific SCHC ACK.";
    }
    choice mode {
      case no-ack;
      case ack-always;
      case ack-on-error {
        leaf tile-size {
          when "derived-from-or-self(../fragmentation-mode,
                             'fragmentation-mode-ack-on-error')";
          type uint8;
          description
            "Size, in bits, of tiles. If not specified or set to 0,
             tiles fill the fragment.";
        }
        leaf tile-in-all-1 {
          when "derived-from-or-self(../fragmentation-mode,
                             'fragmentation-mode-ack-on-error')";
          type schc:all-1-data-type;
          description
            "Defines whether the sender and receiver expect a tile in
             All-1 fragments or not, or if it is left to the sender's
             choice.";
        }
        leaf ack-behavior {
          when "derived-from-or-self(../fragmentation-mode,
                             'fragmentation-mode-ack-on-error')";
          type schc:ack-behavior-type;
          description
            "Sender behavior to acknowledge, after All-0, All-1 or
             when the LPWAN allows it.";
        }
      }
      description
        "RFC 8724 defines 3 fragmentation modes.";
    }
    reference
      "RFC 8724 SCHC: Generic Framework for Static Context Header
                Compression and Fragmentation";
  }

  // Define rule ID. Rule ID is composed of a RuleID value and a 
  // Rule ID Length

  grouping rule-id-type {
    leaf rule-id-value {
      type uint32;
      description
        "Rule ID value, this value must be unique, considering its
         length.";
    }
    leaf rule-id-length {
      type uint8 {
        range "0..32";
      }
      description
        "Rule ID length, in bits. The value 0 is for implicit
         rules.";
    }
    description
      "A rule ID is composed of a value and a length, expressed in
       bits.";
    reference
      "RFC 8724 SCHC: Generic Framework for Static Context Header
                Compression and Fragmentation";
  }

  // SCHC table for a specific device.

  container schc {
    list rule {
      key "rule-id-value rule-id-length";
      uses rule-id-type;
      leaf rule-nature {
        type nature-type;
        mandatory true;
        description
          "Specify the rule's nature.";
      }
      choice nature {
        case fragmentation {
          if-feature "fragmentation";
          uses fragmentation-content;
        }
        case compression {
          if-feature "compression";
          uses compression-content;
        }
        description
          "A rule is for compression, for no-compression or for
           fragmentation.";
      }
      description
        "Set of rules compression, no compression or fragmentation
         rules identified by their rule-id.";
    }
    description
      "A SCHC set of rules is composed of a list of rules which are
       used for compression, no-compression or fragmentation.";
    reference
      "RFC 8724 SCHC: Generic Framework for Static Context Header
                Compression and Fragmentation";
  }
}
<CODE ENDS>
]]></artwork></figure>

</section>
<section anchor="implementation-status"><name>Implementation Status</name>

<!--NOTE TO RFC EDITOR:  remove the entire section before
   publication, as well as the reference to RFC 7942. -->

<t>This section records the status of known implementations of the
protocol defined by this specification at the time of posting of
this Internet-Draft, and is based on a proposal described in
<xref target="RFC7942"/>.  The description of implementations in this section is
intended to assist the IETF in its decision processes in
progressing drafts to RFCs.  Please note that the listing of any
individual implementation here does not imply endorsement by the
IETF.  Furthermore, no effort has been spent to verify the
information presented here that was supplied by IETF contributors.
This is not intended as, and must not be construed to be, a
catalog of available implementations or their features.  Readers
are advised to note that other implementations may exist.</t>

<t>According to <xref target="RFC7942"/>, "this will allow reviewers and working
groups to assign due consideration to documents that have the
benefit of running code, which may serve as evidence of valuable
experimentation and feedback that have made the implemented
protocols more mature.  It is up to the individual working groups
to use this information as they see fit".</t>

<t><list style="symbols">
  <t>Openschc is implementing the conversion between the local rule 
representation and the representation conforming to the data model 
in JSON and CBOR (following -08 draft).</t>
</list></t>

</section>
<section anchor="iana-considerations"><name>IANA Considerations</name>

<t>This document registers one URIs and one YANG modules.</t>

<section anchor="uri-registration"><name>  URI Registration</name>

<t>This document requests IANA to register the following four URIs in the "IETF XML Registry" <xref target="RFC3688"/>:</t>

<ul empty="true"><li>
  <t>URI:  urn:ietf:params:xml:ns:yang:ietf-schc</t>
</li></ul>

<ul empty="true"><li>
  <t>Registrant Contact:  The IESG.</t>
</li></ul>

<ul empty="true"><li>
  <t>XML:  N/A; the requested URI is an XML namespace.</t>
</li></ul>

</section>
<section anchor="yang-module-name-registration"><name>  YANG Module Name Registration</name>

<t>This document registers the following one YANG modules in the "YANG Module Names" registry <xref target="RFC6020"/>.</t>

<ul empty="true"><li>
  <t>name:           ietf-schc</t>
</li></ul>

<ul empty="true"><li>
  <t>namespace:      urn:ietf:params:xml:ns:yang:ietf-schc</t>
</li></ul>

<ul empty="true"><li>
  <t>prefix:         schc</t>
</li></ul>

<ul empty="true"><li>
  <t>reference:      RFC XXXX Data Model for Static Context Header Compression (SCHC)</t>
</li></ul>

</section>
</section>
<section anchor="security-considerations"><name>Security Considerations</name>

<t>The YANG module specified in this document defines a schema for data that is designed to be accessed via network management protocols such as NETCONF <xref target="RFC6241"/> or RESTCONF <xref target="RFC8040"/>. The lowest NETCONF layer is the secure transport layer, and the mandatory-to-implement secure transport is Secure Shell (SSH) <xref target="RFC6242"/>. The lowest RESTCONF layer is HTTPS, and the mandatory-to-implement secure transport is TLS 
<xref target="RFC8446"/>.</t>

<t>The Network Configuration Access Control Model (NACM) <xref target="RFC8341"/> provides the means to restrict access for particular NETCONF or RESTCONF users to a preconfigured subset of all available NETCONF or RESTCONF protocol operations and content.</t>

<t>This data model formalizes the rules elements described in <xref target="RFC8724"/> for compression, and fragmentation. As explained in the architecture document <xref target="I-D.ietf-lpwan-architecture"/>, a rule can be read, created, updated or deleted in response to a management request. These actions can be done between two instances of SCHC or between a SCHC instance and a rule repository.</t>

<figure><artwork><![CDATA[
                     create
          (-------)  read   +=======+ *
          ( rules )<------->|Rule   |<--|-------->
          (-------)  update |Manager|   NETCONF, RESTCONF or CORECONF
             . read  delete +=======+   request
             .
          +-------+
      <===| R & D |<===
      ===>| C & F |===>
          +-------+
]]></artwork></figure>

<t>The rule contains some sensible informations such as the application IPv6 address. An attacker by changing a rule content may block the communication or intercept the traffic. Therefore, the identity of the requester must be validated. This can be done through certificates or access lists.</t>

<t>The full tree is sensitive, since it represents all the elements that can be managed.  This module aims to be encapsulated into a YANG module including access controls and identities.</t>

</section>
<section anchor="acknowledgements"><name>Acknowledgements</name>

<t>The authors would like to thank Dominique Barthel, Carsten Bormann, Ivan Martinez, Alexander Pelov for their careful reading and valuable inputs. A special thanks for 
Joe Clarke, Carl Moberg, Tom Petch, Martin Thomson, 
and Eric Vyncke for their explanations and wise advices when building the model.</t>

</section>


  </middle>

  <back>


    <references title='Normative References'>




<reference anchor='RFC0768' target='https://www.rfc-editor.org/info/rfc768'>
  <front>
    <title>User Datagram Protocol</title>
    <author fullname='J. Postel' surname='Postel'/>
    <date month='August' year='1980'/>
  </front>
  <seriesInfo name='STD' value='6'/>
  <seriesInfo name='RFC' value='768'/>
  <seriesInfo name='DOI' value='10.17487/RFC0768'/>
</reference>


<reference anchor='RFC2119' target='https://www.rfc-editor.org/info/rfc2119'>
  <front>
    <title>Key words for use in RFCs to Indicate Requirement Levels</title>
    <author fullname='S. Bradner' 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='RFC3688' target='https://www.rfc-editor.org/info/rfc3688'>
  <front>
    <title>The IETF XML Registry</title>
    <author fullname='M. Mealling' surname='Mealling'/>
    <date month='January' year='2004'/>
    <abstract>
      <t>This document describes an IANA maintained registry for IETF standards which use Extensible Markup Language (XML) related items such as Namespaces, Document Type Declarations (DTDs), Schemas, and Resource Description Framework (RDF) Schemas.</t>
    </abstract>
  </front>
  <seriesInfo name='BCP' value='81'/>
  <seriesInfo name='RFC' value='3688'/>
  <seriesInfo name='DOI' value='10.17487/RFC3688'/>
</reference>


<reference anchor='RFC6020' target='https://www.rfc-editor.org/info/rfc6020'>
  <front>
    <title>YANG - A Data Modeling Language for the Network Configuration Protocol (NETCONF)</title>
    <author fullname='M. Bjorklund' role='editor' surname='Bjorklund'/>
    <date month='October' year='2010'/>
    <abstract>
      <t>YANG is a data modeling language used to model configuration and state data manipulated by the Network Configuration Protocol (NETCONF), NETCONF remote procedure calls, and NETCONF notifications. [STANDARDS-TRACK]</t>
    </abstract>
  </front>
  <seriesInfo name='RFC' value='6020'/>
  <seriesInfo name='DOI' value='10.17487/RFC6020'/>
</reference>


<reference anchor='RFC7136' target='https://www.rfc-editor.org/info/rfc7136'>
  <front>
    <title>Significance of IPv6 Interface Identifiers</title>
    <author fullname='B. Carpenter' surname='Carpenter'/>
    <author fullname='S. Jiang' surname='Jiang'/>
    <date month='February' year='2014'/>
    <abstract>
      <t>The IPv6 addressing architecture includes a unicast interface identifier that is used in the creation of many IPv6 addresses.  Interface identifiers are formed by a variety of methods.  This document clarifies that the bits in an interface identifier have no meaning and that the entire identifier should be treated as an opaque value.  In particular, RFC 4291 defines a method by which the Universal and Group bits of an IEEE link-layer address are mapped into an IPv6 unicast interface identifier.  This document clarifies that those two bits are significant only in the process of deriving interface identifiers from an IEEE link-layer address, and it updates RFC 4291 accordingly.</t>
    </abstract>
  </front>
  <seriesInfo name='RFC' value='7136'/>
  <seriesInfo name='DOI' value='10.17487/RFC7136'/>
</reference>


<reference anchor='RFC7252' target='https://www.rfc-editor.org/info/rfc7252'>
  <front>
    <title>The Constrained Application Protocol (CoAP)</title>
    <author fullname='Z. Shelby' surname='Shelby'/>
    <author fullname='K. Hartke' surname='Hartke'/>
    <author fullname='C. Bormann' 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='RFC8174' target='https://www.rfc-editor.org/info/rfc8174'>
  <front>
    <title>Ambiguity of Uppercase vs Lowercase in RFC 2119 Key Words</title>
    <author fullname='B. Leiba' surname='Leiba'/>
    <date month='May' year='2017'/>
    <abstract>
      <t>RFC 2119 specifies common key words that may be used in protocol specifications.  This document aims to reduce the ambiguity by clarifying that only UPPERCASE usage of the key words have the defined special meanings.</t>
    </abstract>
  </front>
  <seriesInfo name='BCP' value='14'/>
  <seriesInfo name='RFC' value='8174'/>
  <seriesInfo name='DOI' value='10.17487/RFC8174'/>
</reference>


<reference anchor='RFC8200' target='https://www.rfc-editor.org/info/rfc8200'>
  <front>
    <title>Internet Protocol, Version 6 (IPv6) Specification</title>
    <author fullname='S. Deering' surname='Deering'/>
    <author fullname='R. Hinden' surname='Hinden'/>
    <date month='July' year='2017'/>
    <abstract>
      <t>This document specifies version 6 of the Internet Protocol (IPv6).  It obsoletes RFC 2460.</t>
    </abstract>
  </front>
  <seriesInfo name='STD' value='86'/>
  <seriesInfo name='RFC' value='8200'/>
  <seriesInfo name='DOI' value='10.17487/RFC8200'/>
</reference>


<reference anchor='RFC8342' target='https://www.rfc-editor.org/info/rfc8342'>
  <front>
    <title>Network Management Datastore Architecture (NMDA)</title>
    <author fullname='M. Bjorklund' surname='Bjorklund'/>
    <author fullname='J. Schoenwaelder' surname='Schoenwaelder'/>
    <author fullname='P. Shafer' surname='Shafer'/>
    <author fullname='K. Watsen' surname='Watsen'/>
    <author fullname='R. Wilton' surname='Wilton'/>
    <date month='March' year='2018'/>
    <abstract>
      <t>Datastores are a fundamental concept binding the data models written in the YANG data modeling language to network management protocols such as the Network Configuration Protocol (NETCONF) and RESTCONF.  This document defines an architectural framework for datastores based on the experience gained with the initial simpler model, addressing requirements that were not well supported in the initial model.  This document updates RFC 7950.</t>
    </abstract>
  </front>
  <seriesInfo name='RFC' value='8342'/>
  <seriesInfo name='DOI' value='10.17487/RFC8342'/>
</reference>


<reference anchor='RFC8613' target='https://www.rfc-editor.org/info/rfc8613'>
  <front>
    <title>Object Security for Constrained RESTful Environments (OSCORE)</title>
    <author fullname='G. Selander' surname='Selander'/>
    <author fullname='J. Mattsson' surname='Mattsson'/>
    <author fullname='F. Palombini' surname='Palombini'/>
    <author fullname='L. Seitz' surname='Seitz'/>
    <date month='July' year='2019'/>
    <abstract>
      <t>This document defines Object Security for Constrained RESTful Environments (OSCORE), a method for application-layer protection of the Constrained Application Protocol (CoAP), using CBOR Object Signing and Encryption (COSE). OSCORE provides end-to-end protection between endpoints communicating using CoAP or CoAP-mappable HTTP. OSCORE is designed for constrained nodes and networks supporting a range of proxy operations, including translation between different transport protocols.</t>
      <t>Although an optional functionality of CoAP, OSCORE alters CoAP options processing and IANA registration. Therefore, this document updates RFC 7252.</t>
    </abstract>
  </front>
  <seriesInfo name='RFC' value='8613'/>
  <seriesInfo name='DOI' value='10.17487/RFC8613'/>
</reference>


<reference anchor='RFC8724' target='https://www.rfc-editor.org/info/rfc8724'>
  <front>
    <title>SCHC: Generic Framework for Static Context Header Compression and Fragmentation</title>
    <author fullname='A. Minaburo' surname='Minaburo'/>
    <author fullname='L. Toutain' surname='Toutain'/>
    <author fullname='C. Gomez' surname='Gomez'/>
    <author fullname='D. Barthel' surname='Barthel'/>
    <author fullname='JC. Zuniga' surname='Zuniga'/>
    <date month='April' year='2020'/>
    <abstract>
      <t>This document defines the Static Context Header Compression and fragmentation (SCHC) framework, which provides both a header compression mechanism and an optional fragmentation mechanism. SCHC has been designed with Low-Power Wide Area Networks (LPWANs) in mind.</t>
      <t>SCHC compression is based on a common static context stored both in the LPWAN device and in the network infrastructure side. This document defines a generic header compression mechanism and its application to compress IPv6/UDP headers.</t>
      <t>This document also specifies an optional fragmentation and reassembly mechanism. It can be used to support the IPv6 MTU requirement over the LPWAN technologies. Fragmentation is needed for IPv6 datagrams that, after SCHC compression or when such compression was not possible, still exceed the Layer 2 maximum payload size.</t>
      <t>The SCHC header compression and fragmentation mechanisms are independent of the specific LPWAN technology over which they are used. This document defines generic functionalities and offers flexibility with regard to parameter settings and mechanism choices. This document standardizes the exchange over the LPWAN between two SCHC entities. Settings and choices specific to a technology or a product are expected to be grouped into profiles, which are specified in other documents. Data models for the context and profiles are out of scope.</t>
    </abstract>
  </front>
  <seriesInfo name='RFC' value='8724'/>
  <seriesInfo name='DOI' value='10.17487/RFC8724'/>
</reference>


<reference anchor='RFC8824' target='https://www.rfc-editor.org/info/rfc8824'>
  <front>
    <title>Static Context Header Compression (SCHC) for the Constrained Application Protocol (CoAP)</title>
    <author fullname='A. Minaburo' surname='Minaburo'/>
    <author fullname='L. Toutain' surname='Toutain'/>
    <author fullname='R. Andreasen' surname='Andreasen'/>
    <date month='June' year='2021'/>
    <abstract>
      <t>This document defines how to compress Constrained Application Protocol (CoAP) headers using the Static Context Header Compression and fragmentation (SCHC) framework.  SCHC defines a header compression mechanism adapted for Constrained Devices.  SCHC uses a static description of the header to reduce the header's redundancy and size.  While RFC 8724 describes the SCHC compression and fragmentation framework, and its application for IPv6/UDP headers, this document applies SCHC to CoAP headers.  The CoAP header structure differs from IPv6 and UDP, since CoAP uses a flexible header with a variable number of options, themselves of variable length.  The CoAP message format is asymmetric: the request messages have a header format different from the format in the response messages.  This specification gives guidance on applying SCHC to flexible headers and how to leverage the asymmetry for more efficient compression Rules.</t>
    </abstract>
  </front>
  <seriesInfo name='RFC' value='8824'/>
  <seriesInfo name='DOI' value='10.17487/RFC8824'/>
</reference>


<reference anchor='RFC6241' target='https://www.rfc-editor.org/info/rfc6241'>
  <front>
    <title>Network Configuration Protocol (NETCONF)</title>
    <author fullname='R. Enns' role='editor' surname='Enns'/>
    <author fullname='M. Bjorklund' role='editor' surname='Bjorklund'/>
    <author fullname='J. Schoenwaelder' role='editor' surname='Schoenwaelder'/>
    <author fullname='A. Bierman' role='editor' surname='Bierman'/>
    <date month='June' year='2011'/>
    <abstract>
      <t>The Network Configuration Protocol (NETCONF) defined in this document provides mechanisms to install, manipulate, and delete the configuration of network devices.  It uses an Extensible Markup Language (XML)-based data encoding for the configuration data as well as the protocol messages.  The NETCONF protocol operations are realized as remote procedure calls (RPCs).  This document obsoletes RFC 4741. [STANDARDS-TRACK]</t>
    </abstract>
  </front>
  <seriesInfo name='RFC' value='6241'/>
  <seriesInfo name='DOI' value='10.17487/RFC6241'/>
</reference>


<reference anchor='RFC8040' target='https://www.rfc-editor.org/info/rfc8040'>
  <front>
    <title>RESTCONF Protocol</title>
    <author fullname='A. Bierman' surname='Bierman'/>
    <author fullname='M. Bjorklund' surname='Bjorklund'/>
    <author fullname='K. Watsen' surname='Watsen'/>
    <date month='January' year='2017'/>
    <abstract>
      <t>This document describes an HTTP-based protocol that provides a programmatic interface for accessing data defined in YANG, using the datastore concepts defined in the Network Configuration Protocol (NETCONF).</t>
    </abstract>
  </front>
  <seriesInfo name='RFC' value='8040'/>
  <seriesInfo name='DOI' value='10.17487/RFC8040'/>
</reference>


<reference anchor='RFC6242' target='https://www.rfc-editor.org/info/rfc6242'>
  <front>
    <title>Using the NETCONF Protocol over Secure Shell (SSH)</title>
    <author fullname='M. Wasserman' surname='Wasserman'/>
    <date month='June' year='2011'/>
    <abstract>
      <t>This document describes a method for invoking and running the Network Configuration Protocol (NETCONF) within a Secure Shell (SSH) session as an SSH subsystem.  This document obsoletes RFC 4742. [STANDARDS-TRACK]</t>
    </abstract>
  </front>
  <seriesInfo name='RFC' value='6242'/>
  <seriesInfo name='DOI' value='10.17487/RFC6242'/>
</reference>


<reference anchor='RFC8446' target='https://www.rfc-editor.org/info/rfc8446'>
  <front>
    <title>The Transport Layer Security (TLS) Protocol Version 1.3</title>
    <author fullname='E. Rescorla' surname='Rescorla'/>
    <date month='August' year='2018'/>
    <abstract>
      <t>This document specifies version 1.3 of the Transport Layer Security (TLS) protocol. TLS allows client/server applications to communicate over the Internet in a way that is designed to prevent eavesdropping, tampering, and message forgery.</t>
      <t>This document updates RFCs 5705 and 6066, and obsoletes RFCs 5077, 5246, and 6961. This document also specifies new requirements for TLS 1.2 implementations.</t>
    </abstract>
  </front>
  <seriesInfo name='RFC' value='8446'/>
  <seriesInfo name='DOI' value='10.17487/RFC8446'/>
</reference>


<reference anchor='RFC8341' target='https://www.rfc-editor.org/info/rfc8341'>
  <front>
    <title>Network Configuration Access Control Model</title>
    <author fullname='A. Bierman' surname='Bierman'/>
    <author fullname='M. Bjorklund' surname='Bjorklund'/>
    <date month='March' year='2018'/>
    <abstract>
      <t>The standardization of network configuration interfaces for use with the Network Configuration Protocol (NETCONF) or the RESTCONF protocol requires a structured and secure operating environment that promotes human usability and multi-vendor interoperability. There is a need for standard mechanisms to restrict NETCONF or RESTCONF protocol access for particular users to a preconfigured subset of all available NETCONF or RESTCONF protocol operations and content. This document defines such an access control model.</t>
      <t>This document obsoletes RFC 6536.</t>
    </abstract>
  </front>
  <seriesInfo name='STD' value='91'/>
  <seriesInfo name='RFC' value='8341'/>
  <seriesInfo name='DOI' value='10.17487/RFC8341'/>
</reference>




    </references>

    <references title='Informative References'>




<reference anchor='RFC7942' target='https://www.rfc-editor.org/info/rfc7942'>
  <front>
    <title>Improving Awareness of Running Code: The Implementation Status Section</title>
    <author fullname='Y. Sheffer' surname='Sheffer'/>
    <author fullname='A. Farrel' surname='Farrel'/>
    <date month='July' year='2016'/>
    <abstract>
      <t>This document describes a simple process that allows authors of Internet-Drafts to record the status of known implementations by including an Implementation Status section. This will allow reviewers and working groups to assign due consideration to documents that have the benefit of running code, which may serve as evidence of valuable experimentation and feedback that have made the implemented protocols more mature.</t>
      <t>This process is not mandatory. Authors of Internet-Drafts are encouraged to consider using the process for their documents, and working groups are invited to think about applying the process to all of their protocol specifications. This document obsoletes RFC 6982, advancing it to a Best Current Practice.</t>
    </abstract>
  </front>
  <seriesInfo name='BCP' value='205'/>
  <seriesInfo name='RFC' value='7942'/>
  <seriesInfo name='DOI' value='10.17487/RFC7942'/>
</reference>


<reference anchor='RFC7967' target='https://www.rfc-editor.org/info/rfc7967'>
  <front>
    <title>Constrained Application Protocol (CoAP) Option for No Server Response</title>
    <author fullname='A. Bhattacharyya' surname='Bhattacharyya'/>
    <author fullname='S. Bandyopadhyay' surname='Bandyopadhyay'/>
    <author fullname='A. Pal' surname='Pal'/>
    <author fullname='T. Bose' surname='Bose'/>
    <date month='August' year='2016'/>
    <abstract>
      <t>There can be machine-to-machine (M2M) scenarios where server responses to client requests are redundant. This kind of open-loop exchange (with no response path from the server to the client) may be desired to minimize resource consumption in constrained systems while updating many resources simultaneously or performing high-frequency updates. CoAP already provides Non-confirmable (NON) messages that are not acknowledged by the recipient. However, the request/response semantics still require the server to respond with a status code indicating "the result of the attempt to understand and satisfy the request", per RFC 7252.</t>
      <t>This specification introduces a CoAP option called 'No-Response'. Using this option, the client can explicitly express to the server its disinterest in all responses against the particular request. This option also provides granular control to enable expression of disinterest to a particular response class or a combination of response classes. The server MAY decide to suppress the response by not transmitting it back to the client according to the value of the No-Response option in the request. This option may be effective for both unicast and multicast requests. This document also discusses a few examples of applications that benefit from this option.</t>
    </abstract>
  </front>
  <seriesInfo name='RFC' value='7967'/>
  <seriesInfo name='DOI' value='10.17487/RFC7967'/>
</reference>


<reference anchor='RFC7950' target='https://www.rfc-editor.org/info/rfc7950'>
  <front>
    <title>The YANG 1.1 Data Modeling Language</title>
    <author fullname='M. Bjorklund' role='editor' surname='Bjorklund'/>
    <date month='August' year='2016'/>
    <abstract>
      <t>YANG is a data modeling language used to model configuration data, state data, Remote Procedure Calls, and notifications for network management protocols.  This document describes the syntax and semantics of version 1.1 of the YANG language.  YANG version 1.1 is a maintenance release of the YANG language, addressing ambiguities and defects in the original specification.  There are a small number of backward incompatibilities from YANG version 1.  This document also specifies the YANG mappings to the Network Configuration Protocol (NETCONF).</t>
    </abstract>
  </front>
  <seriesInfo name='RFC' value='7950'/>
  <seriesInfo name='DOI' value='10.17487/RFC7950'/>
</reference>


<reference anchor='RFC8376' target='https://www.rfc-editor.org/info/rfc8376'>
  <front>
    <title>Low-Power Wide Area Network (LPWAN) Overview</title>
    <author fullname='S. Farrell' role='editor' surname='Farrell'/>
    <date month='May' year='2018'/>
    <abstract>
      <t>Low-Power Wide Area Networks (LPWANs) are wireless technologies with characteristics such as large coverage areas, low bandwidth, possibly very small packet and application-layer data sizes, and long battery life operation.  This memo is an informational overview of the set of LPWAN technologies being considered in the IETF and of the gaps that exist between the needs of those technologies and the goal of running IP in LPWANs.</t>
    </abstract>
  </front>
  <seriesInfo name='RFC' value='8376'/>
  <seriesInfo name='DOI' value='10.17487/RFC8376'/>
</reference>


<reference anchor='RFC9011' target='https://www.rfc-editor.org/info/rfc9011'>
  <front>
    <title>Static Context Header Compression and Fragmentation (SCHC) over LoRaWAN</title>
    <author fullname='O. Gimenez' role='editor' surname='Gimenez'/>
    <author fullname='I. Petrov' role='editor' surname='Petrov'/>
    <date month='April' year='2021'/>
    <abstract>
      <t>The Static Context Header Compression and fragmentation (SCHC) specification (RFC 8724) describes generic header compression and fragmentation techniques for Low-Power Wide Area Network (LPWAN) technologies. SCHC is a generic mechanism designed for great flexibility so that it can be adapted for any of the LPWAN technologies.</t>
      <t>This document defines a profile of SCHC (RFC 8724) for use in LoRaWAN networks and provides elements such as efficient parameterization and modes of operation.</t>
    </abstract>
  </front>
  <seriesInfo name='RFC' value='9011'/>
  <seriesInfo name='DOI' value='10.17487/RFC9011'/>
</reference>


<reference anchor='I-D.ietf-lpwan-architecture' target='https://datatracker.ietf.org/api/v1/doc/document/draft-ietf-lpwan-architecture/'>
  <front>
    <title>LPWAN Static Context Header Compression (SCHC) Architecture</title>
    <author fullname='Alexander Pelov'/>
    <author fullname='Pascal Thubert'/>
    <author fullname='Ana Minaburo'/>
    <date day='30' month='June' year='2022'/>
    <abstract>
      <t>This document defines the LPWAN SCHC architecture.</t>
    </abstract>
  </front>
  <seriesInfo name='Internet-Draft' value='draft-ietf-lpwan-architecture-02'/>
</reference>




    </references>



  </back>

<!-- ##markdown-source:
H4sIAAAAAAAAA+1963bbyJHwfz5Fr3zOZ8khKJGSJZkzmYSW5BntWpeV5JnN
2WxyQLJJYQ0CDABKZiznWfZZ9sm2Ln0FQIoeaSN5vzCZGRFEd1dVV1XXrbuD
IGjkRZgM/xzGaSK7oshmshFNM/orLzpbW2+2Oo1hOkjCCfw8zMJREUSyGAXx
9DZMgnxwPQjmYTIOhmERBpN0KOOgvdsYhEVX5MWwMY26DSHy+SSTo7wrXs5l
/hIfpFlRelJk0aCw3wfpZBq6D4p0oL80iqiIAZxDGFOc4JhilGbisgiLaCAO
0qSQnwrxkwyHMoOvk2km8zxKE7F+efDTwUYj7PczedMV789/6Z0KfCb+0Dv9
UQD4s1g2bsddQeiJX9LsY5SMxY9ZOps2wllxnWbdRiCiBCDvtcRJlIT9WZYC
eEygXhK6D9MMuuoNPsZRyihKCRi129t7PRHeyGQmxVDm4uA6nExz8TYOk0GO
uEfFvCu2X79ub4kDAD1Ngkt5E40TCV+H8hORZ5YUGbz1LoNGEp7ISRjFXREm
4e9DGLEFQypA37fEVTorwigxcL4PZ5lMCuc5gXqc5EDaWSFOjk+PLsXV0fuj
g7OT78TxyZXoFQBeEf1lJi0q8FcgOiIjPEQcIibQHwCahZGkXw8uRXtvd2vP
RWtv96vRUgC3FMC/jyZFEBqIWqOskaTZBOb/RiJUQly8O9ja2903Xzrt9hvz
ZXt33/6yu9XZMl/22tu79kvndcd82W/v7dgvIBn2y/aO89pue9t+2es4bfbx
S5SMKoDuvXE62Huzu+d8ee2Os2dhe7PVbvOX4+Cw5YhkmA2uo0IOCiAYv9AI
gkCEfZgzEKhG4+o6ygWI9GyCHAD8N8iiPnBhyEKAgiwmRqiKa8kSsn6veG2I
xsARNlArYpSFYxwGWsKTDKQrb5UhIHrE0V8BBByMAZpSg3REj6gdQdOXRQGD
RgBClk6By/pRDFyFz2+lTBhSYPoCuScXMoLmmWgUqZCfBtegpySgmcsCe+Ze
EcUU8Y1Gc1BLEz3aNMxAUmCYvCUaRMFJNByCdmg0XoCcFBnoigEB+fmF+/VL
o8FAIEGXk2MiEaQonxBqgzTBGYoSORQJoAOqB4gkR/QggmE+K4b68qXVOC5w
gH6Yw2/YNwgkTc5ATU5+HWbwU38uoCMBI0ZFhFNcED37IGXDMJtr+tYM3Wo4
44lplt5EQ+KRBIbjGROZROQMOt5kzRAyRX7GzlBicyhduqzDrwebhxsN+K9H
n81MhnkuJ/14Ti+927zYAE0GQ4xTGJ2Gc/kI/oaZNNy0nJngzXQ0kqDNG6/o
cQ6zzeSO+O0EyFRcA+2GeVNIUNYi4g6I+ZIq/ghLhH3Ck+8EdAsLyGwK4iT1
0CmRA3rE4ZELZ1NmuXwqB9EI5u8mjGcA3bpsjVvi+PxmF0gPMH1qIiYFLCw0
UjgcIvWarVZrA8Tp8+clKgBmL4rjGc5voSTMiIIRglmOqxz+VlIBFWFlhjTK
gldM5k3UVTAaoGYIwyRcQSk0xe11NLgWMSgVmhxoM8EffRIjJykS4Z9hHDtT
KmOJvZK8vhAX8i+zKOMnsHok41k4loiNFB/lXACPw0BrJx8ur9aa/F9xekZ/
Xxz964fji6ND/Pvyp9779+YP/cblT2cf3h/av2xLWC1Pjk4PuTE8Fd6jxtpJ
7w/wCxJh7ez86vjstPd+DYXb52SQXaRBX/EakKAAaQpzo6xJIbw9OBftHaY9
rm5Ae5ZZWKjg79trmfBQaQISxF+BWvNGOJ3KEJUoEXAQTqMijGEKYID8Or1N
BHCpbCERr2Q2iZI0TsdzUHP47YtiiFyy8tP8gNNQOG/juOEgS5P5RCmDMpak
xEBXoYBVmgNnMi6w5KG+A2nqTafaYoM/42hALNFksrCWBHXntgJrTIT2VYA5
GQKfg14ZyOgGOR4szI+yQIbbHGXphMA4lDc03tuoC/8MgYcI0zBuoXWDS6jM
aLEKxbtIxkNowDqGFkvQsDQkq5hrWiNzRMcMlYHhF+PgQBClIM0gYv3DlEh3
eNsEcCVTbByneQ7qeoPgOjjsdd1Vd/PQU6c96qiloOqrqZmGUYZQhPRrrgAF
NoM1FDUmsleh1gLui9dF/Q2QZVzEiHCm6S2UivWbACrpjWTDIc2icYSqkoRW
q0G3J0aJVy0wlfXafGEXEQcKZ+XQpKX2h2jMw7+igVzGD+rV4+ND/TYu5ECA
EP8a4ioJMGW8xsBbTKVI/5Br9mCpxFbc5TF0Z2bwGHgM+C2lbmDymF6FjONc
6Tg724YtFFfg9Ddh7tEoeRttVDiMFKjhLjUAyHB6q/Qh+Flgs4AjhSv2ADki
GTcd7U6LHNKWAb8FwEHegRs/OlAtXa6bggSFTBxYtVmqpbYacLLKP2l5eodk
Z3x8WgMOJRoD8ODtpTGvFsxwy0lBA7zX/b+XyRjWnYh7i/mbXoM1SyrKe8wo
2K6Snwhd1rlg8swmfUni048KprTbisQb1mh4nYcio5JaFvOp5MW8CSKQRWE/
Bg4t0o9gTfC7TYGLOPXJiOoujITOko8JKmUlbkU0kVpCxABMJBb3Kw/RkrRG
niHJUp4BhtOUFKKlt7ZDWF+u5zNgV0CEDBGA8MPhOeugd+ddWlDMtDDRgIFY
YNUKM5nFRTSNGeicFhwFWFO1O09zNrfUyIoB0sFgBgCCDc8acNncg4uzjuST
n8CJRvKOoiwH0yqLgmmI5JjyOgErFqBrnoNNVwxaDNNB2jtXgG002QdFshCn
t5m2rMC2EFECNWTmnMgQtOnaME1eFrCSZnKN9bZrPF8qudprdYh4pH/qFc+l
ZLOVCK6sPITENeiUsQV+qlJp7zsYpxh2mVSK6WEljSazichn/SGsdblRN/M4
DYds4RGL4cvQw21EpkCWzUEIwDVJgYTwGMa8piU5QhtNvYujkX8DXcKMw0ou
sA0IRwDSBdgAE2ThMEqXNJ9E4+sCLRxwXQBD4BFojh1dOS/laMbjQHk+mzBn
9ZW3Ao6/4GUG5YHmP0TdSmqdyHJy1hUnYQGEAwKeoa9IShlsglR9MevLBF8D
SHiS0YcKtbCUJOkWFuxFLxq9SqIJy8c6/2HmdwPjQ1bXsWOk2lm1qR2PnBwu
cuR83Y1dc8txhG4JK7KWv3jCSzmrD4VjPptO06zgccCVEqNZogwbcKAJ7quf
u+IqzMbQCyGIXS7ElLmH2AbmhCgoFX0KIy8VVUTjfABD7sP0V6w6ev01tAK8
3NVHP2+Rk07fyDVQLrlrJqFZJROw5AbMlxNAz3HIhynQPkkLsGbAocP4QWid
NK0ukZnmFU2rAy1I9ussnY2vUVDKC59Yh/UQlE0oploFrr87pweONXh4vMEm
vGY5IvoA+iPJgYUJMQjjhiJ3RpGADDi+5akg7IK/79N3RmWu1y+kPakcfqez
BX5cE7U9fccwGn4nLcnKp/O6g35lMohntICwjrWrDHaYoIuboYjySpNLof3E
3T0F09nlwdnFkRp2t72NRvs7FXSKQwr1+GDHuAAX1q4CSwxZux8wJi010yUP
k13B3IZ+lHdpYzx2uWWkNKdnJJugk3Lpvo0vLgrNkItZjqTJBJf+3LOwtTuM
z3yAc3BlmQOs6TaClR61PwZ6JPtPwOQvvPA2W82fX+AIf0bbI//SKMdxgN1W
i+O4YBIZGj3vmQ41sSpixYv8j++kFJcalWJtLXGEOjojy4U1ChoFKh4KXcJi
rj1cV970VLvOg14KJspSQ6f/b/RpwCLym+Chn99AL3ei9kPa77T+t9LnrvEY
oEAvtaAQINFKgAAod43HAOWuAaCQ7qpA0l4REgAFetHA/Mb5vzNQdegqKNDL
HevV9t2793fvzu8Oj+/UAvYzKsS7yvp/h+KiPGZ0le8eH5bOs4AFvAoidaul
/g9f1DNkbPOnqH/yaLBsGrqcPoAujwHKZmOBPH/Fx/TQ+GNlxK/9bAqrsj53
xYt30TgYFKBQKbn525euYvdDPCpc8vILLgCOSUEGDWnSRsM+dsNv0kl2OqsT
LmfGwGL7tJiD5WMXG9S3MslxARrHaR8WjVmCibeEYkOwiMkwn4tw5ixi0Qjs
MjlE1UxG/RTMkgF7g6laPHEZkrfsJTu5jDFmW3HVcEFRfs0oxXAHsAsF7k03
ZL7p1wXH+awx+lHOMd5LYwQ4WosbZ2A/myCyah1Jn2BujplJpBIvwnREXrhU
7j6AtODFKwq9k5Mq1j9/xvl2EPzyZYOir7mAf6HFWEKeB2HT6uLgEpwLmx05
uJYDsH4lTshAbgBKY3DEimsdeh3O0CQUVdMIV03mwYbY3BRBQF2b5gR5jguq
IW02yAPze2AIKj5TptFJtzRYUNYUI85V8Mv2HfnxvRlQEAZvqXbEMvblMM5T
L9ZMrqGyVBBm9i7WvoPmXyoAKwNIAUlzsgCP7xahcXBxILY7xujjIGM4iwsa
HXhFjdHi77nYEf05JlziNBlbsDSH+MM7FKQ/3an/rCC4H+ovi2CnPjVPsyWm
IPK1jzusUkLntULrC6zTrIU6ia3S5AafKseu7P2Afkp0pA/DlMomt+6etfTy
RYE7UloU6gHDXDOSlsQ4ygsOy5FbwFFG/yFOknZbwzHaooWfHwRk2TgPp2g3
ZxF2TcYreWTTKUieA3RLeC6XdSFJiZJUkwJjUhwqh44MZsy+ztBjBHkEwigl
kTdNrGBgM4xpIq1fqZw9mNeh/KTyvW78FIs9nGRiC7wxpi/6cuabSiOixHHY
raisEMoryjXtbKIUvcdZUnaDmq7fBn1/WJRgbHLchqlCWbi+tCESx4XW6w61
d1kOltEePzWk1XULhg4UJr8N57lS+kO73I2ioRUkcvUSV/uKhoktub3pcOXQ
8dCA2PjnwGF96PuP3//xe28+fvjBHa/Rg+UH/KU8Av/Q9cdp+TANiTJqwTKg
W4AUsByqVHA0HECgqzUAZk0tn4s4xXijREh8BHyDXhw/uAat12DHC2OK7CR7
/nfTaW4oSFGAnAPiiDkuOgjnaAao07ugedzUe+TxVJgk8lOP0nlKO/pxBpUl
ZzyayhiB6WqYiIzVVEVLnKaFtJHPw2g0ugT4OLJfJvBVFo7QAT2IYam1VF6i
4lQIvtHwvkamEgU5C4y3MVprnIJ0F7PQuroED8dzjBusAnZ+aMdZFBtrN2G2
Zt4zKy7lh3T6QcOkWG399hqcdRdQk/tAKHAJ26iEj9yFeK34GDtjIikmYRKO
NW6oaRpXTsbDBAKvamWGWDWucqoZgdhScZBLZPOCCo85S3XJmion0l0eu8Lc
NyAhmZWJ4crJGa7tAQMYQ7Wq8Gj5xDppKD23WtZcVbaEsXSUUHOWiRoSLPzt
RhoYeOoxPoyZUi+fQqkYZLaGH2BRZro2a8zy1GaZghWAqyk4VUwilsmpLCJl
SP6sMyScAJW5lTIXWFwRowmGojGETz3zQ1wGgRiZtVf1auzEw5S90BKr0YEV
otYaM3i636qjcU36ljms5gexPow2XOsVc7vo7Wjp5eQXpbsokO/EczGpCz1Q
QcaMI+DrH6b0zCRi1w9vNzxFXhKOYVQVjjowHTnRBIC2tOys1RLB9crF5xcF
ff0z8cEX7sd7gwiuTao+WGYZqnp2QZjBkrlJcoYxlnkOdcA+lqOC8kx6ilna
2AxCJ1PnFWYmCYsjNdmlI2uHn4Jnx7S6jsbXEmDh3wzzlj2MslDy61SqhLax
BA6cSWM/kHkYTGBCcR4ODntifbFXzoUXauq4X9REOtSeSzC3dCVETt4rRrqP
/jJTqcSTy7dNn8ImRmpyZKrEqaKmeDgqyyFXfaul+/dQKPcfJnoMA54tojq2
lMzZ/gBDNit4ddxikJW9hp1E41k6I8E8rlZ5uKhg6IKhLjENTlZuU13wKEU3
vpZXK0GjRqPySKyfnG0wm5q1gdPGQ6u2FXzMMKrM0VpH7FgoTLTGLrwUWd1a
vCNOzpYucJO0KsMnZ7UiO0lZZAUtDi+qmIMjNKaCqpxazskxuonkrS85/VkU
Fzp/WdwELGtinbPVnrB/2ail+X2sD+Pf9wrIz2Fvo1zuYWYHOBd4oJwKRO3o
ZQOByeqovosSqo3LeroPhmGV8CjXivIvSgmVWhwceh+wuwTaPEmpH5tq0i8h
5QsdTBrNOIeDNZ/4+iSc6yYCHTvAVAui6aC1bFZRjdHUBSo/yKEmQONdpcgS
dDoGf0xiyH8DyMNZvDDW0LoRwgQt9CnV6qXadcec0cCo0jUvsrSmE1bonzVO
Ul4mqqmuUlINsWKjrIcmmTi0lYCcXoPOLiMctaaIVFASeORbzWb15eJH1lla
62HgMBmiFM2dZToyJVyeKBrNFKoilcRGVVw2AaAyqnfAie+7FYRCl5nqpU2x
nD8TSPFGLYdvlwvI4U1eSk5T3GaiSkDwMS1+iTt4E3k0HGAxUSyHY10yzWW6
8BxJ+wp7ET1ylbvKM/dGvAXapLdiMsupeAOchTgaRCgAtmdSr7g2iXFKZpxO
0n8qWnoI6Oooy9KsK8CrU52ipnY7MWWrbCVQ0SYWS0oshMlZiCYRF8hoKPOy
+vTAp/1JygISy/yPSqMaf6QyE1qJ1Ewp75WAn3osVLqxqYaipdWLWWdcxNHU
7oy2Uapjmzku6cUaQ5wiwGo5Q92jUqg6Xbs+GOGChrFAHCLgNwPub4MYLaSA
+BiEFmyJMRir8MUo9Lm22of6nb50ZwdlpU4J6GIumIaB0aipNUp0d7lXU+lq
LPIjgCmsg+bUgGpythiBX5jd1n/ZMOILLBkw11NP+BUmnjiUhYyMVftWkwbT
5Ult86tuhL+X9aUuJXDhR7+HkyQIxWkaoGzggCyMoWEjsyrBm6dcjrj+7uB0
Q0+yqRJQ728WUez4XchVindY2MqAWDWYclU4Yb2gxsHHvp7QKhV/FwSq4kgj
orYNYQbsTsf6hcD3ruDhXXAS4N+n+DcmrCkvGfzG/Dfw/qYPfNNJvr/VfBp3
lJ4+PhR34hB5Fv77C2bygH74t4HsXNXG3cGiNKQE0jpoep6ejUeCpRRxL0uZ
Drsf1igJNrzVJHDu74V4H+aFfZErKVgDxt4vFFwyUqnVPluDyb35JFXDnCrd
q/wkELtGkYVJTkoYFz6SFxQgE9DEynWu/Cw0TJoB6xY44+jYzI8J3h1hAC0B
w7uBuRh26EwSa7EuzwZ5VXnb7pXORlepIvXspfTiOGhbSqLa/E9c/rQNoTNQ
aLRSFIgi5WhkR6p2yDVy3NBZoy+vw5so5U1IIY7D22iTtGvpZUY2PhSs4/ha
k+FQ45e6mINhUNOHieMbSpOi0K5NtR/cMwHMObhOo4Gs6xHpkfJqoqI4yrJy
+mcqmBUcyaQ4icImBAJFu6kKaannZEGrzqomp1NiqZfjnm/36Dd5pJJRVJa7
cWo5OJ2STpV+ET+CszAqa9Z4b6Vlt8voAADBWWELXFmBNIog4I698kxVZTCF
uWepa7hbtPdMHGCc0QtGgrjMKDKD7Ar+QjRU8oPL1wDzi5gcC6N4hnGFENtP
wqkiM655/lqj5nOoprhhqhlAgSut3zv4l1UUvmiLhcq+VpO6Op2VOun0g9+2
rfI2urtcxIFl7RhEXKjT64dc8jZrfH5Yq/wXwrt15yzsb4nehEHLAX9dTcky
eO+HoFxqotlOLzm95UJAZQd27SnryybPt2b7W5VFK0mWY8oqA0SXshYULaRa
7pI9EYdzGL7T1PsfcPckrWZKCNAMIoW1tSEaet+FqTjl/UjSCoGvvEzj9tKQ
K6ARaJWxwmKCCucKUDF7FVnNcB54EmL4RtpIAfkxqiBVvY87x0DY47KdTLs2
BmAcs3mYSXf5DQoakmP+pBRmXAykvTG1/U3NCwGAEVMy+vV2vv1WB/630yq5
3RuUBzRJz6aKl+n4H5/dAIaDjr+TCooS3G12ExVzD7Ra2MJ+yv5PWEI517uE
V4MS6ay3ajjOacUVQneeYKJNuzkmxoatktOdcvbeZHqRQzPaN6viwzlnU3CH
ODXELfnQEDfATSZk+ocWUQC13RHX6SxjZ2IExGk6pfLccw4vxOg/mwjlJIrj
iPeucGI4k2B4kaTk87yQk5w3E2tPaY5OUspZPwwTYXRIdY5iY7dDYrL2NnVt
E+3VG5S7WLLyyp+wlFdsjBfwZikVWlfiQLnbbDKLQ9H5E74W6Jab7a0/7bbE
L+TQuz+4cWumyCyJCruRZZCljH+rJkEF4HS27LbhkNsisVtbO/uv914L3bZn
W2x33BYIjI9fP50VsCbhZIl2G/fSAIJ5yxDDbgjDtmYVBj2ulRdCAbhqZ17D
7OPtYKCyjcRNKi6PllKoZk4zAyCF+JC91n7D3MSvouzUMiEv8XVBiXM980o/
1VTOlzeGKc1SIgIW6k+m4BKWhVkXbxSuDdwl3TUJP+HqEygtBGphNQlvaL+H
VgWHexmHupKVEperVXVUPm6AjK+4E2ClYIDObdez6Kj+ymvQ1LncpuC6RbVU
0d5ylYFV65uXDatjY2D2fZpVuzGPSi2Kypt0CsYci5xUSk2N6jF4mxNoWu2Z
AFAmOerAjXmvOYwED5Aq1Lcyn0iDwyThJrKAK64UUVzTVr3gFDDMEluTbxzO
lng712i4Os8Kfruzv8XVBi0ni+Gk8GdJzuiqzG6u99mZ1D1t+segma0kwXgb
xdHcLaakqEJVv6p+drblqLjbBod0I4ouUho3NJuvGHjelqOf6am1uz+oihVb
Y49BNOQqP6+G0aQ7dZrSHpwQ6gAgzqvd2Lkl9I7fSoME0+q04KlQExIyk2jT
4Bi5Pe1h8e6VLu/GNrHsbukME03MMM/TQUT1qOWAZYuj0QO3k6Jmj6/mampm
NqlJIqqq8KOphlVNh4GTtArMbaiLhdbL+y61LtndIGb2lF93eRpiGX4lLVqO
Qup9OuV0iF3Zc9ysV79NKFIHyQCNsLYCzScZz7WtQbPplCnTbPHsBoowyPTm
WZIGDr3scw+yZc42v1+1ePm572ajzUFulZt8san9zJMTopQSo8zN8pt8vuY0
rptqhOWEYNlO1Cxf3hKFzxulnUu6b9chV0kbXRhERZVF7myjp52j+NZcONls
XTvubGLyJEsX9eN5HJqRKP9mdVs/vTElcRUobZ2S15cfdnVaBbQrC92rY/es
FlWm4R7PFJBaIoSapfrRyOxmBEvfxJApBWhTDSVwne5EQxUReOosRqdHpQAL
KkRzMaL+YFzSkZkcxZTiKa493ewTLkrAXHd2uuHBS+RKYfAyLx1uoWLwTvGF
m8U3jowGl0oMzuxxPhx7hQUoxYNRXrE6Orl8iy+51aB6Lymn6AO90VglZ7V9
rUZpLMjTIrvWZG/vZ1i2QZXFpv3VliCqMAEmRBazbdSkKht0MhETLXJ2jni8
7CSPv2hRIwV2BXqpXp95ZXb+GTfAqDg3uUoPNk7VHt4TLB5k9sEoeF6gRdlz
979Xlq7tnQ6t/xTgEA0+k6gr6EAkPKCQNwRmt0J9Efo70vWV+He9QCtHTH1j
TfUfJmRlm9h3qx+sMdvuLGiklF9to/26NkrR1n2ULsf5KLVc5582ftdwXoef
uuueytwQn73vX7z373Rv1Vxo6TW9JwqJ212Qbq3t2bW1f7eEHm4bG3Ytf2h4
Vd9W3xRs0Zqxlg53W99gaZvRIKFWX9PG29fhDVfdKFLbQY2l/js7aHu3HjuK
oNWhuKQROm50/g140DdyiMbEROa/W4peORJU5SB+j7xp4x8v6rP0OvuhBMEy
uOuCZU8BR9nxtZRfTL91FKSNsnwKJdVg5kGHGwt+xbF478OyN4AilL2reUdY
NEEjlZilDuZKmygJKMaq2pGkOimmGqZ2u3CDr3pk7sL5odIJYebYJ6DtnG++
rjNDkfnyqvST/vy72arAfxjDyOikwBQO/Ue1D6UcdB81H1agylFc3kH9QsId
xCu0N7B7n8pkug1rsPQHrtG9bnu3TA3WXLI4a8jk6AwsPxV1slR6k7pEzuB6
0kUAVKyyMuVUpeXK7Z8QF2TlgGsig7C0HhIug2FVrpZ3cC82YmVsxCJslIGm
U1B8WjRGL7GwUSeizvR3MHI5qWTsSap6YCPzRB08+ULFf9j6a3x/cHZ4JN4e
/Xh8evkDMDu8smbswN93tjqdYGs/6Lxu4ZnVa8pUtJYi7bak46zV3jjRbrW/
U6cm51M8rmltliVdbNClmEHe/TSJu0nexVZd0xHtr+SjO2lCvmvwEcthEv01
NHsz146Prt6p07Uw3Ps+vRXn4Ghn4hewwoNeJkNxqo+CXaezPTeoyBHYkMlO
QSYajHzSQcH9/vKj+EX2u/Dn99dFMc27m5tIRTyX5iN46whmC6DZvB1vUq+b
FPLe/IE7hdbvwWGE5t/j4ctF2p0G8NLvdTP12tEwKqiCr+Y0afro1rE6u7lY
dHZzpcPSMdpeb84B1z8Q5uUdr2vc4iCdzjM6ZWp9sCFw6gWR+woPNjcVDyDL
OW5idMKDYc4d8HHfZv/pgMqysBxEULcYoqGtbZg4ogYXchhhKqw/Mw4zljNj
dX06ywYcMlRF7+T7qP0MqTJE8AtmHugwYnO+JRZG4MmYBUajprMsn4W0H5+3
5eSz/n9iIUWh6EQ5zmggKfkp0b9yz25i//RC3kSUb748hInmd3PJrIOA8S4l
fWzZTmugSWDp9zIX7+UYPMhzLJnPqfpb0SBWFQIpv36oHD71+7rmRzpfXkrL
iwrqAGMpG5qklCTWsqhP/HVPno3opGY+9urdgfg3+JQGur29bWWjQSCJu2go
HGITnuHbG9+pgzYldRAVuYxHhhS8STEmVJMUDD0KUCvQ3JNkX2II4WWT/4sl
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
9CqRlycMdX0qnZNKZcNa2TgFttRhE+ZUO6a5yxQq2cqAoDREOeql0tJrgfdL
dVdH4B/L3ArTmJSnsbYwul78cEAMQcu8yP9hXCwwLhybGOiKnk671QLqVcza
+mpHKqtkHWMTOzhHuBqqSLc+RY2WPfBVSoLEm50813BAgSfaPf6d+8giU3lc
2mGMH1X2D+6ht8jg55G54H4WcBKxdcp/EYGJyDXGE+1fw9S9v/RRuqagmrsS
xLzbaxQpX9/fvulPtEu4KPH2lT4b4pEVV9qZthItD+0WUip8pOJp2nWntl3Q
wSeZ2v+qdu05R9bwx98Dq3fRUTFIhEU/uGzEclToEmse4WXu98Kcv2QK3L2o
z3MGyltsV+NnprfBDPOOZksqxtdpvzFtgm4qUpeUpi2a46NxVH17VMvPSxWY
CfLpqNl23XkezzFrqcKdFOA8Pmxx+eDxYbl0OFQJSF3biluABfegW3AVoxeA
pKCaf1YX+17qeU1tPOqz7c7SZV0PSK2bjv1tImqzJPoL/qRrtxCWyC0v4IKP
Oq9QQVZX67lgodtqtbY7q61zGvJYFXwqZcyOIKOwhZTHiY4mePZ95PhKzra8
JfHrnp7L6hS6cxfX1JzqoQim5xPP1q5uwX69bw2oM6XwPWtLo1Zx8zxEEa8c
wudAf9b9JInLw/oHyyoqlGuZgjjFSY5ZRVIf51hYUeWeO4tDvcxVt9VQobJ9
KrAMKoeAeOo/GgUjyW3W6mPQhgi1mYS6BYeGrCaYqwPWZbXMcDVpu7rBFlCu
Z/JSyCtebcOIllgvA55mbhYDP7XVDvdI9qU06a98aTlFORpcEu9S5QdMfpRp
FlxB9ElOcheWihJwM3W53paeGa/eBKhKSFRo9hxLQr40vj84O8T9d4eXPzT+
Bp/G56548S4aB6QSiqiI5W/XiEp0RAYuyzEomRfiGNStsxERYZrljcb3/xQE
p2dXR+LqjDJTR4fHV2cXXUR1kt5wKhonLJMmg9+XgBRRYDrr6+tLKN1/K8Fu
DnPlgCpSod3C97/tdFoiCH5oNBqUidP9gTGZZkO1QY/Awunjqv/Ig1p7tw0T
BtQFBsRKkam0UhtinBAFtgQmoY1s6ahBLx9jWCaRRXCYgS3FOz3gsVMBhjv+
0jyMdWqXV5HPnwEfROfLlxafZODwKpWzl6Cm5K2DcZQ3MCQE5h3tQQph0nMG
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

-->

</rfc>

