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


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

]>


<rfc ipr="trust200902" docName="draft-ietf-scim-device-model-02" 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="2024" month="January" day="11"/>

    
    
    <keyword>Internet-Draft</keyword>

    <abstract>


<?line 64?>

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



    </abstract>



  </front>

  <middle>


<?line 72?>

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

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

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

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

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

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

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

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

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

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

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

]]></artwork></figure>

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

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

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

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

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

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

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

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

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

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

<t>id</t>

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

<t>externalID</t>

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

<t>meta</t>

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

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

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

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

<t>deviceDisplayName</t>

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

<t>adminState</t>

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

<t>mudUrl</t>

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

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

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

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

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

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

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

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

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

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

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

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

<t>applicationType</t>

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

<t>applicationName</t>

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

<t>clientToken</t>

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

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

<t>certificateInfo</t>

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

<t>rootCN</t>

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

<t>subjectName</t>

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

<t>subjectAlternativeName</t>

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

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

]]></artwork></figure>

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

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

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

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

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

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

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

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

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

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

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

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

<t>deviceMacAddress</t>

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

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

<t>isRandom</t>

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

<t>separateBroadcastaddress</t>

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

<t>irk</t>

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

<t>mobility</t>

<t>A boolean attribute to enable mobility on BLE device. If set to True, 
the BLE device will automatically connect to the closest AP. For 
example, BLE device is connected with AP-1 and moves out of range but 
comes in range of AP-2, it will be disconnected with AP-1 and connects 
with AP-2. It is returned by default and mutable.</t>

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

<t>versionSupport</t>

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

