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


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

]>


<rfc ipr="trust200902" docName="draft-ietf-scim-device-model-12" 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="2025" month="April" day="28"/>

    
    
    <keyword>Internet-Draft</keyword>

    <abstract>


<?line 99?>

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



    </abstract>



  </front>

  <middle>


<?line 107?>

<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 device credentials and other
attributes into a network. 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>

<t>A primary purpose of this specification is to provision the network
for onboarding and communications access to and from devices within a
local deployment based on the underlying capabilities of those
devices. The underlying security mechanisms of some devices range from
non-existent such as the Bluetooth Low Energy (BLE) "Just Works"
pairing method to a robust FIDO Device Onboard (FDO) mechanism.
Information from the SCIM server is dispatched to control functions
based on selected schema extensions to enable these communications
within a network.  The SCIM database is therefore essentially
equivalent to a network's Authentication, Authorization, and
Accounting (AAA) database, and should be carefully treated as such.</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 <xref target="RFC6241"/> or RESTCONF <xref target="RFC8040"/> with YANG
<xref target="RFC7950"/>. After all, there are all sorts of existing models
available. The answer is four fold:
- First, NETCONF and RESTCONF focus on <strong>configuration</strong> rather than
  provisioning.
- Second, SCIM is designed with inter-domain provisioning in mind.
  The use of HTTP as a substrate permits both user-based authentication
  for local provisioning applications, as well as OAUTH or certificate-
  based authentication.  the inter-domain nature of these operations
  does not expose local policy, which itself must be (and often is)
  configured with other APIs, many of which are not standardized.
- SCIM is also a familiar tool within the enterprise enviroment, used
  extensively to configure federated user accounts.  (Amusingly, one
  author noted a billboard in San Francisco highlighting a SCIM as
  part of a product capability.)
- Finally, once one chooses a vehicle such as SCIM, one is beholden
  to its data model.  The SCM data model is articulated in <xref target="RFC7643"/>.</t>

<t>This taken together with the fact that end devices are not intended to
be <strong>directly</strong> configured leave us with SCIM as the best standard option.</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 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 Wi-fi Easy Connect 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="JSONSChema"/> for this
purpose. The use of XML for SCIM devices is not supported.</t>

<t>Several additional schemas specify specific onboarding mechanisms,
such as BLE and Wi-fi 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"/>).  It comprises a core device schema and several
extension schemas. The core schema provides a minimal resource
representation, whereas extension schemas extend the core schema
depending on the device's capability. The JSON schema for Device
resource type is in <xref target="resource-schema"/>.</t>

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

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

<t>id</t>

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

<t>externalID</t>

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

<t>meta</t>

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

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

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

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

<t>displayName</t>

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

<t>active</t>

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

<t>mudUrl</t>

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

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

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

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

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

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

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

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

<t>This section defines a new resource type, 'EndpointApp'. The 
"ResourceType" schema specifies the metadata about a resource type 
(see section 6 of <xref target="RFC7643"/>). The resource "EndpointApp" represents
client applications that can control and/or receive data from the
devices. The JSON schema for EndpointApp resource type is in <xref target="resource-schema"/>.</t>

<t>The attributes comprising EndpointsApp are listed in <xref target="endpointapp-schema"/>.
The "EndpointApp" are included in the endpoint applications extension 
("endpointAppsExt") <xref target="endpointsappext-schema"/>.</t>

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

<t>The EndpointApp schema is used to authorize clients control
or telemetry services for clients.  The schema identifies the application
and how clients are to authenticate to the various services.</t>

<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 attribute is 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 not mutable, read-only, generated if
no certificateInfo object is provisioned, case sensitive and returned
by default if it exists.  The SCIM server should expect that client
tokens will be shared by the SCIM client with other components within
the client's infrastructure.</t>

</section>
<section anchor="complex-attributes"><name>Complex Attributes</name>

<section anchor="certificateinfo"><name>certificateInfo</name>

