<?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-03" 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="March" day="04"/>

    
    
    <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>deviceDisplayName</t>

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

<t>adminState</t>

<t>The "adminState" attribute is of type "boolean" and is a mutable
attribute, 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>deviceDisplayName</c>
      <c>F</c>
      <c>F</c>
      <c>F</c>
      <c>RW</c>
      <c>Def</c>
      <c>None</c>
      <c>adminState</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",
        "deviceDisplayName": "BLE Heart Monitor",
        "adminState": true,
        "meta": {
          "resourceType": "Device",
      "created": "2022-01-23T04:56:22Z",
          "lastModified": "2022-05-13T04:42:34Z",
          "version": "W\/\"a330bc54f0671c9\"",
          "location": "https://example.com/v2/Device/e9e30dba-f08f
             -4109-8486-d5c6a3316111"
        }
}
<CODE ENDS>
]]></artwork></figure>

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

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

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

</section>
<section anchor="resource-type-endpointapp"><name>Resource Type EndpointApp</name>

<t>This section defines a new resource type, 'EndpointApp'. The 
"ResourceType" schema specifies the metadata about a resource type 
(see section 6 of <xref target="RFC7643"/>). The resource "EndpointApp" represents
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="scim-device-extensions"><name>SCIM Device Extensions</name>

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

<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",
  "deviceDisplayName": "BLE Heart Monitor",
  "adminState": true,
  "urn:ietf:params:scim:schemas:extension:ble:2.0:Device" : {
    "versionSupport": ["5.3"],
    "deviceMacAddress": "2C:54:91:88:C9:E2",
    "isRandom": false,
    "separateBroadcastAddress": ["AA:BB:88:77:22:11", "AA:BB:88:77
       :22:12"],
    "mobility": true,
    "pairingMethods": ["urn:ietf:params:scim:schemas:extension
       :pairingPassKey:2.0:Device"],
    "urn:ietf:params:scim:schemas:extension:pairingPassKey:2.0
       :Device" : {
      "key": 123456
    }
  },
  "meta": {
    "resourceType": "Device",
      "created": "2022-01-23T04:56:22Z",
    "lastModified": "2022-05-13T04:42:34Z",
    "version": "W\/\"a330bc54f0671c9\"",
    "location": "https://example.com/v2/Device/e9e30dba-f08f-4109
       -8486-d5c6a3316111"
  }
}
<CODE ENDS>
]]></artwork></figure>

<t>In the above example, the pairing method is "pairingPassKey", which implies
that this BLE device pairs using only a passkey. In another example below,
the pairing method is "pairingOOB," implying that this BLE device uses the
out-of-band pairing method.</t>

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

  "id": "e9e30dba-f08f-4109-8486-d5c6a3316111",
  "deviceDisplayName": "BLE Heart Monitor",
  "adminState": true,
  "urn:ietf:params:scim:schemas:extension:ble:2.0:Device" : {
    "versionSupport": ["5.3"],
    "deviceMacAddress": "2C:54:91:88:C9:E2",
    "isRandom": false,
    "separateBroadcastAddress": ["AA:BB:88:77:22:11", "AA:BB:88:77
       :22:12"],
    "mobility": true,
    "pairingMethods": ["urn:ietf:params:scim:schemas:extension
       :pairingOOB:2.0:Device"],
    "urn:ietf:params:scim:schemas:extension:pairingOOB:2.0:Device":
        {
      "key": "TheKeyvalueRetrievedFromOOB",
      "randNumber": 238796813516896
    }
  },
  "meta": {
    "resourceType": "Device",
      "created": "2022-01-23T04:56:22Z",
    "lastModified": "2022-05-13T04:42:34Z",
    "version": "W\/\"a330bc54f0671c9\"",
    "location": "https://example.com/v2/Device/e9e30dba-f08f-4109
       -8486-d5c6a3316111"
  }
}
<CODE ENDS>
]]></artwork></figure>