<t>pairingMethods</t>

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

  "id": "e9e30dba-f08f-4109-8486-d5c6a3316111",
  "deviceDisplayName": "BLE Heart Monitor",
  "adminState": true,
  "urn:ietf:params:scim:schemas:extension:ble:2.0:Device" : {
    "versionSupport": ["5.3"],
    "deviceMacAddress": "2C:54:91:88:C9:E2",
    "isRandom": false,
    "separateBroadcastAddress": ["AA:BB:88:77:22:11", "AA:BB:88:77
       :22:12"],
    "mobility": true,
    "pairingMethods": ["urn:ietf:params:scim:schemas:extension
       :pairingPassKey:2.0:Device"],
    "urn:ietf:params:scim:schemas:extension:pairingPassKey:2.0
       :Device" : {
      "key": 123456
    }
  },
  "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>In the above example, the pairing method is "pairingPassKey", which implies
that this BLE device pairs using only a passkey. In another example below,
the pairing method is "pairingOOB," implying that this BLE device uses the
out-of-band pairing method.</t>

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

  "id": "e9e30dba-f08f-4109-8486-d5c6a3316111",
  "deviceDisplayName": "BLE Heart Monitor",
  "adminState": true,
  "urn:ietf:params:scim:schemas:extension:ble:2.0:Device" : {
    "versionSupport": ["5.3"],
    "deviceMacAddress": "2C:54:91:88:C9:E2",
    "isRandom": false,
    "separateBroadcastAddress": ["AA:BB:88:77:22:11", "AA:BB:88:77
       :22:12"],
    "mobility": true,
    "pairingMethods": ["urn:ietf:params:scim:schemas:extension
       :pairingOOB:2.0:Device"],
    "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>However, a device can have more than one pairing method. Support for multiple
pairing methods is also provided by the multi-valued attribute pairingMethods.
In the example below, the BLE device can pair with both passkey and OOB pairing
methods.</t>

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

  "id": "e9e30dba-f08f-4109-8486-d5c6a3316111",
  "deviceDisplayName": "BLE Heart Monitor",
  "adminState": true,
  "urn:ietf:params:scim:schemas:extension:ble:2.0:Device" : {
    "versionSupport": ["5.3"],
    "deviceMacAddress": "2C:54:91:88:C9:E2",
    "isRandom": false,
    "separateBroadcastAddress": ["AA:BB:88:77:22:11", "AA:BB:88:77
       :22:12"],
    "mobility": true,
    "pairingMethods": ["urn:ietf:params:scim:schemas:extension
       :pairingPassKey:2.0:Device",
        "urn:ietf:params:scim:schemas:extension:pairingOOB:2.0
           :Device"],
    "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   |   R     |  Def   | Ent    |
+--------------------+-------+-----+------+---------+--------+--------+
| telEntEndpoint     |   F   |  T  |  T   |   R     |  Def   | Ent    |
+--------------------+-------+-----+------+---------+--------+--------+
| applications       |   T   |  T  |  F   |   RW    |  Def   | None   |
+--------------------+-------+-----+------+---------+--------+--------+
| value              |   F   |  T  |  F   |   R     |  Def   | None   |
+--------------------+-------+-----+------+---------+--------+--------+
| $ref               |   F   |  T  |  F   |   R     |  Def   | None   |
+--------------------+-------+-----+------+---------+--------+--------+
]]></artwork></figure>

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

<figure><artwork><![CDATA[
<CODE BEGINS>
{
  "schemas": ["urn:ietf:params:scim:schemas:core:2.0:Device",
     "urn:ietf:params:scim:schemas:extension:ble:2.0:Device",
     "urn:ietf:params:scim:schemas:extension:endpointAppsExt:2.0
        :Device"],
  "id": "e9e30dba-f08f-4109-8486-d5c6a3316111",
  "deviceDisplayName": "BLE Heart Monitor",
  "adminState": true,
  "urn:ietf:params:scim:schemas:extension:ble:2.0:Device" : {
    "versionSupport": ["5.3"],
    "deviceMacAddress": "2C:54:91:88:C9:E2",
    "isRandom": false,
    "separateBroadcastAddress": ["AA:BB:88:77:22:11", "AA:BB:88:77
       :22:12"],
    "mobility": false,
    "pairingMethods": [
        "urn:ietf:params:scim:schemas:extension:pairingNull:2.0
           :Device",
        "urn:ietf:params:scim:schemas:extension:pairingJustWorks
           :2.0:Device",
        "urn:ietf:params:scim:schemas:extension:pairingPassKey:2.0
           :Device",
        "urn:ietf:params:scim:schemas:extension:pairingOOB:2.0
           :Device"],
    "urn:ietf:params:scim:schemas:extension:pairingNull:2.0:Device"
       : null,
    "urn:ietf:params:scim:schemas:extension:pairingJustWorks:2.0
       :Device": {
      "key": null
    },
    "urn:ietf:params:scim:schemas:extension:pairingPassKey:2.0
       :Device" : {
      "key": 123456
    },
    "urn:ietf:params:scim:schemas:extension:pairingOOB:2.0:Device":
        {
      "key": "TheKeyvalueRetrievedFromOOB",
      "randNumber": 238796813516896
    }
  },

  "urn:ietf:params:scim:schemas:extension:endpointAppsExt:2.0
     :Device": {

    "applications": [
      {
        "value" : "e9e30dba-f08f-4109-8486-d5c6a3316212",
        "$ref" : "https://example.com/v2/EndpointApp/e9e30dba-f08f
           -4109-8486-d5c6a3316212"
      },
      {
        "value" : "e9e30dba-f08f-4109-8486-d5c6a3316333",
        "$ref" : "https://example.com/v2/EndpointApp/e9e30dba-f08f
           -4109-8486-d5c6a3316333"
      }
    ],
    "deviceControlEnterpriseEndpoint":
        "https//enterprise.com/device_control_app_endpoint/",
    "telemetryEnterpriseEndpoint":
        "https//enterprise.com/telemetry_app_endpoint/"
  },


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

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

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

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

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

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

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

</section>
<section anchor="endpointapp-schema-json"><name>EndpointApp Schema JSON</name>

<figure><artwork><![CDATA[
<CODE BEGINS>
{
  "id": "urn:ietf:params:scim:schemas:core:2.0:EndpointApp",
  "name": "EndpointApp",
  "description": "Endpoint application and their credentials",
  "attributes" : [
    {
      "name": "applicationType",
      "type": "string",
      "description": "This attribute will only contain two values;
          'deviceControl' or 'telemetry'.",
      "multivalues": false,
      "required": true,
      "caseExact": false,
      "mutability": "readOnly",
      "returned": "default",
      "uniqueness": "none"
    },
    {
      "name": "applicationName",
      "type": "string",
      "description": "Human readable name of the application.",
      "multivalues": false,
      "required": true,
      "caseExact": false,
      "mutability": "readWrite",
      "returned": "default",
      "uniqueness": "none"
    },
    {
      "name": "certificateInfo",
      "type": "complex",
      "description": "Contains x509 certificate's subject name and
          root CA information associated with the device control or
          telemetry app.",
      "multivalues": false,
      "required": false,
      "caseExact": false,
      "mutability": "readWrite",
      "returned": "default",
      "uniqueness": "none",
      "subAttributes" : [
        {
          "name" : "rootCN",
          "type" : "string",
          "description" : "A root certificate common name.",
          "multiValued" : false,
          "required" : true,
          "caseExact" : true,
          "mutability" : "readOnly",
          "returned" : "default",
          "uniqueness" : "none"
        },
        {
          "name" : "subjectName",
          "type" : "string",
          "description" : "Also known as the Common Name (CN), the
              Subject Name is a field in the X.509 certificate that
              identifies the primary domain or IP address for which
              the certificate is issued.",
          "multiValued" : false,
          "required" : false,
          "caseExact" : true,
          "mutability" : "readOnly",
          "returned" : "default",
          "uniqueness" : "none"
        },
        {
          "name" : "subjectAlternativeName",
          "type" : "string",
          "description" : "This attribute allows for the inclusion
              of multiple domain names and IP addresses in a single
              certificate. This enables the certificate to be used
              for multiple related domains or IPs without the need
              for separate certificates for each.",
          "multiValued" : true,
          "required" : false,
          "caseExact" : true,
          "mutability" : "readOnly",
          "returned" : "default",
          "uniqueness" : "none"
        }
      ]
    },
    {
      "name": "clientToken",
      "type": "string",
      "description": "This attribute contains a token that the
          client will use to authenticate itself.  Each token may
          be a string up to 500 characters in length.",
      "multivalues": false,
      "required": false,
      "caseExact": true,
      "mutability": "readOnly",
      "returned": "default",
      "uniqueness": "none"
    }
  ],
  "meta" : {
    "resourceType" : "Schema",
    "location" :
      "/v2/Schemas/urn:ietf:params:scim:schemas:core:2.0:Device"
  }
}
<CODE ENDS>
]]></artwork></figure>

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

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

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

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

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

</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>Devices provisioned with this model may be completely controlled by
the administrator of the SCIM server, depending on how those systems
are defined.  For instance, if BLE passkeys are provided, the device
can be connected to, and perhaps paired with.  Any additional security
must be provided at higher application layers.  For example, if client
applications wish to keep private information to and from the device,
they should encrypt that information over-the-top.</t>

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

<t>TBD</t>

</section>


  </middle>

  <back>


    <references title='Normative References' anchor="sec-normative-references">

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


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

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


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

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

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

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

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




    </references>

    <references title='Informative References' anchor="sec-informative-references">



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




    </references>


<?line 1827?>

<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 scheme!</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: false
          writeOnly: false

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

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

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

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

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

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

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

    CommonAttributes:
      type: object
      properties:
        schemas:
          type: array
          items:
            type: string
            enum:
              - urn:ietf:params:scim:schemas:core:2.0:EndpointApp
          description: The list of schemas that define the resource.
          nullable: false
        id:
          type: string
          format: uri
          description: The unique identifier for a resource.
          nullable: false
          readOnly: true
          writeOnly: false
        meta:
          type: object
          readOnly: true
          properties:
            resourceType:
              type: string
              description: The name of the resource type of the 
                           resource.
              nullable: false
              readOnly: true
              writeOnly: false
            location:
              type: string
              format: uri
              description: The URI of the resource being returned.
              nullable: false
              readOnly: true
              writeOnly: false
            created:
              type: string
              format: date-time
              description: The date and time the resource was added
                           to the service provider.
              nullable: false
              readOnly: true
              writeOnly: false
            lastModified:
              type: string
              format: date-time
              description: The most recent date and time that the 
                           details of this resource were updated at
                           the service provider.
              nullable: false
              readOnly: true
              writeOnly: false
            version:
              type: string
              description: The version of the resource. 
              nullable: true
              readOnly: true
              writeOnly: false
          additionalProperties: false
<CODE ENDS>
]]></artwork></figure>

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

<figure><artwork><![CDATA[
<CODE BEGINS>
components:
  schemas:
    BleDevice:
      type: object
      description: BLE Device schema.
      properties:
        schemas:
          type: array
          items:
            type: string
            enum:
              - urn:ietf:params:scim:schemas:extension:ble:2.0:Device
        urn:ietf:params:scim:schemas:extension:ble:2.0:Device:
          $ref: '#/components/schemas/BleDeviceExtension'
          required: true
    BleDeviceExtension:
      type: object
      properties:
        versionSupport:
          type: array
          items:
            type: string
          description: Provides a list of all the BLE versions 
                       supported by the device. For example, 
                       [4.1, 4.2, 5.0, 5.1, 5.2, 5.3].
          nullable: false
          readOnly: false
          writeOnly: false

        deviceMacAddress:
          type: string
          description: It is the public MAC address assigned by the 
                       manufacturer. It is unique 48 bit value. The
                       regex pattern is 
                       ^[0-9A-Fa-f]{2}(:[0-9A-Fa-f]{2}){5}.
          nullable: false
          readOnly: false
          writeOnly: false

        isRandom:
          type: boolean
          description: AddressType flag is taken from the BLE core 
                       specifications 5.3. If FALSE, the device is 
                       using public MAC address. If TRUE, device is 
                       using Random address which is resolved using
                       the IRK.
          nullable: false
          readOnly: false
          writeOnly: false
        
        separateBroadcastAddress:
          type: string
          description: "When present, this address is used for 
                        broadcasts/advertisements.  This value MUST NOT
                        be set when an IRK is provided.  Its form is 
                        the same as deviceMa`cAddress."
          nullable: false
          readOnly: false
          writeOnly: false

        irk:
          type: string
          description: Identity resolving key, which is unique for 
                       every device. It is used to resolve random 
                       address.
          nullable: true
          readOnly: false
          writeOnly: false
        mobility:
          type: boolean
          description: If set to True, the BLE device will 
                       automatically connect to the closest AP. For 
                       example, BLE device is connected with AP-1 and 
                       moves out of range but comes in range of AP-2, 
                       it will be disconnected with AP-1 and connects 
                       with AP-2.
          nullable: false
          readOnly: false
          writeOnly: false
        pairingMethods:
          type: array
          items:
            type: string
          description: List of pairing methods associated with the 
                       ble device, stored as schema URI.
          nullable: true
          readOnly: false
          writeOnly: false
        urn:ietf:params:scim:schemas:extension:pairingNull:2.0: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: true
          writeOnly: false
        
        telemetryEnterpriseEndpoint:
          type: string
          format: url
          description: The URL of the enterprise endpoint which 
                       telemetry apps use to reach enterprise network 
                       gateway.
          nullable: false
          readOnly: true
          writeOnly: false

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

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

</section>
</section>


  </back>

<!-- ##markdown-source:
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
gcOo8b0wo7wJIo14Tq4NyqoSjHuUWCHNGMYhYeeUy4YKFoGac3mROuGsfVVe
JzewmrhIeHKajsNYta9ClmTmBtoQoNMulG7AZMBJ9apuFabA0xGzkBYZhOQi
vZQ1nfKrvAinOUOkAEdFCQ0RDc4IMBQkGIcZTSggV0acCASqKPqunZEHFVSC
VIXQFqnQTwH5F8FMxIvJEUIvu8kVmmERkiWIAVJBaCbJYLJpgnZ4EZ1fgL5i
a41xcEV5llzzGIAV1HTKs0CXOR5Z5G/DcIbHn9/RgUYrpQAedkzG5cWyi9i9
wqJ483iMPv7salYIfdV+OQUU9+DJXpHOMGnn4e7xbgt+hSfPnuwz1uv1qB4O
Y3u0a5wLMA6CLEYl7SflKliQ8HM/CyYF761vDNDn9D84308v/oW/psj787RQ
+oZb7zX8F/PiunzxMIkwSwmwtGBKPF7IX9RmPRUZW63SVSLrqcskZOZY+IKm
Z/NshoHgfV+CMtWdm/O0krLMkzqVsXpwcWroRTjTqWZry6LWGI84B2GOJkWO
5zmVqUjSTgxBHfOkog0DeZGpxV8vVuqOOu6o3gIRPJByRV5CQYSnXsLc5B6u
ZDuzy2aLNoQp4GgeVucrZjtzP61zn/laWKtUCZCJ0KwXMPYSoRDrpHVDrY1u
ckX8XKJpVnfLZCar4kueW/MhbNXEZM6nZZYy3+uV5GW1Kct8b7fJZNbc+xJp
zXyNSLemnePMn+SsCQ927rOGjGe+JjyJ0GzAanmwzGorMKFISNZiwgphOeCw
JPq5snWKMizE5UGGjnxG3E3muAmIanCf783BNAWtaE4RTZEIrva1InUHfhUW
9bj71PmrdGmDup41o+VFo028NHLTaSaI4xcTuw00/wd87bv7Rrbfl4L9vsjO
Yhw0a/Re+aqW+e2kt7Nq2G9S+WzraoSK2cBBuIdXOIje+XRQok2PL5NfwMdk
dgSLfFUerSCKO1Xb2syaaHw9zG/q+Nn+LOThYCl4bFYs8ah3EqNVkwGTHbYZ
iztlkzK0TtU7oVjmajYtkKOOgSOU3puZexyjlILqWB1eb0Rl3UQQLxjjs8y/
Xmav4QRbgzHYhAbURa8aYwHRLz3kZ5nGsTYiEj/KpF5iwPUTohYVlnNRY2IY
Ioso78FtjVPWrlhhmGN4r4cViRcNFh8UewDwsDvmy0AubE2kl8HRaCTjiikN
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
+f8AkPGMVqRAAQA=

-->

</rfc>

