<?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-14" 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="May" day="20"/>

    
    
    <keyword>Internet-Draft</keyword>

    <abstract>


<?line 93?>

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

<section anchor="introduction"><name>Introduction</name>

<t>The Internet of Things presents a management challenge in many
dimensions. One of them is the ability to onboard and manage large
number of devices. There are many models for bootstrapping trust
between devices and network deployments. Indeed it is expected that
different manufacturers will make use of different methods.</t>

<t>SCIM (System for Cross Identity Management) <xref target="RFC7643"/> <xref target="RFC7644"/>
defines a protocol and a schema for provisioning of users. However, it
can easily be extended to provision device credentials and other
attributes into a network. The protocol and core schema were designed
to permit just such extensions. Bulk operations are supported. This is
good because often devices are procured in bulk.</t>

<t>A primary purpose of this specification is to provision the network
for onboarding and communications access to and from devices within a
local deployment based on the underlying capabilities of those
devices. The underlying security mechanisms of some devices range from
non-existent such as the Bluetooth Low Energy (BLE) "Just Works"
pairing method to a robust FIDO Device Onboard (FDO) mechanism.
Information from the SCIM server is dispatched to control functions
based on selected schema extensions to enable these communications
within a network.  The SCIM database is therefore essentially
equivalent to a network's Authentication, Authorization, and
Accounting (AAA) database, and should be carefully treated as such.</t>

<section anchor="why-scim-for-devices"><name>Why SCIM for devices?</name>
<t>Some might ask why SCIM is well suited for this purpose and not, for
example, NETCONF <xref target="RFC6241"/> or RESTCONF <xref target="RFC8040"/> with YANG
<xref target="RFC7950"/>. After all, there are all sorts of existing models
available. The answer is four fold:
- First, NETCONF and RESTCONF focus on <strong>configuration</strong> rather than
  provisioning.
- Second, SCIM is designed with inter-domain provisioning in mind.
  The use of HTTP as a substrate permits both user-based authentication
  for local provisioning applications, as well as OAUTH or certificate-
  based authentication.  the inter-domain nature of these operations
  does not expose local policy, which itself must be (and often is)
  configured with other APIs, many of which are not standardized.
- SCIM is also a familiar tool within the enterprise enviroment, used
  extensively to configure federated user accounts.  (Amusingly, one
  author noted a billboard in San Francisco highlighting a SCIM as
  part of a product capability.)
- Finally, once one chooses a vehicle such as SCIM, one is beholden
  to its data model.  The SCM data model is articulated in <xref target="RFC7643"/>.</t>

<t>This taken together with the fact that end devices are not intended to
be <strong>directly</strong> configured leave us with SCIM as the best standard option.</t>

</section>
<section anchor="protocol-participants"><name>Protocol Participants</name>

<t>In the normal SCIM model, it was presumed that large federated
deployments would be SCIM clients who provision and remove employees
and contractors as they enter and depart those deployments, and
federated services such as sales, payment, or conferencing services
would be the servers.</t>

<t>In the device model, the roles are reversed, and may be somewhat more
varied. A deployment network management system gateway (NMS gateway)
plays the role of the server, receiving information about devices that
are expected to be connected to its network. That server will apply
appropriate local policies regarding whether/how the device should be
connected.</t>

<t>The client may be one of a number of entities:</t>

<t><list style="symbols">
  <t>A vendor who is authorized to add devices to a network as part of
a sales transaction. This is similar to the sales integration
sometimes envisioned by Bootstrapping Remote Key Infrastructure
(BRSKI) <xref target="RFC8995"/>.</t>
  <t>A client application that administrators or employees use to add,
remove, or get information about devices. An example might be an
tablet or phone app that scans Wi-fi Easy Connect QR codes.</t>
</list></t>

<figure title="Basic Architecture" anchor="arch"><artwork><![CDATA[

                            +-----------------------------------+
                            |                                   |
    +-----------+   Request |  +---------+                      |
    | onboarding|------------->|  SCIM   |                      |
    |    app    |<-------------| Server  |                      |
    +-----------+  Ctrl Endpt  +---------+                      |
                            |                                   |
    +-----------+           |  +------------+         +-------+ |
    |  Control  |...........|..|    ALG     |.........|device | |
    |    App    |           |  +------------+         +-------+ |
    +-----------+           |                                   |
                            |                                   |
                            +-----------------------------------+

]]></artwork></figure>

