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


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

]>


<rfc ipr="trust200902" docName="draft-shahzad-scim-device-model-05" 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="June" day="02"/>

    
    
    <keyword>Internet-Draft</keyword>

    <abstract>


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



    </abstract>



  </front>

  <middle>


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

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

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

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

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

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

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

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

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

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

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

]]></artwork></figure>

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

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

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

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

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

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

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

</section>
</section>
<section anchor="resourcetype-device"><name>ResourceType Device</name>
<t>This section defines a new resource type, 'Device'. The "ResourceType" 
schema specifies the metadata about a resource type (see section 6 of 
<xref target="RFC7643"/>). The resource "Devices" comprises a core device schema 
and several extension schemas. The core schema provides a minimal 
resource representation, whereas extension schemas extend the core 
schema depending on the device's capability. The JSON schema for Device
resource type is in <xref target="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>client-token</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  |
+-------------------+-------+-----+------+---------+--------+--------+
| client-token      |   F   |  T  |  T   |   RW    |  Def   |  None  |
+-------------------+-------+-----+------+---------+--------+--------+
| certificateInfo   |   F   |  F  |  F   |   R     |  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 client-token and certificateInfo are used for the
authentication of the application. Both SHALL NOT exist together in the
SCIM object. Either client-token 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, client-token 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"]
  },
  "client-token": 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>

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

<t>versionSupport</t>

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

<t>pairingMethods</t>

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

<figure title="Characteristics of BLE extension schema attributes. 
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   |
+--------------------+-------+-----+------+---------+--------+--------+
| 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"],
    "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|         |        |        |
+====================+=======+=====+======+=========+========+========+
| deviceEui64Address |   F   |  T  |  F   |   RW    |  Def   | None   |
+--------------------+-------+-----+------+---------+--------+--------+
| versionSupport     |   T   |  T  |  F   |   RW    |  Def   | None   |
+--------------------+-------+-----+------+---------+--------+--------+
]]></artwork></figure>

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

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

  "id": "e9e30dba-f08f-4109-8486-d5c6a3316111",
  "displayName": "Zigbee Heart Monitor",
  "adminState": true,
  "urn:ietf:params:scim:schemas:extension:zigbee:2.0:Device" : {
    "versionSupport": ["3.0"],
    "deviceEui64Address": "50325FFFFEE76728"
  },

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

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

</section>
</section>
<section anchor="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   |   RW    |  Def   | Ent    |
+--------------------+-------+-----+------+---------+--------+--------+
| telEntEndpoint     |   F   |  T  |  T   |   RW    |  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",
  "displayName": "BLE Heart Monitor",
  "adminState": true,
    "urn:ietf:params:scim:schemas:extension:ble:2.0:Device" :
    {          "versionSupport": ["5.3"],
    "deviceMacAddress": "2C:54:91:88:C9:E2",
    "addressType": false,
      "pairingMethods": [
        "urn:ietf:params:scim:schemas:extension:pairingNull:2.0
           :Device",
        "urn:ietf:params:scim:schemas:extension:pairingJustWorks
           :2.0:Device",
        "urn:ietf:params:scim:schemas:extension:pairingPassKey:2.0
           :Device",
        "urn:ietf:params:scim:schemas:extension:pairingOOB:2.0
           :Device"],
    "urn:ietf:params:scim:schemas:extension:pairingNull:2.0:Device"
       : null,
    "urn:ietf:params:scim:schemas:extension:pairingJustWorks:2.0
       :Device": {
      "key": null
    },
    "urn:ietf:params:scim:schemas:extension:pairingPassKey:2.0
       :Device" : {
      "key": 123456
    },
    "urn:ietf:params:scim:schemas:extension:pairingOOB:2.0:Device":
        {
      "key": "TheKeyvalueRetrievedFromOOB",
      "randNumber": 238796813516896
    }
  },

  "urn:ietf:params:scim:schemas:extension: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": "client-token",
      "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": "readWrite",
      "returned": "default",
      "uniqueness": "none"
    }
  ],
  "meta" : {
    "resourceType" : "Schema",
    "location" :
      "/v2/Schemas/urn:ietf:params:scim:schemas:core:2.0:Device"
  }
}
<CODE ENDS>
]]></artwork></figure>

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

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

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

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

</section>
<section anchor="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": false,
      "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": "readWrite",
      "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": "readWrite",
      "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>

</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: true
          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/client-token'
        - $ref: '#/components/schemas/certificateInfo'

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

    client-token:
      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: false
      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: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="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
        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:Device:
          $ref: '#/components/schemas/NullPairing'
          required: false
        urn:ietf:params:scim:schemas:extension:pairingJustWorks:2.0:Device:
          $ref: '#/components/schemas/PairingJustWorks'
          required: false
        urn:ietf:params:scim:schemas:extension:pairingPassKey:2.0:Device:
          $ref: '#/components/schemas/PairingPassKey'
          required: false
        urn:ietf:params:scim:schemas:extension:pairingOOB:2.0: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: false
          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: false
          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'>

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




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



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


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

	 </t>
      </abstract>
   </front>
   <seriesInfo name='Internet-Draft' value='draft-bhutton-json-schema-01'/>
   