<t>However, a device can have more than one pairing method. Support for multiple
pairing methods is also provided by the multi-valued attribute pairingMethods.
In the example below, the BLE device can pair with both passkey and OOB pairing
methods.</t>

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

  "id": "e9e30dba-f08f-4109-8486-d5c6a3316111",
  "deviceDisplayName": "BLE Heart Monitor",
  "adminState": true,
  "urn:ietf:params:scim:schemas:extension:ble:2.0:Device" : {
    "versionSupport": ["5.3"],
    "deviceMacAddress": "2C:54:91:88:C9:E2",
    "isRandom": false,
    "separateBroadcastAddress": ["AA:BB:88:77:22:11", "AA:BB:88:77
       :22:12"],
    "mobility": true,
    "pairingMethods": ["urn:ietf:params:scim:schemas:extension
       :pairingPassKey:2.0:Device",
        "urn:ietf:params:scim:schemas:extension:pairingOOB:2.0
           :Device"],
    "urn:ietf:params:scim:schemas:extension:pairingPassKey:2.0
       :Device" : {
      "key": 123456
    },
    "urn:ietf:params:scim:schemas:extension:pairingOOB:2.0:Device":
        {
      "key": "TheKeyvalueRetrievedFromOOB",
      "randNumber": 238796813516896
    }
  },
  "meta": {
    "resourceType": "Device",
      "created": "2022-01-23T04:56:22Z",
    "lastModified": "2022-05-13T04:42:34Z",
    "version": "W\/\"a330bc54f0671c9\"",
    "location": "https://example.com/v2/Device/e9e30dba-f08f-4109
       -8486-d5c6a3316111"
  }
}
<CODE ENDS>
]]></artwork></figure>

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

</section>
</section>
<section anchor="dpp-easyconnect-extension"><name>DPP EasyConnect Extension</name>

<t>A schema that extends the device schema to enable WiFi EasyConnect
(otherwise known as Device Provisioning Protocol). The extension is 
identified using the following schema URI:</t>

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

<t>The attributes in this extension are adopted from <xref target="DPP2"/>. The 
attributes are as follows:</t>

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

<t>dppVersion</t>

<t>An integer that represents the version of DPP the device supports. 
This attribute is required, case insensitive, mutable, and 
returned by default.</t>

<t>bootstrapKey</t>

<t>A string value representing Elliptic-Curve Diffie–Hellman (ECDH) public 
key. The base64 encoded lengths for P-256, P-384, and P-521 are 
80, 96, and 120 characters. This attribute is required, case-sensitive,
mutable, and returned by default.</t>

<t>deviceMacAddress</t>

<t>The manufacturer assigns the MAC address stored as string. It is a 
unique 48-bit value. This attribute is optional, case insensitive, 
mutable, and returned by default. The regex pattern is as follows:</t>

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

<t>serialNumber</t>

<t>An alphanumeric serial number, stored as string, may also be passed 
as bootstrapping information. This attribute is optional, case 
insensitive, mutable, and returned by default.</t>

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

<t>bootstrappingMethod</t>

<t>It is the array of strings of all the bootstrapping methods available 
on the enrollee device. For example, [QR, NFC]. This attribute is 
optional, case insensitive, mutable, and returned by default.</t>

<t>classChannel</t>

<t>This attribute is an array of strings of global operating class and 
channel shared as bootstrapping information. It is formatted as 
class/channel. For example, ['81/1','115/36']. This attribute 
is optional, case insensitive, mutable, and returned by default.</t>

<figure title="Characteristics of DPP extension schema attributes. 
(Req = Required, T = True, F = False, RW = ReadWrite, Def = Default,
and Manuf = Manufacturer)." anchor="tabDPP"><artwork><![CDATA[
+====================+=====+===+======+=========+========+========+
| Attribute          |Multi|Req| Case | Mutable | Return | Unique |
|                    |Value|   | Exact|         |        |        |
+====================+=====+===+======+=========+========+========+
| dppVersion         |  F  | T |  F   |   RW    |  Def   | None   |
+--------------------+-----+---+------+---------+--------+--------+
| bootstrapKey       |  F  | T |  T   |   RW    |  Def   | None   |
+--------------------+-----+---+------+---------+--------+--------+
| deviceMacAddress   |  F  | F |  F   |   RW    |  Def   | Manuf  |
+--------------------+-----+---+------+---------+--------+--------+
| serialNumber       |  F  | F |  F   |   RW    |  Def   | None   |
+--------------------+-----+---+------+---------+--------+--------+
| bootstrappingMethod|  T  | F |  F   |   RW    |  Def   | None   |
+--------------------+-----+---+------+---------+--------+--------+
| classChannel       |  T  | F |  F   |   RW    |  Def   | None   |
+--------------------+-----+---+------+---------+--------+--------+
]]></artwork></figure>

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

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

        "id": "e9e30dba-f08f-4109-8486-d5c6a3316111",
        "displayName": "WiFi Heart Monitor",
        "adminState": true,
        "urn:ietf:params:scim:schemas:extension:dpp:2.0:Device" : {
                "dppVersion": 2,
                "bootstrappingMethod": ["QR"],
                "bootstrapKey":
                    "MDkwEwYHKoZIzj0CAQYIKoZIzj0DAQcDIgADURzxmt
                   tZoIRIPWGoQMV00XHWCAQIhXruVWOz0NjlkIA=",
                "deviceMacAddress": "2C:54:91:88:C9:F2",
                "classChannel": ["81/1", "115/36"],
                "serialNumber": "4774LH2b4044"
        },

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

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

