<?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.7.1 (Ruby 2.6.10) -->


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

]>


<rfc ipr="trust200902" docName="draft-ietf-scim-device-model-01" 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="October" day="17"/>

    
    
    <keyword>Internet-Draft</keyword>

    <abstract>


<?line 64?>

<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>


<?line 72?>

<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="resource-schema"/>.</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-schema-json"/>, while the openAPI representation is provided in 
Section <xref target="device-schema-openapi-representation"/>.</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="resource-type-endpointapp"><name>Resource Type EndpointApp</name>
<t>This section defines a new resource type, 'EndpointApp'. The 
"ResourceType" schema specifies the metadata about a resource type 
(see section 6 of <xref target="RFC7643"/>). The resource "EndpointApp" represents
partner applications that can control and/or receive data from the
devices. The JSON schema for EndpointApp resource type is in <xref target="resource-schema"/>.
The attributes comprising EndpointsApp are listed in <xref target="endpointapp-schema"/>.
The "EndpointApp" are included in the endpoint applications extension 
("endpointAppsExt") <xref target="endpointsappext-schema"/>.</t>

</section>
<section anchor="endpointapp-schema"><name>SCIM EndpointApp Schema</name>
<t>The schema for "EndpointApp" is identified using the schema URI:
"urn:ietf:params:scim:schemas:core:2.0:EndpointApp". The following
attributes are defined in this schema.</t>

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

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

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

<t>applicationType</t>

<t>This attribute is of type "string" and represents the type of 
application. It will only contain two values; 'deviceControl' 
or 'telemetry'. 'deviceControl' is the application that sends commands
to control the device. 'telemetry' is the application that receives
data from the device. The attribute is required, and is not 
case-sensitive. The is attribute readOnly and should be returned 
by default. No uniqueness constraints are imposed on this attribute.</t>

<t>applicationName</t>

<t>The "applicationName" attribute is of type "string" and represents a
human readable name for the application. This attribute is required and
mutable. The attribute should be returned by default and there is no 
uniqueness contraint on the attribute.</t>

<t>clientToken</t>

<t>This attribute type string contains a token that the client will use 
to authenticate itself.  Each token may be a string up to 500 
characters in length. It is mutable, required, case sensitive 
and returned by default if exists.</t>

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

<t>certificateInfo</t>

<t>It is the complex attribute that Contains x509 certificate's subject
name and root CA information associated with the device control or 
telemetry app. It further has three attributes that are described 
below.</t>

<t>rootCN</t>

<t>It is the root certificate common name. This attribute is required,
read only, singular and case sensitive.</t>

<t>subjectName</t>

<t>Also known as the Common Name (CN), the Subject Name is a field in the
X.509 certificate that identifies the primary domain or IP address for
which the certificate is issued. This attribute is not required,
read only, singular and case sensitive.</t>

<t>subjectAlternativeName</t>

<t>This attribute allows for the inclusion of multiple domain names and
IP addresses in a single certificate. This enables the certificate to
be used for multiple related domains or IPs without the need for 
separate certificates for each. This attribute is not required,
read only, multivalued and case sensitive.</t>

<figure title="Characteristics of EndpointApp schema attributes. (Req = Required,
T = True, F = False, R = ReadOnly, RW = ReadWrite, Manuf = Manufactirer
and Def = Default)" anchor="tabEndpointApp"><artwork><![CDATA[
+=================+=======+=====+======+=========+========+========+
|Attribute        | Multi | Req | Case | Mutable | Return | Unique |
|                 | Value |     | Exact|         |        |        |
+=================+=======+=====+======+=========+========+========+
|applicationType  |   F   |  T  |  F   |   R     |  Def   |  None  |
+-----------------+-------+-----+------+---------+--------+--------+
|applicationName  |   F   |  T  |  F   |   RW    |  Def   |  None  |
+-----------------+-------+-----+------+---------+--------+--------+
|clientToken      |   F   |  T  |  T   |   R     |  Def   |  None  |
+-----------------+-------+-----+------+---------+--------+--------+
|certificateInfo  |   F   |  F  |  F   |   RW    |  Def   |  None  |
+-----------------+-------+-----+------+---------+--------+--------+
|rootCN           |   F   |  T  |  T   |   R     |  Def   |  None  |
+-----------------+-------+-----+------+---------+--------+--------+
|subjectName      |   F   |  F  |  T   |   R     |  Def   |  None  |
+-----------------+-------+-----+------+---------+--------+--------+
|subjectAltName   |   T   |  F  |  T   |   R     |  Def   |  None  |
+-----------------+-------+-----+------+---------+--------+--------+

]]></artwork></figure>

<t>Note that attributes clientToken and certificateInfo are used for the
authentication of the application. Both SHALL NOT exist together in the
SCIM object. Either clientToken or certificateInfo SHALL be present
in the SCIM object.</t>

<t>An example of a endpointApp SCIM object is as follows. Note that since
certificateInfo is present in the example, clientToken attribute is 
NULL.</t>

<figure><artwork><![CDATA[
<CODE BEGINS>
{
  "schemas": ["urn:ietf:params:scim:schemas:core:2.0:EndpointApp"],
  "id": "e9e30dba-f08f-4109-8486-d5c6a3316212",
  "applicationType": "deviceControl",
  "applicationName": "Device Control App 1",
  "certificateInfo": {
      "rootCN": "DigiCert Global Root CA",
      "subjectName": "wwww.example.com",
      "subjectAlternativeName": ["xyz.example.com",
          "abc.example.com"]
  },
  "clientToken": null,
  "meta": {
    "resourceType": "EndpointApp",
    "created": "2022-01-23T04:56:22Z",
    "lastModified": "2022-05-13T04:42:34Z",
    "version": "W\/\"a330bc54f0671c9\"",
    "location": "https://example.com/v2/EndpointApp/e9e30dba-f08f
       -4109-8486-d5c6a3316212"
  }
}
<CODE ENDS>
]]></artwork></figure>

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

</section>
</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-2"><name>Singular Attributes</name>

<t>deviceMacAddress</t>

<t>A string value 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>isRandom</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 not required, it is 
mutable, and returned by default.  Its default value is FALSE.</t>

<t>separateBroadcastaddress</t>

<t>When present, this address is used for broadcasts/advertisements.
This value MUST NOT be set when an IRK is provided.  Its form is the
same as deviceMacAddress.  It is not required, multivalued, mutable,
and returned 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>

