<?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-15" 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="June" day="18"/>

    
    
    <keyword>Internet-Draft</keyword>

    <abstract>


<?line 94?>

<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 102?>

<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. The SCIM server resides within a deployment and is used for
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 - non-IP example" 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.  That control endpoint will then communicate
with the application layer gateway (ALG) to reach the endpoint.</t>

<figure title="Interaction with AAA" anchor="arch2"><artwork><![CDATA[

                            +-----------------------------------+
                            |                                   |
    +-----------+   Request |  +---------+   +----+   +------+  |
    | onboarding|------------->|  SCIM   |-->| AAA|<->|switch|  |
    |    app    |<-------------| Server  |   +----+   +------+  |
    +-----------+  Ctrl Endpt  +---------+                |     |
                            |                             |     |
    +-----------+           |  +------------+         +-------+ |
    |  Control  |...........|..| router/fw  |.........|device | |
    |    App    |           |  +------------+         +-------+ |
    +-----------+           |                                   |
                            |                                   |
                            +-----------------------------------+

]]></artwork></figure>

<t><xref target="arch2"/> shows how IP-based endpoints can be provisioned.  In this
case, the onboarding app provisions a device via SCIM. The necessary
information is passed to the AAA subsystem, such that the device is
permitted to connect.  Once it is online, since the device is based
on IP, it will not need an ALG, but will use the normal IP
infrastructure to communicate with its control application.</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"/>.  No semantic or syntax changes are made here, but the
attributes are listed merely for completeness.</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.  All the SCIM Server related Schema URIs are valid only
with Device resource types.</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 the following extensions in the SCIM
Server-Related Schema URIs registry as described in <xref target="extensions"/>:</t>

<texttable>
      <ttcol align='left'>URN</ttcol>
      <ttcol align='left'>Description</ttcol>
      <ttcol align='left'>Resource Type</ttcol>
      <ttcol align='left'>Reference</ttcol>
      <c>urn:ietf:params:scim: schemas:extension: ble:2.0:Device</c>
      <c>BLE Extension</c>
      <c>Device</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>Device</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>Device</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>Device</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>Device</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>Device</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>Device</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>Device</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, Paulo Jorge N. Correia, and Phil Hunt for
their reviews, and Nick Ross for his contribution to the Appendix.</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="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>




    </references>

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

<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="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 2491?>

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

<t>Draft 13:
  * post IANA and IETF LC</t>

<t>Drafts 10-12:
  * additional WGLC and shepherd comments</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>
<section anchor="fido-device-onboarding-example-flow"><name>Fido Device Onboarding Example Flow</name>

<t>The following diagrams are included to demonstrate how FDO can be used.  In this first diagram, a device
is onboarded not only to the device owner process, but also to the AAA server for initial onboarding.
The voucher contains a device certificate that is used by the AAA system for authentication.</t>

<figure><artwork><![CDATA[
 ,------.               ,------.               ,-------.
 |SCIM  |               |SCIM  |               |Owner  |   ,---.
 |Client|               |Server|               |Service|   |AAA|
 `---+--'               `---+--'               `---+---'   `-+-'
,------------------------------!.                  |         |  
|voucher contains              |_\                 |         |  
|an X.509 cert chain             |                 |         |  
`--------------------------------'                 |         |  
     |1 POST [FDO(voucher)] |                      |         |  
     |/HTTP                 |                      |         |  
     |--------------------->|                      |         |  
     |                      |                      |         |  
     |                      |----.                 |         |  
     |                      |    | 2 Recover X.509 |         |  
     |                      |<---' cert chain      |         |  
     |                      |      from voucher    |         |  
     |                      |                      |         |  
     |                      |                      |         |  
     |                      |3 Add device(voucher) |         |  
     |                      |/HTTP                 |         |  
     |                      |--------------------->|         |  
     |                      |                      |         |  
     |                      |     4 200 "ok"       |         |  
     |                      |<---------------------|         |  
     |                      |                      |         |  
     |                      |            5 add identity      |  
     |                      |------------------------------->|  
     |                      |                      |         |  
     |                      |              6 200 "ok"        |  
     |                      |<-------------------------------|  
     |                      |                      |         |  
     |     7 200 "ok"       |                      |         |  
     |<---------------------|                      |         |  
     |                      |                      |         |  
     |                      |                      |         |  
]]></artwork></figure>

<t>After this flow is complete, the device can then first provisionally onboard, and then later receive
a trust anchor through FDO's TO2 process.  This is shown below.</t>

<figure><artwork><![CDATA[
 ,-------.                          ,------.                           
 |Owner  |          ,---.           |Access|           ,------.        
 |Service|          |AAA|           |Point |           |Device|        
 `---+---'          `-+-'           `---+--'           `---+--'        
     |                |                 |        ,------------------!. 
     |                |                 |        |Device configured |_\
     |                |                 |        |with well-known     |
     |                |                 |        |RCOI and for trust  |
     |                |                 |        |on first use        |
     |                |                 |        `--------------------'
     |                |        ,---------------!.          |           
     |                |        |WLAN configured|_\         |           
     |                |        |with well-known  |         |           
     |                |        |RCOI             |         |           
     |                |        `-----------------'         |           
     |                |                 | 1 EAP-TLS/EAPOL  |           
     |                |                 |<-----------------|           
     |                |                 |                  |           
     |                |2 EAP-TLS/Radius |                  |           
     |                |<----------------|                  |           
     |                |                 |                  |           
     |                |            ,--------------------------!.       
     |                |            |Device skips              |_\      
     |                |            |server authentication       |      
     |                |            `----------------------------'      
     |                |3 Result=Success |                  |           
     |                |---------------->|                  |           
     |                |                 |                  |           
     |            ,-----------------------!.               |           
     |            |Limited access         |_\              |           
     |            |for now                  |              |           
     |            `-------------------------'              |           
     |                |                 |4 Result=Success  |           
     |                |                 |----------------->|           
     |                |                 |                  |           
     |                |    5 FDO TO2    |                  |           
     |<----------------------------------------------------|           
     |                |                 |                  |           
,-------------------------------------------------------------!.       
|FSIM, Runtime SSID,                                          |_\      
|Credentials incl.                                              |      
|local trust anchor                                             |      
`---------------------------------------------------------------'      
     |                |                 | 6 dissasociate   |           
     |                |                 |<-----------------|           
     |                |                 |                  |           
     |                |                 |7 EAP-TLS w/ LSC  |           
     |                |                 |<-----------------|           
     |                |                 |                  |           
     |                |                 |                  |           
     .                .        etc      .                  .           

]]></artwork></figure>

</section>


  </back>

<!-- ##markdown-source:
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

-->

</rfc>