</section>
</section>
<section anchor="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",
  "adminState": 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:Device",
     "urn:ietf:params:scim:schemas:extension:fido-device-onboard
        :2.0:Device"],

  "id": "e9e30dba-f08f-4109-8486-d5c6a3316111",
  "displayName": "Some random Ethernet Device",
  "adminState": true,
  "urn:ietf:params:scim:schemas:extension:fido-device-onboard:2.0
     :Device" : {
     "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",
  "adminState": true,
  "urn:ietf:params:scim:schemas:extension:zigbee:2.0:Device" : {
    "versionSupport": ["3.0"],
    "deviceEui64Address": "50325FFFFEE76728"
  },

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

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

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

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

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

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

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

<t>deviceControlEnterpriseEndpoint</t>

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

<t>telemetryEnterpriseEndpoint</t>

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

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

<t>applications</t>

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

<t>value</t>

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

<t>$ref</t>

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

<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",
  "deviceDisplayName": "BLE Heart Monitor",
  "adminState": true,
  "urn:ietf:params:scim:schemas:extension:ble:2.0:Device" : {
    "versionSupport": ["5.3"],
    "deviceMacAddress": "2C:54:91:88:C9:E2",
    "isRandom": false,
    "separateBroadcastAddress": ["AA:BB:88:77:22:11", "AA:BB:88:77
       :22:12"],
    "mobility": false,
    "pairingMethods": [
        "urn:ietf:params:scim:schemas:extension:pairingNull:2.0
           :Device",
        "urn:ietf:params:scim:schemas:extension:pairingJustWorks
           :2.0:Device",
        "urn:ietf:params:scim:schemas:extension:pairingPassKey:2.0
           :Device",
        "urn:ietf:params:scim:schemas:extension:pairingOOB:2.0
           :Device"],
    "urn:ietf:params:scim:schemas:extension:pairingNull:2.0:Device"
       : null,
    "urn:ietf:params:scim:schemas:extension:pairingJustWorks:2.0
       :Device": {
      "key": null
    },
    "urn:ietf:params:scim:schemas:extension:pairingPassKey:2.0
       :Device" : {
      "key": 123456
    },
    "urn:ietf:params:scim:schemas:extension:pairingOOB:2.0:Device":
        {
      "key": "TheKeyvalueRetrievedFromOOB",
      "randNumber": 238796813516896
    }
  },

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

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


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

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

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

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

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

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

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

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

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

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

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

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

</section>
<section anchor="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:Device",
  "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:Device"
  }
}
<CODE ENDS>
]]></artwork></figure>

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

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

</section>
</section>
<section anchor="security-considerations"><name>Security Considerations</name>

<t>Because provisioning operations are senstive, each client must be
appropriately authenticated.  Certain objects may be read-only or
not visible based on who is connected.</t>

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

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

<t>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</c>
      <c>urn:ietf:params:scim:schemas:extension: ble:2.0:Device</c>
      <c>BLE Extension</c>
      <c>This memo</c>
      <c>urn:ietf:params:scim:schemas:extension: ethernet-mab:2.0:Device</c>
      <c>Ethernet MAB</c>
      <c>This memo</c>
      <c>urn:ietf:params:scim:schemas:extension: fido-device-onboard:2.0:Device</c>
      <c>Fido Device Onboard</c>
      <c>This memo</c>
      <c>urn:ietf:params:scim:schemas:extension: dpp:2.0:Device</c>
      <c>Device Provisioning Protocol</c>
      <c>This memo</c>
      <c>urn:ietf:params:scim:schemas:extension: endpointAppsExt:2.0:Device</c>
      <c>Application Endpoint Extension</c>
      <c>This memo</c>
      <c>urn:ietf:params:scim:schemas:extension: pairingJustWorks:2.0:Device</c>
      <c>Just Works Auth BLE</c>
      <c>This memo</c>
      <c>urn:ietf:params:scim:schemas:extension: pairingOOB:2.0:Device</c>
      <c>Out of Band Pairing for BLE</c>
      <c>This memo</c>
      <c>urn:ietf:params:scim:schemas:extension: pairingPassKey:2.0:Device</c>
      <c>Passkey Pairing for BLE</c>
      <c>This memo</c>
</texttable>

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

</section>


  </middle>

  <back>


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

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




    </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="20" month="October" year="2023"/>
      <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-00"/>
   
</reference>




    </references>


<?line 1998?>