<t>mobility</t>

<t>A boolean attribute to enable mobility on BLE device. If set to True, 
the BLE device will automatically connect to the closest AP. For 
example, BLE device is connected with AP-1 and moves out of range but 
comes in range of AP-2, it will be disconnected with AP-1 and connects 
with AP-2. It is returned by default and mutable.</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 default.</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. 
sepBroadcastAdd is short for separateBroadcastaddress. (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  |
+------------------+-------+-----+------+---------+--------+--------+
|isRandom          |   F   |  T  |  F   |   RW    |  Def   | None   |
+------------------+-------+-----+------+---------+--------+--------+
|sepBroadcastAdd   |   F   |  T  |  F   |   RW    |  Def   | None   |
+------------------+-------+-----+------+---------+--------+--------+
|irk               |   F   |  F  |  F   |   RW    |  Def   | Manuf  |
+------------------+-------+-----+------+---------+--------+--------+
|versionSupport    |   T   |  T  |  F   |   RW    |  Def   | None   |
+------------------+-------+-----+------+---------+--------+--------+
|mobility          |   F   |  F  |  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",
    "isRandom": false,
    "separateBroadcastAddress": ["AA:BB:88:77:22:11", "AA:BB:88:77
       :22:12"],
    "mobility": true,
    "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-3"><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" : {
                "dppVersion": 2,
                "bootstrappingMethod": ["QR"],
                "bootstrapKey":
                    "MDkwEwYHKoZIzj0CAQYIKoZIzj0DAQcDIgADURzxmt
                   tZoIRIPWGoQMV00XHWCAQIhXruVWOz0NjlkIA=",
                "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|         |        |        |
+==================+=======+=====+======+=========+========+========+
|deviceEui64Addres |   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="endpointsappext-schema"><name>The Endpoint Applications Extension Schema</name>

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

<t>endpointAppsExt provides the list application that connect to 
enterprise gateway. The endpointAppsExt has one multivalued attribute 
and two singular attributes. The extension is identified using the
following schema URI:</t>

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

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

<t>deviceControlEnterpriseEndpoint</t>

<t>Device control apps use this URL of the enterprise endpoint to reach
the enterprise 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. The uniqueness is
enforced by the enterprise.</t>

<t>telemetryEnterpriseEndpoint</t>

<t>Telemetry apps use this URL of the enterprise endpoint to reach
the enterprise 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. The uniqueness is
enforced by the enterprise.</t>

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

<t>applications</t>

<t>This is a complex multivalued attribute. It represents a list of 
endpoint applications i.e., deviceControl and telemetry. Each entry in
the list comprises two attributes including "value" and "$ref".</t>

<t>value</t>

<t>It is the identifier of the endpoint application formated as UUID. It
is same as the common attribute "$id" of the resource "endpointApp".
It is readOnly, required, case insensitive and returned by default.</t>

<t>$ref</t>

<t>It is the reference to the respective endpointApp resource object 
stored in the SCIM server. It is readOnly, required, case sensitive
and returned by default.</t>

<figure title="Characteristics of EndpointAppsExt extension schema 
attributes. DevContEntEndpoint represents attribute 
deviceControlEnterpriseEndpoint and telEntEndpoint represents 
telemetryEnterpriseEndpoint. (Req = Required, T = True, F = False, 
R = ReadOnly, RW = ReadWrite, Ent = Enterprise, and Def = Default)." anchor="tabEndpointAppsExt"><artwork><![CDATA[
+==================+=======+=====+======+=========+========+========+
|Attribute         | Multi | Req | Case | Mutable | Return | Unique |
|                  | Value |     | Exact|         |        |        |
+==================+=======+=====+======+=========+========+========+
|devContEntEndpoint|   F   |  T  |  T   |   R     |  Def   | Ent    |
+------------------+-------+-----+------+---------+--------+--------+
|telEntEndpoint    |   F   |  T  |  T   |   R     |  Def   | Ent    |
+------------------+-------+-----+------+---------+--------+--------+
|applications      |   T   |  T  |  F   |   RW    |  Def   | None   |
+------------------+-------+-----+------+---------+--------+--------+
|value             |   F   |  T  |  F   |   R     |  Def   | None   |
+------------------+-------+-----+------+---------+--------+--------+
|$ref              |   F   |  T  |  F   |   R     |  Def   | None   |
+------------------+-------+-----+------+---------+--------+--------+
]]></artwork></figure>

<t>An example of a device object with endpointAppsExt 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:endpointAppsExt: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",
    "isRandom": false,
    "separateBroadcastAddress": ["AA:BB:88:77:22:11", "AA:BB:88:77
       :22:12"],
    "mobility": 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:endpointAppsExt:2.0
     :Device": {

    "applications": [
      {
        "value" : "e9e30dba-f08f-4109-8486-d5c6a3316212",
        "$ref" : "https://example.com/v2/EndpointApp/e9e30dba-f08f
           -4109-8486-d5c6a3316212"
      },
      {
        "value" : "e9e30dba-f08f-4109-8486-d5c6a3316333",
        "$ref" : "https://example.com/v2/EndpointApp/e9e30dba-f08f
           -4109-8486-d5c6a3316333"
      }
    ],
    "deviceControlEnterpriseEndpoint":
        "https//enterprise.com/device_control_app_endpoint/",
    "telemetryEnterpriseEndpoint":
        "https//enterprise.com/telemetry_app_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 endpointAppsExt extension along with BLE extension is 
presented in JSON format in Section <xref target="endpointappsext-extension-schema-json"/>, while 
the openAPI representation is provided in Section <xref target="endpointappsext-extension-schema-openapi-representation"/>.</t>

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

<section anchor="resource-schema"><name>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"
    }
  },
  {
    "schemas": ["urn:ietf:params:scim:schemas:core:2.0
       :ResourceType"],
    "id": "EndpointApp",
    "name": "EndpointApp",
    "endpoint": "/EndpointApp",
    "description": "Endpoint application such as device control and
        telemetry.",
    "schema": "urn:ietf:params:scim:schemas:core:2.0:EndpointApp",
    "meta": {
      "location": "https
         ://example.com/v2/ResourceTypes/EndpointApp",
      "resourceType": "ResourceType"
    }
  }
]
<CODE ENDS>
]]></artwork></figure>

</section>
<section anchor="device-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="endpointapp-schema-json"><name>EndpointApp Schema JSON</name>

