<?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 2.6.10) -->


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

]>


<rfc ipr="trust200902" docName="draft-shahzad-scim-device-model-03" category="std" consensus="true" submissionType="IETF" tocInclude="true" sortRefs="true" symRefs="true">
  <front>
    <title abbrev="SCIM Device Schema Extensions">Device Schema Extensions to the SCIM model</title>

    <author initials="M." surname="Shahzad" fullname="Muhammad Shahzad">
      <organization>North Carolina State University</organization>
      <address>
        <postal>
          <street>Department of Computer Science</street> <street>890 Oval Drive</street> <street>Campus Box 8206</street>
          <city>Raleigh, NC</city>
          <code>27695-8206</code>
          <country>USA</country>
        </postal>
        <email>mshahza@ncsu.edu</email>
      </address>
    </author>
    <author initials="H." surname="Iqbal" fullname="Hassan Iqbal">
      <organization>North Carolina State University</organization>
      <address>
        <postal>
          <street>Department of Computer Science</street> <street>890 Oval Drive</street> <street>Campus Box 8206</street>
          <city>Raleigh, NC</city>
          <code>27695-8206</code>
          <country>USA</country>
        </postal>
        <email>hiqbal@ncsu.edu</email>
      </address>
    </author>
    <author initials="E." surname="Lear" fullname="Eliot Lear">
      <organization>Cisco Systems</organization>
      <address>
        <postal>
          <street>Richtistrasse 7</street>
          <city>Wallisellen</city>
          <code>CH-8304</code>
          <country>Switzerland</country>
        </postal>
        <phone>+41 44 878 9200</phone>
        <email>lear@cisco.com</email>
      </address>
    </author>

    <date year="2023" month="March" day="13"/>

    
    
    <keyword>Internet-Draft</keyword>

    <abstract>


<t>The initial core schema for SCIM (System for Cross Identity
Management) was designed for provisioning users.  This memo specifies
schema extensions that enables provisioning of devices, using various
underlying bootstrapping systems, such as Wifi EasyConnect, RFC 8366
vouchers, and BLE passcodes.</t>



    </abstract>



  </front>

  <middle>


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

<t>The Internet of Things presents a management challenge in many
dimensions.  One of them is the ability to onboard and manage large
number of devices.  There are many models for bootstrapping trust
between devices and network deployments.  Indeed it is expected that
different manufacturers will make use of different methods.</t>

<t>SCIM (System for Cross Identity Management) <xref target="RFC7643"/> <xref target="RFC7644"/>
defines a protocol and a schema for provisioning of users.  However,
it can easily be extended to provision devices.  The protocol and core
schema were designed to permit just such extensions.  Bulk operations
are supported.  This is good because often devices are procured in
bulk.</t>

<section anchor="why-scim-for-devices"><name>Why SCIM for devices?</name>
<t>Some might ask why SCIM is well suited for this purpose and not, for
example, NETCONF or RESTCONF with YANG.  After all, there are all sorts
of existing models available.  The answer is that the only information
being passed about the device is neither state nor device configuration
information, but only information necessary to bootstrap trust so that
the device may establish connectivity.</t>

</section>
<section anchor="protocol-participants"><name>Protocol Participants</name>

<t>In the normal SCIM model, it was presumed that large federated
deployments would be SCIM clients who provision and remove employees
and contractors as they are enter and depart those deployments, and
federated services such as sales, payment, or conferencing services
would be the servers.</t>

<t>In the device model, the roles are reversed, and may be somewhat more
varied.  A deployment network management system gateway (NMS gateway)
plays the role of the server, receiving information about devices that
are expected to be connected to its network.  That server will apply
appropriate local policies regarding whether/how the device should be
connected.</t>

<t>The client may be one of a number of entities:</t>

<t><list style="symbols">
  <t>A vendor who is authorized to add devices to a network as part of
a sales transaction.  This is similar to the sales integration
sometimes envisioned by Bootstrapping Remote Key Infrastructure
(BRSKI) <xref target="RFC8995"/>.</t>
  <t>A client application that administrators or employees use to add,
remove, or get information about devices.  An example might be an
tablet or phone app that scans Easyconnect QR codes.</t>
</list></t>

<figure title="Basic Architecture" anchor="arch"><artwork><![CDATA[

                            +-----------------------------------+
                            |                                   |
    +-----------+   Request |  +---------+                      |
    | onboarding|------------->|  SCIM   |                      |
    |    app    |<-------------| Server  |                      |
    +-----------+  Ctrl Endpt  +---------+                      |
                            |                                   |
    +-----------+           |  +------------+         +-------+ |
    |  Control  |...........|..|    ALG     |.........|device | |
    |    App    |           |  +------------+         +-------+ |
    +-----------+           |                                   |
                            |                                   |
                            +-----------------------------------+

]]></artwork></figure>

<t>In <xref target="arch"/>, the onboarding app provides the device particulars.  As
part of the response, the SCIM server might provide additional
information, especially in the case of non-IP devices, where an
application-layer gateway may need to be used to communicate with
the device.  The control endpoint is one among a number of objects
that may be returned.</t>

</section>
<section anchor="schema-description"><name>Schema Description</name>

<t>RFC 7643 does not prescribe a language to describe a schema. We
have chosen the JSON schema language <xref target="I-D.bhutton-json-schema"/> for
this purpose.  This implies that use of XML for this device extension
is not supported.</t>

<t>Several additional schemas specify specific onboarding mechanisms,
such as BLE and Wifi Easy Connect.</t>

</section>
<section anchor="schema-representation"><name>Schema Representation</name>

<t>Attributes defined in the device core schema and extensions comprise
characteristics and SCIM datatypes defined in Sections 2.2 and 2.3 of
the <xref target="RFC7643"/>. This RFC does not define new characteristics and
datatypes for the SCIM attributes.</t>

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

</section>
</section>
<section anchor="resourcetype-device"><name>ResourceType Device</name>
<t>This section defines a new resource type, 'Device'. The "ResourceType" 
schema specifies the metadata about a resource type (see section 6 of 
<xref target="RFC7643"/>). The resource "Devices" comprises a core device schema 
and several extension schemas. The core schema provides a minimal 
resource representation, whereas extension schemas extend the core 
schema depending on the device's capability. The JSON schema for Device
resource type is in <xref target="device-resource-schema"></xref>.</t>

<section anchor="common-attributes"><name>Common Attributes</name>

<t>The Device schema contains three common attributes as defined in the
<xref target="RFC7643"/>.</t>

<t>id</t>

<t>An id is a required and unique attribute of the device core schema
(see section 3.1 of <xref target="RFC7643"/>).</t>

<t>externalID</t>

<t>An externalID is an optional attribute (see section 3.1 of <xref target="RFC7643"/>).</t>

<t>meta</t>

<t>Meta is a complex attribute and is required (see section 3.1 of <xref target="RFC7643"/>).</t>

</section>
</section>
<section anchor="scim-core-device-schema"><name>SCIM Core Device Schema</name>

<t>The core device schema provides the minimal representation of a
resource "Device". It contains only those attributes that any device
may need. Not all attributes are optional.  The core schema for
"Device" is identified using the schema URI:
"urn:ietf:params:scim:schemas:core:2.0:Device". The following
attributes are defined in the device core schema.</t>

<section anchor="singular-attributes"><name>Singular Attributes</name>

<t>deviceDisplayName</t>

<t>This attribute is of type "string" and provides a human-readable name 
for a device. It is intended to be displayed to end-users and should be
suitable for that purpose. The attribute is not required, and is not 
case-sensitive. The attribute may be modified and should be returned 
by default. No uniqueness constraints are imposed on this attribute.</t>

<t>adminState</t>

<t>The "adminState" attribute is of type "boolean" and is a mutable 
attribute. If set to TRUE, the commands such as connect, disconnect, 
subscribe that control app sends to the controller for the devices 
will be processed by the controller. If set to FALSE, any command 
coming from the control app for the device will be rejected by the 
controller. This attribute is required and mutable. The attribute 
should be returned by default and there is uniqueness contraint 
on the attribute.</t>

<t>mudUrl</t>

<t>The mudUrl attribute represents the URL to the MUD file associated
with this device. This attribute is optional and mutable. The mudUrl
value is case sensitive and not unique. When present, this attribute
may be used as described in <xref target="RFC8520"/>. This attribute is case 
sensitive and returned by default.</t>

<figure title="Characteristics of device schema attributes. (Req = Required,
T = True, F = False, RW = ReadWrite, and Def = Default)" anchor="tabDevice"><artwork><![CDATA[
+===================+=======+=====+======+=========+========+========+
| Attribute         | Multi | Req | Case | Mutable | Return | Unique |
|                   | Value |     | Exact|         |        |        |
+===================+=======+=====+======+=========+========+========+
| deviceDisplayName |   F   |  F  |  F   |   RW    |  Def   |  None  |
+-------------------+-------+-----+------+---------+--------+--------+
| adminState        |   F   |  T  |  F   |   RW    |  Def   |  None  |
+-------------------+-------+-----+------+---------+--------+--------+
| mudUrl            |   F   |  F  |  T   |   RW    |  Def   |  None  |
+-------------------+-------+-----+------+---------+--------+--------+
]]></artwork></figure>

<t>An example of a device SCIM object is as follows:</t>

