<?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.17 (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-06" 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>hassaniqbal931@gmail.com</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="August" day="12"/>

    
    
    <keyword>Internet-Draft</keyword>

    <abstract>


<?line 71?>

<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, FIDO
device onboarding vouchers, BLE passcodes, and MAC authenticated bypass.</t>



    </abstract>



  </front>

  <middle>


<?line 79?>

<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. The use of XML for this SCIM devices 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 specifciation 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>A new resource type 'Device' is specified. 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, and only one attribute is required. 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>displayName</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. It may be modified and SHOULD be returned 
by default. No uniqueness constraints are imposed on this attribute.</t>

<t>active</t>

<t>The "active" attribute is of type "boolean" and is a mutable
attribute, and is required. If set to TRUE, it means that this device
is intended to be operational. Attempts to control or access a device
where this value is set to FALSE may fail. For example, when used in
conjunction with NIPC <xref target="I-D.brinckman-nipc"/>, commands such as
connect, disconnect, subscribe that control app sends to the
controller for the devices any command coming from the control app for
the device will be rejected by the controller.</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>

<texttable title="Characteristics of device schema attributes. (Req = Required,
T = True, F = False, RW = ReadWrite, and Def = Default)" anchor="tabDevice">
      <ttcol align='left'>Attribute</ttcol>
      <ttcol align='left'>Multi Value</ttcol>
      <ttcol align='left'>Req</ttcol>
      <ttcol align='left'>Case Exact</ttcol>
      <ttcol align='left'>Mutable</ttcol>
      <ttcol align='left'>Return</ttcol>
      <ttcol align='left'>Unique</ttcol>
      <c>displayName</c>
      <c>F</c>
      <c>F</c>
      <c>F</c>
      <c>RW</c>
      <c>Def</c>
      <c>None</c>
      <c>active</c>
      <c>F</c>
      <c>T</c>
      <c>F</c>
      <c>RW</c>
      <c>Def</c>
      <c>None</c>
      <c>mudUrl</c>
      <c>F</c>
      <c>F</c>
      <c>T</c>
      <c>RW</c>
      <c>Def</c>
      <c>None</c>
</texttable>

<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",
        "displayName": "BLE Heart Monitor",
        "active": 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
client applications that can control and/or receive data from the
devices. The JSON schema for EndpointApp resource type is in <xref target="resource-schema"/>.</t>

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

<texttable title="Characteristics of EndpointApp schema attributes. (Req = Required,
T = True, F = False, R = ReadOnly, RW = ReadWrite, Manuf = Manufactirer
and Def = Default)" anchor="tabEndpointApp">
      <ttcol align='left'>Attribute</ttcol>
      <ttcol align='left'>Multi Value</ttcol>
      <ttcol align='left'>Req</ttcol>
      <ttcol align='left'>Case Exact</ttcol>
      <ttcol align='left'>Mutable</ttcol>
      <ttcol align='left'>Return</ttcol>
      <ttcol align='left'>Unique</ttcol>
      <c>applicationType</c>
      <c>F</c>
      <c>T</c>
      <c>F</c>
      <c>R</c>
      <c>Def</c>
      <c>None</c>
      <c>applicationName</c>
      <c>F</c>
      <c>T</c>
      <c>F</c>
      <c>RW</c>
      <c>Def</c>
      <c>None</c>
      <c>clientToken</c>
      <c>F</c>
      <c>T</c>
      <c>T</c>
      <c>R</c>
      <c>Def</c>
      <c>None</c>
      <c>certificateInfo</c>
      <c>F</c>
      <c>F</c>
      <c>F</c>
      <c>RW</c>
      <c>Def</c>
      <c>None</c>
      <c>rootCN</c>
      <c>F</c>
      <c>T</c>
      <c>T</c>
      <c>R</c>
      <c>Def</c>
      <c>None</c>
      <c>subjectName</c>
      <c>F</c>
      <c>F</c>
      <c>T</c>
      <c>R</c>
      <c>Def</c>
      <c>None</c>
      <c>subjectAltName</c>
      <c>T</c>
      <c>F</c>
      <c>T</c>
      <c>R</c>
      <c>Def</c>
      <c>None</c>
</texttable>

<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="extensions"><name>SCIM Device Extensions</name>

<t>SCIM provides various extension schemas, their attributes, JSON
representation, and example object. The core schema is extended with a
new resource type, as described in <xref target="resource-schema"/>.  No
schemaExtensions list is specified in that definition.  Instead, an
IANA registry is created, where all values for "required" are set to
false.  All extensions involving Devices MUST be registered via IANA,
as described in <xref target="device-schema-extensions"></xref>.  The schemas below demonstrate how
this model is to work.</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 
isRandom 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>