<t>In <xref target="arch"/>, the onboarding app provides the device particulars. As
part of the response, the SCIM server might provide additional
information, especially in the case of non-IP devices, where an
application-layer gateway may need to be used to communicate with
the device. The control endpoint is one among a number of objects
that may be returned.</t>

</section>
<section anchor="schema-description"><name>Schema Description</name>

<t>RFC 7643 does not prescribe a language to describe a schema. We have
chosen the JSON schema language <xref target="JSONSChema"/> for this
purpose. The use of XML for SCIM devices is not supported.</t>

<t>Several additional schemas specify specific onboarding mechanisms,
such as BLE and Wi-fi Easy Connect.</t>

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

<t>Attributes defined in the device core schema and extensions comprise
characteristics and SCIM datatypes defined in Sections 2.2 and 2.3 of
the <xref target="RFC7643"/>. This specifciation does not define new
characteristics and datatypes for the SCIM attributes.</t>

</section>
<section anchor="terminology"><name>Terminology</name>
<t>The key words "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL
NOT", "SHOULD", "SHOULD NOT", "RECOMMENDED", "NOT RECOMMENDED",
"MAY", and "OPTIONAL" in this document are to be interpreted as
described in BCP 14 <xref target="RFC2119"/> <xref target="RFC8174"/> when, and only when, they
appear in all capitals, as shown here.</t>

</section>
</section>
<section anchor="resourcetype-device"><name>ResourceType Device</name>

<t>A new resource type 'Device' is specified. The "ResourceType" schema
specifies the metadata about a resource type (see section 6 of
<xref target="RFC7643"/>).  It comprises a core device schema and several
extension schemas. The core schema provides a minimal resource
representation, whereas extension schemas extend the core schema
depending on the device's capability. The JSON schema for Device
resource type is in <xref target="resource-schema"/>.</t>

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

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

<t>id</t>

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

<t>externalID</t>

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

<t>meta</t>

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

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

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

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

<t>displayName</t>

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

<t>active</t>

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

<t>mudUrl</t>

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

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

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

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

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

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

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

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

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

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

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

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

<t>The schema for "EndpointApp" is identified using the schema URI:
"urn:ietf:params:scim:schemas:core:2.0:EndpointApp". The following
attributes are defined in this schema.</t>

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

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

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

<t>applicationType</t>

<t>This attribute is of type "string" and represents the type of 
application. It will only contain two values; 'deviceControl' 
or 'telemetry'. 'deviceControl' is the application that sends commands
to control the device. 'telemetry' is the application that receives
data from the device. The attribute is required, and is not 
case-sensitive. The attribute is readOnly and should be returned 
by default. No uniqueness constraints are imposed on this attribute.</t>

<t>applicationName</t>

<t>The "applicationName" attribute is of type "string" and represents a
human readable name for the application. This attribute is required and
mutable. The attribute should be returned by default and there is no 
uniqueness contraint on the attribute.</t>

<t>clientToken</t>

<t>This attribute type string contains a token that the client will use
to authenticate itself. Each token may be a string up to 500
characters in length. It is not mutable, read-only, generated if
no certificateInfo object is provisioned, case sensitive and returned
by default if it exists.  The SCIM server should expect that client
tokens will be shared by the SCIM client with other components within
the client's infrastructure.</t>

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

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

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

<t>rootCA</t>

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

<t>subjectName</t>

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

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

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

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

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

<t>certificateInfo is preferred in situations where client functions
are federated such that different clients may connect for different
purposes.</t>

<figure><artwork><![CDATA[
<CODE BEGINS>
{
  "schemas": ["urn:ietf:params:scim:schemas:core:2.0:EndpointApp"],
  "id": "e9e30dba-f08f-4109-8486-d5c6a3316212",
  "applicationType": "deviceControl",
  "applicationName": "Device Control App 1",
  "certificateInfo": {
      "rootCA" : "MIIBIjAN...",
      "subjectName": "wwww.example.com"
  },
  "meta": {
    "resourceType": "EndpointApp",
    "created": "2022-01-23T04:56:22Z",
    "lastModified": "2022-05-13T04:42:34Z",
    "version": "W\/\"a330bc54f0671c9\"",
    "location": "https://example.com/v2/EndpointApp/e9e30dba-f08f
       -4109-8486-d5c6a3316212"
  }
}
<CODE ENDS>
]]></artwork></figure>

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

</section>
</section>
</section>
<section anchor="extensions"><name>SCIM Device Extensions</name>