<figure><artwork><![CDATA[
<CODE BEGINS>
{
  "id": "urn:ietf:params:scim:schemas:core:2.0:EndpointApp",
  "name": "EndpointApp",
  "description": "Endpoint application and their credentials",
  "attributes" : [
    {
      "name": "applicationType",
      "type": "string",
      "description": "This attribute will only contain two values;
          'deviceControl' or 'telemetry'.",
      "multivalues": false,
      "required": true,
      "caseExact": false,
      "mutability": "readOnly",
      "returned": "default",
      "uniqueness": "none"
    },
    {
      "name": "applicationName",
      "type": "string",
      "description": "Human readable name of the application.",
      "multivalues": false,
      "required": true,
      "caseExact": false,
      "mutability": "readWrite",
      "returned": "default",
      "uniqueness": "none"
    },
    {
      "name": "certificateInfo",
      "type": "complex",
      "description": "Contains x509 certificate's subject name and
          root CA information associated with the device control or
          telemetry app.",
      "multivalues": false,
      "required": false,
      "caseExact": false,
      "mutability": "readWrite",
      "returned": "default",
      "uniqueness": "none",
      "subAttributes" : [
        {
          "name" : "rootCN",
          "type" : "string",
          "description" : "A root certificate common name.",
          "multiValued" : false,
          "required" : true,
          "caseExact" : true,
          "mutability" : "readOnly",
          "returned" : "default",
          "uniqueness" : "none"
        },
        {
          "name" : "subjectName",
          "type" : "string",
          "description" : "Also known as the Common Name (CN), the
              Subject Name is a field in the X.509 certificate that
              identifies the primary domain or IP address for which
              the certificate is issued.",
          "multiValued" : false,
          "required" : false,
          "caseExact" : true,
          "mutability" : "readOnly",
          "returned" : "default",
          "uniqueness" : "none"
        },
        {
          "name" : "subjectAlternativeName",
          "type" : "string",
          "description" : "This attribute allows for the inclusion
              of multiple domain names and IP addresses in a single
              certificate. This enables the certificate to be used
              for multiple related domains or IPs without the need
              for separate certificates for each.",
          "multiValued" : true,
          "required" : false,
          "caseExact" : true,
          "mutability" : "readOnly",
          "returned" : "default",
          "uniqueness" : "none"
        }
      ]
    },
    {
      "name": "clientToken",
      "type": "string",
      "description": "This attribute contains a token that the
          client will use to authenticate itself.  Each token may
          be a string up to 500 characters in length.",
      "multivalues": false,
      "required": false,
      "caseExact": true,
      "mutability": "readOnly",
      "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": "isRandom",
        "type": "boolean",
          "description": "The isRandom flag is taken from the BLE
              core specifications 5.3. If TRUE, device is using
              Random address which is resolved using IRK.  If not
              present, the value is FALSE.",
        "multivalues": false,
        "required": false,
        "caseExact": false,
        "mutability": "readWrite",
        "returned": "default",
        "uniqueness": "none"
      },
      {
        "name": "separateBroadcastAddress",
        "type": "string",
        "description": "When present, this address is used for
            broadcasts/advertisements.  This value MUST NOT be set
            when an IRK is provided.  Its form is the same as
            deviceMa`cAddress.",
        "multivalues": true,
        "required": false,
        "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. 
            This value MUST NOT be set when
            separateBroadcastAddress is set.",
        "multivalues": false,
        "required": false,
        "caseExact": false,
        "mutability": "readWrite",
        "returned": "default",
        "uniqueness": "Manufacturer"
      },
      {
        "name": "mobility",
        "type": "bool",
        "description": "If set to True, the BLE device will
            automatically connect to the closest AP. For example,
            BLE device is connected with AP-1 and moves out of
            range but comes in range of AP-2, it will be
            disconnected with AP-1 and connects with AP-2.",
        "multivalues": false,
        "required": false,
        "caseExact": false,
        "mutability": "readWrite",
        "returned": "default",
        "uniqueness": "none"
      },
      {
        "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:\n
                  schemas:extension:zigbee:2.0:Device"
  }
}
<CODE ENDS>
]]></artwork></figure>

</section>
<section anchor="endpointappsext-extension-schema-json"><name>EndpointAppsExt JSON Extension Schema</name>
<figure><artwork><![CDATA[
<CODE BEGINS>
{
  "id": "urn:ietf:params:scim:schemas:extension:endpointAppsExt:2.0
     :Device",
  "name": "endpointAppsExt",
  "description": "Extension for partner endpoint applications that
      can onboard, control, and communicate with the device.",
  "attributes" : [
    {
      "name": "applications",
      "type": "complex",
      "description": "Includes references to two types of
          application that connect with entrprise, i.e.,
          deviceControl and telemetry.",
      "multivalues": true,
      "required": true,
      "caseExact": false,
      "mutability": "readWrite",
      "returned": "default",
      "uniqueness": "none",
      "subAttributes" : [
        {
          "name" : "value",
          "type" : "string",
          "description" : "The identifier of the endpointApp.",
          "multiValued" : false,
          "required" : true,
          "caseExact" : false,
          "mutability" : "readOnly",
          "returned" : "default",
          "uniqueness" : "none"
        },
        {
          "name" : "$ref",
          "type" : "reference",
          "referenceTypes" : "EndpointApps",
          "description" : "The URI of the corresponding
              'EndpointApp' resource which will control or obtain
              data from the device.",
          "multiValued" : false,
          "required" : false,
          "caseExact" : true,
          "mutability" : "readOnly",
          "returned" : "default",
          "uniqueness" : "none"
        }
      ]
    },
    {
      "name": "deviceControlEnterpriseEndpoint",
      "type": "reference",
      "description": "The URL of the enterprise endpoint which
          device control apps use to reach enterprise network
          gateway.",
      "multivalues": false,
      "required": true,
      "caseExact": true,
      "mutability": "readOnly",
      "returned": "default",
      "uniqueness": "Enterprise"
    },
    {
      "name": "telemetryEnterpriseEndpoint",
      "type": "reference",
      "description": "The URL of the enterprise endpoint which
          telemetry apps use to reach enterprise network gateway.",
      "multivalues": false,
      "required": true,
      "caseExact": true,
      "mutability": "readOnly",
      "returned": "default",
      "uniqueness": "Enterprise"
    }
  ],
  "meta" : {
    "resourceType" : "Schema",
    "location" : "/v2/Schemas/urn:ietf:params:scim:schemas
       :extension:endpointAppsExt: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>

<?line 1773?>

</section>
<section anchor="openapi-representation"><name>OpenAPI representation</name>

<t>The following sections are provided for informational purposes.</t>

<section anchor="device-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>
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:
        schemas:
          type: array
          items:
            type: string
            enum:
              - urn:ietf:params:scim:schemas:core:2.0:Device
          description: The list of schemas that define the resource.
          nullable: false
        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
          readOnly: true
          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: true
              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: true
              writeOnly: false
          additionalProperties: false
<CODE ENDS>
]]></artwork></figure>

</section>
<section anchor="endpointapp-schema-openapi-representation"><name>EndpointApp Schema OpenAPI Representation</name>
<t>OpenAPI representation of endpointApp schema is as follows:</t>

<figure><artwork><![CDATA[
<CODE BEGINS>
components:
  schemas:
    EndpointApp:
      title: EndpointApp
      description: Endpoint application resource
      type: object
      properties:
        applicationType:
          type: string
          description: "This attribute will only contain two values;
                       'deviceControl' or 'telemetry'."
          nullable: false
          readOnly: false
          writeOnly: false

        applicationName:
          type: string
          description: Human readable name of the application.
          nullable: false
          readOnly: false
          writeOnly: false
        
      required:
        - applicationType
        - applicationName

      additionalProperties: true
      oneOf:
        - $ref: '#/components/schemas/clientToken'
        - $ref: '#/components/schemas/certificateInfo'

      allOf:
        - $ref: '#/components/schemas/CommonAttributes'

    clientToken:
      type: string
      description: "This attribute contains a token that the client
                    will use to authenticate itself. Each token may
                    be a string up to 500 characters in length."
      nullable: true
      readOnly: true
      writeOnly: false

    certificateInfo:
      type: object
      description: "Contains x509 certificate's subject name and 
                    root CA information associated with the device
                    control or telemetry app."
      properties:
        rootCN:
          type: string
          description: "A root certificate common name."
          nullable: false
          readOnly: true
          writeOnly: false

        subjectName:
          type: string
          description: "Also known as the Common Name (CN), the
                        Subject Name is a field in the X.509 
                        certificate that identifies the primary
                        domain or IP address for which the
                        certificate is issued."
          nullable: false
          readOnly: true
          writeOnly: false

        subjectAlternativeName:
          type: array
          items:
            type: string
          description: "This attribute allows for the inclusion of
                        multiple domain names and IP addresses in a
                        single certificate. This enables the 
                        certificate to be used for multiple related
                        domains or IPs without the need for 
                        separate certificates for each. "
          nullable: true
          readOnly: true
          writeOnly: false
      required:
      - rootCN

    CommonAttributes:
      type: object
      properties:
        schemas:
          type: array
          items:
            type: string
            enum:
              - urn:ietf:params:scim:schemas:core:2.0:EndpointApp
          description: The list of schemas that define the resource.
          nullable: false
        id:
          type: string
          format: uri
          description: The unique identifier for a resource.
          nullable: false
          readOnly: true
          writeOnly: false
        meta:
          type: object
          readOnly: true
          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: true
              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: true
              writeOnly: false
          additionalProperties: false
<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>
components:
  schemas:
    BleDevice:
      type: object
      description: BLE Device schema.
      properties:
        schemas:
          type: array
          items:
            type: string
            enum:
              - urn:ietf:params:scim:schemas:extension:ble:2.0:Device
        urn:ietf:params:scim:schemas:extension:ble:2.0:Device:
          $ref: '#/components/schemas/BleDeviceExtension'
          required: true
    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

        isRandom:
          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
        
        separateBroadcastAddress:
          type: string
          description: "When present, this address is used for 
                        broadcasts/advertisements.  This value MUST
                        NOT be set when an IRK is provided.  Its
                        form is the same as deviceMa`cAddress."
          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
        mobility:
          type: boolean
          description: If set to True, the BLE device will 
                       automatically connect to the closest AP. For 
                       example, if the BLE device connected to AP-1
                       and moves out of range but comes in range of
                       AP-2, it will be disconnected with AP-1 and
                       connects with AP-2.
          nullable: false
          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
          urn:ietf:params:scim:schemas:extension:pairingNull:2.0:\n
                Device:
          $ref: '#/components/schemas/NullPairing'
          required: false
          urn:ietf:params:scim:schemas:extension:pairingJustWorks:\n
                2.0:Device:
          $ref: '#/components/schemas/PairingJustWorks'
          required: false
        urn:ietf:params:scim:schemas:extension:pairingPassKey:2.0:\n
                Device:
          $ref: '#/components/schemas/PairingPassKey'
          required: false
        urn:ietf:params:scim:schemas:extension:pairingOOB:2.0:\n
                Device:
          $ref: '#/components/schemas/PairingOOB'
          required: 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
<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>
components:
  schemas:
    DppDevice:
      type: object
      description: DPP device extension schema
      properties:
        schemas:
          type: array
          items:
            type: string
            enum:
              - urn:ietf:params:scim:schemas:extension:dpp:2.0:Device
        urn:ietf:params:scim:schemas:extension:dpp:2.0:Device:
          $ref: '#/components/schemas/DppDeviceExtension'
          required: true
    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
<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>
components:
  schemas:
    ZigbeeDevice:
      type: object
      description: Zigbee Device schema.
      properties:
        schemas:
          type: array
          items:
            type: string
            enum:
              - urn:ietf:params:scim:schemas:extension:zigbee:2.0:Device
        urn:ietf:params:scim:schemas:extension:zigbee:2.0:Device:
          $ref: '#/components/schemas/ZigbeeDeviceExtension'
          required: true
    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.
<CODE ENDS>
]]></artwork></figure>

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

<figure><artwork><![CDATA[
<CODE BEGINS>
components:
  schemas:
    EndpointAppsExt:
      type: object
      properties:
        applications:
          $ref: '#/components/schemas/applications'
        
        deviceControlEnterpriseEndpoint:
          type: string
          format: url
          description: The URL of the enterprise endpoint which device
                       control apps use to reach enterprise network 
                       gateway.
          nullable: false
          readOnly: true
          writeOnly: false
        
        telemetryEnterpriseEndpoint:
          type: string
          format: url
          description: The URL of the enterprise endpoint which 
                       telemetry apps use to reach enterprise network 
                       gateway.
          nullable: false
          readOnly: true
          writeOnly: false

      required:
        - applications
        - deviceControlEnterpriseEndpoint
        - telemetryEnterpriseEndpoint
        
    applications:
      type: array
      items:
        value:
          type: string
          description: The identifier of the endpointApp.
          nullable: false
          readOnly: true
          writeOnly: false
        ref:
          type: string
          format: uri
          description: The URI of the corresponding 'EndpointApp' 
                      resource which will control or obtain data from 
                      the device.
          nullable: false
          readOnly: true
          writeOnly: false
      required:
        - value
        - ref

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

</section>
</section>
<section anchor="changes"><name>Changes</name>

<t><list style="symbols">
  <t>04 openapi model and narrative clarified.</t>
  <t>05 typos</t>
</list></t>

</section>
<section anchor="tbd"><name>TBD</name>

<t>Fido</t>

</section>


  </middle>

  <back>


    <references title='Normative References' anchor="sec-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">
  <front>
    <title>System for Cross-domain Identity Management: Core Schema</title>
    <author fullname="P. Hunt" initials="P." role="editor" surname="Hunt"/>
    <author fullname="K. Grizzle" initials="K." surname="Grizzle"/>
    <author fullname="E. Wahlstroem" initials="E." surname="Wahlstroem"/>
    <author fullname="C. Mortimore" initials="C." surname="Mortimore"/>
    <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">
  <front>
    <title>System for Cross-domain Identity Management: Protocol</title>
    <author fullname="P. Hunt" initials="P." role="editor" surname="Hunt"/>
    <author fullname="K. Grizzle" initials="K." surname="Grizzle"/>
    <author fullname="M. Ansari" initials="M." surname="Ansari"/>
    <author fullname="E. Wahlstroem" initials="E." surname="Wahlstroem"/>
    <author fullname="C. Mortimore" initials="C." surname="Mortimore"/>
    <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">
   <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">
  <front>
    <title>Key words for use in RFCs to Indicate Requirement Levels</title>
    <author fullname="S. Bradner" initials="S." surname="Bradner"/>
    <date month="March" year="1997"/>
    <abstract>
      <t>In many standards track documents several words are used to signify the requirements in the specification. These words are often capitalized. This document defines these words as they should be interpreted in IETF documents. This document specifies an Internet Best Current Practices for the Internet Community, and requests discussion and suggestions for improvements.</t>
    </abstract>
  </front>
  <seriesInfo name="BCP" value="14"/>
  <seriesInfo name="RFC" value="2119"/>
  <seriesInfo name="DOI" value="10.17487/RFC2119"/>
</reference>

<reference anchor="RFC8174">
  <front>
    <title>Ambiguity of Uppercase vs Lowercase in RFC 2119 Key Words</title>
    <author fullname="B. Leiba" initials="B." surname="Leiba"/>
    <date month="May" year="2017"/>
    <abstract>
      <t>RFC 2119 specifies common key words that may be used in protocol specifications. This document aims to reduce the ambiguity by clarifying that only UPPERCASE usage of the key words have the defined special meanings.</t>
    </abstract>
  </front>
  <seriesInfo name="BCP" value="14"/>
  <seriesInfo name="RFC" value="8174"/>
  <seriesInfo name="DOI" value="10.17487/RFC8174"/>
</reference>

<reference anchor="RFC8520">
  <front>
    <title>Manufacturer Usage Description Specification</title>
    <author fullname="E. Lear" initials="E." surname="Lear"/>
    <author fullname="R. Droms" initials="R." surname="Droms"/>
    <author fullname="D. Romascanu" initials="D." surname="Romascanu"/>
    <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' anchor="sec-informative-references">



<reference anchor="RFC8995">
  <front>
    <title>Bootstrapping Remote Secure Key Infrastructure (BRSKI)</title>
    <author fullname="M. Pritikin" initials="M." surname="Pritikin"/>
    <author fullname="M. Richardson" initials="M." surname="Richardson"/>
    <author fullname="T. Eckert" initials="T." surname="Eckert"/>
    <author fullname="M. Behringer" initials="M." surname="Behringer"/>
    <author fullname="K. Watsen" initials="K." surname="Watsen"/>
    <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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
9wBcKKTAG1FQWaMaxBRQgt46EMY99aYZWHDvI+IKgg37Ywvu8Uj3veNjM5Gy
uWmN201iY5olc67btxYO7ZfJEysvM7mbYSzVdQKWlQrqFqEMx2bKXpkP9Z5n
c5vcghdyNJ3WbW7Lo0eO73SUTUvpLnj3DnOA86PvZpoGz854zdb4dCrSgvNk
M8L0tjfEOcrF7ECNCWlmUoEv3aj01cTjc7+FtefdxO+uMt2CrKls3CsQ2dm5
8RgzqQ17u7P8TUz3kgug2P/7P//3aTwe49mXu/u7e0/vyR1owhwciDqMD9ne
BA7CVJQjcaSD+9OPe+tb2134Z+PhJofyuLe1vsYwTB6udumjbX55bX1VZ+Qq
as8lUPucUXf+zrQvgoElWjAUWxGfwEllxi0UoL7x5AkcczpUQRzCcUIVwpke
fBRssK2u4xWMcIWQH7E+VKEvPYwFmCLRmK8rfMdtPL0CbEzg+pDyuyIXX7eC
gS7bUovwnMd5LFM3o2fTzmFuHIRpgBUSZmw/SWt3TC1IuDJpnolR+4t8QMwg
k9ul9iDU3pNMba1Sh8Qpy2GiT8lZO6W//frzSRedjrgnWh08qeOJBoMfwrJc
gFUJMnrsO74Ypd4xXvIwSZHIHI99YTtcegx5a2BjRoLaNeTkqOQX+AYm5TDd
F81U0LHycO3+2kp3ZW1t6/7G9ooHLWTOVGmAloC3sbVzzuttbO1u9HobW7sb
vd7GRUaklyqrszZuNa+XpLWbBGAxF6UQLHNcNkuDpeqFbe3iWxosplyu4qWR
W235NNIytHJW4lPBYso7Ay+fAxYzawyqcUEPH96t9/C5rjq6gKuORZx9lKfO
hhOEMAuorXfSCRvyY1115qeplS0Uf28+Z9uXJ9pdMHON7dFjdtFCSWsWsmdM
v4SBIi3C0RlQRWLHM2cZcX4+MZP5VB//CT0SXpR2DvdeX+9f//3pT9k/Dv74
fXV35+e/H4jvezs/D/cOLnf2Xpz88XZS+t4v/5EdnBwcv/wx+/nwl9XVvz19
CQ0cXP0tn/3y8vkfq0e/j18f7Pzg4Ycmfssn674XTVnBBo+aB/okuerhRYQp
d7GjzQcPNp89XT/fXN3cNPLqmGz1LRkR+yycjMjrkanIosYeGZgay/HIEKPl
YMNhjwy6ZP6RXJ7H8Ud6YvjxdrsoEhEtWxl1bj065A/WqeVtOSirwTN2Vlq8
ZUapmmkw5x1ECLhbpBm/P0u2N/VRhJTuvzjobW/Su/uyIpTY7j+QyMjvSTQH
rfqP8bwYxgj5OLN9zYgCCtq3noBgv7knTVrBNdUgYCLOYgRM2I3+qt98rT2I
sbid9i0qREeFGEz+GaMfvqCIA0PvFvwcVr3FA3Xa94LKN3OVNE7caKrZFZgS
mRK/gb79yTbFK7J+4X1xW38Wo1/2pngV3Np9cRBozr64uZYgnFurG+tbT+Cz
v/9g+8H6ww6Rat+37bW222s+jq/T56yNME7ZFiodqd9la9J2jVaHap2Zpw6P
qus0gErTq6bwcxL/EVbEkRcxs+vuqEhVngifa2+4QwnYFJhUgeNWaR5VlIeV
9ADzn53BEqVIAUOTvl0rUJ6QI7JCDNsoMyvg8APw9OC4x4/+qvhp4qQ4tCsA
YKrFam454+gWiXnREdxMFEALFdZpVuqW/mNOzOWBGfU8EccNVWLycZuPDryW
ahzcKiRWSoR9hQrJUiqFqZFTXRSYQwJhynGRHsNAo0pLyc4ARkNecsmHZ3bK
0rkp8/65eS/YBilrya5axU7CgQpdOEn3eDVDntaPGTbw4zwaYgVAEqnKVTIy
2m6zPgeZs9c3X7lk9Dey4yUFcB3ImKE+eawRABytcq/5CHJmJmb7RovbpkWd
yWOmXRU7XolZE8UrKvqVSH0mo9CS9udz5ccVrInKj51JRhBnu2IsiI6HzZTc
0xV/UDJZkQh4SgIR3GHg8dSSnX/L44sOHndgF83NSSWvcs1jVVjFuslt2Bcv
DvZwrLiFJo8x+46aQbegxxkV5UTy39jM7UrkaT+ZJChsB9eYeDg+Kw1hzGvB
Ks4zjiuamT0UUIL7ibDUzeQ8vO6dPpYYAFSBWXMq+5slWm+J4iTYx/84hZon
EIOX6DItUZiBBhxyvJ8HFktkKNx/njh8Hsdj80vTZIDLhgXnvMu7nwkWf3I1
plw2SrDGnqz4D4ipaO5VZoe11Gh1dY7eJxeYQEN1Gko12t/vxSD1Wd9wfvxA
dfO+8hRNdxNdVb7tzuLnCv9v+bbHAlA7Hlaw9bcDBZ/hQIHZVfVEwaJx9TIM
fqnB+t+OF3w7XvAVHC9oIVeCotHEPx+5qUgZM9OIMBEmU5tslOJNZmDRj0hc
iJ+a5IUGBReFeGNj45NAjP1IiNm/tigPaiYGc3GYACRtryNUvIF/Co/VP4Ge
/5Tkvy+XgBr9ZX4H6mWnbcGV3/zyC/jlwypaNMYq7P7zm6RJKIaVGrNAv7fX
ga/Tb5Lm52Ra9FGbjJMjgw3AqWZetZqND9sCUKWglJ/frU4Uzs6L0k0waWsd
V60rVmEoOY25imlxeie1MuzKq7GaeLRz377Fvf9TyZ/CF70zHGYzeL5rAo73
F1DNxds645Nf5Dfso6LIzlFypHNIqoc1Irw1BJ6YxE8MAd/SaqBD3iIQVu+m
kPnMoMw/EfyJIfFljvqM4FSzLX1GYBz1tgEglkbjRGU2WXJNkVrcd/UFV5+w
BLCpId+ucPckBpcS3nPLEvOe+46s3/ftL8jtaKdeEVajkSTRuyKLrg8e2OZS
UHPNPFpWW29OUPIqlJocz9zKtPW50gSYPvHuO09xTDInYT8ncOv11LfCBxbx
yFjEO9qFibYGX38VsmWbVSeUwl8p8CYKpanrTtdPPeXSxL4TbxyTb/LC8YYY
QBVVRA6xnXqj6rwTnbiiXGLG68I5tkLjctjXoOm9wcJ2DnmkijYUIrBTcKul
cofte0pXUyeXflSTxfhWE8ck85/qm3o/FG+nWSq5rusnheHjq9BAVp0PEWFH
5euSeXpFWuZ0xKa5iA/mBDHwyPpM8GQA258roPdZoRL3emrX35WJVHUb3jL2
qor9PRosY2+0wfsIFrR369nrrLYWGG5pe09de/zXrGtfbaBFhXt/763Z0TxH
8sVwIy/eXeVEtb1bw4sYNQEz+vDFHr1Ixo44oHexUgAWo7+3zJlrIfGWUEWE
+sGXLup3RaBfhy8VFW8AlV6QDi5h/KHifqsFocYFwFcsT5lZsWKFKmQscdVy
1+Gg6tJIMdFpgIdAfYyVAOq3WNvcYjVtVzYnRKa22KshCtyqrk7V108nHnAP
8LbWKqfCzxKVBrMk1J9DlLoVjirIEqFNQWw1KE9KZXlSgxEXLlRqLsxWxdKv
R9NS9wA/Ox5hYRJKEwtltyg61TVvllKwO2xdIRZl619tJVb7ZYZHFvYzwpct
rNjIpO6BUwuhvrsGUqlPJNiIpR7MutilFr/j50N3DjrNwlwfgdNmtWaNJvBT
X3mW+ivPOm20rEPLc/E6bZTBqrQfwQzVu18PN7jV1xZnjIZFdx2C1JXgpaES
vE4bbQryUlGQ12likfK8nibm1Oqt5bEKm3zxLCa+vapfco2afB+p9gULppvW
n1M6vWHldKMFfw11bwn1T2c0LUOB/OJtpkoNONNsarLH18BAmhOMptgW7iow
Ai7cx2Pz1Atzo1V9fwELyfLhyz6dIDDDDx+YL1WYjlUlIhV276tJZIkutz6R
/2iyU4XIasGqSPTKFHPOxHDydATMhTr9tIGGOmeC1EwR/xaL7aA1gvAWIZCO
zq+v12fht3QS56lKZDIZHrWS4YlD8FYTxoH4JknrwiR0qfFl0NDMwtOElipG
0kND18PrIyMiWaXvZwUHkaqVmoOuolKpQFioCoTcw+sUH3TedyoLqgIpvhKD
2GaauTq0UfIvdusFLkRz99aXOHGDka+LTOBmlRMttIerKIryWN4yilYTjUsq
yrNI1ttScv1vVV9xERH9NZA6yV8vJpabF4W0MMsLRNbXh3RrQ1oNzCmjaS/U
AT4Wpai+vgncVmqrcPOA1K4jsFMA01P/0sJ1q1qYUkmyWmhfFtN6XZfInF8h
057sDapl6mKZXx3PNJUEzhmERYTCM6FBN6iIacv7sbHhrpMeqUPvy1aQnVu3
inH2rxX5Y8bb15uStjHZ3IzUyA2bb8rENcOCWtmDgRMnAfsQzy+IspoB85AV
ZXTKt7GaymO1Uqh6guayYu62m0UZeVlHtyJj5wsgRd2ZkmWQpHJep8Zud18J
ECdcMlKSqLX1zooWVqWMSE9fI2YMWKo1PLEgnzDsnji6h12wkpcM5+XwmFSK
9LuyQuWntepUycs/meSpiyhdGs+LANHmHC9eCPD7caCK56fn9h1aJG8pLxiK
eewRKAGF0qPPnAVVOi9gLRYFKnUBz6/OVfFFM7UnLnlpLO0cYqxnZ31i7nOx
8lz1cMcQsLk87afKoiKznttRAGDB8ZMsZoHUZbPvp1QGa9Rvs3jrYoLiKPPW
d/2qp3sNwqqFZRdD26m/9qzZvKgyYnGmrk1LK7Vpv24b8UsTsc5pCy1e68Pf
seRUq32xRSS1kxHdEc1wd96emIh+r2TxQOEMQ2gtm43s6wvNhl/cAlCJOl2h
KkD9WSWKLzH9Iuvcmcy3Na9ijyVQdPWeRsV7sHaP9T6sjYvtJH4xgqcJaX5a
UPdgbmOhC8+rIWai1a4nVl9OzKgmZlGmUlkMYKipK/YnVXCWsht85hQ+MzaA
K17Fr2AD+GvaS7BKViym/kuhGC7xZVGgfbUv63Wr8ldd4S9R9st6WdYA+9NK
VKuayELkrCvIxx2xsgSfhVldjq+WoF/dfLJ16C9GiXY0VEN7DuvObm2Qxupz
O+W5mhgdx684lN+2Feg26jN/nzNSs1M3gXiyptGXNbFkf9jVLYwJ0TCYbKO/
+ioYPmnFQn7pR0o8Oe3nIdqvBzSoqKLxbJdWCVQ+qZQ5+dpO8ZCFIlZby5vf
3KB0xsgN5jdpcQSQpf1h5/9qMtfXZ/BZoqyamzDMEl3O017RtW9FwkLvZQrr
pj/ls3G4YwgGikiI3ZXnnrpUng8GzmBR284BqTZC0Mp3VpmZ8857HfAd2kLn
UmZp+/G4ITZR2FEbwUT8Ik1nKXN9spzXxot12a+/Fimp7rU+58XTt5n4aHvy
pC6D9455Wk7jcTknvarvfhGHe1haOz9Cq6fGBUTiMkvjwZ40hdd8Arw4OZCY
H2Y5z3k/qoawrhitrujM4zzOjoUz6cOPNDvH8x5OC6OojHSQrSkQFiPw13u0
Zl4qwYq0m58xgFOyttKCe6zOTVajqjaIigxmI2lcYqCD8basz7A8zeS2TtJo
BNcrhHW5Fz8NRUpPCY0wMb5mEiymIH6cOdqoJs28k06UMpXdKInDMy2q0G4n
MSPLlS4A4TvdWclIzoozyOEWogRJzmakaCmX7/UpPcrE0VrGS8z+hTacHJBY
CQgU3ZRORDJO1iHPEMDoyBWUjF4k6vSddahBuKr6hDzsP+ivQb9uDkcnCWQV
HSw4TthBEQ7LTIKui1Kw1jxDcLJlIvw2ogCml1cw8+g0zicJetUYa2CSHsDZ
LBqLbBIcoRzow52/U7EjKuK2JUwijo+xiHjYJR+C0HlRoHOKdn7Ms9m0w9Vc
g6nZbZa/Aoir6FZpCmt3TrOiSDDaAbNrxsNZjmSBlaBAgouKLcGkmo/jYYRC
wS51OpUvsg6wkAcvOcPEhjhWOcFQtfMYK8PkGcAMkmN8Yx2wxCMJu3HOknLw
HPUF85uxlD3RqMeydmQ5wSA37JwlSmIVr4Bs11eZFSsNo/vtV3qIp2b4yV0e
DYCE69PfXhFysHO002DYhJw93iNklxGv4MrDfpSPUVv8Rfow5mQi3cuji5L2
VtcGyK7/g9K97Oov9CU7EnCZlVLxsYvLxtFf9Jur4s2DNMH8KYAPjn0gYa/X
o5NkNBpjMSv63JubleeV9UgMxg8yaSvymeF3hG6ms3yK4er9UBo12Z09KSuJ
1QIJXgnxg4sTVakGuUqI6y3I6jFp0TADlSgtCzx1Kg1YJoP5EORhVFZaYiAu
EqmSqCVU3pGHMuVbsDAMBIOKS8jReDYnLnSG5EpONrNgN2+DGyiWPmR0vmBO
NvvTOENbqIWVSi0Dka7NeAEjRBEKvnobN+SKbaeAxM81Goy+Wzp/WhVf4nRd
CGGLpk+zPg1zqYVer6RY8yZWC73dJN9afe8tkq+FGhHOVzMTWzgVWx0ezAxt
NXnZQk0E0rWZgHl50GW1BZiQp01rMGG5sBxQWETDXNk4kRqWBAsgQ8VnI+4u
ZrhVicp5n+7OwGCG5XXG4q4SHgIeagV05AS3iG/i0o+7j52/UsPXqOsZM1pc
hIEkfIE51nLTaiYaj59fmG2gU2JAV767r2X7fSHY7/McMtpttMLec68qmd9M
elurhvkmK9xtXAU0TKzHgrxCQfTOJgOHNj3aJgtCiMnMOBup6vMDIIziVv24
JrMmGS2H+XVFQdPLhjwctYLHZEWHR4OTGG2tHJjsoMlY7CmbutBa9fcYYlkw
GJtNc+SopSlzXfh25h7FWKqoOlaL12tR6ZsI/AVtErv8G2R2DyeYGozGJjQg
LwbVGAOIvvNQmGVqx1qLSPxIQ7/FgP0TwosKw+WpMHEeI4tIn8anGqeosLHA
MEfwXg9rI88bLD7IDX942B7zdSQWtjrSixBu1znxyTjBKC5ym2iaZEXJ6srC
cu6iTLhd6rA0gtmfjAvOViKzA8cxOitm0xEvPxpUMdhwPiOaRUTAxwiYNzpk
11rxXLwFhe7HjKBOranJWuRJ9Rq0qj3JX0OmddiyNsu3zrGsmxvWxigc69q4
4zOxvTljJeHa6WxOptjW9vaCmWKtz7y0scu2WHyDX8TZ0DCV620ZXHXmg01V
/x0cssSFfx4acxlYuLl1YeSgW2n6ip0pdkUB9nFWDXvRAMe2aCzy1vJ1MBWe
aNzL2nOT4gVz4ulPm+x4xGUyg35eAe2fGQ4paoxAG2VtcvX6F+V2aXu9TRi7
2U4C3xohyBPftpZ989LdLtlG03a2TizbHuaF0snqT6PEssG33YyzgRyzwffr
c8/WAh7IQnvLNHLSvS7TNVIrr0LZYN2sN+anRV7YYBs8X+ycDLHN2EOljvUm
i53DIsEksqyxMPj1+WRpSwd+M6+Lu4D3hDzizPRn88lVVVtGtW+OOfb55qYy
P9/cVB83zm9uqnkY+uamsj7f3FTLcVPV5Nb2+6lqXE92leKlOZ8ej2MnsGOO
fYdw7BmxNpFkni9Z7Qjlr1OtLPS2CUSdP0LhWHHBivGm0vs0M1ZfaKnu2UfQ
bs3caJj2PCjTmp1aC73tpEZ306G31MCauwvdI+htje+muchrl4M2x9JDbVRO
roUebHJy/dbQLfN9t49p4ihFlbYmVzgPkwtyqD9ruAjmMUJRarDHs4NXae3N
P17fSLNM5KE2EFxMUr5sUskbWuwHMia3dlM1y/od1plapAAPtuGkhg6mAw82
4EkT7ksNfnsTKH/dWkQ1z8sdRH6LHN2hJuREaeduaR7zIfJat5YsDbJah8fU
JsN1ELdybUwu3M51EmpoE1NQBwFx0mDXpb4OteFmxK7Jgh1qwpMc+7bkk52b
+ta0ohb5q4MEnpvL+pamRGNN2E0+7DnM3U5JPtKZnf3a8ccBqtPGeiBtr9If
O602AXmhTLTLQe6x1ebygZXJ9ZYFKLQ3H0jfjrdt+Bg3XKXduGXoicZVW1iI
G3UOAPaIwcUtTbZG3umKOyQZSU9IauY9ty1z/CxtV8vl/KZ+g7mpv2twA7pH
FTkiC2EIOy3SewelcPNU36EWRAbw21nRfBMAILLoJMVIQyrNyfK7ZBo1SEod
Qiwyf21+6s+HchSGDdH9fFb2soseJiz2YVyXsmqM8fkiA8AzMiiH0b1U1cvM
S9yaTfwpiW8L1GpG4NYAB5IBR750wEHhI0IpgumBb0UDDPG3/mVSMuD0DuXN
be3zxlaW4PO+Q7Qn+g4byt50KvSSO56Zesc3VRGWkT9P2J3qJL2jMGZ3bHbG
zA3zMrc37lgMYc5q+w5zg99xuKexH9xO6KabWeh1C4w69U7hXXvC71jsarrC
HVJpX3gdzbw00OmMPWQQc/lOaDI3yWV8xzsZ2cS6E56Od2rmo77nySe8bGYK
hl3U5h2mLvOpT7MkxMHXrezEPCOxH8GaS5aBX1STqoidi63mGYGDA26THjjY
iE4b3CRVcLAZI4XwbXJ1ZRNlAczXJvG1d0iCw/Vl8As+3GQf5DaRZibPvVUZ
0CTJrkqsG0RX84y74Taapt8NNiDS8upUvLdJIDMdbnuObpELl57HwRE3yYt7
e0hQa7h+uGcswOZVU/LK6+1DLGoyzbZWOEWC1VvROTmQbdVOMTQ74uJrVDgr
aTxb65yVFhqrnSbqm2ue3rfaK59OLMZtiu2aeIx/2KmDa4R2i0zCt68gmAl+
F1MRGuT3lep8WJ+ty/fbTFtgeYA/sdS1Oc+SxxXk+m3emrzYnKH6YaHsJuFt
KJ2bpOVd/OAmRWiqAyLLEPDOgNtLCjNnbmPZZr5kiDR3IgXTVTaaVTrseVw7
2ZpkTBQAhQ2QFhktw1NWZldsPeVcmzIsofS3mtyTnx69QZS0zE/5OVBbK85M
Tq8KsyCDm4/WEMqlq3cyehZsd7FmbvXFlqr6ZMq3yMkoXtrxaTKHT/1JiZ00
xCEOa5Se2EhIHGrH0F5uDXn+hRd5wLwACBbMHVovqciSSAg8vrpJxRKHyUBj
npo8RbZjidXADM7ZUYU+e3gL6ZUV2AjLt/gkGWXk/wMhFZSrcDgBAA==

-->

</rfc>