<texttable 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">
      <ttcol align='left'>Attribute</ttcol>
      <ttcol align='left'>Multi Value</ttcol>
      <ttcol align='left'>Req</ttcol>
      <ttcol align='left'>Case Exact</ttcol>
      <ttcol align='left'>Mutable</ttcol>
      <ttcol align='left'>Return</ttcol>
      <ttcol align='left'>Unique</ttcol>
      <c>deviceMacAddress</c>
      <c>F</c>
      <c>T</c>
      <c>F</c>
      <c>RW</c>
      <c>Def</c>
      <c>Manuf</c>
      <c>isRandom</c>
      <c>F</c>
      <c>T</c>
      <c>F</c>
      <c>RW</c>
      <c>Def</c>
      <c>None</c>
      <c>sepBroadcastAdd</c>
      <c>T</c>
      <c>T</c>
      <c>F</c>
      <c>RW</c>
      <c>Def</c>
      <c>None</c>
      <c>irk</c>
      <c>F</c>
      <c>F</c>
      <c>F</c>
      <c>RW</c>
      <c>Def</c>
      <c>Manuf</c>
      <c>versionSupport</c>
      <c>T</c>
      <c>T</c>
      <c>F</c>
      <c>RW</c>
      <c>Def</c>
      <c>None</c>
      <c>mobility</c>
      <c>F</c>
      <c>F</c>
      <c>F</c>
      <c>RW</c>
      <c>Def</c>
      <c>None</c>
      <c>pairingMethods</c>
      <c>T</c>
      <c>T</c>
      <c>T</c>
      <c>RW</c>
      <c>Def</c>
      <c>None</c>
</texttable>

<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",
  "displayName": "BLE Heart Monitor",
  "active": 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",
  "displayName": "BLE Heart Monitor",
  "active": 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",
  "displayName": "BLE Heart Monitor",
  "active": 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="easyconnect-extension"><name>EasyConnect Extension</name>

<t>A schema that extends the device schema to enable WiFi EasyConnect
(otherwise known as Device Provisioning Protocol or DPP). 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",
        "active": 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="ethernet-mab-extension"><name>Ethernet MAB Extension</name>

<t>This extension enables a legacy means of (very) weak authentication,
known as MAC Authenticated Bypass (MAB), that is supported in many wired
ethernet solutions. If the MAC address is known, then the device may
be permitted (perhaps limited) access. The extension is identified
by the following URI:</t>

<t>urn:ietf:params:scim:schemas:extension:ethernet-mab:2.0:Device</t>

<section anchor="single-attribute"><name>Single Attribute</name>

<t>This extension has a singular attribute:</t>

<t>deviceMacAddress</t>

<t>This is the Ethernet address to be provisioned onto the network. It
takes the identical form as found in both the BLE and DPP extensions.</t>

<texttable title="Characteristics of MAB extension schema attributes
(Req = Required, T = True, F = False, RW = ReadWrite, and 
Def = Default)" anchor="tabMAB">
      <ttcol align='left'>Attribute</ttcol>
      <ttcol align='left'>Multi Value</ttcol>
      <ttcol align='left'>Req</ttcol>
      <ttcol align='left'>Case Exact</ttcol>
      <ttcol align='left'>Mutable</ttcol>
      <ttcol align='left'>Return</ttcol>
      <ttcol align='left'>Unique</ttcol>
      <c>deviceMacAddress</c>
      <c>F</c>
      <c>T</c>
      <c>F</c>
      <c>RW</c>
      <c>Def</c>
      <c>None</c>
</texttable>

<t>An example of a device object with EthernetMAB 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:ethernet-mab:2.0
        :Device"],

  "id": "e9e30dba-f08f-4109-8486-d5c6a3316111",
  "displayName": "Some random Ethernet Device",
  "active": true,
  "urn:ietf:params:scim:schemas:extension:ethernet-mab:2.0:Device" 
     : {
    "deviceMacAddress": "2C:54:91:88:C9:E2"
  },

  "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 EthernetMAB extension is presented in JSON format in
Section <xref target="ethernet-mab-extension-schema-json"></xref>, while the openAPI
representation is provided in Section <xref target="ethernet-mab-extension-schema-openapi-representation"></xref>.</t>

</section>
</section>
<section anchor="fido-device-onboarding-extension"><name>Fido Device Onboarding Extension</name>

<t>This extension specifies a voucher to be used by a Fido Device Onboarding
(FDO) owner process <xref target="FDO11"/>, so that a trusted introduction can be made using that mechanism.</t>

<t>urn:ietf:params:scim:schemas:extension:fido-device-onboard:2.0:Device</t>

