<?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.29 (Ruby 2.6.10) -->


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

<!ENTITY RFC7643 SYSTEM "https://bib.ietf.org/public/rfc/bibxml/reference.RFC.7643.xml">
<!ENTITY RFC7644 SYSTEM "https://bib.ietf.org/public/rfc/bibxml/reference.RFC.7644.xml">
<!ENTITY RFC2119 SYSTEM "https://bib.ietf.org/public/rfc/bibxml/reference.RFC.2119.xml">
<!ENTITY RFC8174 SYSTEM "https://bib.ietf.org/public/rfc/bibxml/reference.RFC.8174.xml">
<!ENTITY RFC8520 SYSTEM "https://bib.ietf.org/public/rfc/bibxml/reference.RFC.8520.xml">
<!ENTITY RFC4648 SYSTEM "https://bib.ietf.org/public/rfc/bibxml/reference.RFC.4648.xml">
<!ENTITY RFC5280 SYSTEM "https://bib.ietf.org/public/rfc/bibxml/reference.RFC.5280.xml">
<!ENTITY RFC6241 SYSTEM "https://bib.ietf.org/public/rfc/bibxml/reference.RFC.6241.xml">
<!ENTITY RFC8040 SYSTEM "https://bib.ietf.org/public/rfc/bibxml/reference.RFC.8040.xml">
<!ENTITY RFC7950 SYSTEM "https://bib.ietf.org/public/rfc/bibxml/reference.RFC.7950.xml">
<!ENTITY RFC8995 SYSTEM "https://bib.ietf.org/public/rfc/bibxml/reference.RFC.8995.xml">
<!ENTITY I-D.ietf-asdf-nipc SYSTEM "https://bib.ietf.org/public/rfc/bibxml3/reference.I-D.ietf-asdf-nipc.xml">
<!ENTITY I-D.brinckman-nipc SYSTEM "https://bib.ietf.org/public/rfc/bibxml3/reference.I-D.brinckman-nipc.xml">
]>


<rfc ipr="trust200902" docName="draft-ietf-scim-device-model-16" 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="July" day="04"/>

    
    
    <keyword>Internet-Draft</keyword>

    <abstract>


<?line 117?>