<figure><artwork><![CDATA[
<CODE BEGINS>
{
        "schemas": ["urn:ietf:params:scim:schemas:core:2.0:Device"],
        "id": "e9e30dba-f08f-4109-8486-d5c6a3316111",
        "deviceDisplayName": "BLE Heart Monitor",
        "adminState": true,
        "meta": {
          "resourceType": "Device",
      "created": "2022-01-23T04:56:22Z",
          "lastModified": "2022-05-13T04:42:34Z",
          "version": "W\/\"a330bc54f0671c9\"", 
          "location": "https://example.com/v2/Device/e9e30dba-f08f-4109-8486-d5c6a3316111"
        }
}
<CODE ENDS>
]]></artwork></figure>

<t>The schema for the device is presented in JSON format in Section
<xref target="device-core-schema-json"></xref>, while the openAPI representation is provided in 
Section <xref target="device-core-schema-openapi-representation"></xref>.</t>

</section>
</section>
<section anchor="device-groups"><name>Device Groups</name>

<t>Device groups are created using the SCIM groups as defined in
<xref target="RFC7643"/> Section 4.2.</t>

</section>
<section anchor="scim-device-extensions"><name>SCIM Device Extensions</name>

<t>SCIM provides various extension schemas, their attributes,
JSON representation, and example object. These schemas extend the core
device schema based on the device's capability (communication stack).
This RFC presents an additional hierarchical level by introducing
extensions within an extension.  See below for more details.</t>

<t>[[ DISCUSS: Is this okay with the working group? ]]</t>

<section anchor="ble-extension"><name>BLE Extension</name>

<t>This schema extends the device schema to represent the devices
supporting BLE. The extension is identified using the following 
schema URI:</t>

<t>urn:ietf:params:scim:schemas:extension:ble:2.0:Device</t>

<t>The attributes are as follows:</t>

<section anchor="singular-attributes-1"><name>Singular Attributes</name>

<t>deviceMacAddress</t>

<t>A string vakue that represent a public MAC address assigned by the 
manufacturer. It is a unique  48-bit value. Ir is required, case 
insensitive, and it is mutable and return as default. The regex 
pattern is the following:</t>

<figure><artwork><![CDATA[
^[0-9A-Fa-f]{2}(:[0-9A-Fa-f]{2}){5}
]]></artwork></figure>

<t>addressType</t>

<t>A boolean flag taken from the BLE core specification, 5.3. If FALSE, the
device is using a public MAC address. If TRUE, the device uses a
Random address resolved using IRK. This attribute is required, it is 
mutable, and return by default.</t>

<t>irk</t>

<t>A string value, Identity resolving key, which is unique for every 
device. It is used to resolve the random address. It is required when 
addressType is TRUE. It is mutable and return by default.</t>

</section>
<section anchor="multivalued-attributes"><name>Multivalued Attributes</name>

<t>versionSupport</t>

<t>A multivalued attribute that provides all the BLE versions supported by the
device in the form of an array. For example, 
[4.1, 4.2, 5.0, 5.1, 5.2, 5.3]. It is required, mutable, and 
return as default.</t>

<t>pairingMethods</t>

<t>An array of pairing methods associated with the BLE
device. The pairing methods may require sub-attributes, such as
key/password, for the device pairing process. To enable the
scalability of pairing methods in the future, they are represented as
extensions to incorporate various attributes that are part of the
respective pairing process. Pairing method extensions are nested
inside the BLE extension. It is required, case sensitive, mutable, and 
returned by deafult.</t>

</section>
<section anchor="ble-pairing-method-extensions"><name>BLE Pairing Method Extensions</name>

<t>The details on pairing methods and their associated attributes are in
section 2.3 of <xref target="BLE53"/>.  This memo defines extensions for four
pairing methods that are nested insided the BLE extension schema. Each 
extension contains the common attributes <xref target="common-attributes"></xref>. These 
extension are are as follows.</t>

<t>(i) pairingNull extension is identified using the following schema URI:</t>

<t>urn:ietf:params:scim:schemas:extension:pairingNull:2.0:Device</t>

<t>pairingNull does not have any attribute. It allows pairing for BLE
devices that do not require a pairing method.</t>

<t>(ii) pairingJustWorks extension is identified using the following 
schema URI:</t>

<t>urn:ietf:params:scim:schemas:extension:pairingJustWorks:2.0:Device</t>

<t>Just works pairing method does not require a key to pair devices. For
completeness, the key attribute is included and is set to 'null'. Key 
attribute is required, immutable, and return by default.</t>

<t>(iii) pairingPassKey extension is identified using the following 
schema URI:</t>

<t>urn:ietf:params:scim:schemas:extension:pairingPassKey:2.0:Device</t>

<t>The pass key pairing method requires a 6-digit key to pair devices.
This extension has one singular integer attribute, "key", which is 
required, mutable and returned by default. The key pattern is
as follows:</t>

<figure><artwork><![CDATA[
^[0-9]{6}$
]]></artwork></figure>

<t>(iv) pairingOOB extension is identified using the following 
schema URI:</t>

<t>urn:ietf:params:scim:schemas:extension:pairingOOB:2.0:Device</t>

<t>The out-of-band pairing method includes three singular attributes,
i.e., key, randomNumber, and confirmationNumber.</t>

<t>key  The key is string value, required and received from out-of-bond 
sources such as NFC. It is case sensitive, mutable, and returned 
by default.</t>

<t>randomNumber  It represents a nounce added to the key. It is and 
integer value that is required attribute. It is mutable and 
returned by default.</t>

<t>confirmationNumber  An integer which some solutions require in RESTful
message exchange. It is not required. It is mutable and returned by 
default if it exists.</t>

<figure title="Characteristics of BLE extension schema attributes. 
(Req = Required, T = True, F = False, RW = ReadWrite, Def = Default, 
and Manuf = Manufacturer)." anchor="tabBLE"><artwork><![CDATA[
+===================+=======+=====+======+=========+========+========+
| Attribute         | Multi | Req | Case | Mutable | Return | Unique |
|                   | Value |     | Exact|         |        |        |
+===================+=======+=====+======+=========+========+========+
| deviceMacAddress  |   F   |  T  |  F   |   RW    |  Def   | Manuf  |
+-------------------+-------+-----+------+---------+--------+--------+
| addressType       |   F   |  T  |  F   |   RW    |  Def   | None   |
+-------------------+-------+-----+------+---------+--------+--------+
| irk               |   F   |  F  |  F   |   RW    |  Def   | Manuf  |
+-------------------+-------+-----+------+---------+--------+--------+
| versionSupport    |   T   |  T  |  F   |   RW    |  Def   | None   |
+-------------------+-------+-----+------+---------+--------+--------+
| pairingMethods    |   T   |  T  |  T   |   RW    |  Def   | None   |
+-------------------+-------+-----+------+---------+--------+--------+
]]></artwork></figure>

<t>An example of a device object with BLE extension is as follows:</t>

<figure><artwork><![CDATA[
<CODE BEGINS>
{
  "schemas": ["urn:ietf:params:scim:schemas:core:2.0:Device",
     "urn:ietf:params:scim:schemas:extension:ble:2.0:Device"],

  "id": "e9e30dba-f08f-4109-8486-d5c6a3316111",
  "deviceDisplayName": "BLE Heart Monitor",
  "adminState": true,
  "urn:ietf:params:scim:schemas:extension:ble:2.0:Device" : {       
    "versionSupport": ["5.3"],
    "deviceMacAddress": "2C:54:91:88:C9:E2",
    "addressType": false,
    "pairingMethods": ["urn:ietf:params:scim:schemas:extension:pairingNull:2.0:Device",
        "urn:ietf:params:scim:schemas:extension:pairingJustWorks:2.0:Device",
        "urn:ietf:params:scim:schemas:extension:pairingPassKey:2.0:Device",
        "urn:ietf:params:scim:schemas:extension:pairingOOB:2.0:Device"],
    "urn:ietf:params:scim:schemas:extension:pairingNull:2.0:Device": null,
    "urn:ietf:params:scim:schemas:extension:pairingJustWorks:2.0:Device": {
      "key": null
    },
    "urn:ietf:params:scim:schemas:extension:pairingPassKey:2.0:Device" : {
      "key": 123456
    },
    "urn:ietf:params:scim:schemas:extension:pairingOOB:2.0:Device": {
      "key": "TheKeyvalueRetrievedFromOOB",
      "randNumber": 238796813516896
    }         
  },
  "meta": {
    "resourceType": "Device",
      "created": "2022-01-23T04:56:22Z",
    "lastModified": "2022-05-13T04:42:34Z",
    "version": "W\/\"a330bc54f0671c9\"", 
    "location": "https://example.com/v2/Device/e9e30dba-f08f-4109-8486-d5c6a3316111"
  }
}
<CODE ENDS>
]]></artwork></figure>

<t>The schema for the BLE extension is presented in JSON format in Section 
<xref target="ble-extension-schema-json"></xref>, while the openAPI representation is provided in 
Section <xref target="ble-extension-schema-openapi-representation"></xref>.</t>

</section>
</section>
<section anchor="dpp-easyconnect-extension"><name>DPP EasyConnect Extension</name>

<t>A schema that extends the device schema to enable WiFi EasyConnect
(otherwise known as Device Provisioning Protocol). The extension is 
identified using the following schema URI:</t>

<t>urn:ietf:params:scim:schemas:extension:dpp:2.0:Device</t>

<t>The attributes in this extension are adopted from <xref target="DPP2"/>. The 
attributes are as follows:</t>

<section anchor="singular-attributes-2"><name>Singular Attributes</name>

<t>dppVersion</t>

<t>An integer that represents the version of DPP the device supports. 
This attribute is required, case insensitive, mutable, and 
returned by default.</t>

<t>bootstrapKey</t>