<section anchor="single-attribute-1"><name>Single Attribute</name>

<t>This extension has a singular attribute:</t>

<t>fdoVoucher</t>

<t>The voucher is formated as a PEM-encoded object in accordance with the FDO
specification (citation needed).</t>

<texttable title="Characteristics of FDO extension schema attributes
(Req = Required, T = True, F = False, RW = ReadWrite, and 
Def = Default)" anchor="tabFDO">
      <ttcol align='left'>Attribute</ttcol>
      <ttcol align='left'>Multi Value</ttcol>
      <ttcol align='left'>Req</ttcol>
      <ttcol align='left'>Case Exact</ttcol>
      <ttcol align='left'>Mutable</ttcol>
      <ttcol align='left'>Return</ttcol>
      <ttcol align='left'>Unique</ttcol>
      <c>fdoVoucher</c>
      <c>F</c>
      <c>T</c>
      <c>F</c>
      <c>RW</c>
      <c>Def</c>
      <c>None</c>
</texttable>

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

<figure><artwork><![CDATA[
<CODE BEGINS>
{
  "schemas": ["urn:ietf:params:scim:schemas:core:2.0:Devices",
     "urn:ietf:params:scim:schemas:extension:fido-device-onboard
        :2.0:Devices"],

  "id": "e9e30dba-f08f-4109-8486-d5c6a3316111",
  "displayName": "Some random Ethernet Device",
  "active": true,
  "urn:ietf:params:scim:schemas:extension:fido-device-onboard:2.0
     :Devices" : {
     "fdoVoucher": "{... voucher ...}"
  },

  "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 FDO extension is presented in JSON format in
Section <xref target="fdo-extension-schema-json"></xref>, while the openAPI
representation is provided in Section <xref target="fdo-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]{2}(:[0-9A-Fa-f]{2}){7}$
]]></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>

<texttable title="Characteristics of Zigbee extension schema attributes.
(Req = Required, T = True, F = False, RW = ReadWrite, and 
Def = Default)" anchor="tabZigbee">
      <ttcol align='left'>Attribute</ttcol>
      <ttcol align='left'>Multi Value</ttcol>
      <ttcol align='left'>Req</ttcol>
      <ttcol align='left'>Case Exact</ttcol>
      <ttcol align='left'>Mutable</ttcol>
      <ttcol align='left'>Return</ttcol>
      <ttcol align='left'>Unique</ttcol>
      <c>deviceEui64Address</c>
      <c>F</c>
      <c>T</c>
      <c>F</c>
      <c>RW</c>
      <c>Def</c>
      <c>None</c>
      <c>versionSupport</c>
      <c>T</c>
      <c>T</c>
      <c>F</c>
      <c>RW</c>
      <c>Def</c>
      <c>None</c>
</texttable>

<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",
  "active": true,
  "urn:ietf:params:scim:schemas:extension:zigbee:2.0:Device" : {
    "versionSupport": ["3.0"],
    "deviceEui64Address": "50:32:5F:FF:FE:E7:67:28"
  },

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

<texttable 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">
      <ttcol align='left'>Attribute</ttcol>
      <ttcol align='left'>Multi Value</ttcol>
      <ttcol align='left'>Req</ttcol>
      <ttcol align='left'>Case Exact</ttcol>
      <ttcol align='left'>Mutable</ttcol>
      <ttcol align='left'>Return</ttcol>
      <ttcol align='left'>Unique</ttcol>
      <c>devContEntEndpoint</c>
      <c>F</c>
      <c>T</c>
      <c>T</c>
      <c>R</c>
      <c>Def</c>
      <c>Ent</c>
      <c>telEntEndpoint</c>
      <c>F</c>
      <c>T</c>
      <c>T</c>
      <c>R</c>
      <c>Def</c>
      <c>Ent</c>
      <c>applications</c>
      <c>T</c>
      <c>T</c>
      <c>F</c>
      <c>RW</c>
      <c>Def</c>
      <c>None</c>
      <c>value</c>
      <c>F</c>
      <c>T</c>
      <c>F</c>
      <c>R</c>
      <c>Def</c>
      <c>None</c>
      <c>$ref</c>
      <c>F</c>
      <c>T</c>
      <c>F</c>
      <c>R</c>
      <c>Def</c>
      <c>None</c>
</texttable>

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

<figure><artwork><![CDATA[
<CODE BEGINS>
{
  "schemas": ["urn:ietf:params:scim:schemas:core:2.0:Device",
     "urn:ietf:params:scim:schemas:extension:ble:2.0:Device",
     "urn:ietf:params:scim:schemas:extension:endpointAppsExt:2.0
        :Device"],
  "id": "e9e30dba-f08f-4109-8486-d5c6a3316111",
  "displayName": "BLE Heart Monitor",
  "active": 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": "/Devices",
    "description": "Device Account",
    "schema": "urn:ietf:params:scim:schemas:core:2.0:Device",
    "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": "displayName",
      "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": "active",
      "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="ethernet-mab-extension-schema-json"><name>Ethernet MAB Extension Schema JSON</name>
<figure><artwork><![CDATA[
<CODE BEGINS>
{
  "id": "urn:ietf:params:scim:schemas:extension:ethernet-mab:2.0
     :Device",
  "name": "ethernetMabExtension",
  "description": "Device extension schema for MAC authentication
      Bypass.",
  "attributes" : [
      {
        "name": "deviceMacAddress",
        "type": "string",
        "description": "A 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"
      }
  ],
  "meta" : {
    "resourceType" : "Schema",
    "location" : "/v2/Schemas/urn:ietf:params:scim:schemas
       :extension:ethernet-mab:2.0:Device"
  }
}
<CODE ENDS>
]]></artwork></figure>

</section>
<section anchor="fdo-extension-schema-json"><name>FDO Extension Schema JSON</name>
<figure><artwork><![CDATA[
<CODE BEGINS>
{
  "id": "urn:ietf:params:scim:schemas:extension:fido-device-onboard
     :2.0:Devices",
  "name": "FDOExtension",
  "description": "Device extension schema for Fido Device Onboard.",
  "attributes" : [
      {
        "name": "fdoVoucher",
        "type": "string",
        "description": "A Fido Voucher as Defined in the FDO
            specification"
        "multivalues": false,
        "required": true,
        "caseExact": false,
        "mutability": "readWrite",
        "returned": "default",
        "uniqueness": "Manufacturer"
      }
  ],
  "meta" : {
    "resourceType" : "Schema",
    "location" : "/v2/Schemas/urn:ietf:params:scim:schemas
       :extension:fido-device-onboard:2.0:Devices"
  }
}
<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 anchor="representation-of-schema"><name>Representation of Schema</name>

<t>The following is the JSON representation of the Schema. Implementors MUST NOT vary from the schema definitions in their implementations.  They may choose not to implement a particular extension, but if they do, they MUST implement all mandatory elements, and they must implement optional elements as specified.</t>

<figure><artwork><![CDATA[
<CODE BEGINS>
{
  "id" : "urn:ietf:params:scim:schemas:core:2.0:Schema",
  "name" : "Schema",
  "description" : "Specifies the schema that describes a SCIM
      schema",
  "attributes" : [
    {
      "name" : "id",
      "type" : "string",
      "multiValued" : false,
      "description" : "The unique URI of the schema. When
          applicable, service providers MUST specify the URI.",
      "required" : true,
      "caseExact" : false,
      "mutability" : "readOnly",
      "returned" : "default",
      "uniqueness" : "none"
    },
    {
      "name" : "name",
      "type" : "string",
      "multiValued" : false,
      "description" : "The schema's human-readable name.  When
          applicable, service providers MUST specify the name,
          e.g., 'Device'.",
      "required" : true,
      "caseExact" : false,
      "mutability" : "readOnly",
      "returned" : "default",
      "uniqueness" : "none"
    },
    {
      "name" : "description",
      "type" : "string",
      "multiValued" : false,
      "description" : "Human-readable description of the schema,
          e.g., 'Device account'.",
      "required" : false,
      "caseExact" : false,
      "mutability" : "readOnly",
      "returned" : "default",
      "uniqueness" : "none"
    },
    {
      "name" : "attributes",
      "type" : "complex",
      "multiValued" : true,
      "description" : "A complex attribute that includes the
          attributes of a schema.",
      "required" : true,
      "mutability" : "readOnly",
      "returned" : "default",
      "subAttributes" : [
        {
          "name" : "name",
          "type" : "string",
          "multiValued" : false,
          "description" : "The attribute's name, e.g.,
              'displayName'.",
          "required" : true,
          "caseExact" : true,
          "mutability" : "readOnly",
          "returned" : "default",
          "uniqueness" : "none"
        },
        {
          "name" : "type",
          "type" : "string",
          "multiValued" : false,
          "description" : "The attribute's data type. Valid values
              include 'string', 'complex', 'boolean', 'decimal',
              'integer', 'dateTime', 'reference'.",
          "required" : true,
          "caseExact" : false,
          "mutability" : "readOnly",
          "returned" : "default",
          "uniqueness" : "none",
          "canonicalValues" : [
            "string",
            "complex",
            "boolean",
            "decimal",
            "integer",
            "dateTime",
            "reference"
          ]
        },
        {
          "name" : "multiValued",
          "type" : "boolean",
          "multiValued" : false,
          "description" : "A Boolean value indicating an
              attribute's plurality.",
          "required" : true,
          "mutability" : "readOnly",
          "returned" : "default"
        },
        {
          "name" : "description",
          "type" : "string",
          "multiValued" : false,
          "description" : "A human-readable description of the
              attribute.",
          "required" : true,
          "caseExact" : false,
          "mutability" : "readOnly",
          "returned" : "default",
          "uniqueness" : "none"
        },
        {
          "name" : "required",
          "type" : "boolean",
          "multiValued" : false,
          "description" : "A boolean value indicating whether or
            not the attribute is required.",
          "required" : true,
          "mutability" : "readOnly",
          "returned" : "default"
        },
        {
          "name" : "canonicalValues",
          "type" : "string",
          "multiValued" : true,
          "description" : "A collection of canonical values.  When
              applicable, service providers MUST specify the
              canonical types, e.g., mutability of an attribute,
              return type, uniqueness.",
          "required" : false,
          "caseExact" : true,
          "mutability" : "readOnly",
          "returned" : "default",
          "uniqueness" : "none"
        },
        {
          "name" : "caseExact",
          "type" : "boolean",
          "multiValued" : false,
          "description" : "A Boolean value indicating whether or
              not a string attribute is case sensitive.",
          "required" : false,
          "mutability" : "readOnly",
          "returned" : "default"
        },
         {
          "name" : "mutability",
          "type" : "string",
          "multiValued" : false,
          "description" : "Indicates whether or not an attribute is
              modifiable.",
          "required" : false,
          "caseExact" : true,
          "mutability" : "readOnly",
          "returned" : "default",
          "uniqueness" : "none",
          "canonicalValues" : [
            "readOnly",
            "readWrite",
            "immutable",
            "writeOnly"
          ]
        },
        {
          "name" : "returned",
          "type" : "string",
          "multiValued" : false,
          "description" : "Indicates when an attribute is returned
              in a response (e.g., to a query).",
          "required" : false,
          "caseExact" : true,
          "mutability" : "readOnly",
          "returned" : "default",
          "uniqueness" : "none",
          "canonicalValues" : [
            "always",
            "never",
            "default",
            "request"
          ]
        },
        {
          "name" : "uniqueness",
          "type" : "string",
          "multiValued" : false,
          "description" : "Indicates how unique a value must be.",
          "required" : false,
          "caseExact" : true,
          "mutability" : "readOnly",
          "returned" : "default",
          "uniqueness" : "none",
          "canonicalValues" : [
            "none",
            "Enterprise",
            "Manufacturer"
          ]
        },
        {
          "name" : "referenceTypes",
          "type" : "string",
          "multiValued" : false,
          "description" : "Used only with an attribute of type
              'reference'.  Specifies a SCIM resourceType that a
              reference attribute MAY refer to, e.g.,
              'EndpointApp'.",
          "required" : false,
          "caseExact" : true,
          "mutability" : "readOnly",
          "returned" : "default",
          "uniqueness" : "none"
        },
        {
          "name" : "subAttributes",
          "type" : "complex",
          "multiValued" : true,
          "description" : "Used to define the sub-attributes of a
              complex attribute.",
          "required" : false,
          "mutability" : "readOnly",
          "returned" : "default",
          "subAttributes" : [
            {
              "name" : "name",
              "type" : "string",
              "multiValued" : false,
              "description" : "The attribute's name.",
              "required" : true,
              "caseExact" : true,
              "mutability" : "readOnly",
              "returned" : "default",
              "uniqueness" : "none"
            },
            {
              "name" : "type",
              "type" : "string",
              "multiValued" : false,
              "description" : "The attribute's data type. Valid
                  values include 'string', 'complex', 'boolean',
                  'decimal', 'integer', 'dateTime', 'reference'.",
              "required" : true,
              "caseExact" : false,
              "mutability" : "readOnly",
              "returned" : "default",
              "uniqueness" : "none",
              "canonicalValues" : [
                "string",
                "complex",
                "boolean",
                "decimal",
                "integer",
                "dateTime",
                "reference"
              ]
            },
            {
              "name" : "multiValued",
              "type" : "boolean",
              "multiValued" : false,
              "description" : "A Boolean value indicating an
                  attribute's plurality.",
              "required" : true,
              "mutability" : "readOnly",
              "returned" : "default"
            },
            {
              "name" : "description",
              "type" : "string",
              "multiValued" : false,
              "description" : "A human-readable description of the
                  attribute.",
              "required" : true,
              "caseExact" : false,
              "mutability" : "readOnly",
              "returned" : "default",
              "uniqueness" : "none"
            },
            {
              "name" : "required",
              "type" : "boolean",
              "multiValued" : false,
              "description" : "A boolean value indicating whether
                  or not the attribute is required.",
              "required" : true,
              "mutability" : "readOnly",
              "returned" : "default"
            },
            {
              "name" : "canonicalValues",
              "type" : "string",
              "multiValued" : true,
              "description" : "A collection of canonical values. 
                  When applicable, service providers MUST specify
                  the canonical types, e.g., mutability of an
                  attribute, return type, uniqueness.",
              "required" : false,
              "caseExact" : true,
              "mutability" : "readOnly",
              "returned" : "default",
              "uniqueness" : "none"
            },
            {
              "name" : "caseExact",
              "type" : "boolean",
              "multiValued" : false,
              "description" : "A Boolean value indicating whether
                  or not a string attribute is case sensitive.",
              "required" : false,
              "mutability" : "readOnly",
              "returned" : "default"
            },
            {
              "name" : "mutability",
              "type" : "string",
              "multiValued" : false,
              "description" : "Indicates whether or not an
                  attribute is modifiable.",
              "required" : false,
              "caseExact" : true,
              "mutability" : "readOnly",
              "returned" : "default",
              "uniqueness" : "none",
              "canonicalValues" : [
                "readOnly",
                "readWrite",
                "immutable",
                "writeOnly"
              ]
            },
            {
              "name" : "returned",
              "type" : "string",
              "multiValued" : false,
              "description" : "Indicates when an attribute is
                  returned in a response (e.g., to a query).",
              "required" : false,
              "caseExact" : true,
              "mutability" : "readOnly",
              "returned" : "default",
              "uniqueness" : "none",
              "canonicalValues" : [
                "always",
                "never",
                "default",
                "request"
              ]
            },
            {
              "name" : "uniqueness",
              "type" : "string",
              "multiValued" : false,
              "description" : "Indicates how unique a value must
                  be.",
              "required" : false,
              "caseExact" : true,
              "mutability" : "readOnly",
              "returned" : "default",
              "uniqueness" : "none",
              "canonicalValues" : [
                "none",
                "Enterprise",
                "Manufacturer"
              ]
            },
            {
              "name" : "referenceTypes",
              "type" : "string",
              "multiValued" : false,
              "description" : "Used only with an attribute of type
                  'reference'.  Specifies a SCIM resourceType that
                  a reference attribute MAY refer to, e.g.,
                  'EndpointApp'.",
              "required" : false,
              "caseExact" : true,
              "mutability" : "readOnly",
              "returned" : "default",
              "uniqueness" : "none"
            }
          ]
        }
      ]
    }
  ]
}
<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>

<section anchor="new-schemas"><name>New Schemas</name>

<t>The IANA is requested to add the following additions to the "SCIM
Schema URIs for Data Resources" registry as follows:</t>

<texttable>
      <ttcol align='left'>URN</ttcol>
      <ttcol align='left'>Name</ttcol>
      <ttcol align='left'>Reference</ttcol>
      <c>urn:ietf:params:scim:schemas:core: 2.0:Device</c>
      <c>Core Device Schema</c>
      <c>This memo, <xref target="scim-core-device-schema"></xref></c>
      <c>urn:ietf:params:scim:schemas:core: 2.0:EndpointApp</c>
      <c>Endpoint Application</c>
      <c>This memo, <xref target="endpointapp-schema"/></c>
</texttable>

<t>Note that the line break in URNs should be removed, as should this comment.</t>

</section>
<section anchor="device-schema-extensions"><name>Device Schema Extensions</name>

<t>IANA is requested to create a separate table for Device Schema Extensions,
as described in <xref target="extensions"/>, with the following columns:</t>

<t><list style="symbols">
  <t>schemaExtensionURI</t>
  <t>Short Description</t>
  <t>Reference</t>
</list></t>

<t>The policy for entries into this table shall be both "Expert Review"
and "Specification Required", as specified in <xref target="RFC8126"/>.  Reviewers
shall check that each schema is produced in the format described in
<xref target="RFC7643"/>, and that the semantics of the schema are clear and
unambiguous.  It is also RECOMMENDED that schemas be made available in
OpenAPI.</t>

<t>The initial table entries shall be as follows:</t>

<texttable>
      <ttcol align='left'>URN</ttcol>
      <ttcol align='left'>Description</ttcol>
      <ttcol align='left'>Reference</ttcol>
      <c>urn:ietf:params:scim:schemas:extension: ble:2.0:Device</c>
      <c>BLE Extension</c>
      <c>This memo, <xref target="ble-extension"></xref></c>
      <c>urn:ietf:params:scim:schemas:extension: ethernet-mab:2.0:Device</c>
      <c>Ethernet MAB</c>
      <c>This memo, <xref target="ethernet-mab-extension"></xref></c>
      <c>urn:ietf:params:scim:schemas:extension: fido-device-onboard:2.0:Device</c>
      <c>Fido Device Onboard</c>
      <c>This memo, <xref target="fido-device-onboarding-extension"></xref></c>
      <c>urn:ietf:params:scim:schemas:extension: dpp:2.0:Device</c>
      <c>Wifi EasyConnect</c>
      <c>This memo, <xref target="easyconnect-extension"></xref></c>
      <c>urn:ietf:params:scim:schemas:extension: endpointAppsExt:2.0:Device</c>
      <c>Application Endpoint Extension</c>
      <c>This memo, <xref target="ble-pairing-method-extensions"></xref></c>
      <c>urn:ietf:params:scim:schemas:extension: pairingJustWorks:2.0:Device</c>
      <c>Just Works Auth BLE</c>
      <c>This memo, <xref target="ble-pairing-method-extensions"></xref></c>
      <c>urn:ietf:params:scim:schemas:extension: pairingOOB:2.0:Device</c>
      <c>Out of Band Pairing for BLE</c>
      <c>This memo, <xref target="ble-pairing-method-extensions"></xref></c>
      <c>urn:ietf:params:scim:schemas:extension: pairingPassKey:2.0:Device</c>
      <c>Passkey Pairing for BLE</c>
      <c>This memo, <xref target="ble-pairing-method-extensions"></xref></c>
</texttable>

</section>
</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="FDO11" >
  <front>
    <title>FIDO Device Onboading Specification 1.1</title>
    <author >
      <organization>FIDO Alliance</organization>
    </author>
    <date year="2022" month="April"/>
  </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>

<reference anchor="RFC8126">
  <front>
    <title>Guidelines for Writing an IANA Considerations Section in RFCs</title>
    <author fullname="M. Cotton" initials="M." surname="Cotton"/>
    <author fullname="B. Leiba" initials="B." surname="Leiba"/>
    <author fullname="T. Narten" initials="T." surname="Narten"/>
    <date month="June" year="2017"/>
    <abstract>
      <t>Many protocols make use of points of extensibility that use constants to identify various protocol parameters. To ensure that the values in these fields do not have conflicting uses and to promote interoperability, their allocations are often coordinated by a central record keeper. For IETF protocols, that role is filled by the Internet Assigned Numbers Authority (IANA).</t>
      <t>To make assignments in a given registry prudently, guidance describing the conditions under which new values should be assigned, as well as when and how modifications to existing values can be made, is needed. This document defines a framework for the documentation of these guidelines by specification authors, in order to assure that the provided guidance for the IANA Considerations is clear and addresses the various issues that are likely in the operation of a registry.</t>
      <t>This is the third edition of this document; it obsoletes RFC 5226.</t>
    </abstract>
  </front>
  <seriesInfo name="BCP" value="26"/>
  <seriesInfo name="RFC" value="8126"/>
  <seriesInfo name="DOI" value="10.17487/RFC8126"/>
</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>


<reference anchor="I-D.brinckman-nipc">
   <front>
      <title>An Application Layer Interface for Non-IP device control (NIPC)</title>
      <author fullname="Bart Brinckman" initials="B." surname="Brinckman">
         <organization>Cisco Systems</organization>
      </author>
      <author fullname="Rohit Mohan" initials="R." surname="Mohan">
         <organization>Cisco Systems</organization>
      </author>
      <author fullname="Braeden Sanford" initials="B." surname="Sanford">
         <organization>Philips</organization>
      </author>
      <date day="21" month="April" year="2024"/>
      <abstract>
	 <t>   This memo specifies RESTful application layer interface for gateways
   providing operations against non-IP devices.  The described interface
   is extensible.  This memo initially describes Bluetooth Low Energy
   and Zigbee as they are the most commonly deployed.

	 </t>
      </abstract>
   </front>
   <seriesInfo name="Internet-Draft" value="draft-brinckman-nipc-01"/>
   
</reference>




    </references>


<?line 2375?>

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

<t>Draft -03:
  * Add MAB, FDO
  * Some grammar improvements
  * fold OpenAPI
  * IANA considerations</t>

<t>Draft -02:
  *  Clean up examples
  *  Move openapi to appendix
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:
        displayName:
          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
        active:
          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:
        - active
      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

    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="ethernet-mab-extension-schema-openapi-representation"><name>Ethernet MAB Extension Schema OpenAPI Representation</name>
<t>OpenAPI representation of Ethernet MAB extension schema is as follows:</t>

<figure><artwork><![CDATA[
<CODE BEGINS>
components:
  schemas:
    EthernetMABDevice:
      type: object
      description: Ethernet MAC Authenticated Bypass
      properties:
        schemas:
          type: array
          items:
            type: string
            enum:
              - urn:ietf:params:scim:schemas:extension:ethernet-mab
                 :2.0:Device
        urn:ietf:params:scim:schemas:extension:ethernet-mab:2.0
           :Device:
          $ref: '#/components/schemas/EthernetMABDeviceExtension'
          required: true
    EthernetMABDeviceExtension:
      type: object
      properties:
        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
      required:
        - deviceMacAddress
      description: Device extension schema for Ethernet-MAB
<CODE ENDS>
]]></artwork></figure>

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

<figure><artwork><![CDATA[
<CODE BEGINS>
components:
  schemas:
    FDODevice:
      type: object
      description: Fido Device Onboarding Voucher Extension
      properties:
        schemas:
          type: array
          items:
            type: string
            enum:
              - urn:ietf:params:scim:schemas:extension:ethernet-mab
                 :2.0:Devices
        urn:ietf:params:scim:schemas:extension:ethernet-mab:2.0
           :Devices:
          $ref: '#/components/schemas/FDODeviceExtension'
          required: true
    FDODeviceExtension:
      type: object
      properties:
        fdoVoucher:
          type: string
          description: A Fido Device Onboarding Voucher
          nullable: false
          readOnly: false
          writeOnly: false
      required:
        - fdoVoucher
      description: Device Extension for a Fido Device Onboarding
          Voucher
<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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
v+Ul8xZyjhV3TYy6Ah9hmlITJ2tZR/EbdZ5AnuU+qVcstqKxPCE3DsXG6Ois
5TUPABSI1gp1e8OaSUW/dCKB5qp6zaLzjf994393w/9cFXdB3ldoRGVTFkW2
twJaLNAjaXyg0aRhALrqEaiq0IDhbKhasvYGn2xuPX70ZPfxxtbOxu7jJ99Y
5jwsUyW0NfIWRpSRBRITWSI7isneU+A2Qkn4tg9zyQqMEhq6oWunFHmCTR+0
S0cxLsZ2FD932ak2IVvjJYsVSYg9dL2TPJkETrQFyXY9k0j4G6v8xirvSVS0
QqcX4ph22PFnEj+/MfzfD8OvdFQs6dUzuCoKD4/ggD8Y3zHbX3HtFu6KtQ1X
uyyusd+ZlePf9j9D3xHpY0Z1Bppc0OQB9ZvwyCkZ4D0guf46zAITUSW9I8/s
RPE6GTdmKjs7Wyu4q3l3c7g4GI+bvNVU/G/hSHSQjHN1CvDhA5bJ4NPeQBQD
iR0jS4Ov23gsK2dwGjRpUXc93BjwkkLQzgMdO2vB+wmaqhpC4vg4wnFim+U0
XedaB35T8sTTQ6QA9ijClJ799v4kBVHoIBzCiv3vf//PsyCKMAD1weH+wbM1
5VHmkQKIoOvBuHa3AY8wI/JABlbyMflZe3NntwX/2Xq8zaM8a+9sbhCEvcfr
LfFkl29vbK4LE5/ZGBoo3GDf1nRPsyqXRMr+Y5njpMMhL5XtiJiBPMEZfRhy
xvdQRsIWfA/r0w9VreAMbnLGAdHyP6w7HpzJ9xC969LQj3hvYT+aaAxC72QE
9/uCn8qksK0SBFrkKEMybi9QxQPwwNItn2HFos4AFa8esWsSITX5QTkjYQnH
DkvVXkM8ITIjKycodxLao0TVVhBeorIyUDorE6ru+D/97Zefzlt4loieTuXJ
e004McPk+7A1Z/uwYnEQVeUQ8OPKOV5w/IXMdYax19gOc48+tyYyoEJe7Ybl
ZFDyDXZLEjymh7KZEjhWH2883FhtrW5s7Dzc2l2tAIs3hVRmAAvi9vdV/vnf
63+/t284v8yPQo4teX0kZPt4HvxDHkZOya0lKq6PdKaJjz6qs0z9qPxjSXMx
e5TdGR0HvZrtSKgyTff3+t/v7RvOL/MDxmHvRFXjmH4etJxxFDcDaxxHsx0c
LmccNhMuwKN5HHe1LoZZqjO6ex2HzdQMPO57HCrTPGZkQzGt9twRnzafOxYP
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
2ghtz6veG/8/9L96EyORAQA=

-->

</rfc>