<t>It is the complex attribute that contains x509 certificate's subject
name and root CA information associated with application clients that
will connect for purposes of device control or telemetry.</t>

<t>rootCA</t>

<t>This is the base64 encoding a trust anchor certificate as
described in <xref target="rfc4648"/> Section 4.  This trust anchor is applicable
for certificates used for client application access.  The object
is not required, singular, case sensitive, and read/write.  If not
present, a set of trust anchors MUST be configured out of band.</t>

<t>subjectName</t>

<t>If present, this field may contain one of two names:</t>

<t><list style="symbols">
  <t>a distinguished name as that will be present in the certificate
subject field, as de  scribed in Section 4.1.2.4 of <xref target="RFC5280"/>; or</t>
  <t>or a dnsName as part of a subjectAlternateName as  described in
Section 4.2.1.6 of <xref target="RFC5280"/>.</t>
</list></t>

<t>In the latter case, servers validating such certificates SHALL reject
connections when name of the peer as resolved by a DNS reverse lookup
does not match the dnsName in the certificate.  If multiple dnsNames
are present, it is left to server implementations to address any
authorization conflicts associated with those names.  This attribute
is not required, read write, singular and NOT case sensitive.</t>

<texttable title="Characteristics of EndpointApp schema attributes. (Req = Required, T = True, F = False, R = ReadOnly, RW = ReadWrite, Manuf = Manufacturer, N = No, 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>F</c>
      <c>T</c>
      <c>R</c>
      <c>N</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>rootCA</c>
      <c>F</c>
      <c>F</c>
      <c>T</c>
      <c>RW</c>
      <c>Def</c>
      <c>None</c>
      <c>subjectName</c>
      <c>F</c>
      <c>T</c>
      <c>T</c>
      <c>RW</c>
      <c>Def</c>
      <c>None</c>
</texttable>

<t>Note that either clientToken and certificateInfo are used for the
authentication of the application.  If certificateInfo is NOT present
when an endpointApp is object created, then the server SHOULD return
a clientToken.  Otherwise, if the server accepts the certificateInfo
object for authentication, it SHOULD NOT return a clientToken.
If the server accepts and produces a clientToken, then control and
telemetry servers MUST validate both.  The SCIM client will know
that this is the case based on the SCIM object that is returned.</t>

<t>certificateInfo is preferred in situations where client functions
are federated such that different clients may connect for different
purposes.</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": {
      "rootCA" : "MIIBIjAN...",
      "subjectName": "wwww.example.com"
  },
  "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>
<section anchor="extensions"><name>SCIM Device Extensions</name>

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

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

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

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

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

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

<t>deviceMacAddress</t>

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

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

<t>isRandom</t>

<t>A boolean flag taken from the BLE core specification, 5.3. If FALSE,
the device is using a public MAC address. If TRUE, the device uses a
random address.  If an Idenifying Resolving Key (IRK) is present, the
address represents a resolvable private address.  Otherwise, the
address is assumed to be a random static address.  Non-resolvable
private addresses are not supported by this specification.  This
attribute is not required. It is mutable, and is returned by default.
The 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 that specifies the identity resolving key (IRK), which
is unique to each device. It is used to resolve private random
address. It should only be provisioned when isRandom is TRUE. It is
mutable and never returned.  For more information about the use of
the IRK, see Section 5.4.5 of <xref target="BLE54"/>.</t>

<t>mobility</t>

<t>A boolean attribute to enable BLE device mobility. If set to TRUE, the
device could be expected to move within a network of APs.  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="BLE54"/>. 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 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 returned 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 passkey 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</t>

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

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

<t>confirmationNumber</t>