<t>A string value representing Elliptic-Curve Diffie–Hellman (ECDH) public 
key. The base64 encoded lengths for P-256, P-384, and P-521 are 
80, 96, and 120 characters. This attribute is required, case-sensitive,
mutable, and returned by default.</t>

<t>deviceMacAddress</t>

<t>The manufacturer assigns the MAC address stored as string. It is a 
unique 48-bit value. This attribute is optional, case insensitive, 
mutable, and returned by default. The regex pattern is as follows:</t>

<figure><artwork><![CDATA[
^[0-9A-Fa-f]{2}(:[0-9A-Fa-f]{2}){5}.
]]></artwork></figure>

<t>serialNumber</t>

<t>An alphanumeric serial number, stored as string, may also be passed 
as bootstrapping information. This attribute is optional, case 
insensitive, mutable, and returned by default.</t>

</section>
<section anchor="multivalued-attributes-1"><name>Multivalued Attributes</name>

<t>bootstrappingMethod</t>

<t>It is the array of strings of all the bootstrapping methods available 
on the enrollee device. For example, [QR, NFC]. This attribute is 
optional, case insensitive, mutable, and returned by default.</t>

<t>classChannel</t>

<t>This attribute is an array of strings of global operating class and 
channel shared as bootstrapping information. It is formatted as 
class/channel. For example, ['81/1','115/36']. This attribute 
is optional, case insensitive, mutable, and returned by default.</t>

<figure title="Characteristics of DPP extension schema attributes. 
(Req = Required, T = True, F = False, RW = ReadWrite, Def = Default,
and Manuf = Manufacturer)." anchor="tabDPP"><artwork><![CDATA[
+====================+=======+=====+======+=========+========+========+
| Attribute          | Multi | Req | Case | Mutable | Return | Unique |
|                    | Value |     | Exact|         |        |        |
+====================+=======+=====+======+=========+========+========+
| dppVersion         |   F   |  T  |  F   |   RW    |  Def   | None   |
+--------------------+-------+-----+------+---------+--------+--------+
| bootstrapKey       |   F   |  T  |  T   |   RW    |  Def   | None   |
+--------------------+-------+-----+------+---------+--------+--------+
| deviceMacAddress   |   F   |  F  |  F   |   RW    |  Def   | Manuf  |
+--------------------+-------+-----+------+---------+--------+--------+
| serialNumber       |   F   |  F  |  F   |   RW    |  Def   | None   |
+--------------------+-------+-----+------+---------+--------+--------+
| bootstrappingMethod|   T   |  F  |  F   |   RW    |  Def   | None   |
+--------------------+-------+-----+------+---------+--------+--------+
| classChannel       |   T   |  F  |  F   |   RW    |  Def   | None   |
+--------------------+-------+-----+------+---------+--------+--------+
]]></artwork></figure>

<t>An example of a device object with DPP extension is below:</t>

<figure><artwork><![CDATA[
<CODE BEGINS>
{
        "schemas": ["urn:ietf:params:scim:schemas:core:2.0:Device",
                 "urn:ietf:params:scim:schemas:extension:dpp:2.0:Device"],

        "id": "e9e30dba-f08f-4109-8486-d5c6a3316111",
        "displayName": "WiFi Heart Monitor",
        "adminState": true,
        "urn:ietf:params:scim:schemas:extension:dpp:2.0:Device" : {
                "versionSupport": ["802.11ax"],
                "bootstrappingMethod": ["QR"],
                "bootstrapKey": "MDkwEwYHKoZIzj0CAQYIKoZIzj0DAQcDIgADURzxmttZoIRIPWGoQMV00XHWCAQIhXruVWOz0NjlkIA=",
                "deviceMacAddress": "2C:54:91:88:C9:F2",
                "classChannel": ["81/1", "115/36"], 
                "serialNumber": "4774LH2b4044"          
        },

        "meta": {
          "resourceType": "Device",
      "created": "2022-01-23T04:56:22Z",
          "lastModified": "2022-05-13T04:42:34Z",
          "version": "W\/\"a330bc54f0671c9\"", 
          "location": "https://example.com/v2/Device/e9e30dba-f08f-4109-8486-d5c6a3316111"
        }
}
<CODE ENDS>
]]></artwork></figure>

<t>The schema for the DPP extension is presented in JSON format in Section 
<xref target="dpp-extension-schema-json"></xref>, while the openAPI representation is provided 
in Section <xref target="dpp-extension-schema-openapi-representation"></xref>.</t>

</section>
</section>
<section anchor="zigbee-extension"><name>Zigbee Extension</name>

<t>A schema that extends the device schema to enable the provisioning of 
Zigbee devices. The extension is identified using the following 
schema URI:</t>

<t>urn:ietf:params:scim:schemas:extension:zigbee:2.0:Device</t>

<t>It has one singular attribute and one multivalued 
attribute. The attributes are as follows:</t>

<section anchor="singular-attribute"><name>Singular Attribute</name>

<t>deviceEui64Address</t>

<t>An EUI-64 (Extended Unique Identifier) device address stored as string.
This attribute is required, case insensitive, mutable, and returned by
default. The regex pattern is as follows:</t>

<figure><artwork><![CDATA[
^[0-9A-Fa-f]{16}$
]]></artwork></figure>

</section>
<section anchor="multivalued-attribute"><name>Multivalued Attribute</name>

<t>versionSupport</t>

<t>An array of strings of all the Zigbee versions supported
by the device. For example, [3.0]. This attribute is required, case 
insensitive, mutable, and returned by default.</t>

<figure title="Characteristics of Zigbee extension schema attributes.
(Req = Required, T = True, F = False, RW = ReadWrite, and 
Def = Default)" anchor="tabZigbee"><artwork><![CDATA[
+====================+=======+=====+======+=========+========+========+
| Attribute          | Multi | Req | Case | Mutable | Return | Unique |
|                    | Value |     | Exact|         |        |        |
+====================+=======+=====+======+=========+========+========+
| deviceEui64Address |   F   |  T  |  F   |   RW    |  Def   | None   |
+--------------------+-------+-----+------+---------+--------+--------+
| versionSupport     |   T   |  T  |  F   |   RW    |  Def   | None   |
+--------------------+-------+-----+------+---------+--------+--------+
]]></artwork></figure>

<t>An example of a device object with Zigbee extension is shown below:</t>

<figure><artwork><![CDATA[
<CODE BEGINS>
{
  "schemas": ["urn:ietf:params:scim:schemas:core:2.0:Device",
     "urn:ietf:params:scim:schemas:extension:zigbee:2.0:Device"],
     
  "id": "e9e30dba-f08f-4109-8486-d5c6a3316111",
  "displayName": "Zigbee Heart Monitor",
  "adminState": true,
  "urn:ietf:params:scim:schemas:extension:zigbee:2.0:Device" : {
    "versionSupport": ["3.0"],
    "deviceEui64Address": "50325FFFFEE76728"
  },
  
  "meta": {
    "resourceType": "Device",
      "created": "2022-01-23T04:56:22Z",
    "lastModified": "2022-05-13T04:42:34Z",
    "version": "W\/\"a330bc54f0671c9\"", 
    "location": "https://example.com/v2/Device/e9e30dba-f08f-4109-8486-d5c6a3316111"
  }
}
<CODE ENDS>
]]></artwork></figure>

<t>The schema for the Zigbee extension is presented in JSON format in 
Section <xref target="zigbee-extension-schema-json"></xref>, while the openAPI 
representation is provided in Section <xref target="zigbee-extension-schema-openapi-representation"></xref>.</t>

</section>
</section>
<section anchor="the-endpoint-applications-extension-schema"><name>The Endpoint Applications Extension Schema</name>

<t>Sometimes non-IP devices such as those using BLE or Zigbe require an
application gateway interface to manage them. SCIM clients MUST NOT
specify this to describe native IP-based devices.</t>

<t>The device schema is a base schema upon which specific onboarding
technology schemas are built. This extension provides two complex
attributes deviceControl, and dataReceiver to represent
two types of partner endpoint applications, device
control, and data receiver applications, respectively. 
The extension is identified using the following schema URI:</t>

<t>urn:ietf:params:scim:schemas:extension:endpointApps:2.0:Device</t>

<section anchor="devicecontrol-complex-attribute"><name>"deviceControl" Complex Attribute</name>

<t>A complex attribute representing the application responsible for
controlling the device. Device control applications provide access
control for the device. It determines which other applications can
access the data from the device. Depending on the use case, there can
be more than one device control application. deviceControl has two 
sub-attributes: (i) a multvalued client-tokens
attribute and (ii) a singular attribute called
enterpriseEndpoint.</t>

<t>client-tokens</t>

<t>This attribute contains a list of tokens that the client will used to
authenticate itself.  Each token may be a string up to 500 characters
in length. This attribute is a multivalued string which is required,
case-sensitive, mutable, and returned by default.</t>

<t>[[ We probably need something better here. ]]</t>

<t>enterpriseEndpoint</t>

<t>Device control apps use the URL of the enterprise endpoint to reach
the network gateway. When the enterprise receives the SCIM object from
the onboarding app, it adds this attribute to it and sends it back as
a response to the onboarding app. This attribute is required,
case-sensitive, mutable, and returned by default.</t>

</section>
<section anchor="datareceiver-complex-attribute"><name>"dataReceiver" Complex Attribute</name>

<t>A complex attribute representing the application(s) that receive data
from the device. Depending on the use case, there can be more than one
data receiver application. "dataReceiver" has two sub-attributes: 
(i) a multi-valued attribute called client-tokens, and (ii) a singular
attribute called enterpriseEndpoint.</t>