<t>The initial core schema for SCIM (System for Cross-domain 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 125?>

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

<t>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 managed as such.</t>

<section anchor="why-scim-for-devices"><name>Why SCIM for devices?</name>
<t>There are a number of existing models that might provide the basis for
a scheme for provisioning devices onto a network, including two
standardised by the IETF:  NETCONF <xref target="RFC6241"/> or RESTCONF <xref target="RFC8040"/>
with YANG <xref target="RFC7950"/>. SCIM was chosen for the following reasons:</t>

<t><list style="symbols">
  <t>NETCONF and RESTCONF focus on <strong>configuration</strong> rather than
provisioning.</t>
  <t>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.</t>
  <t>SCIM is also a familiar tool within the enterprise enviroment, used
extensively to configure federated user accounts.</t>
  <t>Finally, once one chooses a vehicle such as SCIM, one is beholden
to its data model.  The SCIM data model is more targeted to provisioning
as articulated in <xref target="RFC7643"/>.</t>
</list></t>

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

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

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

<t>In the device model, the roles are reversed, and may be somewhat more
varied. The SCIM server resides within a deployment and is used for
receiving information about devices that are expected to be connected
to its network. That server will apply appropriate local policies
regarding whether/how the device should be connected.</t>

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

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

<figure title="Basic Architecture - non-IP example" anchor="arch"><artset><artwork  type="svg"><svg xmlns="http://www.w3.org/2000/svg" version="1.1" height="304" width="496" viewBox="0 0 496 304" class="diagram" text-anchor="middle" font-family="monospace" font-size="13px" stroke-linecap="round">
<path d="M 8,64 L 8,112" fill="none" stroke="black"/>
<path d="M 8,176 L 8,224" fill="none" stroke="black"/>
<path d="M 104,64 L 104,112" fill="none" stroke="black"/>
<path d="M 104,176 L 104,224" fill="none" stroke="black"/>
<path d="M 200,32 L 200,72" fill="none" stroke="black"/>
<path d="M 200,128 L 200,256" fill="none" stroke="black"/>
<path d="M 224,64 L 224,112" fill="none" stroke="black"/>
<path d="M 224,176 L 224,208" fill="none" stroke="black"/>
<path d="M 264,120 L 264,168" fill="none" stroke="black"/>
<path d="M 304,64 L 304,112" fill="none" stroke="black"/>
<path d="M 328,176 L 328,208" fill="none" stroke="black"/>
<path d="M 408,176 L 408,208" fill="none" stroke="black"/>
<path d="M 472,176 L 472,208" fill="none" stroke="black"/>
<path d="M 488,32 L 488,256" fill="none" stroke="black"/>
<path d="M 200,32 L 488,32" fill="none" stroke="black"/>
<path d="M 8,64 L 104,64" fill="none" stroke="black"/>
<path d="M 224,64 L 304,64" fill="none" stroke="black"/>
<path d="M 112,80 L 216,80" fill="none" stroke="black"/>
<path d="M 112,96 L 216,96" fill="none" stroke="black"/>
<path d="M 8,112 L 104,112" fill="none" stroke="black"/>
<path d="M 224,112 L 304,112" fill="none" stroke="black"/>
<path d="M 8,176 L 104,176" fill="none" stroke="black"/>
<path d="M 224,176 L 328,176" fill="none" stroke="black"/>
<path d="M 408,176 L 472,176" fill="none" stroke="black"/>
<path d="M 224,208 L 328,208" fill="none" stroke="black"/>
<path d="M 408,208 L 472,208" fill="none" stroke="black"/>
<path d="M 8,224 L 104,224" fill="none" stroke="black"/>
<path d="M 200,256 L 488,256" fill="none" stroke="black"/>
<polygon class="arrowhead" points="272,168 260,162.4 260,173.6" fill="black" transform="rotate(90,264,168)"/>
<polygon class="arrowhead" points="224,80 212,74.4 212,85.6" fill="black" transform="rotate(0,216,80)"/>
<polygon class="arrowhead" points="120,96 108,90.4 108,101.6" fill="black" transform="rotate(180,112,96)"/>
<g class="text">
<text x="160" y="68">Request</text>
<text x="60" y="84">onboarding</text>
<text x="260" y="84">SCIM</text>
<text x="56" y="100">app</text>
<text x="260" y="100">Server</text>
<text x="140" y="116">Ctrl</text>
<text x="184" y="116">Endpt</text>
<text x="296" y="148">(device</text>
<text x="352" y="148">info)</text>
<text x="56" y="196">Control</text>
<text x="152" y="196">...........</text>
<text x="212" y="196">..</text>
<text x="272" y="196">ALG</text>
<text x="368" y="196">.........</text>
<text x="436" y="196">device</text>
<text x="56" y="212">App</text>
<text x="296" y="244">Local</text>
<text x="352" y="244">network</text>
</g>
</svg>
</artwork><artwork  type="ascii-art"><![CDATA[
                            +-----------------------------------+
                            |                                   |
    +-----------+   Request |  +---------+                      |
    | onboarding|------------->|  SCIM   |                      |
    |    app    |<-------------| Server  |                      |
    +-----------+  Ctrl Endpt  +---------+                      |
                            |       |                           |
                            |       |(device info)              |
                            |       v                           |
    +-----------+           |  +------------+         +-------+ |
    |  Control  |...........|..|    ALG     |.........|device | |
    |    App    |           |  +------------+         +-------+ |
    +-----------+           |                                   |
                            |         Local network             |
                            +-----------------------------------+

]]></artwork></artset></figure>

<t>In <xref target="arch"/>, the onboarding application (app) provides the device particulars,
which will vary based on the type of device, as indicated by the
selection of schema extensions. 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 (c.f., <xref target="I-D.ietf-asdf-nipc"/>). The control endpoint
is one among a number of objects
that may be returned.  That control endpoint will then communicate
with the application layer gateway (ALG) to reach the device.</t>

<figure title="Interaction with AAA" anchor="arch2"><artset><artwork  type="svg"><svg xmlns="http://www.w3.org/2000/svg" version="1.1" height="272" width="504" viewBox="0 0 504 272" class="diagram" text-anchor="middle" font-family="monospace" font-size="13px" stroke-linecap="round">
<path d="M 8,64 L 8,112" fill="none" stroke="black"/>
<path d="M 8,144 L 8,192" fill="none" stroke="black"/>
<path d="M 104,64 L 104,112" fill="none" stroke="black"/>
<path d="M 104,144 L 104,192" fill="none" stroke="black"/>
<path d="M 200,32 L 200,72" fill="none" stroke="black"/>
<path d="M 200,128 L 200,224" fill="none" stroke="black"/>
<path d="M 224,64 L 224,112" fill="none" stroke="black"/>
<path d="M 224,144 L 224,176" fill="none" stroke="black"/>
<path d="M 304,64 L 304,112" fill="none" stroke="black"/>
<path d="M 328,144 L 328,176" fill="none" stroke="black"/>
<path d="M 336,64 L 336,96" fill="none" stroke="black"/>
<path d="M 376,64 L 376,96" fill="none" stroke="black"/>
<path d="M 408,144 L 408,176" fill="none" stroke="black"/>
<path d="M 416,64 L 416,96" fill="none" stroke="black"/>
<path d="M 440,104 L 440,136" fill="none" stroke="black"/>
<path d="M 472,64 L 472,96" fill="none" stroke="black"/>
<path d="M 472,144 L 472,176" fill="none" stroke="black"/>
<path d="M 496,32 L 496,224" fill="none" stroke="black"/>
<path d="M 200,32 L 496,32" fill="none" stroke="black"/>
<path d="M 8,64 L 104,64" fill="none" stroke="black"/>
<path d="M 224,64 L 304,64" fill="none" stroke="black"/>
<path d="M 336,64 L 376,64" fill="none" stroke="black"/>
<path d="M 416,64 L 472,64" fill="none" stroke="black"/>
<path d="M 112,80 L 216,80" fill="none" stroke="black"/>
<path d="M 312,80 L 328,80" fill="none" stroke="black"/>
<path d="M 384,80 L 408,80" fill="none" stroke="black"/>
<path d="M 112,96 L 216,96" fill="none" stroke="black"/>
<path d="M 336,96 L 376,96" fill="none" stroke="black"/>
<path d="M 416,96 L 472,96" fill="none" stroke="black"/>
<path d="M 8,112 L 104,112" fill="none" stroke="black"/>
<path d="M 224,112 L 304,112" fill="none" stroke="black"/>
<path d="M 8,144 L 104,144" fill="none" stroke="black"/>
<path d="M 224,144 L 328,144" fill="none" stroke="black"/>
<path d="M 408,144 L 472,144" fill="none" stroke="black"/>
<path d="M 224,176 L 328,176" fill="none" stroke="black"/>
<path d="M 408,176 L 472,176" fill="none" stroke="black"/>
<path d="M 8,192 L 104,192" fill="none" stroke="black"/>
<path d="M 200,224 L 496,224" fill="none" stroke="black"/>
<polygon class="arrowhead" points="416,80 404,74.4 404,85.6" fill="black" transform="rotate(0,408,80)"/>
<polygon class="arrowhead" points="392,80 380,74.4 380,85.6" fill="black" transform="rotate(180,384,80)"/>
<polygon class="arrowhead" points="336,80 324,74.4 324,85.6" fill="black" transform="rotate(0,328,80)"/>
<polygon class="arrowhead" points="224,80 212,74.4 212,85.6" fill="black" transform="rotate(0,216,80)"/>
<polygon class="arrowhead" points="120,96 108,90.4 108,101.6" fill="black" transform="rotate(180,112,96)"/>
<g class="text">
<text x="160" y="68">Request</text>
<text x="60" y="84">onboarding</text>
<text x="260" y="84">SCIM</text>
<text x="360" y="84">AAA</text>
<text x="444" y="84">switch</text>
<text x="56" y="100">app</text>
<text x="260" y="100">Server</text>
<text x="140" y="116">Ctrl</text>
<text x="184" y="116">Endpt</text>
<text x="56" y="164">Control</text>
<text x="152" y="164">...........</text>
<text x="212" y="164">..</text>
<text x="272" y="164">router/fw</text>
<text x="368" y="164">.........</text>
<text x="436" y="164">device</text>
<text x="56" y="180">App</text>
<text x="304" y="212">Local</text>
<text x="360" y="212">network</text>
</g>
</svg>
</artwork><artwork  type="ascii-art"><![CDATA[
                            +------------------------------------+
                            |                                    |
    +-----------+   Request |  +---------+   +----+    +------+  |
    | onboarding|------------->|  SCIM   |-->| AAA|<-->|switch|  |
    |    app    |<-------------| Server  |   +----+    +------+  |
    +-----------+  Ctrl Endpt  +---------+                |      |
                            |                             |      |
    +-----------+           |  +------------+         +-------+  |
    |  Control  |...........|..| router/fw  |.........|device |  |
    |    App    |           |  +------------+         +-------+  |
    +-----------+           |                                    |
                            |          Local network             |
                            +------------------------------------+

]]></artwork></artset></figure>

<t><xref target="arch2"/> shows how IP-based endpoints can be provisioned.  In this
case, the onboarding application provisions a device via SCIM. The necessary
information is passed to the Authentication, Authorization, and Accounting
(AAA) subsystem, such that the device is
permitted to connect.  Once it is online, since the device is based
on IP, it will not need an ALG, but will use the normal IP
infrastructure to communicate with its control application.</t>

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

<t>RFC 7643 does not prescribe a language to describe a schema, but instead
uses narrative description with examples.  We follow that approach.
In addition, we provide non-normative JSON Schema 
<xref target="JSONSchema"/> and OpenAPI <xref target="OpenAPI"/> versions in the appendices for 
ease of implementation, neither of which existed when SCIM was originally
developed.  The only difference the authors note
between the normative schema representations is that JSON Schema and OpenAPI
do not have a means to express case sensitivity, and thus attributes that
are not case sensitive must be manually validated.</t>

<t>Several additional schemas specify specific onboarding mechanisms,
such as Bluetooth Low energy (BLE) <xref target="BLE54"/>, Wi-fi Easy Connect <xref target="DPP2"/>,
and FIDO Device Onboard <xref target="FDO11"/>.</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
<xref target="RFC7643"/>. This specification 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>

<t>The reader is also expected to be familiar with the narrative schema
language used in <xref target="RFC7643"/>.</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. This schema provides a minimal resource
representation, whereas extension schemas extend it
depending on the device's capability.</t>

<section anchor="commonatts"><name>Common Attributes</name>

<t>The Device schema contains three common attributes as defined in Section
3.1 of <xref target="RFC7643"/>.  No semantic or syntax changes are made here, but the
attributes are listed merely for completeness.</t>

<dl>
  <dt>id:</dt>
  <dd>
    <t>A required and unique attribute of the core device schema
 (see section 3.1 of <xref target="RFC7643"/>).</t>
  </dd>
  <dt>externalID:</dt>
  <dd>
    <t>An optional attribute (see section 3.1 of <xref target="RFC7643"/>).</t>
  </dd>
  <dt>meta:</dt>
  <dd>
    <t>A complex attribute and is required (see section 3.1 of <xref target="RFC7643"/>).</t>
  </dd>
</dl>

</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.  It is identified using the
schema URI:</t>

<t>"urn:ietf:params:scim:schemas:core:2.0:Device".</t>

<t>The following attributes are defined in the core device schema.</t>

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

<dl>
  <dt>displayName:</dt>
  <dd>
    <t>A string that 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>
  </dd>
  <dt>active:</dt>
  <dd>
    <t>A mutable boolean that 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 application sends to the
 controller for the devices any command will be rejected by the controller.</t>
  </dd>
  <dt>mudUrl:</dt>
  <dd>
    <t>A string that represents the URL to the Manufacturer Usage Description
 (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>
  </dd>
</dl>

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

<figure title="Core Device Example Entries" anchor="coreExample"><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>

</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 the 'EndpointApp' resource type. 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.</t>

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

<t>The EndpointApp schema is used to authorize 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"><name>Common Attributes</name>

<t>Like <xref target="commonatts"/> The EndpointApp schema contains the three common 
attributes specified in Section 3.1 <xref target="RFC7643"/>.</t>

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

<dl>
  <dt>applicationType:</dt>
  <dd>
    <t>A string that 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>
  </dd>
  <dt>applicationName:</dt>
  <dd>
    <t>a string that 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>
  </dd>
  <dt>clientToken:</dt>
  <dd>
    <t>A 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>
  </dd>
</dl>

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

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

<t>certificateInfo is a 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>

<dl>
  <dt>rootCA:</dt>
  <dd>
    <t>A base64-encoded string as
 described in <xref target="RFC4648"/> Section 4 a trust anchor certificate.
 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>
  </dd>
  <dt>subjectName:</dt>
  <dd>
    <t>when present, a string taht contains one of two one of two names:
</t>

    <t><list style="symbols">
      <t>a distinguished name as that will be present in the certificate
subject field, as described 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, mutable, singular and NOT case sensitive.</t>
  </dd>
</dl>

<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 or 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 title="Endpoint App Example" anchor="eaExample"><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": "www.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>

</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, Device.  No
schemaExtensions list is specified in that definition.  Instead,
IANA registry entries are 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>Bluetooth Low Energy (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>

<dl>
  <dt>deviceMacAddress:</dt>
  <dd>
    <t>A string value that represent a public MAC address assigned by the
 manufacturer. It is a unique 48-bit value. It is required, case
 insensitive, is mutable, and is returned by default. The ECMA
 regular expression pattern <xref target="ECMA"/> is the following:</t>
  </dd>
</dl>

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

<dl>
  <dt>isRandom:</dt>
  <dd>
    <t>A boolean flag taken from <xref target="BLE54"/>. 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>
  </dd>
  <dt>separateBroadcastAddress:</dt>
  <dd>
    <t>When present, this string represents an address 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>
  </dd>
  <dt>irk:</dt>
  <dd>
    <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>
  </dd>
  <dt>mobility:</dt>
  <dd>
    <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>
  </dd>
</dl>

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

<dl>
  <dt>versionSupport:</dt>
  <dd>
    <t>A multivalued set of strings that specifies 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", "5.4"]. It is required, mutable, and
 return as default.</t>
  </dd>
  <dt>pairingMethods:</dt>
  <dd>
    <t>An multivalued set of strings that specifies 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>
  </dd>
</dl>

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

<dl>
  <dt>key:</dt>
  <dd>
    <t>A string value, required and received from out-of-band
 sources such as NFC. It is case sensitive, mutable, and returned
 by default.</t>
  </dd>
  <dt>randomNumber:</dt>
  <dd>
    <t>An integer that represents a nonce added to the key. It is 
 a required attribute. It is mutable and returned by default.</t>
  </dd>
  <dt>confirmationNumber:</dt>
  <dd>
    <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>
  </dd>
</dl>

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

<figure title="BLE Example" anchor="btExample"><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 title="BLE with pairingOOB" anchor="btExample2"><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 title="BLE Pairing with both passkey and OOB" anchor="btExample3"><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>

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

<dl>
  <dt>dppVersion:</dt>
  <dd>
    <t>An integer that represents the version of DPP the device supports.
 This attribute is required, case insensitive, mutable, and
 returned by default.</t>
  </dd>
  <dt>bootstrapKey:</dt>
  <dd>
    <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>
  </dd>
  <dt>deviceMacAddress:</dt>
  <dd>
    <t>A MAC address stored as string. It is a unique 48-bit value. This attribut
 is optional, case insensitive, mutable, and returned by default.  Its form
 is identical to that of the deviceMacAddress for BLE devices.</t>
  </dd>
  <dt>serialNumber:</dt>
  <dd>
    <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>
  </dd>
</dl>

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

<dl>
  <dt>bootstrappingMethod:</dt>
  <dd>
    <t>One or more 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>
  </dd>
  <dt>classChannel:</dt>
  <dd>
    <t>One or more strings representing the 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>
  </dd>
</dl>

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

<figure title="DPP Example" anchor="dPPExample"><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>

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

<t>Note that this method is not likely to work properly with
MAC address randomization.</t>

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

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

<dl>
  <dt>deviceMacAddress:</dt>
  <dd>
    <t>This is the Ethernet address to be provisioned onto the network. It
 takes the identical form as found in the BLE extension.</t>
  </dd>
</dl>

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

<figure title="MAB Example" anchor="MABExample"><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>

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

<dl>
  <dt>fdoVoucher:</dt>
  <dd>
    <t>The voucher is formated as a PEM-encoded object in accordance with <xref target="FDO11"/>.</t>
  </dd>
</dl>

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

<figure title="FDO Example" anchor="fdoExample"><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>

</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 <xref target="Zigbee"/>. 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>

<dl>
  <dt>deviceEui64Address:</dt>
  <dd>
    <t>An EUI-64 (Extended Unique Identifier) device address stored as string.
 This attribute is required, case insensitive, mutable, and returned by
 default. It takes the same form as the deviceMACaddress in the BLE
 extension.</t>
  </dd>
</dl>

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

<dl>
  <dt>versionSupport:</dt>
  <dd>
    <t>One or more 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>
  </dd>
</dl>

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

<figure title="Zigbee Example" anchor="zigBeeExample"><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>

</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 of applications 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>

<dl>
  <dt>deviceControlEnterpriseEndpoint:</dt>
  <dd>
    <t>A string representing the URL of the
 enterprise endpoint to reach the enterprise gateway. When the enterprise
 receives the SCIM object from
 the onboarding application, it adds this attribute to it and sends it back as
 a response to the onboarding application. This attribute is required,
 case-sensitive, mutable, and returned by default. The uniqueness is
 enforced by the enterprise.</t>
  </dd>
  <dt>telemetryEnterpriseEndpoint:</dt>
  <dd>
    <t>A string representing a URL of the enterprise endpoint to reach the
 an enterprise gateway for telemetry. When the enterprise receives the SCIM object from
 the onboarding application, it adds this attribute to it and sends it back as
 a response to the onboarding application. 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>
  </dd>
</dl>

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

<dl>
  <dt>applications:</dt>
  <dd>
    <t>A  multivalued attribute of one or more complex attributes that represent
 a list of endpoint applications i.e., deviceControl and telemetry. Each
entry in the list comprises two attributes including "value" and "$ref".</t>
  </dd>
  <dt>value:</dt>
  <dd>
    <t>A string containingthe 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>
  </dd>
  <dt>$ref:</dt>
  <dd>
    <t>A reference  to the respective endpointApp resource object
 stored in the SCIM server. It is readOnly, required, case sensitive
 and returned by default.</t>
  </dd>
</dl>

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

<figure title="Endpoint Applications Extension Example" anchor="eaExtension"><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 <xref target="endpointappsext-extension-schema-json"/>, while
the openAPI representation is provided in <xref target="endpointappsext-extension-schema-openapi-representation"/>.</t>

</section>
</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 specify each operation below:</t>

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

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

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

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

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

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

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

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

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

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

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

</section>
<section anchor="logging"><name>Logging</name>

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

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

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

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

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

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

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

<t>IANA is requested to create the following extensions in the SCIM
Server-Related Schema URIs registry as described in <xref target="extensions"/>:</t>

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

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

<t>The authors would like to thank Bart Brinckman, Rohit Mohan, Lars
Streubesand, Christian Amsüss, Jason Livingwood, Mike Ounsworth, Monty
Wiseman, Geoffrey Cooper, Paulo Jorge N. Correia, Phil Hunt, and Elwyn
Davies for their reviews, and Nick Ross for his contribution to the Appendix.</t>

</section>


  </middle>

  <back>


<references title='References' anchor="sec-combined-references">

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

<reference anchor="BLE54" target="https://www.bluetooth.org/DocMan/handlers/DownloadDoc.ashx?doc_id=587177">
  <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="ECMA" target="https://ecma-international.org/publications-and-standards/standards/ecma-262/">
  <front>
    <title>ECMA-262, 16th Edition</title>
    <author >
      <organization>ECMA International</organization>
    </author>
    <date year="2025" month="June"/>
  </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="Zigbee" target="https://zigbeealliance.org/wp-content/uploads/2019/11/docs-05-3474-21-0csg-zigbee-specification.pdf">
  <front>
    <title>Zigbee Specification</title>
    <author >
      <organization>Zigbee Alliance</organization>
    </author>
    <date year="2015" month="August"/>
  </front>
</reference>
&RFC7643;
&RFC7644;
&RFC2119;
&RFC8174;
&RFC8520;
&RFC4648;
&RFC5280;


    </references>

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

<reference anchor="JSONSchema" target="https://json-schema.org/draft/2020-12/json-schema-core">
  <front>
    <title>JSON Schema- A Media Type for Describing JSON Documents</title>
    <author initials="A." surname="Wright" fullname="Austin Wright" role="editor">
      <organization></organization>
    </author>
    <author initials="H. A." surname="Andrews" fullname="Henry Andrews" role="editor">
      <organization></organization>
    </author>
    <author initials="B." surname="Hutton" fullname="Ben Hutton" role="editor">
      <organization>Postman</organization>
    </author>
    <author initials="G." surname="Dennis" fullname="Greg Dennis">
      <organization></organization>
    </author>
    <date year="2022" month="December"/>
  </front>
</reference>
<reference anchor="OpenAPI" target="https://swagger.io/specification/">
  <front>
    <title>OpenAPI Specification, Version 3.1.1</title>
    <author >
      <organization>swagger.io</organization>
    </author>
    <date year="2024" month="October"/>
  </front>
</reference>
&RFC6241;
&RFC8040;
&RFC7950;
&RFC8995;
&I-D.ietf-asdf-nipc;
&I-D.brinckman-nipc;


    </references>

</references>


<?line 1354?>

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

<t>Draft 16:</t>

<t><list style="symbols">
  <t>More DISCUSS resolution: make clear that JSON Schema is not normative</t>
  <t>Add reference for ECMA for regex</t>
  <t>lots of typo/spelling error cleanup</t>
  <t>Add figure labels for examples</t>
  <t>fix an aasvg rendering problem</t>
  <t>add some reference targets.</t>
  <t>Elwyn Davies review suggestions.</t>
</list></t>

<t>Drafts 14 and 15:
  * Resolve DISCUSSes</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="json-schema-representation"><name>JSON Schema 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>Core Device Schema</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</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</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</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</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</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</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 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>
<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>Core Device Schema OpenAPI Representation</name>

<t>OpenAPI representation of core device 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><artset><artwork  type="svg"><svg xmlns="http://www.w3.org/2000/svg" version="1.1" height="592" width="520" viewBox="0 0 520 592" class="diagram" text-anchor="middle" font-family="monospace" font-size="13px" stroke-linecap="round">
<path d="M 8,96 L 8,144" fill="none" stroke="black"/>
<path d="M 16,32 L 16,80" fill="none" stroke="black"/>
<path d="M 48,152 L 48,576" fill="none" stroke="black"/>
<path d="M 72,32 L 72,80" fill="none" stroke="black"/>
<path d="M 200,32 L 200,80" fill="none" stroke="black"/>
<path d="M 232,152 L 232,576" fill="none" stroke="black"/>
<path d="M 256,32 L 256,80" fill="none" stroke="black"/>
<path d="M 272,120 L 272,144" fill="none" stroke="black"/>
<path d="M 272,224 L 272,256" fill="none" stroke="black"/>
<path d="M 384,32 L 384,80" fill="none" stroke="black"/>
<path d="M 416,80 L 416,416" fill="none" stroke="black"/>
<path d="M 416,504 L 416,576" fill="none" stroke="black"/>
<path d="M 448,32 L 448,80" fill="none" stroke="black"/>
<path d="M 480,48 L 480,80" fill="none" stroke="black"/>
<path d="M 496,80 L 496,576" fill="none" stroke="black"/>
<path d="M 512,48 L 512,80" fill="none" stroke="black"/>
<path d="M 16,32 L 72,32" fill="none" stroke="black"/>
<path d="M 200,32 L 256,32" fill="none" stroke="black"/>
<path d="M 384,32 L 448,32" fill="none" stroke="black"/>
<path d="M 480,48 L 512,48" fill="none" stroke="black"/>
<path d="M 16,80 L 72,80" fill="none" stroke="black"/>
<path d="M 200,80 L 256,80" fill="none" stroke="black"/>
<path d="M 384,80 L 448,80" fill="none" stroke="black"/>
<path d="M 480,80 L 512,80" fill="none" stroke="black"/>
<path d="M 8,96 L 248,96" fill="none" stroke="black"/>
<path d="M 8,144 L 272,144" fill="none" stroke="black"/>
<path d="M 56,192 L 224,192" fill="none" stroke="black"/>
<path d="M 240,224 L 272,224" fill="none" stroke="black"/>
<path d="M 240,256 L 272,256" fill="none" stroke="black"/>
<path d="M 240,352 L 408,352" fill="none" stroke="black"/>
<path d="M 240,400 L 408,400" fill="none" stroke="black"/>
<path d="M 240,448 L 488,448" fill="none" stroke="black"/>
<path d="M 240,496 L 488,496" fill="none" stroke="black"/>
<path d="M 56,544 L 224,544" fill="none" stroke="black"/>
<path d="M 264,96 L 276,120" fill="none" stroke="black"/>
<polygon class="arrowhead" points="496,448 484,442.4 484,453.6" fill="black" transform="rotate(0,488,448)"/>
<polygon class="arrowhead" points="416,352 404,346.4 404,357.6" fill="black" transform="rotate(0,408,352)"/>
<polygon class="arrowhead" points="248,496 236,490.4 236,501.6" fill="black" transform="rotate(180,240,496)"/>
<polygon class="arrowhead" points="248,400 236,394.4 236,405.6" fill="black" transform="rotate(180,240,400)"/>
<polygon class="arrowhead" points="248,256 236,250.4 236,261.6" fill="black" transform="rotate(180,240,256)"/>
<polygon class="arrowhead" points="232,192 220,186.4 220,197.6" fill="black" transform="rotate(0,224,192)"/>
<polygon class="arrowhead" points="64,544 52,538.4 52,549.6" fill="black" transform="rotate(180,56,544)"/>
<g class="text">
<text x="36" y="52">SCIM</text>
<text x="220" y="52">SCIM</text>
<text x="408" y="52">Owner</text>
<text x="44" y="68">Client</text>
<text x="228" y="68">Server</text>
<text x="416" y="68">Service</text>
<text x="496" y="68">AAA</text>
<text x="256" y="100">!</text>
<text x="40" y="116">voucher</text>
<text x="108" y="116">contains</text>
<text x="260" y="116">|_</text>
<text x="20" y="132">an</text>
<text x="56" y="132">X.509</text>
<text x="100" y="132">cert</text>
<text x="144" y="132">chain</text>
<text x="56" y="164">1</text>
<text x="84" y="164">POST</text>
<text x="164" y="164">[FDO(voucher)]</text>
<text x="72" y="180">/HTTP</text>
<text x="288" y="244">2</text>
<text x="328" y="244">Recover</text>
<text x="384" y="244">X.509</text>
<text x="300" y="260">cert</text>
<text x="344" y="260">chain</text>
<text x="300" y="276">from</text>
<text x="352" y="276">voucher</text>
<text x="240" y="324">3</text>
<text x="264" y="324">Add</text>
<text x="344" y="324">device(voucher)</text>
<text x="256" y="340">/HTTP</text>
<text x="280" y="388">4</text>
<text x="304" y="388">200</text>
<text x="340" y="388">&quot;ok&quot;</text>
<text x="336" y="436">5</text>
<text x="360" y="436">add</text>
<text x="412" y="436">identity</text>
<text x="416" y="468">|</text>
<text x="352" y="484">6</text>
<text x="376" y="484">200</text>
<text x="412" y="484">&quot;ok&quot;</text>
<text x="96" y="532">7</text>
<text x="120" y="532">200</text>
<text x="156" y="532">&quot;ok&quot;</text>
</g>
</svg>
</artwork><artwork  type="ascii-art"><![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></artset></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><artset><artwork  type="svg"><svg xmlns="http://www.w3.org/2000/svg" version="1.1" height="864" width="576" viewBox="0 0 576 864" class="diagram" text-anchor="middle" font-family="monospace" font-size="13px" stroke-linecap="round">
<path d="M 8,640 L 8,704" fill="none" stroke="black"/>
<path d="M 16,32 L 16,80" fill="none" stroke="black"/>
<path d="M 48,80 L 48,632" fill="none" stroke="black"/>
<path d="M 48,712 L 48,824" fill="none" stroke="black"/>
<path d="M 80,32 L 80,80" fill="none" stroke="black"/>
<path d="M 152,480 L 152,528" fill="none" stroke="black"/>
<path d="M 168,48 L 168,80" fill="none" stroke="black"/>
<path d="M 184,80 L 184,472" fill="none" stroke="black"/>
<path d="M 184,536 L 184,600" fill="none" stroke="black"/>
<path d="M 184,712 L 184,824" fill="none" stroke="black"/>
<path d="M 200,48 L 200,80" fill="none" stroke="black"/>
<path d="M 256,192 L 256,256" fill="none" stroke="black"/>
<path d="M 288,368 L 288,416" fill="none" stroke="black"/>
<path d="M 296,32 L 296,80" fill="none" stroke="black"/>
<path d="M 328,80 L 328,184" fill="none" stroke="black"/>
<path d="M 328,264 L 328,360" fill="none" stroke="black"/>
<path d="M 328,424 L 328,472" fill="none" stroke="black"/>
<path d="M 328,536 L 328,600" fill="none" stroke="black"/>
<path d="M 328,712 L 328,824" fill="none" stroke="black"/>
<path d="M 352,32 L 352,80" fill="none" stroke="black"/>
<path d="M 360,504 L 360,528" fill="none" stroke="black"/>
<path d="M 400,96 L 400,176" fill="none" stroke="black"/>
<path d="M 400,216 L 400,256" fill="none" stroke="black"/>
<path d="M 448,48 L 448,80" fill="none" stroke="black"/>
<path d="M 480,184 L 480,360" fill="none" stroke="black"/>
<path d="M 480,424 L 480,632" fill="none" stroke="black"/>
<path d="M 480,712 L 480,824" fill="none" stroke="black"/>
<path d="M 504,48 L 504,80" fill="none" stroke="black"/>
<path d="M 520,392 L 520,416" fill="none" stroke="black"/>
<path d="M 520,664 L 520,704" fill="none" stroke="black"/>
<path d="M 568,120 L 568,176" fill="none" stroke="black"/>
<path d="M 16,32 L 80,32" fill="none" stroke="black"/>
<path d="M 296,32 L 352,32" fill="none" stroke="black"/>
<path d="M 168,48 L 200,48" fill="none" stroke="black"/>
<path d="M 448,48 L 504,48" fill="none" stroke="black"/>
<path d="M 16,80 L 80,80" fill="none" stroke="black"/>
<path d="M 168,80 L 200,80" fill="none" stroke="black"/>
<path d="M 296,80 L 352,80" fill="none" stroke="black"/>
<path d="M 448,80 L 504,80" fill="none" stroke="black"/>
<path d="M 400,96 L 544,96" fill="none" stroke="black"/>
<path d="M 400,176 L 568,176" fill="none" stroke="black"/>
<path d="M 256,192 L 376,192" fill="none" stroke="black"/>
<path d="M 256,256 L 400,256" fill="none" stroke="black"/>
<path d="M 336,288 L 472,288" fill="none" stroke="black"/>
<path d="M 192,336 L 320,336" fill="none" stroke="black"/>
<path d="M 288,368 L 496,368" fill="none" stroke="black"/>
<path d="M 288,416 L 520,416" fill="none" stroke="black"/>
<path d="M 192,448 L 320,448" fill="none" stroke="black"/>
<path d="M 152,480 L 336,480" fill="none" stroke="black"/>
<path d="M 152,528 L 360,528" fill="none" stroke="black"/>
<path d="M 336,560 L 472,560" fill="none" stroke="black"/>
<path d="M 56,608 L 472,608" fill="none" stroke="black"/>
<path d="M 8,640 L 496,640" fill="none" stroke="black"/>
<path d="M 8,704 L 520,704" fill="none" stroke="black"/>
<path d="M 336,736 L 472,736" fill="none" stroke="black"/>
<path d="M 336,784 L 472,784" fill="none" stroke="black"/>
<path d="M 352,480 L 364,504" fill="none" stroke="black"/>
<path d="M 512,640 L 524,664" fill="none" stroke="black"/>
<path d="M 392,192 L 404,216" fill="none" stroke="black"/>
<path d="M 512,368 L 524,392" fill="none" stroke="black"/>
<path d="M 560,96 L 572,120" fill="none" stroke="black"/>
<polygon class="arrowhead" points="480,560 468,554.4 468,565.6" fill="black" transform="rotate(0,472,560)"/>
<polygon class="arrowhead" points="344,784 332,778.4 332,789.6" fill="black" transform="rotate(180,336,784)"/>
<polygon class="arrowhead" points="344,736 332,730.4 332,741.6" fill="black" transform="rotate(180,336,736)"/>
<polygon class="arrowhead" points="344,288 332,282.4 332,293.6" fill="black" transform="rotate(180,336,288)"/>
<polygon class="arrowhead" points="328,448 316,442.4 316,453.6" fill="black" transform="rotate(0,320,448)"/>
<polygon class="arrowhead" points="200,336 188,330.4 188,341.6" fill="black" transform="rotate(180,192,336)"/>
<polygon class="arrowhead" points="64,608 52,602.4 52,613.6" fill="black" transform="rotate(180,56,608)"/>
<g class="text">
<text x="40" y="52">Owner</text>
<text x="324" y="52">Access</text>
<text x="48" y="68">Service</text>
<text x="184" y="68">AAA</text>
<text x="320" y="68">Point</text>
<text x="476" y="68">Device</text>
<text x="552" y="100">!</text>
<text x="428" y="116">Device</text>
<text x="500" y="116">configured</text>
<text x="556" y="116">|_</text>
<text x="420" y="132">with</text>
<text x="484" y="132">well-known</text>
<text x="420" y="148">RCOI</text>
<text x="456" y="148">and</text>
<text x="488" y="148">for</text>
<text x="528" y="148">trust</text>
<text x="412" y="164">on</text>
<text x="448" y="164">first</text>
<text x="488" y="164">use</text>
<text x="384" y="196">!</text>
<text x="276" y="212">WLAN</text>
<text x="348" y="212">configured|_</text>
<text x="276" y="228">with</text>
<text x="340" y="228">well-known</text>
<text x="276" y="244">RCOI</text>
<text x="344" y="276">1</text>
<text x="408" y="276">EAP-TLS/EAPOL</text>
<text x="192" y="324">2</text>
<text x="260" y="324">EAP-TLS/Radius</text>
<text x="504" y="372">!</text>
<text x="316" y="388">Device</text>
<text x="368" y="388">skips</text>
<text x="508" y="388">|_</text>
<text x="316" y="404">server</text>
<text x="404" y="404">authentication</text>
<text x="192" y="436">3</text>
<text x="260" y="436">Result=Success</text>
<text x="344" y="484">!</text>
<text x="184" y="500">Limited</text>
<text x="244" y="500">access</text>
<text x="348" y="500">|_</text>
<text x="168" y="516">for</text>
<text x="200" y="516">now</text>
<text x="336" y="548">4</text>
<text x="404" y="548">Result=Success</text>
<text x="224" y="596">5</text>
<text x="248" y="596">FDO</text>
<text x="280" y="596">TO2</text>
<text x="184" y="628">|</text>
<text x="328" y="628">|</text>
<text x="504" y="644">!</text>
<text x="32" y="660">FSIM,</text>
<text x="88" y="660">Runtime</text>
<text x="144" y="660">SSID,</text>
<text x="508" y="660">|_</text>
<text x="56" y="676">Credentials</text>
<text x="128" y="676">incl.</text>
<text x="32" y="692">local</text>
<text x="80" y="692">trust</text>
<text x="132" y="692">anchor</text>
<text x="344" y="724">6</text>
<text x="404" y="724">dissasociate</text>
<text x="336" y="772">7</text>
<text x="376" y="772">EAP-TLS</text>
<text x="420" y="772">w/</text>
<text x="448" y="772">LSC</text>
<text x="48" y="836">.</text>
<text x="184" y="836">.</text>
<text x="264" y="836">etc</text>
<text x="328" y="836">.</text>
<text x="480" y="836">.</text>
</g>
</svg>
</artwork><artwork  type="ascii-art"><![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></artset></figure>

</section>


  </back>

<!-- ##markdown-source:
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
HPNFlJzD0kp6P0zDgK1oYtHl1nQugckLyhuAb+SBRdTeqjRUAsny8/XV9eXG
8vr61urT7eUyaB5ir3yGzkDDFoysqR0qZws7VewxzDgOm+xXjUN7VEourwce
R4lG5ePYX9g3usA4bEJYgMfkcTzWuuSkSnu5Puk4bJKSw+NTj0Mn/EOZqNZr
h08neu1mPKZbcr/B35YDznMdcOphHHCiGn2sKcS+ZlUfRU4uN6Ac/Tcf5IPk
IXwXggYydyLChUR/W9m2wJOTYNRvywBcqtiDtDB/ObHTMpZfR19IuxKcS292
r272bv726s/J3w9+/WVtp/OXvx3I793OX7q7Bxed3bcnv74fjKq+H/09OTg5
OH73Q/KXN39dW/vvV++ggYPL/07Hf3139Ova4S/R1UHn+wpcmMU6tL9R9aG9
/2nyyK7R8sP8uhIQNg3FjjafPdt8/WrjfHNtc9PKlWij1NcEk3QtnGCSKGTv
+Ljg3EOSaDn3QDTeQy0/DmDTdV7aRoRCXCLbCVCZiYILv3srmaKByj4BuNyu
gFrvXxWP2HvGcIB6klXuB4Sxl7eoFagn0O1Kwxxaz08VYO1pDNG9QcrsBXqU
JoKMzoKguGqrYNACdWmlFtBHSPxbrPub1wZ6Aj8v/SGefoU7QW/FZEOacADS
E+t5boeYywChZ9Ec+OeOJSJP28BHTo1DEwPfovBKijrTyRUsFhukWOACq87Z
s2cLnSSxaVk2CFh/I+yWVvaSS3mXYiXb1TrvmZWIwOCOHgGfj7MPIFG1dXzX
VME94Mxk/pVzZAq1VDowQlaUcWwSy7sR/5+h3L5wEF8xBAk3YL0wg08nCDML
yjKo1JWziHwOvpniXjEU72G9NacYlirHOQ06WyNe3G9Ts9mXFM/EGMdn89N4
mj9+Na1PM63DTilwPWZtNterqjBVz/zyk2C+uk7GXYxHsaqBClPYN016uskn
cI/qq5KFPMuLWElZODpPobP+YXw2Fs7uU+UyD9gYAPoyHOrIdE4+aFvwdDw3
FstOkxgP1lqZZDzJWkNHa5EtUtreUaIPYLGBmafT0PmCekA8uqPoFhMGn1NV
mRup9xXiARksTYrZ02JFwzNN+aV6WzBR1/DfmplN9sNe0pTMDVJwzOGWH8vW
+r3krzxtZmgGCrmxii1bvjree2OyOepMnpQ3MUl7PsbVk6fGrk32ufGnfLK8
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
2v3xU6PydnE5Fl0FZz0edArP6jFmagPTMGa2EXz0FBZrgKTHTn9EQQko0IFs
yGe7ODbeOUyKMiAKSSL2mRS5dLTMlHGiNBL4VuRjs5hhAlNKu/mp4I00GV9c
omy5nKmzow0tCeojlPC/7BJTPZ0HMKZKeayC55irRjazL88RuKzv7I/uOl0c
lQ3MYtOeI3eZ70D8sts5JhXaucXi+l3eji1+yUVSmLL/LgluxVs1WDFBTKoQ
8kCwm78dmRGHQl+MMVAI5LsF2qEDGDdBFDU53RfdXKCdk52jA0JIyg1N+LdQ
O4nGeTRr6Jvzt1MpiS5Pa6e4OrbMbX81rZ27d687h9ba2KL3XO2UVueu/NIs
7dDqVD6aq50yVJfLL83QjnVnXe11jptnr09X4d+j14u2U2YNC45n4q26djbM
JE78XjjOFm2nNIsF25n40YLtTFBPzTaZpR1NubKrcFinoc7UjpgsXGuC++Ys
7UzUWZcnt/MU1KhsHI2+Px0T71oUzsVuqzTNT7TudctcMj9MaefudTgIKfSU
IWPuF60Q09pBfgK0b/JEprdTv8wFm8RicN4sYsKC7ZRG98dPtO7mxhYZIVFM
nLmdaTpE5fUo85piQ5ty5XTsbv/04E1DnYxjStN2enqw2yh3XXfldOxuB7g/
Uic/ysjwO0lKrmpJt4NJCyNXrl+knakGuinXFHpY0e82poHIfElpoBbdF78t
fy9/9ExzfHWzql6f7vy7zGuWdko4bG4Eo66qfsW9RSqm9/8A6cgKWb2RAQA=

-->

</rfc>