<t>SCIM provides various extension schemas, their attributes, JSON
representation, and example object. The core schema is extended with a
new resource type, as described in <xref target="resource-schema"/>.  No
schemaExtensions list is specified in that definition.  Instead, an
IANA registry is created, where all values for "required" are set to
false.  All extensions to the Device schema MUST be registered via IANA,
as described in <xref target="device-schema-extensions"></xref>.  The schemas below demonstrate how
this model is to work.  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:
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="JSONSChema" target="https://json-schema.org/draft/2020-12/json-schema-core">
  <front>
    <title>JSON Schema- A Media Type for Describing JSON Documents</title>
    <author initials="A." surname="Wright" fullname="Austin Wright" role="editor">
      <organization></organization>
    </author>
    <author initials="H. A." surname="Andrews" fullname="Henry Andrews" role="editor">
      <organization></organization>
    </author>
    <author initials="B." surname="Hutton" fullname="Ben Hutton" role="editor">
      <organization>Postman</organization>
    </author>
    <author initials="G." surname="Dennis" fullname="Greg Dennis">
      <organization></organization>
    </author>
    <date year="2022" month="December"/>
  </front>
</reference>


<reference anchor="RFC7643">
  <front>
    <title>System for Cross-domain Identity Management: Core Schema</title>
    <author fullname="P. Hunt" initials="P." role="editor" surname="Hunt"/>
    <author fullname="K. Grizzle" initials="K." surname="Grizzle"/>
    <author fullname="E. Wahlstroem" initials="E." surname="Wahlstroem"/>
    <author fullname="C. Mortimore" initials="C." surname="Mortimore"/>
    <date month="September" year="2015"/>
    <abstract>
      <t>The System for Cross-domain Identity Management (SCIM) specifications are designed to make identity management in cloud-based applications and services easier. The specification suite builds upon experience with existing schemas and deployments, placing specific emphasis on simplicity of development and integration, while applying existing authentication, authorization, and privacy models. Its intent is to reduce the cost and complexity of user management operations by providing a common user schema and extension model as well as binding documents to provide patterns for exchanging this schema using HTTP.</t>
      <t>This document provides a platform-neutral schema and extension model for representing users and groups and other resource types in JSON format. This schema is intended for exchange and use with cloud service providers.</t>
    </abstract>
  </front>
  <seriesInfo name="RFC" value="7643"/>
  <seriesInfo name="DOI" value="10.17487/RFC7643"/>
</reference>

<reference anchor="RFC7644">
  <front>
    <title>System for Cross-domain Identity Management: Protocol</title>
    <author fullname="P. Hunt" initials="P." role="editor" surname="Hunt"/>
    <author fullname="K. Grizzle" initials="K." surname="Grizzle"/>
    <author fullname="M. Ansari" initials="M." surname="Ansari"/>
    <author fullname="E. Wahlstroem" initials="E." surname="Wahlstroem"/>
    <author fullname="C. Mortimore" initials="C." surname="Mortimore"/>
    <date month="September" year="2015"/>
    <abstract>
      <t>The System for Cross-domain Identity Management (SCIM) specification is an HTTP-based protocol that makes managing identities in multi-domain scenarios easier to support via a standardized service. Examples include, but are not limited to, enterprise-to-cloud service providers and inter-cloud scenarios. The specification suite seeks to build upon experience with existing schemas and deployments, placing specific emphasis on simplicity of development and integration, while applying existing authentication, authorization, and privacy models. SCIM's intent is to reduce the cost and complexity of user management operations by providing a common user schema, an extension model, and a service protocol defined by this document.</t>
    </abstract>
  </front>
  <seriesInfo name="RFC" value="7644"/>
  <seriesInfo name="DOI" value="10.17487/RFC7644"/>
</reference>

<reference anchor="RFC2119">
  <front>
    <title>Key words for use in RFCs to Indicate Requirement Levels</title>
    <author fullname="S. Bradner" initials="S." surname="Bradner"/>
    <date month="March" year="1997"/>
    <abstract>
      <t>In many standards track documents several words are used to signify the requirements in the specification. These words are often capitalized. This document defines these words as they should be interpreted in IETF documents. This document specifies an Internet Best Current Practices for the Internet Community, and requests discussion and suggestions for improvements.</t>
    </abstract>
  </front>
  <seriesInfo name="BCP" value="14"/>
  <seriesInfo name="RFC" value="2119"/>
  <seriesInfo name="DOI" value="10.17487/RFC2119"/>
</reference>

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

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

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

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




    </references>

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



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

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

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

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


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

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




    </references>


<?line 2463?>

<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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
AQA=

-->

</rfc>