<t>client-tokens</t>

<t>This attribute contains a list of tokens that the client will used to
authenticate itself.  Each token may be a string up to 500 characters
in length. This attribute is a multivalued string which is required,
case-sensitive, mutable, and returned by default.</t>

<t>[[ We probably need something better here. ]]</t>

<t>enterpriseEndpoint</t>

<t>Data receiver apps use the URL of the enterprise endpoint to reach the
network gateway. When the enterprise receives the SCIM object from the
onboarding app, it adds this attribute to it and sends it back as a
response to the onboarding app. This attribute is required,
case-sensitive, mutable, and returned by default.</t>

<figure title="Characteristics of EndpointApps extension schema 
attributes. (Req = Required, T = True, F = False, RW = ReadWrite,
Def = Default, and Manuf = Manufacturer)." anchor="tabEndpointApps"><artwork><![CDATA[
+====================+=======+=====+======+=========+========+========+
| Attribute          | Multi | Req | Case | Mutable | Return | Unique |
|                    | Value |     | Exact|         |        |        |
+====================+=======+=====+======+=========+========+========+
| client-tokens      |   T   |  T  |  T   |   RW    |  Def   | None   |
+--------------------+-------+-----+------+---------+--------+--------+
| enterpriseEndpoint |   F   |  T  |  T   |   RW    |  Def   | None   |
+--------------------+-------+-----+------+---------+--------+--------+
| deviceControl      |   F   |  T  |  F   |   RW    |  Def   | Manuf  |
+--------------------+-------+-----+------+---------+--------+--------+
| dataReceiver       |   F   |  T  |  F   |   RW    |  Def   | None   |
+--------------------+-------+-----+------+---------+--------+--------+
]]></artwork></figure>

<t>An example of a device object with endpointApps extension is below:</t>

<figure><artwork><![CDATA[
<CODE BEGINS>
{
  "schemas": ["urn:ietf:params:scim:schemas:core:2.0:Device",
     "urn:ietf:params:scim:schemas:extension:ble:2.0:Device",
     "urn:ietf:params:scim:schemas:extension:endpointapps:2.0:Device"],

  "id": "e9e30dba-f08f-4109-8486-d5c6a3316111",
  "displayName": "BLE Heart Monitor",
  "adminState": true,
    "urn:ietf:params:scim:schemas:extension:ble:2.0:Device" :
    {          "versionSupport": ["5.3"],
    "deviceMacAddress": "2C:54:91:88:C9:E2",
    "addressType": false,
      "pairingMethods": [
        "urn:ietf:params:scim:schemas:extension:pairingNull:2.0:Device",
        "urn:ietf:params:scim:schemas:extension:pairingJustWorks:2.0:Device",
        "urn:ietf:params:scim:schemas:extension:pairingPassKey:2.0:Device",
        "urn:ietf:params:scim:schemas:extension:pairingOOB:2.0:Device"],
    "urn:ietf:params:scim:schemas:extension:pairingNull:2.0:Device": null,
    "urn:ietf:params:scim:schemas:extension:pairingJustWorks:2.0:Device": {
      "key": null
    },
    "urn:ietf:params:scim:schemas:extension:pairingPassKey:2.0:Device" : {
      "key": 123456
    },
    "urn:ietf:params:scim:schemas:extension:pairingOOB:2.0:Device": {
      "key": "TheKeyvalueRetrievedFromOOB",
      "randNumber": 238796813516896
    }         
  },

  "urn:ietf:params:scim:schemas:extension:endpointapps:2.0:Device": {
        
    "deviceControl": {
      "client-tokens": [
          "1293847109832471203984789383XXX"
      ],
      "enterpriseEndpoint": "https//enterprise.com/device_control_endpoint/"
    },
    
    "dataReceiver": {
      "client-tokens":[
          "dlku23234sdui232393"
      ],
      "enterpriseEndpoint": "https//enterprise.com/data_receiver_endpoint/"       
    }
  },

  
  "meta": {
    "resourceType": "Device",
      "created": "2022-01-23T04:56:22Z",
    "lastModified": "2022-05-13T04:42:34Z",
    "version": "W\/\"a330bc54f0671c9\"", 
    "location": "https://example.com/v2/Device/e9e30dba-f08f-4109-8486-d5c6a3316111"
  }
}
<CODE ENDS>
]]></artwork></figure>

<t>The schema for the endpointApps extension along with BLE extension is 
presented in JSON format in Section <xref target="endpointapps-extension-schema-json"></xref>, while 
the openAPI representation is provided in Section <xref target="endpointapps-extension-schema-openapi-representation"></xref>.</t>

</section>
</section>
</section>
<section anchor="schema-json-representation"><name>Schema JSON Representation</name>

<section anchor="device-resource-schema"><name>Device Resource Schema</name>

<figure><artwork><![CDATA[
<CODE BEGINS>
[
  {
    "schemas": ["urn:ietf:params:scim:schemas:core:2.0:ResourceType"],
    "id": "Device",
    "name": "Device",
    "endpoint": "/Device",
    "description": "Device Account",
    "schema": "urn:ietf:params:scim:schemas:core:2.0:Device",
    "schemaExtensions": [
      {
        "schema": "urn:ietf:params:scim:schemas:extension:ble:2.0:Device",
        "required": false
      },
      {
        "schema": "urn:ietf:params:scim:schemas:extension:dpp:2.0:Device",
        "required": false
      },
      {
        "schema": "urn:ietf:params:scim:schemas:extension:zigbee:2.0:Device",
        "required": false
      },
      {
        "schema": "urn:ietf:params:scim:schemas:extension:endpointApps:2.0:Device",
        "required": false
      },
      {
        "schema": "urn:ietf:params:scim:schemas:extension:pairingNull:2.0:Device",
        "required": false
      },
      {
        "schema": "urn:ietf:params:scim:schemas:extension:pairingJustWorks:2.0:Device",
        "required": false
      },
      {
        "schema": "urn:ietf:params:scim:schemas:extension:pairingPassKey:2.0:Device",
        "required": false
      },
      {
        "schema": "urn:ietf:params:scim:schemas:extension:pairingOOB:2.0:Device",
        "required": false
      }
    ],
    "meta": {
      "location": "https://example.com/v2/ResourceTypes/Device",
      "resourceType": "ResourceType"
    }
  }

]
<CODE ENDS>
]]></artwork></figure>

</section>
<section anchor="device-core-schema-json"><name>Device Core Schema JSON</name>

<figure><artwork><![CDATA[
<CODE BEGINS>
{  
  "id": "urn:ietf:params:scim:schemas:core:2.0:Device",
  "name": "Device",
  "description": "Device account",
  "attributes" : [
    {
      "name": "deviceDisplayName",
      "type": "string",
      "description": "Human readable name of the device, suitable for
       displaying to end-users. For example, 'BLE Heart Monitor'
       etc.",  
      "multivalues": false,
      "required": false,
      "caseExact": false,
      "mutability": "readWrite",
      "returned": "default",
      "uniqueness": "none"
    },
    {
      "name": "adminState",
      "type": "boolean",
      "description": "A mutable boolean value indicating the device
       administrative status. If set TRUE, the commands (such as
       connect, disconnect, subscribe) that control app sends to the
       controller for the devices will be processeed by the
       controller. If set FALSE, any command comming from the control
       app for the device will be rejected by the controller.",
      "multivalues": false,
      "required": true,
      "caseExact": false,
      "mutability": "readWrite",
      "returned": "default",
      "uniqueness": "none"
    },
    {
      "name": "mudUrl",
      "type": "reference",
      "description": "A URL to MUD file of the device (RFC 8520).",
      "multivalues": false,
      "required": false,
      "caseExact": true,
      "mutability": "readWrite",
      "returned": "default",
      "uniqueness": "none"
    }
  ],
  "meta" : {
    "resourceType" : "Schema",
    "location" :
      "/v2/Schemas/urn:ietf:params:scim:schemas:core:2.0:Device"
  }
}
<CODE ENDS>
]]></artwork></figure>