<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:
        deviceDisplayName:
          type: string
          description: "Human readable name of the device, suitable
                        for displaying to end-users. For example,
                       'BLE Heart Monitor' etc."
          nullable: true
          readOnly: false
          writeOnly: false
        adminState:
          type: boolean
          description: A mutable boolean value indicating the device
                       administrative status. If set TRUE, the
                       commands (such as connect, disconnect,
                       subscribe) that control app sends to the
                       controller for the devices will be processeed
                       by the controller.  If set FALSE, any command
                       comming from the control app for the device
                       will be rejected by the controller.
          nullable: false
          readOnly: false
          writeOnly: false
        mudUrl:
          type: string
          format: uri
          description: A URL to MUD file of the device (RFC 8520).
              It
                       is added for future use. Current usage is not
                       defined yet.
          nullable: true
          readOnly: false
          writeOnly: false
      required:
        - adminState
      additionalProperties: false
      allOf:
        - $ref: '#/components/schemas/CommonAttributes'
    CommonAttributes:
      type: object
      properties:
        schemas:
          type: array
          items:
            type: string
            enum:
              - urn:ietf:params:scim:schemas:core:2.0:Device
          description: The list of schemas that define the resource.
          nullable: false
        id:
          type: string
          format: uri
          description: The unique identifier for a resource.
          nullable: false
          readOnly: true
          writeOnly: false
        externalId:
          type: string
          description: An identifier for the resource that is
              defined
                       by the provisioning client.
          nullable: true
          readOnly: false
          writeOnly: false
        meta:
          type: object
          readOnly: true
          properties:
            resourceType:
              type: string
              description: The name of the resource type of the
                           resource.
              nullable: false
              readOnly: true
              writeOnly: false
            location:
              type: string
              format: uri
              description: The URI of the resource being returned.
              nullable: false
              readOnly: true
              writeOnly: false
            created:
              type: string
              format: date-time
              description: The date and time the resource was added
                           to the service provider.
              nullable: false
              readOnly: true
              writeOnly: false
            lastModified:
              type: string
              format: date-time
              description: The most recent date and time that the
                           details of this resource were updated at
                           the service provider.
              nullable: false
              readOnly: true
              writeOnly: false
            version:
              type: string
              description: The version of the resource.
              nullable: true
              readOnly: true
              writeOnly: false
          additionalProperties: false
<CODE ENDS>
]]></artwork></figure>

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

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

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

      required:
        - applicationType
        - applicationName

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

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

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

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

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

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

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

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

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

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

        isRandom:
          type: boolean
          description: AddressType flag is taken from the BLE core
                       specifications 5.3. If FALSE, the device is
                       using public MAC address. If TRUE, device is
                       using Random address which is resolved using
                       the IRK.
          nullable: false
          readOnly: false
          writeOnly: false

        separateBroadcastAddress:
          type: string
          description: "When present, this address is used for
                        broadcasts/advertisements.  This value MUST
                            NOT
                        be set when an IRK is provided.  Its form is
                        the same as deviceMa`cAddress."
          nullable: false
          readOnly: false
          writeOnly: false

        irk:
          type: string
          description: Identity resolving key, which is unique for
                       every device. It is used to resolve random
                       address.
          nullable: true
          readOnly: false
          writeOnly: false
        mobility:
          type: boolean
          description: If set to True, the BLE device will
                       automatically connect to the closest AP. For
                       example, BLE device is connected with AP-1
                           and
                       moves out of range but comes in range of AP
                          -2,
                       it will be disconnected with AP-1 and
                           connects
                       with AP-2.
          nullable: false
          readOnly: false
          writeOnly: false
        pairingMethods:
          type: array
          items:
            type: string
          description: List of pairing methods associated with the
                       ble device, stored as schema URI.
          nullable: true
          readOnly: false
          writeOnly: false
        urn:ietf:params:scim:schemas:extension:pairingNull:2.0
           :Device:
          $ref: '#/components/schemas/NullPairing'
          required: false
        urn:ietf:params:scim:schemas:extension:pairingJustWorks:2.0
           :Device:
          $ref: '#/components/schemas/PairingJustWorks'
          required: false
        urn:ietf:params:scim:schemas:extension:pairingPassKey:2.0
           :Device:
          $ref: '#/components/schemas/PairingPassKey'
          required: false
        urn:ietf:params:scim:schemas:extension:pairingOOB:2.0
           :Device:
          $ref: '#/components/schemas/PairingOOB'
          required: false
      required:
        - versionSupport
        - deviceMacAddress
        - AddressType
        - pairingMethods
      additionalProperties: false

    NullPairing:
      type: object
      properties:
        id:
          type: string
          description: The id of the null pairing schema.
          nullable: false
          readOnly: true
          writeOnly: false

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

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

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

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

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

</section>
<section anchor="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:Device
        urn:ietf:params:scim:schemas:extension:ethernet-mab:2.0
           :Device:
          $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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
C9VfAQA=

-->

</rfc>

