<?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.6 (Ruby 3.3.0) -->


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

]>


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

    <author initials="M." surname="Shahzad" fullname="Muhammad Shahzad">
      <organization>North Carolina State University</organization>
      <address>
        <postal>
          <street>Department of Computer Science</street> <street>890 Oval Drive</street> <street>Campus Box 8206</street>
          <city>Raleigh, NC</city>
          <code>27695-8206</code>
          <country>USA</country>
        </postal>
        <email>mshahza@ncsu.edu</email>
      </address>
    </author>
    <author initials="H." surname="Iqbal" fullname="Hassan Iqbal">
      <organization>North Carolina State University</organization>
      <address>
        <postal>
          <street>Department of Computer Science</street> <street>890 Oval Drive</street> <street>Campus Box 8206</street>
          <city>Raleigh, NC</city>
          <code>27695-8206</code>
          <country>USA</country>
        </postal>
        <email>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="May" day="20"/>

    
    
    <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 
addressType is TRUE. It is mutable and return by default.</t>

<t>mobility</t>

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

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

<t>versionSupport</t>

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

<t>pairingMethods</t>

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

<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]{16}$
]]></artwork></figure>

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

<t>versionSupport</t>

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

<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": "50325FFFFEE76728"
  },

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

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

</section>
</section>
<section anchor="endpointsappext-schema"><name>The Endpoint Applications Extension Schema</name>

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

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

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

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

<t>deviceControlEnterpriseEndpoint</t>

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

<t>telemetryEnterpriseEndpoint</t>

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

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

<t>applications</t>

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

<t>value</t>

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

<t>$ref</t>

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

<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
      properties:
        id:
          type: string
          description: The id of the null pairing schema.
          nullable: false
          readOnly: true
          writeOnly: false

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

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

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

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

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

</section>
<section anchor="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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
zyXV2atEm3IOCmVJqDlr3eqsV5+zNiYBmuFA8XOTMsp4ZeexfNDwrmLQmxvY
NY/AI1e9XuaRLzQdtjy43FMa02dpGShxxCWJOHL2y3S6LQ+10e8WSL7gd2tT
BY5xZ31rc+c5XIeH3+1+t/nkq7CzuLBThe1N5ntH4OGVncOCP4fQU9d2g9yD
gs+5VfkDE5qawipaFioXRSmUUvE8FPTzcETZOuxi3jqXANfbZAEHDb4ATQlJ
ndrDqfetK31TxeCh36ckWSM/pnLZ0GuH09ly2tJMJzDzVClq8nm062pzmlRx
dNpGL72ByXDhFYrGuIVGKfdjqVqHlVvLC7imMXqHykFLKa/QrJK+qvNQ0ek2
1iipyAkxo9To3c2PtDDeSuNIyevTcxLnHmpQKJTSVaGsUomUgY0XCIsayiTK
Fhh1oR9K0ub3uY57FZzfqNMa66GqpFLMjky+rtSSVZ0chkOpykDIzEReKM6R
0BMqnoyyP/zR8/vvMPMUlXoaA5UEKneF22ZzTYeC2+Z08Ytrtpt6I2EGWAc8
pm9iagwAAKN1LYuqBTm3C118XYv7XosmpcAuZGWO3kzp5UpW0SnlUiEehcpm
dYUsTijjECrnBVOIILNvQWuYqzb2NN8zhcWRMzlO5ZjHBgG8QsPjYj0rf0yD
4QompKGbtp+p5lepwbHyWB1L6evXRwd0nIjypEwzWZUMDLoFGU41a8qpBXa1
LE+lY1Op5Os1xQYlCOfnlHUJhkEaxH2NeVY+OTv/sx6UxH5P6rJ2CvcsSK9M
RtfagephNqTN/Ax1NcS7Q/yfXPSCslZbegC+EUtV1gDp7XHI7j7NWBwq1cby
+TTHpSmxhCDOVadQF+Gy9LEgmYk7jqVcqoKEsJnKVdCbJR3bswWygzJK2yzZ
iHVT5CPFiGsaatrJy2lZqjV9r7mGBmL1n4Rpvqoe7qwOlkWRd15ny08VfDuv
l0FZUq5yNPgazvuA4bx2V+V43kWDcFXGzqoo3IUje3UWTKfVZcQMV4T4LmXE
S49FLmRC1X6UpvLI4lCtCnAuxTdjN3eIbv6/EEs9j9dSHUO04c8zt2UeizIt
V3upUMxT0Ud+SeqHuEPxF7waCsBYK7joiLe2th5kxNiPGjH912XltfKIhVw8
JhiS0WZxVNzA36U95++wnn9Xy/9YbQENUsv0DvTHhbYlVn61Wi9gta4XzPwo
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

-->

</rfc>