</section>
<section anchor="ble-extension-schema-json"><name>BLE Extension Schema JSON</name>
<figure><artwork><![CDATA[
<CODE BEGINS>
[
  {  
    "id": "urn:ietf:params:scim:schemas:extension:ble:2.0:Device",
    "name": "bleExtension",
    "description": "Ble extension for device account",
    "attributes" : [
      {
        "name": "versionSupport",
        "type": "string",
        "description": "Provides a list of all the BLE versions
         supported by the device. For example, [4.1, 4.2, 5.0, 5.1,
         5.2, 5.3].", 
        "multivalues": true,
        "required": true,
        "caseExact": false,
        "mutability": "readWrite",
        "returned": "default",
        "uniqueness": "none"
      },
      {
        "name": "deviceMacAddress",
        "type": "string",
        "description": "It is the public MAC address assigned by the
         manufacturer. It is unique 48 bit value. The regex pattern
         is ^[0-9A-Fa-f]{2}(:[0-9A-Fa-f]{2}){5}.",
        "multivalues": false,
        "required": true,
        "caseExact": false,
        "mutability": "readWrite",
        "returned": "default",
        "uniqueness": "Manufacturer"
      },
      {
        "name": "addressType",
        "type": "boolean",
        "description": "AddressType flag is taken from the BLE core
         specifications 5.3. If FALSE, the device is using public MAC
         address. If TRUE, device is using Random address which is
         resolved using IRK.",
        "multivalues": false,
        "required": true,
        "caseExact": false,
        "mutability": "readWrite",
        "returned": "default",
        "uniqueness": "none"
      },
      {
        "name": "irk",
        "type": "string",
        "description": "Identity resolving key, which is unique for
         every device. It is used to resolve random address.",
        "multivalues": false,
        "required": false,
        "caseExact": false,
        "mutability": "readWrite",
        "returned": "default",
        "uniqueness": "Manufacturer"
      },
      {
        "name": "pairingMethods",
        "type": "string",
        "description": "List of pairing methods associated with the
         ble device, stored as schema URI.",
        "multivalues": true,
        "required": true,
        "caseExact": true,
        "mutability": "readWrite",
        "returned": "default",
        "uniqueness": "none"
      }
    ],
    "meta" : {
      "resourceType" : "Schema",
      "location" : "/v2/Schemas/urn:ietf:params:scim:
                    schemas:extension:ble:2.0:Device"
    }
  },
  {
    "id": "urn:ietf:params:scim:schemas:extension:pairingNull:2.0:Device",
    "name": "nullPairing",
    "description": "Null pairing method for ble. It is included for
                    the devices that do not have a pairing method.", 
    "meta" : {
      "resourceType" : "Schema",
      "location" : "/v2/Schemas/urn:ietf:params:scim:schemas:
                    extension:pairingNull:2.0:Device"
    }
  },
  {
    "id": "urn:ietf:params:scim:schemas:extension:
           pairingJustWorks:2.0:Device",
    "name": "pairingJustWorks",
    "description": "Just works pairing method for ble.",
    "attributes" : [
      {
        "name": "key",
        "type": "integer",
        "description": "Just works does not have any key value. For
         completeness, it is added with a key value 'null'.", 
        "multivalues": false,
        "required": true,
        "caseExact": false,
        "mutability": "immutable",
        "returned": "default",
        "uniqueness": "none"
      }
    ],
    "meta" : {
      "resourceType" : "Schema",
      "location" : "/v2/Schemas/urn:ietf:params:scim:
       schemas:extension:pairingJustWorks:2.0:Device"
    }
  },
  {
    "id": "urn:ietf:params:scim:schemas:
           extension:pairingPassKey:2.0:Device",
    "name": "pairingPassKey",
    "description": "Pass key pairing method for ble.",
    "attributes" : [
      {
        "name": "key",
        "type": "integer",
        "description": "A six digit passkey for ble device. The
         pattern of key is ^[0-9]{6}$.", 
        "multivalues": false,
        "required": true,
        "caseExact": false,
        "mutability": "readWrite",
        "returned": "default",
        "uniqueness": "none"
      }
    ],
    "meta" : {
      "resourceType" : "Schema",
      "location" : "/v2/Schemas/urn:ietf:params:scim:schemas:
       extension:pairingPassKey:2.0:Device"
    }
  },
  {
    "id": "urn:ietf:params:scim:schemas:extension:pairingOOB:2.0:Device",
    "name": "pairingOOB",
    "description": "Pass key pairing method for ble.",
    "attributes" : [
      {
        "name": "key",
        "type": "string",
        "description": "A key value retrieved from out of band source
         such as NFC.", 
        "multivalues": false,
        "required": true,
        "caseExact": true,
        "mutability": "readWrite",
        "returned": "default",
        "uniqueness": "none"
      },
      {
        "name": "randomNumber",
        "type": "integer",
        "description": "Nonce added to the key.",
        "multivalues": false,
        "required": true,
        "caseExact": false,
        "mutability": "readWrite",
        "returned": "default",
        "uniqueness": "none"
      },
      {
        "name": "confirmationNumber",
        "type": "integer",
        "description": "Some solutions require confirmation number in
         RESTful message exchange.",
        "multivalues": false,
        "required": false,
        "caseExact": false,
        "mutability": "readWrite",
        "returned": "default",
        "uniqueness": "none"
      }
    ],
    "meta" : {
      "resourceType" : "Schema",
      "location" : "/v2/Schemas/urn:ietf:params:scim:schemas:
                    extension:pairingOOB:2.0:Device"
    }
  }
]
<CODE ENDS>
]]></artwork></figure>

</section>
<section anchor="dpp-extension-schema-json"><name>DPP Extension Schema JSON</name>
<figure><artwork><![CDATA[
<CODE BEGINS>
{  
    "id": "urn:ietf:params:scim:schemas:extension:dpp:2.0:Device",
    "name": "dppExtension",
    "description": "Device extension schema for DPP",
    "attributes" : [
      {
        "name": "dppVersion",
        "type": "integer",
        "description": "Version of DPP this device supports.",
        "multivalues": false,
        "required": true,
        "caseExact": false,
        "mutability": "readWrite",
        "returned": "default",
        "uniqueness": "none"
      },
      {
        "name": "bootstrappingMethod",
        "type": "string",
        "description": "The list of all the bootstrapping methods
         available on the enrollee device. For example, [QR, NFC].",
        "multivalues": true,
        "required": false,
        "caseExact": false,
        "mutability": "readWrite",
        "returned": "default",
        "uniqueness": "none"
      },
      {
        "name": "bootstrapKey",
        "type": "string",
        "description": "This key is Elliptic-Curve Diffie–Hellman
         (ECDH) public key. The base64 encoded length for P-256,
         P-384, and P-521 is 80, 96, and 120 characters.",
        "multivalues": false,
        "required": true,
        "caseExact": true,
        "mutability": "readWrite",
        "returned": "default",
        "uniqueness": "none"
      },
      {
        "name": "deviceMacAddress",
        "type": "string",
        "description": "The MAC address assigned by the
         manufacturer. It is unique 48 bit value. The regex pattern is
         ^[0-9A-Fa-f]{2}(:[0-9A-Fa-f]{2}){5}.",
        "multivalues": false,
        "required": false,
        "caseExact": false,
        "mutability": "readWrite",
        "returned": "default",
        "uniqueness": "Manufacturer"
      },
      {
        "name": "classChannel",
        "type": "string",
        "description": "A list of global operating class and channel
         shared as bootstrapping information. It is formatted as
         class/channel. For example, '81/1', '115/36'.",
        "multivalues": true,
        "required": false,
        "caseExact": false,
        "mutability": "readWrite",
        "returned": "default",
        "uniqueness": "none"
      },
      {
        "name": "serialNumber",
        "type": "string",
        "description": "An alphanumeric serial number that may also be
         passed as bootstrapping information.",
        "multivalues": false,
        "required": false,
        "caseExact": false,
        "mutability": "readWrite",
        "returned": "default",
        "uniqueness": "none"
      }

    ],
    "meta" : {
      "resourceType" : "Schema",
      "location" : "/v2/Schemas/urn:ietf:params:
                    scim:schemas:extension:dpp:2.0:Device"
    }
  }
<CODE ENDS>
]]></artwork></figure>

</section>
<section anchor="zigbee-extension-schema-json"><name>Zigbee Extension Schema JSON</name>
<figure><artwork><![CDATA[
<CODE BEGINS>
{  
  "id": "urn:ietf:params:scim:schemas:extension:zigbee:2.0:Device",
  "name": "zigbeeExtension",
  "description": "Device extension schema for zigbee.",
  "attributes" : [
    {
      "name": "versionSupport",
      "type": "string",
      "description": "Provides a list of all the zigbee versions
       supported by the device. For example, [3.0].",
      "multivalues": true,
      "required": true,
      "caseExact": false,
      "mutability": "readWrite",
      "returned": "default",
      "uniqueness": "none"
    },
    {
      "name": "deviceEui64Address",
      "type": "string",
      "description": "The EUI-64 (Extended Unique Identifier) device
       address. The regex pattern is ^[0-9A-Fa-f]{16}$.", 
      "multivalues": false,
      "required": true,
      "caseExact": false,
      "mutability": "readWrite",
      "returned": "default",
      "uniqueness": "none"
    }
  ],
  "meta" : {
    "resourceType" : "Schema",
    "location" :
     "/v2/Schemas/urn:ietf:params:scim:schemas:
      extension:zigbee:2.0:Device"
  }
}
<CODE ENDS>
]]></artwork></figure>

</section>
<section anchor="endpointapps-extension-schema-json"><name>EndpointApps Extension Schema JSON</name>
<figure><artwork><![CDATA[
<CODE BEGINS>
{  
  "id": "urn:ietf:params:scim:schemas:extension:endpointApps:2.0:
      Device",
  "name": "endpointApps",
  "description": "Extension for partner endpoint applications that
   can onboard, control, and communicate with the device.",
  "attributes" : [
    {
      "name": "deviceControl",
      "type": "complex",
      "description": "Device control application attributes.",
      "multivalues": false,
      "required": true,
      "caseExact": false,
      "mutability": "readWrite",
      "returned": "default",
      "uniqueness": "none",
      "subAttributes" : [
        {
          "name": "client-tokens",
           "type": "string",
           "description": "This attribute contains a list of tokens
            that the client will used to authenticate itself.  Each
            token may be a string up to 500 characters in length.", 
           "multivalues": true,
           "required": true,
           "caseExact": true,
           "mutability": "readWrite",
           "returned": "default",
           "uniqueness": "none"
        },
        {
          "name": "enterpriseEndpoint",
          "type": "reference",
          "description": "The URL of the enterprise endpoint which
           device control apps uses to reach enterprise network
           gateway. When enterprise receives the SCIM object from
           onboarding app, it adds this attribute to the object and
           sends back the object as response back to the onboarding
           app.",
          "multivalues": false,
          "required": true,
          "caseExact": true,
          "mutability": "readWrite",
          "returned": "default",
          "uniqueness": "none"
        }
      ]
    },
    {
      "name": "dataReceiver",
      "type": "complex",
      "description": "Data receiver application attributes.",
      "multivalues": false,
      "required": true,
      "caseExact": false,
      "mutability": "readWrite",
      "returned": "default",
      "uniqueness": "none",
      "subAttributes" : [
        {
          "name": "client-tokens",
           "type": "string",
           "description": "This attribute contains a list of tokens
            that the client will used to authenticate itself.  Each
            token may be a string up to 500 characters in length.", 
           "multivalues": true,
           "required": true,
           "caseExact": true,
           "mutability": "readWrite",
           "returned": "default",
           "uniqueness": "none"
        },
        {
          "name": "enterpriseEndpoint",
          "type": "reference",
          "description": "The URL of the enterprise endpoint which
            device control apps uses to reach enterprise network
            gateway. When enterprise receives the SCIM object from
            onboarding app, it adds this attribute to the object and
            sends back the object as response back to the onboarding
            app.",
          "multivalues": false,
          "required": true,
          "caseExact": true,
          "mutability": "readWrite",
          "returned": "default",
          "uniqueness": "none"
        }
      ]
      }
  ],
  "meta" : {
    "resourceType" : "Schema",
    "location" :
    "/v2/Schemas/urn:ietf:params:scim:schemas:
     extension:endpointApps:2.0:Device"
  }
}
<CODE ENDS>
]]></artwork></figure>