</reference>



<reference anchor='RFC2119' target='https://www.rfc-editor.org/info/rfc2119'>
<front>
<title>Key words for use in RFCs to Indicate Requirement Levels</title>
<author fullname='S. Bradner' initials='S.' surname='Bradner'><organization/></author>
<date month='March' year='1997'/>
<abstract><t>In many standards track documents several words are used to signify the requirements in the specification.  These words are often capitalized. This document defines these words as they should be interpreted in IETF documents.  This document specifies an Internet Best Current Practices for the Internet Community, and requests discussion and suggestions for improvements.</t></abstract>
</front>
<seriesInfo name='BCP' value='14'/>
<seriesInfo name='RFC' value='2119'/>
<seriesInfo name='DOI' value='10.17487/RFC2119'/>
</reference>



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



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




    </references>

    <references title='Informative References'>





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




    </references>



  </back>

<!-- ##markdown-source:
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
LmcH6kZIM5MKYpFG9a4mwlt4Dazd0TqvtzLRdUJVkDWlLV4NIh3HGo0wYdeg
szdN34V8PzoHiv2///N/n4WjER6nuH+wt//sgdqrZOReQNRhJMH2JnAQZjwc
ykMCwpt90lnf2m7DPxs7mwLKk87W+hphmO2stvnjbXF5bX21SPyU1Ua6c/vo
Snv2HqZvr5vO8xsqrNzJFqQyd7gzUNTEGX2BuWJTW57rcDa1qxMK+CjYYAO2
2Nk2NrarvHj1m9pd5d/LwOgIRmJdEftdo8klYGMM1wdc3JUp39olDLRpQyvA
kwP9UGUIRr+inSrbOFrRACusmrH9JK3dr7QgEcqkecpC7+6JAZHppTYr7UHo
nR+VQVlnqAhjSpVRHLyy9il/+/Xn0za6/HBHsjx4VscTDQY/gGU5A/sRZPTI
dyIuiL1jvBARdTJfNh4kwnaE9BiI1sCaDCS1a8gpUCkuiO1DLmB6KJspoWNl
Z+3h2kp7ZW1t6+HG9ooHLWzGVGmAlm++vka+Pr1mWR1+Nl+WuUJVwXN3vppZ
vtC7962ZwrqMnxnw3Ca9CuFaCrq/S3hMYWjg5zPBYyYqQTWv0teHd+t9fa7T
ji/gtKPYpRv57Gw4QUhTaGa9u058buy0Mz9NrXBpGHjTCttePdnugslSbN8e
2U0L5UlZyN4x/RYGigrJjs6CMhJbnqlLxPn51MwfU378J/RYeFHaOtp/e3Vw
9fdnPyX/OPzj99W93Z//fii/7+/+PNg/vNjdf3X6x/tx7ns//0dyeHp48vrH
5OejX1ZX//bsNTRwePm3dPrL6xd/rB7/Pnp7uPuDhx+aeDCfrvteNMUFDR41
E/ROCtXEiwhTBGNHm48ebT5/tt7fXN3cNFK5mGz1Lf8NfRbOf+P12JRkUWOP
DUyN5XhsmNFyZcPVHht02fwjuuiH4Q09NeJAtV2bh8mWrSQutx678Qd1anlj
DvNyaIudHBVvmTGkZjbGWSHtFe4YZeYfTKPtzSKoPeYHrw4725v8/oEqTCSV
80OFjPSBQnOl1X8Tz4xhrLCbmfVrRoxOpf3rCdf1m4PK5JVcUw7RZTKqv8LE
3eiu+s3b2pD+b3bcsuy4Erd/Xjvuy4oBMPRwyd/Vqrh8oE4bX1AZJ9dK49yB
ptpdgilSmdob6N93tl1ekv0L75jb+rQc/bK3y8vg1u6Yg4BzdszN2YZwbq1u
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
GbGwMFMFMnRINuLufIq7k6idd/neFExmWF6nFGoViajvqlZAR45wV/g6zP24
u+n8VSp+gbqOMaPlRRhIJBaYk0JuWs0Eo9GLc7MNdEv0+Mp3DwvZ/lAK9oci
GUjhOFqh99yrWuY3k97WqmG+SeWUjauAhrH1WCWvcBC903HPoU2Hz3OYvYrJ
zNAapeqLMx9EcauKV5NZEw2Xw/xFXTfTz4Y8HMwFj8mKDo9WTmK0tVJgssMm
Y7GnbOxCa1VBI8RS/BfNphly1NKUhS58O3OPY/hUUB6rxeu1qPRNBPFCYRK7
/FvJ7B5OMDWYApvQgLpYqcYYQHSdh6pZpnastYjEjzL05xiwf0J4UWE4PTUm
+iGyiPJp3NU4ZamEBYY5hPc6WKF21mDxQWH4w8P2mK8CubDVkV5GbbvOiTvj
BKNKxG2iaZxkOVX3hOXcRZl0u9RhaQizPxplgq3kAX2BY3RWTCdDUQSyUsWg
4XxGNMsggJsImHdFlK614rl4qxS6NxlBnVpTk3zGk7Oz0qr2ZPGsMq2rLWuz
iOYMy7q5YW2MwrGujTs+E9ub/FMRbj6dzUn5Obe9vWDKT+szK//nknUd39gX
8TU0TMl5W/ZWnfVgE9V/B4escOGfhgYigYObGxdmLrGVpu/YKT9XNGQ3s2ro
RRMe26SxCFzL2JU5zWTrXt6emd2sMrlZ8ZknzRlz2cygoJ/D/JPDIUaNGWjj
bJ60q/5leb4MrN4mjB1tJxdrjRgUOUznln6zMpfeluQycoTOD/NCmUGLT6Mc
oZVvu8lDK9KFVr5fn0a0FvCKhKK3TCMnc+cynSO1AqsqsacdRGV/5kjxWdmG
SP05I9lnM/bQWUC9eT9nsEhlPlBqrBr8+tSgfE4XfjO/i7uGd6Q8Esz0zSv3
zSv3zSv3zSv3zSv3zSt3Qwx988pZn29eueV45WoyQvvdcjWeNru67tJ8bU9G
oRPHMsOYRTj2jdCiQDHPl6xjVWXo060s9LYJRJ37ReNYc8GK8aZWcgtmLL8w
p25rH7K7NduqYbLuSpnW7Fxe1dtOQm83ifecOudMFUzfcw/Zz6t7Ns2gXbsc
zHPwvqqN0uG8qgebnM2/NXSrLNXzh3AJlKJKW5PhWkQFVnKoP9e1jF0yIm9q
sCdyWpdp7c2aXd9Is/zZVW0guJhae9mkUjcKsV+R53dun1yzXNXVOtOciaur
2ykSGs9OYl3ZipHd2pfR+vZmUPp2bhnVPJ105XjnSC1d1YSaKbdkTdvpmG9t
mZwjZXMlJmamb74lFC2Wp3hOBem4yFvs14xuApMvJWpTwE6cJpYPXTm35Zyw
yQaWD5mdEm5OqODl2RD5tmhtzdW44Wpdxi1joTeu2pNb3qiz4OgRgxXn1Lkb
OVRL9mw0VKZsbKbmtk0r/CxtD8bl6aaG38zs1DW4gbWjjByZKK8KO3NkoK6U
ms2zUVe1IJNU347K5JsAAJFFJyUgGlJpRiLaJdOoQd7kKsQi89emUP58KEfJ
1xDdL6Z5JznvYE5dH8aLCjqNMT5bZAB4RpLfanQvVbc3U+fOzSb+rLm3BWo5
ae3cAFfkqw18GWsrhY/c+K/MYHsrGlsVfxe/TEpWeC2rUrvO7bTEVpbgtLzH
ClfiPRrK/mQi9ZJ7npl6zzdVEZahP5XVvfIkvacxZndsdkbmgXlZ2Af3LIYw
Z7V9h/yY9xzuaezItHOOFc0s9LoFRp16p/FeuDLvWexq+jIdUhXOzDqaeWlQ
ZNz1kEHO5XtVk7lJut173slIE+te9XS8VzMfi3uelLfLZqbKSIHa1LjcZT79
aZYnt/J1K4GuSJrrR3DBJcvAL6pJZcTOxFbzpLWVA54ng21lI0Vm2ybZbCub
MbLc3iZXl7zgC2C+Ns+s7eKuHK4vy1zlw00c2beJNDO/663KgCZ5YHXu10p0
NU8KW91G0wyxlQ3IzLFFttjbJJCZsXV+jp4jXSvvh5UjbpK69faQoNfw4uGO
sQCbV03Jq67Pv0dekwx1boVT5gC9FZ1TADmv2imHZm+Zf40KZynz5Nw6Z6mF
xmqnifrmmqf3rfmVT2cz/TbFds2G+j/s7LY1QnuOZLe3ryCYOWgXUxEaJKFV
6ny1PluXk7aZtkC5au9Y6tqcZ8njEnL9Nm9N6mbBUN1qoezmjW0onZtkkl38
oCFHaMoDYssQ8M6A55cUZprXxrLNfMkQacW3GQkWG82qIm51VDvZmqT4k8xX
bYDMkYOxesqqdIC3KaKKbzXZEu8ev5U4mTOj4mfBba1AM3ndvD6Dxc1Hayjl
EtY7HT1Ltrtck2N9scWqPgHw3Ph2/SPVrIwCZj5GjWYwqj+RrpM6t4rFGqXU
NZLoVrVj6C+3hjz/0os8YF4ABEvmrloxuczrxxg8vrrJ5SKH6StDkU87Rraj
VGBgCKcUbd6lh7eQXkmGjVCGwKfRMGH/H6lG8BNCMwEA

-->

</rfc>