<t>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, WO=Write Only, Def = Default,
Nev = Never, 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>F</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>WO</c>
      <c>Nev</c>
      <c>Manuf</c>
      <c>versionSupport</c>
      <c>T</c>
      <c>T</c>
      <c>F</c>
      <c>RW</c>
      <c>Def</c>
      <c>None</c>
      <c>mobility</c>
      <c>F</c>
      <c>F</c>
      <c>F</c>
      <c>RW</c>
      <c>Def</c>
      <c>None</c>
      <c>pairingMethods</c>
      <c>T</c>
      <c>T</c>
      <c>T</c>
      <c>RW</c>
      <c>Def</c>
      <c>None</c>
</texttable>

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

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

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

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

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

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

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

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

  "id": "e9e30dba-f08f-4109-8486-d5c6a3316111",
  "displayName": "BLE Heart Monitor",
  "active": true,
  "urn:ietf:params:scim:schemas:extension:ble:2.0:Device" : {
    "versionSupport": ["5.3"],
    "deviceMacAddress": "2C:54:91:88:C9:E2",
    "isRandom": false,
    "separateBroadcastAddress": ["AA:BB:88:77:22:11", "AA:BB:88:77
       :22:12"],
    "mobility": true,
    "pairingMethods": ["urn:ietf:params:scim:schemas:extension
       :pairingPassKey:2.0:Device",
        "urn:ietf:params:scim:schemas:extension:pairingOOB:2.0
           :Device"],
    "urn:ietf:params:scim:schemas:extension:pairingPassKey:2.0
       :Device" : {
      "key": 123456
    },
    "urn:ietf:params:scim:schemas:extension:pairingOOB:2.0:Device":
        {
      "key": "TheKeyvalueRetrievedFromOOB",
      "randomNumber": 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="wi-fi-easy-connect-extension"><name>Wi-Fi Easy Connect Extension</name>

<t>A schema that extends the device schema to enable Wi-Fi Easy Connect
(otherwise known as Device Provisioning Protocol or DPP). Throughout this
specification we use the term DPP.  The extension
is identified using the following schema URI:</t>

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

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

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

<t>dppVersion</t>

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

<t>bootstrapKey</t>

<t>A string value representing an 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>

<texttable title="Characteristics of DPP extension schema attributes. 
(Req = Required, T = True, F = False, RW = ReadWrite, WO = Write Only,
Def = Default, Nev = Never, and Manuf = Manufacturer)." anchor="tabDPP">
      <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>dppVersion</c>
      <c>F</c>
      <c>T</c>
      <c>F</c>
      <c>RW</c>
      <c>Def</c>
      <c>None</c>
      <c>bootstrapKey</c>
      <c>F</c>
      <c>T</c>
      <c>T</c>
      <c>WO</c>
      <c>Nev</c>
      <c>None</c>
      <c>deviceMacAddress</c>
      <c>F</c>
      <c>F</c>
      <c>F</c>
      <c>RW</c>
      <c>Def</c>
      <c>Manuf</c>
      <c>serialNumber</c>
      <c>F</c>
      <c>F</c>
      <c>F</c>
      <c>RW</c>
      <c>Def</c>
      <c>None</c>
      <c>bootstrappingMethod</c>
      <c>T</c>
      <c>F</c>
      <c>F</c>
      <c>RW</c>
      <c>Def</c>
      <c>None</c>
      <c>classChannel</c>
      <c>T</c>
      <c>F</c>
      <c>F</c>
      <c>RW</c>
      <c>Def</c>
      <c>None</c>
</texttable>

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

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

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

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

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

</section>
</section>
<section anchor="ethernet-mab-extension"><name>Ethernet MAB Extension</name>

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

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

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

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

<t>deviceMacAddress</t>

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

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

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

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

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

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

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

</section>
</section>
<section anchor="fido-device-onboard-extension"><name>FIDO Device Onboard Extension</name>

<t>This extension specifies a voucher to be used by the FDO Device
Onboard (FDO) protocols <xref target="FDO11"/> to complete a trusted transfer of
ownership and control of the device to the environment.  The SCIM
server MUST know how to process the voucher, either directly
or by forwarding it along to an owner process as defined in the FDO
specification.</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 <xref target="FDO11"/>.</t>

<texttable title="Characteristics of FDO extension schema attributes
(Req = Required, T = True, F = False, WO = WriteOnly, and 
Nev = Never)" 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>WO</c>
      <c>Nev</c>
      <c>None</c>
</texttable>

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

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

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

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

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

</section>
</section>
<section anchor="zigbee-extension"><name>Zigbee Extension</name>

<t>A schema that extends the device schema to enable the provisioning of 
Zigbee devices. The extension is identified using the following 
schema URI:</t>

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

<t>It has one singular attribute and one multivalued 
attribute. The attributes are as follows:</t>

<section anchor="singular-attribute"><name>Singular Attribute</name>

<t>deviceEui64Address</t>

<t>An EUI-64 (Extended Unique Identifier) device address stored as string.
This attribute is required, case insensitive, mutable, and returned by
default. The regex pattern is as follows:</t>

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

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

<t>versionSupport</t>

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

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

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

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

  "id": "e9e30dba-f08f-4109-8486-d5c6a3316111",
  "displayName": "Zigbee Heart Monitor",
  "active": true,
  "urn:ietf:params:scim:schemas:extension:zigbee:2.0:Device" : {
    "versionSupport": ["3.0"],
    "deviceEui64Address": "50:32:5F:FF:FE:E7:67:28"
  },

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

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

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

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

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

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

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

<t>deviceControlEnterpriseEndpoint</t>

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

<t>telemetryEnterpriseEndpoint</t>

<t>Telemetry apps use this URL of the enterprise endpoint to reach the
enterprise gateway. When the enterprise receives the SCIM object from
the onboarding app, it adds this attribute to it and sends it back as
a response to the onboarding app. This attribute is optional,
case-sensitive, mutable, and returned by default. The uniqueness is
enforced by the enterprise.  An implementation MUST generate an
exception if telemetryEnterpriseEndpoint is not returned and telemetry
is required for the proper functioning of a device.</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 read/write, 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>F</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>RW</c>
      <c>Def</c>
      <c>None</c>
      <c>$ref</c>
      <c>F</c>
      <c>T</c>
      <c>F</c>
      <c>R</c>
      <c>Def</c>
      <c>None</c>
</texttable>

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

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

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

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

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

<figure><artwork><![CDATA[
<CODE BEGINS>
[
  {
    "schemas": ["urn:ietf:params:scim:schemas:core:2.0
       :ResourceType"],
    "id": "Device",
    "name": "Device",
    "endpoint": "/Devices",
    "description": "Device Account",
    "schema": "urn:ietf:params:scim:schemas:core:2.0:Device",
    "meta": {
      "location": "https://example.com/v2/ResourceTypes/Device",
      "resourceType": "ResourceType"
    }
  },
  {
    "schemas": ["urn:ietf:params:scim:schemas:core:2.0
       :ResourceType"],
    "id": "EndpointApp",
    "name": "EndpointApp",
    "endpoint": "/EndpointApp",
    "description": "Endpoint application such as device control and
        telemetry.",
    "schema": "urn:ietf:params:scim:schemas:core:2.0:EndpointApp",
    "meta": {
      "location": "https
         ://example.com/v2/ResourceTypes/EndpointApp",
      "resourceType": "ResourceType"
    }
  }
]
<CODE ENDS>
]]></artwork></figure>

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

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

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

<figure><artwork><![CDATA[
<CODE BEGINS>
{
  "id": "urn:ietf:params:scim:schemas:core:2.0:EndpointApp",
  "name": "EndpointApp",
  "description": "Endpoint application and their credentials",
  "attributes" : [
    {
      "name": "applicationType",
      "type": "string",
      "description": "This attribute will only contain two values;
          'deviceControl' or 'telemetry'.",
      "multivalues": false,
      "required": true,
      "caseExact": false,
      "mutability": "readOnly",
      "returned": "default",
      "uniqueness": "none"
    },
    {
      "name": "applicationName",
      "type": "string",
      "description": "Human readable name of the application.",
      "multivalues": false,
      "required": true,
      "caseExact": false,
      "mutability": "readWrite",
      "returned": "default",
      "uniqueness": "none"
    },
    {
      "name": "certificateInfo",
      "type": "complex",
      "description": "Contains x509 certificate's subject name and
          root CA information associated with the device control or
          telemetry app.",
      "multivalues": false,
      "required": false,
      "caseExact": false,
      "mutability": "readWrite",
      "returned": "default",
      "uniqueness": "none",
      "subAttributes" : [
        {
          "name" : "rootCA",
          "type" : "string",
          "description" : "The base64 encoding of the DER encoding
              of the CA certificate",
          "multiValued" : false,
          "required" : false,
          "caseExact" : true,
          "mutability" : "readWrite",
          "returned" : "default",
          "uniqueness" : "none"
        },
        {
          "name" : "subjectName",
          "type" : "string",
          "description" : "A Common Name (CN) of the form of CN =
              dnsName",
          "multiValued" : false,
          "required" : true,
          "caseExact" : true,
          "mutability" : "readWrite",
          "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",
        "pattern": "^[0-9A-Fa-f]{2}(:[0-9A-Fa-f]{2}){5}$",
        "description": "A unique public MAC address assigned by the
            manufacturer.",
        "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 a
              random address.  Default 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 Wi-Fi Easy Connect
        / Device Provisioning Protocol (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": "A base64-encoded Elliptic-Curve Diffie-Hellman
            public key (may be P-256, P-384, or P-521).",
        "multivalues": false,
        "required": true,
        "caseExact": true,
        "mutability": "readWrite",
        "returned": "default",
        "uniqueness": "none"
      },
      {
        "name": "deviceMacAddress",
        "type": "string",
        "pattern": "^[0-9A-Fa-f]{2}(:[0-9A-Fa-f]{2}){5}$",
        "description": "A unique public MAC address assigned by the
            manufacturer.",
        "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",
        "pattern": "^[0-9A-Fa-f]{2}(:[0-9A-Fa-f]{2}){5}$",
        "description": "A MAC address assigned by the manufacturer",
        "multivalues": false,
        "required": true,
        "caseExact": false,
        "mutability": "readWrite",
        "returned": "default",
        "uniqueness": "Manufacturer"
      }
  ],
  "meta" : {
    "resourceType" : "Schema",
    "location" : "/v2/Schemas/urn:ietf:params:scim:schemas
       :extension:ethernet-mab:2.0:Device"
  }
}
<CODE ENDS>
]]></artwork></figure>

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

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

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

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

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

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

<t>Because provisioning operations permit device access to a network,
each SCIM client MUST be appropriately authenticated.</t>

<section anchor="scim-operations"><name>SCIM operations</name>

<t>An attacker that has authenticated to a trusted SCIM client could
manipulate portions of the SCIM database.  To be clear on the risks,
we discuss each operation below:</t>

<section anchor="unauthorized-object-creation"><name>Unauthorized Object Creation</name>

<t>An attacker that is authenticated could attempt to add
elements that the enterprise would not normally permit on a network.
For instance, an enterprise may not wish specific devices that have
well-known vulnerabilities to be introduced to their environment.
To mitigate the attack, network administrators should layer additional
policies regarding what devices are permitted on the network.</t>

<t>An attacker that gains access to SCIM could attempt to add an IP-based
device that itself attempts unauthorized access, effectively acting as
a Bot.  Network administrators SHOULD establish appropriate access-control
policies that follow the principle of least privilege to mitigate this
attack.</t>

</section>
</section>
<section anchor="object-deletion"><name>Object Deletion</name>

<t>Once granted, even if the object is removed, the server may or may not
act on that removal.  The deletion of the object is a signal of intent
by the application that it no longer expects the device to be on the
network.  It is strictly up to the SCIM server and its back end policy
to decide whether or not to revoke access to the infrastructure.  It is
RECOMMENDED that SCIM delete operations trigger a workflow in accordance
with local network policy.</t>

</section>
<section anchor="read-operations"><name>Read operations</name>

<t>Read operations are necessary in order for an application to sync its
state to know what devices it is expected to manage.  An attacker with
access to SCIM objects may gain access to the devices themselves.  To
prevent one SCIM client from interfering with devices that it has no
business managing, only clients that have created objects or those
they authorize SHOULD have the ability to read those objects.</t>

</section>
<section anchor="update-operations"><name>Update Operations</name>

<t>Update operations may be necessary if a device has been modified in
some way.  Attackers with update access may be able to disable network
access to devices or device access to networks.  To avoid this, the
same access control policy for read operations is RECOMMENDED here.</t>

</section>
<section anchor="higher-level-protection-for-certain-systems"><name>Higher level protection for certain systems</name>

<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. If the administrator of
the SCIM client does not wish the network to have complete access to
the device, the device itself MUST support finer levels of access
control and additional authentication mechanisms.
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="logging"><name>Logging</name>

<t>An attacker could learn what devices are on a network by examining
SCIM logs.  Due to the sensitive nature of SCIM operations, logs
SHOULD be encrypted both on the disk and in transit.</t>

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

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

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

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

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

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

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

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

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

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

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

</section>
</section>
<section anchor="acknowledgments"><name>Acknowledgments</name>

<t>The authors would like to thank Bart Brinckman, Rohit Mohan, Lars
Streubesand, Christian Amsüss, Jason Livingwood, Mike Ounsworth, Monty
Wiseman, Geoffrey Cooper, and Phil Hunt for their reviews.</t>

</section>


  </middle>

  <back>


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

<reference anchor="BLE54" >
  <front>
    <title>Bluetooth Core Specification, Version 5.4</title>
    <author >
      <organization>Bluetooth SIG</organization>
    </author>
    <date year="2023"/>
  </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 Onboard Specification 1.1</title>
    <author >
      <organization>FIDO Alliance</organization>
    </author>
    <date year="2022" month="April"/>
  </front>
</reference>
<reference anchor="JSONSChema" target="https://json-schema.org/draft/2020-12/json-schema-core">
  <front>
    <title>JSON Schema- A Media Type for Describing JSON Documents</title>
    <author initials="A." surname="Wright" fullname="Austin Wright" role="editor">
      <organization></organization>
    </author>
    <author initials="H. A." surname="Andrews" fullname="Henry Andrews" role="editor">
      <organization></organization>
    </author>
    <author initials="B." surname="Hutton" fullname="Ben Hutton" role="editor">
      <organization>Postman</organization>
    </author>
    <author initials="G." surname="Dennis" fullname="Greg Dennis">
      <organization></organization>
    </author>
    <date year="2022" month="December"/>
  </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="RFC2119">
  <front>
    <title>Key words for use in RFCs to Indicate Requirement Levels</title>
    <author fullname="S. Bradner" initials="S." surname="Bradner"/>
    <date month="March" year="1997"/>
    <abstract>
      <t>In many standards track documents several words are used to signify the requirements in the specification. These words are often capitalized. This document defines these words as they should be interpreted in IETF documents. This document specifies an Internet Best Current Practices for the Internet Community, and requests discussion and suggestions for improvements.</t>
    </abstract>
  </front>
  <seriesInfo name="BCP" value="14"/>
  <seriesInfo name="RFC" value="2119"/>
  <seriesInfo name="DOI" value="10.17487/RFC2119"/>
</reference>

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

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

<reference anchor="rfc4648">
  <front>
    <title>The Base16, Base32, and Base64 Data Encodings</title>
    <author fullname="S. Josefsson" initials="S." surname="Josefsson"/>
    <date month="October" year="2006"/>
    <abstract>
      <t>This document describes the commonly used base 64, base 32, and base 16 encoding schemes. It also discusses the use of line-feeds in encoded data, use of padding in encoded data, use of non-alphabet characters in encoded data, use of different encoding alphabets, and canonical encodings. [STANDARDS-TRACK]</t>
    </abstract>
  </front>
  <seriesInfo name="RFC" value="4648"/>
  <seriesInfo name="DOI" value="10.17487/RFC4648"/>
</reference>

<reference anchor="RFC5280">
  <front>
    <title>Internet X.509 Public Key Infrastructure Certificate and Certificate Revocation List (CRL) Profile</title>
    <author fullname="D. Cooper" initials="D." surname="Cooper"/>
    <author fullname="S. Santesson" initials="S." surname="Santesson"/>
    <author fullname="S. Farrell" initials="S." surname="Farrell"/>
    <author fullname="S. Boeyen" initials="S." surname="Boeyen"/>
    <author fullname="R. Housley" initials="R." surname="Housley"/>
    <author fullname="W. Polk" initials="W." surname="Polk"/>
    <date month="May" year="2008"/>
    <abstract>
      <t>This memo profiles the X.509 v3 certificate and X.509 v2 certificate revocation list (CRL) for use in the Internet. An overview of this approach and model is provided as an introduction. The X.509 v3 certificate format is described in detail, with additional information regarding the format and semantics of Internet name forms. Standard certificate extensions are described and two Internet-specific extensions are defined. A set of required certificate extensions is specified. The X.509 v2 CRL format is described in detail along with standard and Internet-specific extensions. An algorithm for X.509 certification path validation is described. An ASN.1 module and examples are provided in the appendices. [STANDARDS-TRACK]</t>
    </abstract>
  </front>
  <seriesInfo name="RFC" value="5280"/>
  <seriesInfo name="DOI" value="10.17487/RFC5280"/>
</reference>

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




    </references>

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



<reference anchor="RFC6241">
  <front>
    <title>Network Configuration Protocol (NETCONF)</title>
    <author fullname="R. Enns" initials="R." role="editor" surname="Enns"/>
    <author fullname="M. Bjorklund" initials="M." role="editor" surname="Bjorklund"/>
    <author fullname="J. Schoenwaelder" initials="J." role="editor" surname="Schoenwaelder"/>
    <author fullname="A. Bierman" initials="A." role="editor" surname="Bierman"/>
    <date month="June" year="2011"/>
    <abstract>
      <t>The Network Configuration Protocol (NETCONF) defined in this document provides mechanisms to install, manipulate, and delete the configuration of network devices. It uses an Extensible Markup Language (XML)-based data encoding for the configuration data as well as the protocol messages. The NETCONF protocol operations are realized as remote procedure calls (RPCs). This document obsoletes RFC 4741. [STANDARDS-TRACK]</t>
    </abstract>
  </front>
  <seriesInfo name="RFC" value="6241"/>
  <seriesInfo name="DOI" value="10.17487/RFC6241"/>
</reference>

<reference anchor="RFC8040">
  <front>
    <title>RESTCONF Protocol</title>
    <author fullname="A. Bierman" initials="A." surname="Bierman"/>
    <author fullname="M. Bjorklund" initials="M." surname="Bjorklund"/>
    <author fullname="K. Watsen" initials="K." surname="Watsen"/>
    <date month="January" year="2017"/>
    <abstract>
      <t>This document describes an HTTP-based protocol that provides a programmatic interface for accessing data defined in YANG, using the datastore concepts defined in the Network Configuration Protocol (NETCONF).</t>
    </abstract>
  </front>
  <seriesInfo name="RFC" value="8040"/>
  <seriesInfo name="DOI" value="10.17487/RFC8040"/>
</reference>

<reference anchor="RFC7950">
  <front>
    <title>The YANG 1.1 Data Modeling Language</title>
    <author fullname="M. Bjorklund" initials="M." role="editor" surname="Bjorklund"/>
    <date month="August" year="2016"/>
    <abstract>
      <t>YANG is a data modeling language used to model configuration data, state data, Remote Procedure Calls, and notifications for network management protocols. This document describes the syntax and semantics of version 1.1 of the YANG language. YANG version 1.1 is a maintenance release of the YANG language, addressing ambiguities and defects in the original specification. There are a small number of backward incompatibilities from YANG version 1. This document also specifies the YANG mappings to the Network Configuration Protocol (NETCONF).</t>
    </abstract>
  </front>
  <seriesInfo name="RFC" value="7950"/>
  <seriesInfo name="DOI" value="10.17487/RFC7950"/>
</reference>

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


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

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




    </references>


<?line 2479?>

<section anchor="changes-from-earlier-versions"><name>Changes from Earlier Versions</name>
<t>[RFC Editor to remove this section.]</t>

<t>Draft -09:
  * last call comments, bump BLE version, add acknowledgments.
  * Also, recapture Rohit comments and those of Christian.</t>

<t>Drafts 04-08:
  * Lots of cleanup
  * Security review responses
  * Removal of a tab
  * Dealing with certificate stuff</t>

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

<t>Draft -02:
  *  Clean up examples
  *  Move openapi to appendix
Draft -01:</t>

<t><list style="symbols">
  <t>Doh! We forgot the core device scheme!</t>
</list></t>

<t>Draft -00:</t>

<t><list style="symbols">
  <t>Initial revision</t>
</list></t>

</section>
<section anchor="openapi-representation"><name>OpenAPI representation</name>

<t>The following sections are provided for informational purposes.</t>

<section anchor="device-schema-openapi-representation"><name>Device Core Schema OpenAPI Representation</name>

<t>OpenAPI representation of device core schema is as follows:</t>

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

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

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

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

      required:
        - applicationType
        - applicationName

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

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

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

    certificateInfo:
      type: object
      description: "Contains x509 certificate's subject name and
                    root CA information associated with the device
                    control or telemetry app."
      properties:
        rootCA:
          type: string
          description: "The base64 encoding of a trust anchor
                        certificate,as per RFC 4648 Section 4."
          nullable: false
          readOnly: false
          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: false
          writeOnly: false

      required:
      - subjectName

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

    NullPairing:
      type: object

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

    PairingPassKey:
      type: object
      description: Pass key pairing method for ble
      properties:
        key:
          type: integer
          description: A six digit passkey for ble device.
                       The pattern of key is ^[0-9]{6}$.
          nullable: false
          readOnly: false
          writeOnly: true
      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: true
        confirmationNumber:
          type: integer
          description: Some solutions require a confirmation number
                       in the RESTful message exchange.
          nullable: true
          readOnly: false
          writeOnly: true
      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: Wi-Fi Easy Connect (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: An 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: true
        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 Extension
      properties:
        schemas:
          type: array
          items:
            type: string
            enum:
              - urn:ietf:params:scim:schemas:extension:fido-device
                 -onboard:2.0:Devices
        urn:ietf:params:scim:schemas:extension:fido-device-onboard
           :2.0:Devices:
          $ref: '#/components/schemas/FDODeviceExtension'
          required: true
    FDODeviceExtension:
      type: object
      properties:
        fdoVoucher:
          type: string
          description: A FIDO Device Onboard (FDO) Voucher
          nullable: false
          readOnly: false
          writeOnly: false
      required:
        - fdoVoucher
      description: Device Extension for a FIDO Device Onboard (FDO)
<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

    applications:
      type: array
      items:
        value:
          type: string
          description: The identifier of the endpointApp.
          nullable: false
          readOnly: false
          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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
Q53QozZC2/Oq2d7/A8qpkOpeowEA

-->

</rfc>