<t>The following sections provide representations of schemas for both
   SCIM resources and service provider schemas.  Note that the JSON
   representation has been modified for readability and to fit the
   specification format.</t>

<t>8.7.1.  Resource Schema Representation</t>

<t>The following is intended as an example of the SCIM schema
   representation in JSON format for SCIM resources.  Where permitted,
   individual values and schema MAY change.  This example includes
   schema representations for "User", "Group", and "EnterpriseUser";
   other schema representations are possible.</t>

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

<t>Because provisioning operations are senstive, each client must be
appropriately authenticated.  Certain objects may be read-only or
not visible based on who is connected.</t>

<t>[ More to be added here. ]</t>

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

<t>TBD</t>

</section>
<section anchor="changes-from-earlier-versions"><name>Changes from Earlier Versions</name>

<t>Draft -01:</t>

<t><list style="symbols">
  <t>Doh! We forgot the core device schemea!</t>
</list></t>

<t>Draft -00:</t>

<t><list style="symbols">
  <t>Initial revision</t>
</list></t>

</section>
<section anchor="appendix"><name>APPENDIX</name>

<section anchor="device-core-schema-openapi-representation"><name>Device Core Schema OpenAPI Representation</name>
<t>OpenAPI representation of device core schema is as follows:</t>

<figure><artwork><![CDATA[
<CODE BEGINS>
openapi: 3.0.3
info:
  title: Device Schema
  version: 1.0.0
  description: API for device core schema

components:
  schemas:
    Device:
      title: Device
      description: Device account
      type: object
      properties:
        deviceDisplayName:
          type: string
          description: "Human readable name of the device, suitable
                        for displaying to end-users. For example,
                       'BLE Heart Monitor' etc."
          nullable: true
          readOnly: false
          writeOnly: false
        adminState:
          type: boolean
          description: A mutable boolean value indicating the device
                       administrative status. If set TRUE, the
                       commands (such as connect, disconnect,
                       subscribe) that control app sends to the
                       controller for the devices will be processeed
                       by the controller.  If set FALSE, any command
                       comming from the control app for the device
                       will be rejected by the controller.
          nullable: false
          readOnly: false
          writeOnly: false
        mudUrl:
          type: string
          format: uri
          description: A URL to MUD file of the device (RFC 8520). It
                       is added for future use. Current usage is not 
                       defined yet.
          nullable: true
          readOnly: false
          writeOnly: false
      required:
        - adminState
      additionalProperties: false
      allOf:
        - $ref: '#/components/schemas/CommonAttributes'
    CommonAttributes:
      type: object
      properties:
        id:
          type: string
          format: uri
          description: The unique identifier for a resource.
          nullable: false
          readOnly: true
          writeOnly: false
        externalId:
          type: string
          description: An identifier for the resource that is defined
                       by the provisioning client.
          nullable: true
          readOnly: false
          writeOnly: false
        meta:
          type: object
          properties:
            resourceType:
              type: string
              description: The name of the resource type of the 
                           resource.
              nullable: false
              readOnly: true
              writeOnly: false
            location:
              type: string
              format: uri
              description: The URI of the resource being returned.
              nullable: false
              readOnly: false
              writeOnly: false
            created:
              type: string
              format: date-time
              description: The date and time the resource was added
                           to the service provider.
              nullable: false
              readOnly: true
              writeOnly: false
            lastModified:
              type: string
              format: date-time
              description: The most recent date and time that the 
                           details of this resource were updated at
                           the service provider.
              nullable: false
              readOnly: true
              writeOnly: false
            version:
              type: string
              description: The version of the resource. 
              nullable: true
              readOnly: false
              writeOnly: false
          additionalProperties: false
  

paths:
  /devices:
    post:
      summary: Create a new device
      description: Creates a new device.
      operationId: createDevice
      requestBody:
        description: The device to create
        required: true
        content:
          application/json:
            schema:
              $ref: '#/components/schemas/Device'
      responses:
        '201':
          description: Created
          headers:
            Location:
              schema:
                type: string
                format: uri
              description: The URI of the newly created device.
          content:
            application/json:
              schema:
                $ref: '#/components/schemas/Device'

  /devices/{deviceId}:
    get:
      summary: Get a device by ID
      description: Returns a single device by its ID.
      operationId: getDeviceById
      parameters:
        - name: deviceId
          in: path
          description: The ID of the device to return.
          required: true
          schema:
            type: string
      responses:
        '200':
          description: OK
          content:
            application/json:
              schema:
                $ref: '#/components/schemas/Device'


<CODE ENDS>
]]></artwork></figure>

</section>
<section anchor="ble-extension-schema-openapi-representation"><name>BLE Extension Schema OpenAPI Representation</name>
<t>OpenAPI representation of BLE extension schema is as follows:</t>

<figure><artwork><![CDATA[
<CODE BEGINS>
openapi: 3.0.1
info:
  version: 1.0.0
  title: DPP Extension Schema
  description: API for DPP device extension schema

components:
  schemas:
    BleDeviceExtension:
      type: object
      properties:
        versionSupport:
          type: array
          items:
            type: string
          description: Provides a list of all the BLE versions 
                       supported by the device. For example, 
                       [4.1, 4.2, 5.0, 5.1, 5.2, 5.3].
          nullable: false
          readOnly: false
          writeOnly: false
        deviceMacAddress:
          type: string
          description: It is the public MAC address assigned by the 
                       manufacturer. It is unique 48 bit value. The
                       regex pattern is 
                       ^[0-9A-Fa-f]{2}(:[0-9A-Fa-f]{2}){5}.
          nullable: false
          readOnly: false
          writeOnly: false

        addressType:
          type: boolean
          description: AddressType flag is taken from the BLE core 
                       specifications 5.3. If FALSE, the device is 
                       using public MAC address. If TRUE, device is 
                       using Random address which is resolved using
                       the IRK.
          nullable: false
          readOnly: false
          writeOnly: false
        irk:
          type: string
          description: Identity resolving key, which is unique for 
                       every device. It is used to resolve random 
                       address.
          nullable: true
          readOnly: false
          writeOnly: false
        pairingMethods:
          type: array
          items:
            type: string
          description: List of pairing methods associated with the 
                       ble device, stored as schema URI.
          nullable: true
          readOnly: false
          writeOnly: false
      required:
        - versionSupport
        - deviceMacAddress
        - AddressType
        - pairingMethods
      additionalProperties: false

    NullPairing:
      type: object
      properties:
        id:
          type: string
          description: The id of the null pairing schema.
          nullable: false
          readOnly: true
          writeOnly: false

    PairingJustWorks:
      type: object
      description: Just works pairing method for ble
      properties:
        key:
          type: integer
          description: Just works does not have any key value. For 
                       completeness, it is added with a key value
                       'null'.
          nullable: false
          readOnly: false
          writeOnly: false
      required:
        - key

    PairingPassKey:
      type: object
      description: Pass key pairing method for ble
      properties:
        key:
          type: integer
          description: A six digit passkey for ble device.
                       The pattern of key is ^[0-9]{6}$.
          nullable: false
          readOnly: false
          writeOnly: false
      required:
        - key

    PairingOOB:
      type: object
      description: Out-of-band pairing method for BLE
      properties:
        key:
          type: string
          description: The OOB key value for ble device.
          nullable: false
          readOnly: false
          writeOnly: false
        randomNumber:
          type: integer
          description: Nonce added to the key
          nullable: false
          readOnly: false
          writeOnly: false
        confirmationNumber:
          type: integer
          description: Some solutions require a confirmation number 
                       in the RESTful message exchange.
          nullable: true
          readOnly: false
          writeOnly: false
      required:
        - key
        - randomNumber

paths:
  /devices:
    post:
      summary: Create a new device
      operationId: createDevice
      requestBody:
        required: true
        content:
          application/json:
            schema:
              $ref: '#/components/schemas/BleDeviceExtension'
              anyof:
                - $ref: '#/components/schemas/NullPairing'
                - $ref: '#/components/schemas/PairingJustWorks'
                - $ref: '#/components/schemas/PairingPassKey'
                - $ref: '#/components/schemas/PairingOOB'
      responses:
        '201':
          description: Created
          content:
            application/json:
              schema:
                $ref: '#/components/schemas/BleDeviceExtension'
                anyof:
                  - $ref: '#/components/schemas/NullPairing'
                  - $ref: '#/components/schemas/PairingJustWorks'
                  - $ref: '#/components/schemas/PairingPassKey'
                  - $ref: '#/components/schemas/PairingOOB'
  /devices/{deviceId}:
    get:
      summary: Get a Dpp device by ID
      description: Returns a single Dpp device by its ID.
      operationId: getDeviceById
      parameters:
        - name: id
          in: path
          description: The ID of the device to return.
          required: true
          schema:
            type: string
      responses:
        '200':
          description: OK
          content:
            application/json:
              schema:
                $ref: '#/components/schemas/BleDeviceExtension'
                anyof:
                  - $ref: '#/components/schemas/NullPairing'
                  - $ref: '#/components/schemas/PairingJustWorks'
                  - $ref: '#/components/schemas/PairingPassKey'
                  - $ref: '#/components/schemas/PairingOOB'
<CODE ENDS>
]]></artwork></figure>

</section>
<section anchor="dpp-extension-schema-openapi-representation"><name>DPP Extension Schema OpenAPI Representation</name>
<t>OpenAPI representation of DPP extension schema is as follows:</t>

<figure><artwork><![CDATA[
<CODE BEGINS>
openapi: 3.0.1
info:
  version: 1.0.0
  title: DPP Extension Schema
  description: API for DPP device extension schema

components:
  schemas:
    DppDeviceExtension:
      type: object
      properties:
        dppVersion:
          type: integer
          description: Version of DPP this device supports.
          nullable: false
          readOnly: false
          writeOnly: false
        bootstrappingMethod:
          type: array
          items:
            type: string
          description: The list of all the bootstrapping methods 
                       available on the enrollee device. For 
                       example, [QR, NFC].
          nullable: true
          readOnly: false
          writeOnly: false
        bootstrapKey:
          type: string
          description: This key is Elliptic-Curve Diffie–Hellman 
                       (ECDH) public key. The base64 encoded length
                       for P-256, P-384, and P-521 is 80, 96, and 120
                       characters.
          nullable: false
          readOnly: false
          writeOnly: false
        deviceMacAddress:
          type: string
          description: The MAC address assigned by the manufacturer.
                       The regex pattern is
                       ^[0-9A-Fa-f]{2}(:[0-9A-Fa-f]{2}){5}.
          nullable: false
          readOnly: false
          writeOnly: false
        classChannel:
          type: array
          items:
            type: string
          description: A list of global operating class and channel 
                       shared as bootstrapping information. It is 
                       formatted as class/channel. For example,
                       '81/1', '115/36'.
          nullable: false
          readOnly: false
          writeOnly: false
        serialNumber:
          type: string
          description: An alphanumeric serial number that may also be
                       passed as bootstrapping information.
          nullable: false
          readOnly: false
          writeOnly: false
      required:
        - dppVersion
        - bootstrapKey
      additionalProperties: false


paths:
  /devices:
    post:
      summary: Create a new device
      operationId: createDevice
      requestBody:
        required: true
        content:
          application/json:
            schema:
              $ref: '#/components/schemas/DppDeviceExtension'
      responses:
        '201':
          description: Created
          content:
            application/json:
              schema:
                $ref: '#/components/schemas/DppDeviceExtension'
  /devices/{deviceId}:
    get:
      summary: Get a Dpp device by ID
      description: Returns a single Dpp device by its ID.
      operationId: getDeviceById
      parameters:
        - name: id
          in: path
          description: The ID of the device to return.
          required: true
          schema:
            type: string
      responses:
        '200':
          description: OK
          content:
            application/json:
              schema:
                $ref: '#/components/schemas/DppDeviceExtension'
<CODE ENDS>
]]></artwork></figure>

</section>
<section anchor="zigbee-extension-schema-openapi-representation"><name>Zigbee Extension Schema OpenAPI Representation</name>
<t>OpenAPI representation of zigbee extension schema is as follows:</t>

<figure><artwork><![CDATA[
<CODE BEGINS>
openapi: 3.0.1
info:
  title: Zigbee Device Extension
  description: API for Zigbee device extensions schema
  version: 1.0.0
 
components:
  schemas:
    ZigbeeDeviceExtension:
      type: object
      properties:
        versionSupport:
          type: array
          items:
            type: string
          description: Provides a list of all the Zigbee versions 
                       supported by the device. For example, [3.0].
          nullable: false
          readOnly: false
          writeOnly: false
        deviceEui64Address:
          type: string
          description: The EUI-64 (Extended Unique Identifier) device 
                       address. The regex pattern is
                       ^[0-9A-Fa-f]{16}$.
          nullable: false
          readOnly: false
          writeOnly: false
      required:
        - versionSupport
        - deviceEui64Address
      description: Device extension schema for Zigbee.
      

paths:
  /devices:
    post:
      summary: Create a new device
      operationId: createDevice
      requestBody:
        required: true
        content:
          application/json:
            schema:
              $ref: '#/components/schemas/ZigbeeDeviceExtension'
      responses:
        '201':
          description: Created
          content:
            application/json:
              schema:
                $ref: '#/components/schemas/ZigbeeDeviceExtension'
  /devices/{deviceId}:
    get:
      summary: Get a Zigbee device by ID
      description: Returns a single Zigbee device by its ID.
      operationId: getDeviceById
      parameters:
        - name: id
          in: path
          description: The ID of the device to return.
          required: true
          schema:
            type: string
      responses:
        '200':
          description: OK
          content:
            application/json:
              schema:
                $ref: '#/components/schemas/ZigbeeDeviceExtension'
<CODE ENDS>
]]></artwork></figure>

</section>
<section anchor="endpointapps-extension-schema-openapi-representation"><name>EndpointApps Extension Schema OpenAPI Representation</name>
<t>OpenAPI representation of endpoint Apps schema is as follows:</t>

<figure><artwork><![CDATA[
<CODE BEGINS>
openapi: 3.0.1
info:
  version: 1.0.0
  title: Endpoint Apps Extension
  description: Extension for partner endpoint applications that can
               onboard, control, and communicate with the device.

components:
  schemas:
    endpointApps:
      type: array
      items:
        allOf:
          - $ref: '#/components/schemas/deviceControl'
          - $ref: '#/components/schemas/dataReceiver'  
      
    deviceControl:
      type: array
      items:
        $ref: '#/components/schemas/deviceControlAttributes'
    
    deviceControlAttributes:
      properties:
        client-tokens:
          type: string
          format: uri
          description: This attribute contains a list of tokens that 
                       the client will used to authenticate itself. 
                       Each token may be a string up to 500
                       octets in length.
          nullable: false
          readOnly: false
          writeOnly: false
        enterpriseEndpoint:
          type: string
          format: uri
          description: The URL of the enterprise endpoint which
                       device control apps uses to reach enterprise
                       network gateway. When enterprise receives the
                       SCIM object from onboarding app, it adds this 
                       attribute to the object and sends back the 
                       object as response back to the onboarding
                       app.
          nullable: false
          readOnly: false
          writeOnly: false
      required:
        - client-tokens
        - enterpriseEndpoint

    dataReceiver:
      type: array
      items:
        $ref: '#/components/schemas/dataReceiverAttributes'

    dataReceiverAttributes:
      properties:
        client-tokens:
          type: string
          format: uri
          description: This attribute contains a list of tokens that 
                       the client will used to authenticate itself. 
                       Each token may be a string up to 500 octets
                       in length.
          nullable: false
          readOnly: false
          writeOnly: false

        enterpriseEndpoint:
          type: string
          format: uri
          description: The URL of the enterprise endpoint which data
                       receiver apps uses to reach enterprise network
                       gateway. When enterprise receives the SCIM
                       object from onboarding app, it adds this
                       attribute to the object and sends back the
                      object as response back to the onboarding app.
          nullable: false
          readOnly: false
          writeOnly: false
paths:
  /endpointApps:
    get:
      summary: Get endpoint apps
      description: Returns all endpoint apps
      operationId: getAllEndpointApps
      responses:
        '200':
          description: OK
          content:
            application/json:
              schema:
                type: array
                items:
                  $ref: '#/components/schemas/endpointApps'
<CODE ENDS>
]]></artwork></figure>

</section>
</section>


  </middle>

  <back>


    <references title='Normative References'>

<reference anchor="BLE53" >
  <front>
    <title>Bluetooth Core Specification, Version 5.3</title>
    <author >
      <organization>Bluetooth SIG</organization>
    </author>
    <date year="2021"/>
  </front>
</reference>
<reference anchor="DPP2" >
  <front>
    <title>Wi-Fi Easy Connect Specification, Version 2.0</title>
    <author >
      <organization>Wi-Fi Alliance</organization>
    </author>
    <date year="2020"/>
  </front>
</reference>




<reference anchor='RFC7643' target='https://www.rfc-editor.org/info/rfc7643'>
<front>
<title>System for Cross-domain Identity Management: Core Schema</title>
<author fullname='P. Hunt' initials='P.' role='editor' surname='Hunt'><organization/></author>
<author fullname='K. Grizzle' initials='K.' surname='Grizzle'><organization/></author>
<author fullname='E. Wahlstroem' initials='E.' surname='Wahlstroem'><organization/></author>
<author fullname='C. Mortimore' initials='C.' surname='Mortimore'><organization/></author>
<date month='September' year='2015'/>
<abstract><t>The System for Cross-domain Identity Management (SCIM) specifications are designed to make identity management in cloud-based applications and services easier.  The specification suite builds upon experience with existing schemas and deployments, placing specific emphasis on simplicity of development and integration, while applying existing authentication, authorization, and privacy models.  Its intent is to reduce the cost and complexity of user management operations by providing a common user schema and extension model as well as binding documents to provide patterns for exchanging this schema using HTTP.</t><t>This document provides a platform-neutral schema and extension model for representing users and groups and other resource types in JSON format.  This schema is intended for exchange and use with cloud service providers.</t></abstract>
</front>
<seriesInfo name='RFC' value='7643'/>
<seriesInfo name='DOI' value='10.17487/RFC7643'/>
</reference>



<reference anchor='RFC7644' target='https://www.rfc-editor.org/info/rfc7644'>
<front>
<title>System for Cross-domain Identity Management: Protocol</title>
<author fullname='P. Hunt' initials='P.' role='editor' surname='Hunt'><organization/></author>
<author fullname='K. Grizzle' initials='K.' surname='Grizzle'><organization/></author>
<author fullname='M. Ansari' initials='M.' surname='Ansari'><organization/></author>
<author fullname='E. Wahlstroem' initials='E.' surname='Wahlstroem'><organization/></author>
<author fullname='C. Mortimore' initials='C.' surname='Mortimore'><organization/></author>
<date month='September' year='2015'/>
<abstract><t>The System for Cross-domain Identity Management (SCIM) specification is an HTTP-based protocol that makes managing identities in multi-domain scenarios easier to support via a standardized service. Examples include, but are not limited to, enterprise-to-cloud service providers and inter-cloud scenarios.  The specification suite seeks to build upon experience with existing schemas and deployments, placing specific emphasis on simplicity of development and integration, while applying existing authentication, authorization, and privacy models.  SCIM's intent is to reduce the cost and complexity of user management operations by providing a common user schema, an extension model, and a service protocol defined by this document.</t></abstract>
</front>
<seriesInfo name='RFC' value='7644'/>
<seriesInfo name='DOI' value='10.17487/RFC7644'/>
</reference>


<reference anchor='I-D.bhutton-json-schema' target='https://datatracker.ietf.org/doc/html/draft-bhutton-json-schema-01'>
   <front>
      <title>JSON Schema: A Media Type for Describing JSON Documents</title>
      <author fullname='Austin Wright' initials='A.' surname='Wright'>
         </author>
      <author fullname='Henry Andrews' initials='H.' surname='Andrews'>
         </author>
      <author fullname='Ben Hutton' initials='B.' surname='Hutton'>
         <organization>Postman</organization>
      </author>
      <author fullname='Greg Dennis' initials='G.' surname='Dennis'>
         </author>
      <date day='10' month='June' year='2022'/>
      <abstract>
	 <t>   JSON Schema defines the media type &quot;application/schema+json&quot;, a JSON-
   based format for describing the structure of JSON data.  JSON Schema
   asserts what a JSON document must look like, ways to extract
   information from it, and how to interact with it.  The &quot;application/
   schema-instance+json&quot; media type provides additional feature-rich
   integration with &quot;application/schema+json&quot; beyond what can be offered
   for &quot;application/json&quot; documents.

	 </t>
      </abstract>
   </front>
   <seriesInfo name='Internet-Draft' value='draft-bhutton-json-schema-01'/>
   
</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' initials='S.' surname='Bradner'><organization/></author>
<date month='March' year='1997'/>
<abstract><t>In many standards track documents several words are used to signify the requirements in the specification.  These words are often capitalized. This document defines these words as they should be interpreted in IETF documents.  This document specifies an Internet Best Current Practices for the Internet Community, and requests discussion and suggestions for improvements.</t></abstract>
</front>
<seriesInfo name='BCP' value='14'/>
<seriesInfo name='RFC' value='2119'/>
<seriesInfo name='DOI' value='10.17487/RFC2119'/>
</reference>



<reference anchor='RFC8174' 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' initials='B.' surname='Leiba'><organization/></author>
<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='RFC8520' target='https://www.rfc-editor.org/info/rfc8520'>
<front>
<title>Manufacturer Usage Description Specification</title>
<author fullname='E. Lear' initials='E.' surname='Lear'><organization/></author>
<author fullname='R. Droms' initials='R.' surname='Droms'><organization/></author>
<author fullname='D. Romascanu' initials='D.' surname='Romascanu'><organization/></author>
<date month='March' year='2019'/>
<abstract><t>This memo specifies a component-based architecture for Manufacturer Usage Descriptions (MUDs).  The goal of MUD is to provide a means for end devices to signal to the network what sort of access and network functionality they require to properly function.  The initial focus is on access control.  Later work can delve into other aspects.</t><t>This memo specifies two YANG modules, IPv4 and IPv6 DHCP options, a Link Layer Discovery Protocol (LLDP) TLV, a URL, an X.509 certificate extension, and a means to sign and verify the descriptions.</t></abstract>
</front>
<seriesInfo name='RFC' value='8520'/>
<seriesInfo name='DOI' value='10.17487/RFC8520'/>
</reference>




    </references>

    <references title='Informative References'>





<reference anchor='RFC8995' target='https://www.rfc-editor.org/info/rfc8995'>
<front>
<title>Bootstrapping Remote Secure Key Infrastructure (BRSKI)</title>
<author fullname='M. Pritikin' initials='M.' surname='Pritikin'><organization/></author>
<author fullname='M. Richardson' initials='M.' surname='Richardson'><organization/></author>
<author fullname='T. Eckert' initials='T.' surname='Eckert'><organization/></author>
<author fullname='M. Behringer' initials='M.' surname='Behringer'><organization/></author>
<author fullname='K. Watsen' initials='K.' surname='Watsen'><organization/></author>
<date month='May' year='2021'/>
<abstract><t>This document specifies automated bootstrapping of an Autonomic Control Plane.  To do this, a Secure Key Infrastructure is bootstrapped.  This is done using manufacturer-installed X.509 certificates, in combination with a manufacturer's authorizing service, both online and offline.  We call this process the Bootstrapping Remote Secure Key Infrastructure (BRSKI) protocol. Bootstrapping a new device can occur when using a routable address and a cloud service, only link-local connectivity, or limited/disconnected networks. Support for deployment models with less stringent security requirements is included. Bootstrapping is complete when the cryptographic identity of the new key infrastructure is successfully deployed to the device.  The established secure connection can be used to deploy a locally issued certificate to the device as well.</t></abstract>
</front>
<seriesInfo name='RFC' value='8995'/>
<seriesInfo name='DOI' value='10.17487/RFC8995'/>
</reference>




    </references>



  </back>

<!-- ##markdown-source:
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
eaolE1V6zbI6XEFuaLkEiLlClY1nuQzIcuPJJ/JWla1abjymsc7TZ8547pJf
qXE1Mlb3Px7TGBr0+UzjMff4optXmkLDq3efQrt9Bs0eJxhp2jQ3J3kmPrdP
oZmfutG4HRrodJpsZNlNxXZSjeKkJfcTLzcNntmBLBsrSLPtdrrtjQ3nvbWZ
Wj9QoL301A9nc+7/XqQwjg6urg+vf37xffhL/4/fO/t7P/zcl98P9n4YHvQv
9g5en/3xfpIkv4T9s/7pm+/CH45+7HR+evEGbu5f/hTNfnxz8kfn+Hf/qr/3
bRGr6yQHn3cLnzSNgaAG+B14ulk4HjBHXvCUaWKxr60nT7ZevugOtjpbW430
PmPLsy1UX7eIL7tFvDAxkzM5tRMzoDSrScwwo+XShssTM5iZ+cW7GLjuLRMy
icCbs1DsmGxZ7zS5ly3Bf1CnVtKln+S3XtjHh/GSucfRPK84b09xSdZFRfOH
M29nK91VHPDD1/3WzhZ/eKgg/KQP3lfEiB4pMpcG97dJwBgxCbtd9L5h7CEp
DXMLtpMWR30qspVSk99CyuS26pJIdrPdKY5iK/dUfw3XVhWu5aT984Zr+er5
qsrnt3S3pXyXe9zyhiqne0mfmzIotU/Xmd51bkyewjSp42bfX406Z/1Tb3HJ
WrXtUEs6rL5QnR946kkXec9g7bJFalP3cKzbnc3u9nP4HB4+2XnS3W2kRbiv
hbhlCnFFSlDl8lklM8HgBbw+Vl2Pq9N2heOHnh9O8VBhke2leGdx6gwqVBSC
3xXwkzZimt7wKKBLhBuHFUugGdEr3X5sYappNDXCYoJon7CZJIY0kGHStkFe
FZQUU9BeVDczocsCwlbn/dOWOM2nd+HKff6m40qFkYGjzwfy2RSGJDcw5jHD
WOIOLwXslT5QiH7gYOYJ58kq4aWIMNehgqsx63ZiKBKTUBhlhGE6E5tLI+uI
HcM2BCoXnfWIkgDu0AByBkHjpsKIGWZbVvtWo8z96QkO/4aKeou558t452rk
IG32Pnb0HxsWZRr0WgKE+jF8yb0C/B+rOkh1E0PMJHKgJ7FZNO6Gulc5kwca
V1lBeaTaoNEFh3i6RTWRObZD1YaRmxBCmhtLYaKytN3aEBWBWhJPI4P0qbl0
OBlUKgTJQ/dV4VFjKwQGE9Hm3oBCmFHpJNq21FE8hKLF7BNKPY6nOxyKhaQj
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
k/IlAdL/A81RkZE/DAEA

-->

</rfc>

