<?xml version='1.0' encoding='utf-8'?>
<rfc xmlns:xi="http://www.w3.org/2001/XInclude" version="3" ipr="trust200902" docName="draft-ietf-scim-device-model-18" number="9944" updates="" obsoletes="" xml:lang="en" category="std" consensus="true" submissionType="IETF" tocInclude="true" sortRefs="true" symRefs="true" prepTime="2026-05-13T16:53:24" indexInclude="true" scripts="Common,Latin" tocDepth="3">
  <link href="https://datatracker.ietf.org/doc/draft-ietf-scim-device-model-18" rel="prev"/>
  <link href="https://dx.doi.org/10.17487/rfc9944" rel="alternate"/>
  <link href="urn:issn:2070-1721" rel="alternate"/>
  <front>
    <title abbrev="SCIM Device Schema Extensions">Device Schema Extensions to the System for Cross-Domain Identity Management (SCIM) Model</title>
    <seriesInfo name="RFC" value="9944" stream="IETF"/>
    <author initials="M." surname="Shahzad" fullname="Muhammad Shahzad">
      <organization showOnFrontPage="true">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</city>
          <region>NC</region>
          <code>27695-8206</code>
          <country>United States of America</country>
        </postal>
        <email>mshahza@ncsu.edu</email>
      </address>
    </author>
    <author initials="H." surname="Iqbal" fullname="Hassan Iqbal">
      <organization showOnFrontPage="true">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</city>
          <region>NC</region>
          <code>27695-8206</code>
          <country>United States of America</country>
        </postal>
        <email>hassaniqbal931@gmail.com</email>
      </address>
    </author>
    <author initials="E." surname="Lear" fullname="Eliot Lear">
      <organization showOnFrontPage="true">Cisco Systems</organization>
      <address>
        <postal>
          <street>Richtistrasse 7</street>
          <city>Wallisellen</city>
          <code>8304</code>
          <country>Switzerland</country>
        </postal>
        <phone>+41 44 878 9200</phone>
        <email>lear@cisco.com</email>
      </address>
    </author>
    <date month="05" year="2026"/>
    <area>SEC</area>
    <workgroup>scim</workgroup>
    <keyword>provisioning</keyword>
    <keyword>CRUD</keyword>
    <abstract pn="section-abstract">
      <t indent="0" pn="section-abstract-1">The initial core schema for the System for Cross-domain Identity Management
(SCIM) was designed for provisioning users. This memo specifies schema
extensions that enable provisioning of devices using various underlying
bootstrapping systems such as Wi-Fi Easy Connect, FIDO device onboarding
vouchers, Bluetooth Low Energy (BLE) passcodes, and MAC Authenticated Bypass (MAB).</t>
    </abstract>
    <boilerplate>
      <section anchor="status-of-memo" numbered="false" removeInRFC="false" toc="exclude" pn="section-boilerplate.1">
        <name slugifiedName="name-status-of-this-memo">Status of This Memo</name>
        <t indent="0" pn="section-boilerplate.1-1">
            This is an Internet Standards Track document.
        </t>
        <t indent="0" pn="section-boilerplate.1-2">
            This document is a product of the Internet Engineering Task Force
            (IETF).  It represents the consensus of the IETF community.  It has
            received public review and has been approved for publication by
            the Internet Engineering Steering Group (IESG).  Further
            information on Internet Standards is available in Section 2 of 
            RFC 7841.
        </t>
        <t indent="0" pn="section-boilerplate.1-3">
            Information about the current status of this document, any
            errata, and how to provide feedback on it may be obtained at
            <eref target="https://www.rfc-editor.org/info/rfc9944" brackets="none"/>.
        </t>
      </section>
      <section anchor="copyright" numbered="false" removeInRFC="false" toc="exclude" pn="section-boilerplate.2">
        <name slugifiedName="name-copyright-notice">Copyright Notice</name>
        <t indent="0" pn="section-boilerplate.2-1">
            Copyright (c) 2026 IETF Trust and the persons identified as the
            document authors. All rights reserved.
        </t>
        <t indent="0" pn="section-boilerplate.2-2">
            This document is subject to BCP 78 and the IETF Trust's Legal
            Provisions Relating to IETF Documents
            (<eref target="https://trustee.ietf.org/license-info" brackets="none"/>) in effect on the date of
            publication of this document. Please review these documents
            carefully, as they describe your rights and restrictions with
            respect to this document. Code Components extracted from this
            document must include Revised BSD License text as described in
            Section 4.e of the Trust Legal Provisions and are provided without
            warranty as described in the Revised BSD License.
        </t>
      </section>
    </boilerplate>
    <toc>
      <section anchor="toc" numbered="false" removeInRFC="false" toc="exclude" pn="section-toc.1">
        <name slugifiedName="name-table-of-contents">Table of Contents</name>
        <ul bare="true" empty="true" indent="2" spacing="compact" pn="section-toc.1-1">
          <li pn="section-toc.1-1.1">
            <t indent="0" pn="section-toc.1-1.1.1"><xref derivedContent="1" format="counter" sectionFormat="of" target="section-1"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-introduction">Introduction</xref></t>
            <ul bare="true" empty="true" indent="2" spacing="compact" pn="section-toc.1-1.1.2">
              <li pn="section-toc.1-1.1.2.1">
                <t indent="0" keepWithNext="true" pn="section-toc.1-1.1.2.1.1"><xref derivedContent="1.1" format="counter" sectionFormat="of" target="section-1.1"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-why-scim-for-devices">Why SCIM for Devices?</xref></t>
              </li>
              <li pn="section-toc.1-1.1.2.2">
                <t indent="0" keepWithNext="true" pn="section-toc.1-1.1.2.2.1"><xref derivedContent="1.2" format="counter" sectionFormat="of" target="section-1.2"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-protocol-participants">Protocol Participants</xref></t>
              </li>
              <li pn="section-toc.1-1.1.2.3">
                <t indent="0" keepWithNext="true" pn="section-toc.1-1.1.2.3.1"><xref derivedContent="1.3" format="counter" sectionFormat="of" target="section-1.3"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-schema-description">Schema Description</xref></t>
              </li>
              <li pn="section-toc.1-1.1.2.4">
                <t indent="0" pn="section-toc.1-1.1.2.4.1"><xref derivedContent="1.4" format="counter" sectionFormat="of" target="section-1.4"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-schema-representation">Schema Representation</xref></t>
              </li>
              <li pn="section-toc.1-1.1.2.5">
                <t indent="0" pn="section-toc.1-1.1.2.5.1"><xref derivedContent="1.5" format="counter" sectionFormat="of" target="section-1.5"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-terminology">Terminology</xref></t>
              </li>
            </ul>
          </li>
          <li pn="section-toc.1-1.2">
            <t indent="0" pn="section-toc.1-1.2.1"><xref derivedContent="2" format="counter" sectionFormat="of" target="section-2"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-resourcetype-device">ResourceType Device</xref></t>
            <ul bare="true" empty="true" indent="2" spacing="compact" pn="section-toc.1-1.2.2">
              <li pn="section-toc.1-1.2.2.1">
                <t indent="0" pn="section-toc.1-1.2.2.1.1"><xref derivedContent="2.1" format="counter" sectionFormat="of" target="section-2.1"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-common-attributes">Common Attributes</xref></t>
              </li>
            </ul>
          </li>
          <li pn="section-toc.1-1.3">
            <t indent="0" pn="section-toc.1-1.3.1"><xref derivedContent="3" format="counter" sectionFormat="of" target="section-3"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-scim-core-device-schema">SCIM Core Device Schema</xref></t>
            <ul bare="true" empty="true" indent="2" spacing="compact" pn="section-toc.1-1.3.2">
              <li pn="section-toc.1-1.3.2.1">
                <t indent="0" pn="section-toc.1-1.3.2.1.1"><xref derivedContent="3.1" format="counter" sectionFormat="of" target="section-3.1"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-singular-attributes">Singular Attributes</xref></t>
              </li>
            </ul>
          </li>
          <li pn="section-toc.1-1.4">
            <t indent="0" pn="section-toc.1-1.4.1"><xref derivedContent="4" format="counter" sectionFormat="of" target="section-4"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-groups">Groups</xref></t>
          </li>
          <li pn="section-toc.1-1.5">
            <t indent="0" pn="section-toc.1-1.5.1"><xref derivedContent="5" format="counter" sectionFormat="of" target="section-5"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-resource-type-endpointapp">Resource Type EndpointApp</xref></t>
          </li>
          <li pn="section-toc.1-1.6">
            <t indent="0" pn="section-toc.1-1.6.1"><xref derivedContent="6" format="counter" sectionFormat="of" target="section-6"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-scim-endpointapp-schema">SCIM EndpointApp Schema</xref></t>
            <ul bare="true" empty="true" indent="2" spacing="compact" pn="section-toc.1-1.6.2">
              <li pn="section-toc.1-1.6.2.1">
                <t indent="0" pn="section-toc.1-1.6.2.1.1"><xref derivedContent="6.1" format="counter" sectionFormat="of" target="section-6.1"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-common-attributes-2">Common Attributes</xref></t>
              </li>
              <li pn="section-toc.1-1.6.2.2">
                <t indent="0" pn="section-toc.1-1.6.2.2.1"><xref derivedContent="6.2" format="counter" sectionFormat="of" target="section-6.2"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-singular-attributes-2">Singular Attributes</xref></t>
              </li>
              <li pn="section-toc.1-1.6.2.3">
                <t indent="0" pn="section-toc.1-1.6.2.3.1"><xref derivedContent="6.3" format="counter" sectionFormat="of" target="section-6.3"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-complex-attributes">Complex Attributes</xref></t>
                <ul bare="true" empty="true" indent="2" spacing="compact" pn="section-toc.1-1.6.2.3.2">
                  <li pn="section-toc.1-1.6.2.3.2.1">
                    <t indent="0" pn="section-toc.1-1.6.2.3.2.1.1"><xref derivedContent="6.3.1" format="counter" sectionFormat="of" target="section-6.3.1"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-certificateinfo">certificateInfo</xref></t>
                  </li>
                </ul>
              </li>
            </ul>
          </li>
          <li pn="section-toc.1-1.7">
            <t indent="0" pn="section-toc.1-1.7.1"><xref derivedContent="7" format="counter" sectionFormat="of" target="section-7"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-scim-device-extensions">SCIM Device Extensions</xref></t>
            <ul bare="true" empty="true" indent="2" spacing="compact" pn="section-toc.1-1.7.2">
              <li pn="section-toc.1-1.7.2.1">
                <t indent="0" pn="section-toc.1-1.7.2.1.1"><xref derivedContent="7.1" format="counter" sectionFormat="of" target="section-7.1"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-bluetooth-low-energy-ble-ex">Bluetooth Low Energy (BLE) Extension</xref></t>
                <ul bare="true" empty="true" indent="2" spacing="compact" pn="section-toc.1-1.7.2.1.2">
                  <li pn="section-toc.1-1.7.2.1.2.1">
                    <t indent="0" pn="section-toc.1-1.7.2.1.2.1.1"><xref derivedContent="7.1.1" format="counter" sectionFormat="of" target="section-7.1.1"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-singular-attributes-3">Singular Attributes</xref></t>
                  </li>
                  <li pn="section-toc.1-1.7.2.1.2.2">
                    <t indent="0" pn="section-toc.1-1.7.2.1.2.2.1"><xref derivedContent="7.1.2" format="counter" sectionFormat="of" target="section-7.1.2"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-multivalued-attributes">Multivalued Attributes</xref></t>
                  </li>
                  <li pn="section-toc.1-1.7.2.1.2.3">
                    <t indent="0" pn="section-toc.1-1.7.2.1.2.3.1"><xref derivedContent="7.1.3" format="counter" sectionFormat="of" target="section-7.1.3"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-ble-pairing-method-extensio">BLE Pairing Method Extensions</xref></t>
                  </li>
                </ul>
              </li>
              <li pn="section-toc.1-1.7.2.2">
                <t indent="0" pn="section-toc.1-1.7.2.2.1"><xref derivedContent="7.2" format="counter" sectionFormat="of" target="section-7.2"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-wi-fi-easy-connect-extensio">Wi-Fi Easy Connect Extension</xref></t>
                <ul bare="true" empty="true" indent="2" spacing="compact" pn="section-toc.1-1.7.2.2.2">
                  <li pn="section-toc.1-1.7.2.2.2.1">
                    <t indent="0" pn="section-toc.1-1.7.2.2.2.1.1"><xref derivedContent="7.2.1" format="counter" sectionFormat="of" target="section-7.2.1"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-singular-attributes-4">Singular Attributes</xref></t>
                  </li>
                  <li pn="section-toc.1-1.7.2.2.2.2">
                    <t indent="0" pn="section-toc.1-1.7.2.2.2.2.1"><xref derivedContent="7.2.2" format="counter" sectionFormat="of" target="section-7.2.2"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-multivalued-attributes-2">Multivalued Attributes</xref></t>
                  </li>
                </ul>
              </li>
              <li pn="section-toc.1-1.7.2.3">
                <t indent="0" pn="section-toc.1-1.7.2.3.1"><xref derivedContent="7.3" format="counter" sectionFormat="of" target="section-7.3"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-ethernet-mab-extension">Ethernet MAB Extension</xref></t>
                <ul bare="true" empty="true" indent="2" spacing="compact" pn="section-toc.1-1.7.2.3.2">
                  <li pn="section-toc.1-1.7.2.3.2.1">
                    <t indent="0" pn="section-toc.1-1.7.2.3.2.1.1"><xref derivedContent="7.3.1" format="counter" sectionFormat="of" target="section-7.3.1"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-single-attribute">Single Attribute</xref></t>
                  </li>
                </ul>
              </li>
              <li pn="section-toc.1-1.7.2.4">
                <t indent="0" pn="section-toc.1-1.7.2.4.1"><xref derivedContent="7.4" format="counter" sectionFormat="of" target="section-7.4"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-fido-device-onboard-extensi">FIDO Device Onboard Extension</xref></t>
                <ul bare="true" empty="true" indent="2" spacing="compact" pn="section-toc.1-1.7.2.4.2">
                  <li pn="section-toc.1-1.7.2.4.2.1">
                    <t indent="0" pn="section-toc.1-1.7.2.4.2.1.1"><xref derivedContent="7.4.1" format="counter" sectionFormat="of" target="section-7.4.1"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-single-attribute-2">Single Attribute</xref></t>
                  </li>
                </ul>
              </li>
              <li pn="section-toc.1-1.7.2.5">
                <t indent="0" pn="section-toc.1-1.7.2.5.1"><xref derivedContent="7.5" format="counter" sectionFormat="of" target="section-7.5"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-zigbee-extension">Zigbee Extension</xref></t>
                <ul bare="true" empty="true" indent="2" spacing="compact" pn="section-toc.1-1.7.2.5.2">
                  <li pn="section-toc.1-1.7.2.5.2.1">
                    <t indent="0" pn="section-toc.1-1.7.2.5.2.1.1"><xref derivedContent="7.5.1" format="counter" sectionFormat="of" target="section-7.5.1"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-singular-attribute">Singular Attribute</xref></t>
                  </li>
                  <li pn="section-toc.1-1.7.2.5.2.2">
                    <t indent="0" pn="section-toc.1-1.7.2.5.2.2.1"><xref derivedContent="7.5.2" format="counter" sectionFormat="of" target="section-7.5.2"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-multivalued-attribute">Multivalued Attribute</xref></t>
                  </li>
                </ul>
              </li>
              <li pn="section-toc.1-1.7.2.6">
                <t indent="0" pn="section-toc.1-1.7.2.6.1"><xref derivedContent="7.6" format="counter" sectionFormat="of" target="section-7.6"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-the-endpoint-applications-e">The Endpoint Applications Extension Schema</xref></t>
                <ul bare="true" empty="true" indent="2" spacing="compact" pn="section-toc.1-1.7.2.6.2">
                  <li pn="section-toc.1-1.7.2.6.2.1">
                    <t indent="0" pn="section-toc.1-1.7.2.6.2.1.1"><xref derivedContent="7.6.1" format="counter" sectionFormat="of" target="section-7.6.1"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-singular-attributes-5">Singular Attributes</xref></t>
                  </li>
                  <li pn="section-toc.1-1.7.2.6.2.2">
                    <t indent="0" pn="section-toc.1-1.7.2.6.2.2.1"><xref derivedContent="7.6.2" format="counter" sectionFormat="of" target="section-7.6.2"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-multivalued-attribute-2">Multivalued Attribute</xref></t>
                  </li>
                </ul>
              </li>
            </ul>
          </li>
          <li pn="section-toc.1-1.8">
            <t indent="0" pn="section-toc.1-1.8.1"><xref derivedContent="8" format="counter" sectionFormat="of" target="section-8"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-security-considerations">Security Considerations</xref></t>
            <ul bare="true" empty="true" indent="2" spacing="compact" pn="section-toc.1-1.8.2">
              <li pn="section-toc.1-1.8.2.1">
                <t indent="0" pn="section-toc.1-1.8.2.1.1"><xref derivedContent="8.1" format="counter" sectionFormat="of" target="section-8.1"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-scim-operations">SCIM Operations</xref></t>
                <ul bare="true" empty="true" indent="2" spacing="compact" pn="section-toc.1-1.8.2.1.2">
                  <li pn="section-toc.1-1.8.2.1.2.1">
                    <t indent="0" pn="section-toc.1-1.8.2.1.2.1.1"><xref derivedContent="8.1.1" format="counter" sectionFormat="of" target="section-8.1.1"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-unauthorized-object-creatio">Unauthorized Object Creation</xref></t>
                  </li>
                </ul>
              </li>
              <li pn="section-toc.1-1.8.2.2">
                <t indent="0" pn="section-toc.1-1.8.2.2.1"><xref derivedContent="8.2" format="counter" sectionFormat="of" target="section-8.2"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-object-deletion">Object Deletion</xref></t>
              </li>
              <li pn="section-toc.1-1.8.2.3">
                <t indent="0" pn="section-toc.1-1.8.2.3.1"><xref derivedContent="8.3" format="counter" sectionFormat="of" target="section-8.3"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-read-operations">Read Operations</xref></t>
              </li>
              <li pn="section-toc.1-1.8.2.4">
                <t indent="0" pn="section-toc.1-1.8.2.4.1"><xref derivedContent="8.4" format="counter" sectionFormat="of" target="section-8.4"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-update-operations">Update Operations</xref></t>
              </li>
              <li pn="section-toc.1-1.8.2.5">
                <t indent="0" pn="section-toc.1-1.8.2.5.1"><xref derivedContent="8.5" format="counter" sectionFormat="of" target="section-8.5"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-higher-level-protection-for">Higher Level Protection for Certain Systems</xref></t>
              </li>
              <li pn="section-toc.1-1.8.2.6">
                <t indent="0" pn="section-toc.1-1.8.2.6.1"><xref derivedContent="8.6" format="counter" sectionFormat="of" target="section-8.6"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-logging">Logging</xref></t>
              </li>
            </ul>
          </li>
          <li pn="section-toc.1-1.9">
            <t indent="0" pn="section-toc.1-1.9.1"><xref derivedContent="9" format="counter" sectionFormat="of" target="section-9"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-iana-considerations">IANA Considerations</xref></t>
            <ul bare="true" empty="true" indent="2" spacing="compact" pn="section-toc.1-1.9.2">
              <li pn="section-toc.1-1.9.2.1">
                <t indent="0" pn="section-toc.1-1.9.2.1.1"><xref derivedContent="9.1" format="counter" sectionFormat="of" target="section-9.1"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-new-schemas">New Schemas</xref></t>
              </li>
              <li pn="section-toc.1-1.9.2.2">
                <t indent="0" pn="section-toc.1-1.9.2.2.1"><xref derivedContent="9.2" format="counter" sectionFormat="of" target="section-9.2"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-device-schema-extensions">Device Schema Extensions</xref></t>
              </li>
            </ul>
          </li>
          <li pn="section-toc.1-1.10">
            <t indent="0" pn="section-toc.1-1.10.1"><xref derivedContent="10" format="counter" sectionFormat="of" target="section-10"/>. <xref derivedContent="" format="title" sectionFormat="of" target="name-references">References</xref></t>
            <ul bare="true" empty="true" indent="2" spacing="compact" pn="section-toc.1-1.10.2">
              <li pn="section-toc.1-1.10.2.1">
                <t indent="0" pn="section-toc.1-1.10.2.1.1"><xref derivedContent="10.1" format="counter" sectionFormat="of" target="section-10.1"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-normative-references">Normative References</xref></t>
              </li>
              <li pn="section-toc.1-1.10.2.2">
                <t indent="0" pn="section-toc.1-1.10.2.2.1"><xref derivedContent="10.2" format="counter" sectionFormat="of" target="section-10.2"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-informative-references">Informative References</xref></t>
              </li>
            </ul>
          </li>
          <li pn="section-toc.1-1.11">
            <t indent="0" pn="section-toc.1-1.11.1"><xref derivedContent="Appendix A" format="default" sectionFormat="of" target="section-appendix.a"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-json-schema-representation">JSON Schema Representation</xref></t>
            <ul bare="true" empty="true" indent="2" spacing="compact" pn="section-toc.1-1.11.2">
              <li pn="section-toc.1-1.11.2.1">
                <t indent="0" pn="section-toc.1-1.11.2.1.1"><xref derivedContent="A.1" format="counter" sectionFormat="of" target="section-appendix.a.1"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-resource-schema">Resource Schema</xref></t>
              </li>
              <li pn="section-toc.1-1.11.2.2">
                <t indent="0" pn="section-toc.1-1.11.2.2.1"><xref derivedContent="A.2" format="counter" sectionFormat="of" target="section-appendix.a.2"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-core-device-schema">Core Device Schema</xref></t>
              </li>
              <li pn="section-toc.1-1.11.2.3">
                <t indent="0" pn="section-toc.1-1.11.2.3.1"><xref derivedContent="A.3" format="counter" sectionFormat="of" target="section-appendix.a.3"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-endpointapp-schema">EndpointApp Schema</xref></t>
              </li>
              <li pn="section-toc.1-1.11.2.4">
                <t indent="0" pn="section-toc.1-1.11.2.4.1"><xref derivedContent="A.4" format="counter" sectionFormat="of" target="section-appendix.a.4"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-ble-extension-schema">BLE Extension Schema</xref></t>
              </li>
              <li pn="section-toc.1-1.11.2.5">
                <t indent="0" pn="section-toc.1-1.11.2.5.1"><xref derivedContent="A.5" format="counter" sectionFormat="of" target="section-appendix.a.5"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-dpp-extension-schema">DPP Extension Schema</xref></t>
              </li>
              <li pn="section-toc.1-1.11.2.6">
                <t indent="0" pn="section-toc.1-1.11.2.6.1"><xref derivedContent="A.6" format="counter" sectionFormat="of" target="section-appendix.a.6"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-ethernet-mab-extension-sche">Ethernet MAB Extension Schema</xref></t>
              </li>
              <li pn="section-toc.1-1.11.2.7">
                <t indent="0" pn="section-toc.1-1.11.2.7.1"><xref derivedContent="A.7" format="counter" sectionFormat="of" target="section-appendix.a.7"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-fdo-extension-schema">FDO Extension Schema</xref></t>
              </li>
              <li pn="section-toc.1-1.11.2.8">
                <t indent="0" pn="section-toc.1-1.11.2.8.1"><xref derivedContent="A.8" format="counter" sectionFormat="of" target="section-appendix.a.8"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-zigbee-extension-schema">Zigbee Extension Schema</xref></t>
              </li>
              <li pn="section-toc.1-1.11.2.9">
                <t indent="0" pn="section-toc.1-1.11.2.9.1"><xref derivedContent="A.9" format="counter" sectionFormat="of" target="section-appendix.a.9"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-endpointappsext-extension-s">endpointAppsExt Extension Schema</xref></t>
              </li>
            </ul>
          </li>
          <li pn="section-toc.1-1.12">
            <t indent="0" pn="section-toc.1-1.12.1"><xref derivedContent="Appendix B" format="default" sectionFormat="of" target="section-appendix.b"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-openapi-representation">OpenAPI Representation</xref></t>
            <ul bare="true" empty="true" indent="2" spacing="compact" pn="section-toc.1-1.12.2">
              <li pn="section-toc.1-1.12.2.1">
                <t indent="0" pn="section-toc.1-1.12.2.1.1"><xref derivedContent="B.1" format="counter" sectionFormat="of" target="section-appendix.b.1"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-core-device-schema-openapi-">Core Device Schema OpenAPI Representation</xref></t>
              </li>
              <li pn="section-toc.1-1.12.2.2">
                <t indent="0" pn="section-toc.1-1.12.2.2.1"><xref derivedContent="B.2" format="counter" sectionFormat="of" target="section-appendix.b.2"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-endpointapp-schema-openapi-">EndpointApp Schema OpenAPI Representation</xref></t>
              </li>
              <li pn="section-toc.1-1.12.2.3">
                <t indent="0" pn="section-toc.1-1.12.2.3.1"><xref derivedContent="B.3" format="counter" sectionFormat="of" target="section-appendix.b.3"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-ble-extension-schema-openap">BLE Extension Schema OpenAPI Representation</xref></t>
              </li>
              <li pn="section-toc.1-1.12.2.4">
                <t indent="0" pn="section-toc.1-1.12.2.4.1"><xref derivedContent="B.4" format="counter" sectionFormat="of" target="section-appendix.b.4"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-dpp-extension-schema-openap">DPP Extension Schema OpenAPI Representation</xref></t>
              </li>
              <li pn="section-toc.1-1.12.2.5">
                <t indent="0" pn="section-toc.1-1.12.2.5.1"><xref derivedContent="B.5" format="counter" sectionFormat="of" target="section-appendix.b.5"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-ethernet-mab-extension-schem">Ethernet MAB Extension Schema OpenAPI Representation</xref></t>
              </li>
              <li pn="section-toc.1-1.12.2.6">
                <t indent="0" pn="section-toc.1-1.12.2.6.1"><xref derivedContent="B.6" format="counter" sectionFormat="of" target="section-appendix.b.6"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-fdo-extension-schema-openap">FDO Extension Schema OpenAPI Representation</xref></t>
              </li>
              <li pn="section-toc.1-1.12.2.7">
                <t indent="0" pn="section-toc.1-1.12.2.7.1"><xref derivedContent="B.7" format="counter" sectionFormat="of" target="section-appendix.b.7"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-zigbee-extension-schema-ope">Zigbee Extension Schema OpenAPI Representation</xref></t>
              </li>
              <li pn="section-toc.1-1.12.2.8">
                <t indent="0" pn="section-toc.1-1.12.2.8.1"><xref derivedContent="B.8" format="counter" sectionFormat="of" target="section-appendix.b.8"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-endpointappsext-extension-sc">endpointAppsExt Extension Schema OpenAPI Representation</xref></t>
              </li>
            </ul>
          </li>
          <li pn="section-toc.1-1.13">
            <t indent="0" pn="section-toc.1-1.13.1"><xref derivedContent="Appendix C" format="default" sectionFormat="of" target="section-appendix.c"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-fido-device-onboarding-exam">FIDO Device Onboarding Example Flow</xref></t>
          </li>
          <li pn="section-toc.1-1.14">
            <t indent="0" pn="section-toc.1-1.14.1"><xref derivedContent="" format="none" sectionFormat="of" target="section-appendix.d"/><xref derivedContent="" format="title" sectionFormat="of" target="name-acknowledgments">Acknowledgments</xref></t>
          </li>
          <li pn="section-toc.1-1.15">
            <t indent="0" pn="section-toc.1-1.15.1"><xref derivedContent="" format="none" sectionFormat="of" target="section-appendix.e"/><xref derivedContent="" format="title" sectionFormat="of" target="name-authors-addresses">Authors' Addresses</xref></t>
          </li>
        </ul>
      </section>
    </toc>
  </front>
  <middle>
    <section anchor="introduction" numbered="true" removeInRFC="false" toc="include" pn="section-1">
      <name slugifiedName="name-introduction">Introduction</name>
      <t indent="0" pn="section-1-1">The Internet of Things presents a management challenge in many
dimensions. One of them is the ability to onboard and manage a 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 indent="0" pn="section-1-2">The System for Cross-domain Identity Management (SCIM) <xref target="RFC7643" format="default" sectionFormat="of" derivedContent="RFC7643"/> <xref target="RFC7644" format="default" sectionFormat="of" derivedContent="RFC7644"/>
defines a protocol and a schema for the 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 indent="0" pn="section-1-3">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 indent="0" pn="section-1-4">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" numbered="true" removeInRFC="false" toc="include" pn="section-1.1">
        <name slugifiedName="name-why-scim-for-devices">Why SCIM for Devices?</name>
        <t indent="0" pn="section-1.1-1">There are a number of existing models that might provide the basis for
a scheme for provisioning devices onto a network, including two
standardized by the IETF: NETCONF <xref target="RFC6241" format="default" sectionFormat="of" derivedContent="RFC6241"/> or RESTCONF <xref target="RFC8040" format="default" sectionFormat="of" derivedContent="RFC8040"/>
with YANG <xref target="RFC7950" format="default" sectionFormat="of" derivedContent="RFC7950"/>. SCIM was chosen for the following reasons:</t>
        <ul spacing="normal" bare="false" empty="false" indent="3" pn="section-1.1-2">
          <li pn="section-1.1-2.1">
            <t indent="0" pn="section-1.1-2.1.1">NETCONF and RESTCONF focus on <strong>configuration</strong> rather than
provisioning.</t>
          </li>
          <li pn="section-1.1-2.2">
            <t indent="0" pn="section-1.1-2.2.1">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>
          </li>
          <li pn="section-1.1-2.3">
            <t indent="0" pn="section-1.1-2.3.1">SCIM is also a familiar tool within the enterprise environment, used
extensively to configure federated user accounts.</t>
          </li>
          <li pn="section-1.1-2.4">
            <t indent="0" pn="section-1.1-2.4.1">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" format="default" sectionFormat="of" derivedContent="RFC7643"/>.</t>
          </li>
        </ul>
        <t indent="0" pn="section-1.1-3">This taken together with the fact that end devices are not intended to
be <strong>directly</strong> configured leaves us with SCIM as the best standard option.</t>
      </section>
      <section anchor="protocol-participants" numbered="true" removeInRFC="false" toc="include" pn="section-1.2">
        <name slugifiedName="name-protocol-participants">Protocol Participants</name>
        <t indent="0" pn="section-1.2-1">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 indent="0" pn="section-1.2-2">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 indent="0" pn="section-1.2-3">The client may be one of a number of entities:</t>
        <ul spacing="normal" bare="false" empty="false" indent="3" pn="section-1.2-4">
          <li pn="section-1.2-4.1">
            <t indent="0" pn="section-1.2-4.1.1">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 Secure Key Infrastructure
(BRSKI) <xref target="RFC8995" format="default" sectionFormat="of" derivedContent="RFC8995"/>.</t>
          </li>
          <li pn="section-1.2-4.2">
            <t indent="0" pn="section-1.2-4.2.1">A client application that administrators or employees use to add,
remove, or get information about devices. An example might be a
tablet or phone app that scans Wi-Fi Easy Connect QR codes.</t>
          </li>
        </ul>
        <figure anchor="arch" align="left" suppress-title="false" pn="figure-1">
          <name slugifiedName="name-basic-architecture-non-ip-e">Basic Architecture - Non-IP Example</name>
          <artset pn="section-1.2-5.1">
            <artwork type="svg" align="left" pn="section-1.2-5.1.1"><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" align="left" pn="section-1.2-5.1.2">
                            +-----------------------------------+
                            |                                   |
    +-----------+   Request |  +---------+                      |
    | Onboarding|-------------&gt;|  SCIM   |                      |
    |    App    |&lt;-------------| Server  |                      |
    +-----------+  Ctrl Endpt  +---------+                      |
                            |       |                           |
                            |       |(Device Info)              |
                            |       v                           |
    +-----------+           |  +------------+         +-------+ |
    |  Control  |...........|..|    ALG     |.........|Device | |
    |    App    |           |  +------------+         +-------+ |
    +-----------+           |                                   |
                            |         Local Network             |
                            +-----------------------------------+

</artwork>
          </artset>
        </figure>
        <t indent="0" pn="section-1.2-6">In <xref target="arch" format="default" sectionFormat="of" derivedContent="Figure 1"/>, 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" format="default" sectionFormat="of" derivedContent="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 anchor="arch2" align="left" suppress-title="false" pn="figure-2">
          <name slugifiedName="name-interaction-with-aaa">Interaction with AAA</name>
          <artset pn="section-1.2-7.1">
            <artwork type="svg" align="left" pn="section-1.2-7.1.1"><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" align="left" pn="section-1.2-7.1.2">
                            +------------------------------------+
                            |                                    |
    +-----------+   Request |  +---------+   +----+    +------+  |
    | Onboarding|-------------&gt;|  SCIM   |--&gt;| AAA|&lt;--&gt;|Switch|  |
    |    App    |&lt;-------------| Server  |   +----+    +------+  |
    +-----------+  Ctrl Endpt  +---------+                |      |
                            |                             |      |
    +-----------+           |  +------------+         +-------+  |
    |  Control  |...........|..| Router/fw  |.........|Device |  |
    |    App    |           |  +------------+         +-------+  |
    +-----------+           |                                    |
                            |          Local Network             |
                            +------------------------------------+
</artwork>
          </artset>
        </figure>
        <t indent="0" pn="section-1.2-8"><xref target="arch2" format="default" sectionFormat="of" derivedContent="Figure 2"/> 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 it will use the normal IP
infrastructure to communicate with its control application.</t>
      </section>
      <section anchor="schema-description" numbered="true" removeInRFC="false" toc="include" pn="section-1.3">
        <name slugifiedName="name-schema-description">Schema Description</name>
        <t indent="0" pn="section-1.3-1"><xref target="RFC7643" format="default" sectionFormat="of" derivedContent="RFC7643"/> does not prescribe a language to describe a schema but instead
uses a narrative description with examples.  We follow that approach.
In addition, we provide non-normative JSON Schemas 
<xref target="JSONSchema" format="default" sectionFormat="of" derivedContent="JSONSchema"/> and OpenAPI <xref target="OpenAPI" format="default" sectionFormat="of" derivedContent="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 the JSON Schemas and OpenAPI versions
do not have a means to express case sensitivity, and thus attributes that
are not case sensitive must be manually validated.</t>
        <t indent="0" pn="section-1.3-2">Several additional schemas specify specific onboarding mechanisms,
such as Bluetooth Low Energy (BLE) <xref target="BLE54" format="default" sectionFormat="of" derivedContent="BLE54"/>, Wi-Fi Easy Connect <xref target="DPP2" format="default" sectionFormat="of" derivedContent="DPP2"/>,
and FIDO Device Onboard <xref target="FDO11" format="default" sectionFormat="of" derivedContent="FDO11"/>.</t>
        <t indent="0" pn="section-1.3-3">When JSON is presented in this memo, it is folded in accordance with <xref target="RFC8792" format="default" sectionFormat="of" derivedContent="RFC8792"/>.</t>
      </section>
      <section anchor="schema-representation" numbered="true" removeInRFC="false" toc="include" pn="section-1.4">
        <name slugifiedName="name-schema-representation">Schema Representation</name>
        <t indent="0" pn="section-1.4-1">Attributes defined in the device core schema (see <xref target="RFC7643" sectionFormat="of" section="2.2" format="default" derivedLink="https://rfc-editor.org/rfc/rfc7643#section-2.2" derivedContent="RFC7643"/>) and extensions comprise
	characteristics and the SCIM datatypes (defined in <xref target="RFC7643" sectionFormat="of" section="2.3" format="default" derivedLink="https://rfc-editor.org/rfc/rfc7643#section-2.3" derivedContent="RFC7643"/>).  This specification does not define new
	characteristics and datatypes for the SCIM attributes.</t>
      </section>
      <section anchor="terminology" numbered="true" removeInRFC="false" toc="include" pn="section-1.5">
        <name slugifiedName="name-terminology">Terminology</name>
        <t indent="0" pn="section-1.5-1">
    The key words "<bcp14>MUST</bcp14>", "<bcp14>MUST NOT</bcp14>",
    "<bcp14>REQUIRED</bcp14>", "<bcp14>SHALL</bcp14>", "<bcp14>SHALL NOT</bcp14>",
    "<bcp14>SHOULD</bcp14>", "<bcp14>SHOULD NOT</bcp14>",
    "<bcp14>RECOMMENDED</bcp14>", "<bcp14>NOT RECOMMENDED</bcp14>",
    "<bcp14>MAY</bcp14>", and "<bcp14>OPTIONAL</bcp14>" in this document are to be
    interpreted as described in BCP 14 <xref target="RFC2119" format="default" sectionFormat="of" derivedContent="RFC2119"/> <xref target="RFC8174" format="default" sectionFormat="of" derivedContent="RFC8174"/> when, and only when, they appear in all capitals, as
    shown here.
        </t>
        <t indent="0" pn="section-1.5-2">The reader is also expected to be familiar with the narrative schema
language used in <xref target="RFC7643" format="default" sectionFormat="of" derivedContent="RFC7643"/>.</t>
      </section>
    </section>
    <section anchor="resourcetype-device" numbered="true" removeInRFC="false" toc="include" pn="section-2">
      <name slugifiedName="name-resourcetype-device">ResourceType Device</name>
      <t indent="0" pn="section-2-1">A new resource type Device is specified. The "ResourceType" schema
specifies the metadata about a resource type (see 
<xref target="RFC7643" section="6" format="default" sectionFormat="of" derivedLink="https://rfc-editor.org/rfc/rfc7643#section-6" derivedContent="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" numbered="true" removeInRFC="false" toc="include" pn="section-2.1">
        <name slugifiedName="name-common-attributes">Common Attributes</name>
        <t indent="0" pn="section-2.1-1">The device schema contains three common attributes as defined in 
<xref target="RFC7643" section="3.1" format="default" sectionFormat="of" derivedLink="https://rfc-editor.org/rfc/rfc7643#section-3.1" derivedContent="RFC7643"/>.  No semantic or syntax changes are made here, but the
attributes are listed merely for completeness.</t>
        <dl indent="3" newline="false" spacing="normal" pn="section-2.1-2">
          <dt pn="section-2.1-2.1">id:</dt>
          <dd pn="section-2.1-2.2">
            <t indent="0" pn="section-2.1-2.2.1">A required and unique attribute of the core device schema
 (see <xref target="RFC7643" section="3.1" format="default" sectionFormat="of" derivedLink="https://rfc-editor.org/rfc/rfc7643#section-3.1" derivedContent="RFC7643"/>).</t>
          </dd>
          <dt pn="section-2.1-2.3">externalId:</dt>
          <dd pn="section-2.1-2.4">
            <t indent="0" pn="section-2.1-2.4.1">An optional attribute (see <xref target="RFC7643" section="3.1" format="default" sectionFormat="of" derivedLink="https://rfc-editor.org/rfc/rfc7643#section-3.1" derivedContent="RFC7643"/>).</t>
          </dd>
          <dt pn="section-2.1-2.5">meta:</dt>
          <dd pn="section-2.1-2.6">
            <t indent="0" pn="section-2.1-2.6.1">A required and complex attribute (see <xref target="RFC7643" section="3.1" format="default" sectionFormat="of" derivedLink="https://rfc-editor.org/rfc/rfc7643#section-3.1" derivedContent="RFC7643"/>).</t>
          </dd>
        </dl>
      </section>
    </section>
    <section anchor="scim-core-device-schema" numbered="true" removeInRFC="false" toc="include" pn="section-3">
      <name slugifiedName="name-scim-core-device-schema">SCIM Core Device Schema</name>
      <t indent="0" pn="section-3-1">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 indent="0" pn="section-3-2">urn:ietf:params:scim:schemas:core:2.0:Device</t>
      <t indent="0" pn="section-3-3">The following attributes are defined in the core device schema.</t>
      <section anchor="singular-attributes" numbered="true" removeInRFC="false" toc="include" pn="section-3.1">
        <name slugifiedName="name-singular-attributes">Singular Attributes</name>
        <dl indent="3" newline="false" spacing="normal" pn="section-3.1-1">
          <dt pn="section-3.1-1.1">displayName:</dt>
          <dd pn="section-3.1-1.2">
            <t indent="0" pn="section-3.1-1.2.1">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 <bcp14>SHOULD</bcp14> be returned
  by default. No uniqueness constraints are imposed on this attribute.</t>
          </dd>
          <dt pn="section-3.1-1.3">active:</dt>
          <dd pn="section-3.1-1.4">
            <t indent="0" pn="section-3.1-1.4.1">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 Non-Internet-Connected Physical Components (NIPC) <xref target="I-D.ietf-asdf-nipc" format="default" sectionFormat="of" derivedContent="NIPC"/>, commands (such
            as connect, disconnect, and subscribe) that control application
            sends to the controller for devices will be rejected by the
            controller.</t>
          </dd>
          <dt pn="section-3.1-1.5">mudUrl:</dt>
          <dd pn="section-3.1-1.6">
            <t indent="0" pn="section-3.1-1.6.1">A string that represents the URL to the Manufacturer Usage
      Description (MUD) file associated with this device.  This
      attribute is optional, mutable, and returned by default.
      When present, this attribute may be used as described in <xref target="RFC8520" format="default" sectionFormat="of" derivedContent="RFC8520"/>.      
      The mudUrl value is case sensitive and not unique.</t>
          </dd>
          <dt pn="section-3.1-1.7">groups:</dt>
          <dd pn="section-3.1-1.8">
            <t indent="0" pn="section-3.1-1.8.1">An optional read-only complex object that indicates group membership.  Its
form is precisely the same as that defined in <xref section="4.1.2" sectionFormat="of" target="RFC7643" format="default" derivedLink="https://rfc-editor.org/rfc/rfc7643#section-4.1.2" derivedContent="RFC7643"/>.</t>
          </dd>
        </dl>
        <table anchor="tabDevice" align="center" pn="table-1">
          <name slugifiedName="name-characteristics-of-device-s">Characteristics of Device Schema Attributes</name>
          <thead>
            <tr>
              <th align="left" colspan="1" rowspan="1">Attribute</th>
              <th align="left" colspan="1" rowspan="1">Multi Value</th>
              <th align="left" colspan="1" rowspan="1">Req</th>
              <th align="left" colspan="1" rowspan="1">Case Exact</th>
              <th align="left" colspan="1" rowspan="1">Mutable</th>
              <th align="left" colspan="1" rowspan="1">Return</th>
              <th align="left" colspan="1" rowspan="1">Unique</th>
            </tr>
          </thead>
          <tbody>
            <tr>
              <td align="left" colspan="1" rowspan="1">displayName</td>
              <td align="left" colspan="1" rowspan="1">F</td>
              <td align="left" colspan="1" rowspan="1">F</td>
              <td align="left" colspan="1" rowspan="1">F</td>
              <td align="left" colspan="1" rowspan="1">RW</td>
              <td align="left" colspan="1" rowspan="1">Def</td>
              <td align="left" colspan="1" rowspan="1">None</td>
            </tr>
            <tr>
              <td align="left" colspan="1" rowspan="1">active</td>
              <td align="left" colspan="1" rowspan="1">F</td>
              <td align="left" colspan="1" rowspan="1">T</td>
              <td align="left" colspan="1" rowspan="1">F</td>
              <td align="left" colspan="1" rowspan="1">RW</td>
              <td align="left" colspan="1" rowspan="1">Def</td>
              <td align="left" colspan="1" rowspan="1">None</td>
            </tr>
            <tr>
              <td align="left" colspan="1" rowspan="1">mudUrl</td>
              <td align="left" colspan="1" rowspan="1">F</td>
              <td align="left" colspan="1" rowspan="1">F</td>
              <td align="left" colspan="1" rowspan="1">T</td>
              <td align="left" colspan="1" rowspan="1">RW</td>
              <td align="left" colspan="1" rowspan="1">Def</td>
              <td align="left" colspan="1" rowspan="1">None</td>
            </tr>
            <tr>
              <td align="left" colspan="1" rowspan="1">groups</td>
              <td align="left" colspan="1" rowspan="1">T</td>
              <td align="left" colspan="1" rowspan="1">F</td>
              <td align="left" colspan="1" rowspan="1">T</td>
              <td align="left" colspan="1" rowspan="1">RO</td>
              <td align="left" colspan="1" rowspan="1">Def</td>
              <td align="left" colspan="1" rowspan="1">n/a</td>
            </tr>
          </tbody>
        </table>
        <dl indent="9" newline="false" spacing="normal" pn="section-3.1-3">
          <dt pn="section-3.1-3.1">Legend:</dt>
          <dd pn="section-3.1-3.2">Req = Required, T = True, F = False, RO = ReadOnly, RW = ReadWrite, Def = Default</dd>
        </dl>
        <t keepWithNext="true" indent="0" pn="section-3.1-4">Example:</t>
        <figure anchor="coreExample" align="left" suppress-title="false" pn="figure-3">
          <name slugifiedName="name-core-device-example-entries">Core Device Example Entries</name>
          <sourcecode markers="true" pn="section-3.1-5.1">
{
        "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/Devices/e9e30dba-f08f-\
                                              4109-8486-d5c6a3316111"
        }
}
</sourcecode>
        </figure>
      </section>
    </section>
    <section anchor="groups" numbered="true" removeInRFC="false" toc="include" pn="section-4">
      <name slugifiedName="name-groups">Groups</name>
      <t indent="0" pn="section-4-1">Device and EndpointApp groups are created using the SCIM groups as defined
in <xref section="4.2" sectionFormat="of" target="RFC7643" format="default" derivedLink="https://rfc-editor.org/rfc/rfc7643#section-4.2" derivedContent="RFC7643"/>.  If set, the "type" subattribute
of the "members" attribute <bcp14>MUST</bcp14> be set to Device for devices and
EndpointApp for endpoint applications.</t>
    </section>
    <section anchor="resource-type-endpointapp" numbered="true" removeInRFC="false" toc="include" pn="section-5">
      <name slugifiedName="name-resource-type-endpointapp">Resource Type EndpointApp</name>
      <t indent="0" pn="section-5-1">This section defines the EndpointApp resource type. The
"ResourceType" schema specifies the metadata about a resource type
(see <xref target="RFC7643" section="6" format="default" sectionFormat="of" derivedLink="https://rfc-editor.org/rfc/rfc7643#section-6" derivedContent="RFC7643"/>). The resource EndpointApp represents
client applications that can control and/or receive data from the
devices.</t>
    </section>
    <section anchor="endpointapp-schema" numbered="true" removeInRFC="false" toc="include" pn="section-6">
      <name slugifiedName="name-scim-endpointapp-schema">SCIM EndpointApp Schema</name>
      <t indent="0" pn="section-6-1">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 indent="0" pn="section-6-2">The schema for EndpointApp is identified using the schema URI:</t>
      <t indent="0" pn="section-6-3">urn:ietf:params:scim:schemas:core:2.0:EndpointApp</t>
      <t indent="0" pn="section-6-4">The following attributes are defined in this schema.</t>
      <section anchor="common-attributes" numbered="true" removeInRFC="false" toc="include" pn="section-6.1">
        <name slugifiedName="name-common-attributes-2">Common Attributes</name>
        <t indent="0" pn="section-6.1-1">Like <xref target="commonatts" format="default" sectionFormat="of" derivedContent="Section 2.1"/>, the EndpointApp schema contains the three common 
attributes specified in <xref target="RFC7643" section="3.1" format="default" sectionFormat="of" derivedLink="https://rfc-editor.org/rfc/rfc7643#section-3.1" derivedContent="RFC7643"/>.</t>
      </section>
      <section anchor="singular-attributes-1" numbered="true" removeInRFC="false" toc="include" pn="section-6.2">
        <name slugifiedName="name-singular-attributes-2">Singular Attributes</name>
        <dl indent="3" newline="false" spacing="normal" pn="section-6.2-1">
          <dt pn="section-6.2-1.1">applicationType:</dt>
          <dd pn="section-6.2-1.2">
            <t indent="0" pn="section-6.2-1.2.1">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 immutable and should be returned by default. No
            uniqueness constraints are imposed on this attribute.</t>
          </dd>
          <dt pn="section-6.2-1.3">applicationName:</dt>
          <dd pn="section-6.2-1.4">
            <t indent="0" pn="section-6.2-1.4.1">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 constraint on the attribute.</t>
          </dd>
          <dt pn="section-6.2-1.5">clientToken:</dt>
          <dd pn="section-6.2-1.6">
            <t indent="0" pn="section-6.2-1.6.1">A string that 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. It is read-only, case
            sensitive, and generated if no certificateInfo object is
            provisioned. It is 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>
          <dt pn="section-6.2-1.7">groups:</dt>
          <dd pn="section-6.2-1.8">
            <t indent="0" pn="section-6.2-1.8.1">An optional read-only complex object that indicates group membership.  Its
form is precisely the same as that defined in <xref section="4.1.2" sectionFormat="of" target="RFC7643" format="default" derivedLink="https://rfc-editor.org/rfc/rfc7643#section-4.1.2" derivedContent="RFC7643"/>.</t>
          </dd>
        </dl>
      </section>
      <section anchor="complex-attributes" numbered="true" removeInRFC="false" toc="include" pn="section-6.3">
        <name slugifiedName="name-complex-attributes">Complex Attributes</name>
        <section anchor="certificateinfo" numbered="true" removeInRFC="false" toc="include" pn="section-6.3.1">
          <name slugifiedName="name-certificateinfo">certificateInfo</name>
          <t indent="0" pn="section-6.3.1-1">certificateInfo is a complex attribute that contains an X.509 certificate's subject
name and root Certificate Authority (CA) information associated with application clients that
will connect for purposes of device control or telemetry.</t>
          <dl indent="3" newline="false" spacing="normal" pn="section-6.3.1-2">
            <dt pn="section-6.3.1-2.1">rootCA:</dt>
            <dd pn="section-6.3.1-2.2">
              <t indent="0" pn="section-6.3.1-2.2.1">A base64-encoded string as described in <xref target="RFC4648" section="4" format="default" sectionFormat="of" derivedLink="https://rfc-editor.org/rfc/rfc4648#section-4" derivedContent="RFC4648"/>. It is a trust anchor certificate
              applicable for certificates used for client application access.
              The object is not required. It is singular, case sensitive, and
              read/write.  If not present, a set of trust anchors
              <bcp14>MUST</bcp14> be configured out of band.</t>
            </dd>
            <dt pn="section-6.3.1-2.3">subjectName:</dt>
            <dd pn="section-6.3.1-2.4">
              <t indent="0" pn="section-6.3.1-2.4.1">A string that contains one of two names:</t>
              <ul spacing="normal" bare="false" empty="false" indent="3" pn="section-6.3.1-2.4.2">
                <li pn="section-6.3.1-2.4.2.1">
                  <t indent="0" pn="section-6.3.1-2.4.2.1.1">a distinguished name that will be present in the certificate
subject field, as described in <xref target="RFC5280" section="4.1.2.4" format="default" sectionFormat="of" derivedLink="https://rfc-editor.org/rfc/rfc5280#section-4.1.2.4" derivedContent="RFC5280"/> or</t>
                </li>
                <li pn="section-6.3.1-2.4.2.2">
                  <t indent="0" pn="section-6.3.1-2.4.2.2.1">a dnsName as part of a subjectAlternateName, as described in
<xref target="RFC5280" section="4.2.1.6" format="default" sectionFormat="of" derivedLink="https://rfc-editor.org/rfc/rfc5280#section-4.2.1.6" derivedContent="RFC5280"/>.</t>
                </li>
              </ul>
              <t indent="0" pn="section-6.3.1-2.4.3">In the latter case, servers validating such certificates <bcp14>SHALL</bcp14> reject
 connections when the 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 and not case sensitive. It is mutable and singular.</t>
            </dd>
          </dl>
          <table anchor="tabEndpointApp" align="center" pn="table-2">
            <name slugifiedName="name-characteristics-of-endpoint">Characteristics of EndpointApp Schema Attributes</name>
            <thead>
              <tr>
                <th align="left" colspan="1" rowspan="1">Attribute</th>
                <th align="left" colspan="1" rowspan="1">Multi Value</th>
                <th align="left" colspan="1" rowspan="1">Req</th>
                <th align="left" colspan="1" rowspan="1">Case Exact</th>
                <th align="left" colspan="1" rowspan="1">Mutable</th>
                <th align="left" colspan="1" rowspan="1">Return</th>
                <th align="left" colspan="1" rowspan="1">Unique</th>
              </tr>
            </thead>
            <tbody>
              <tr>
                <td align="left" colspan="1" rowspan="1">applicationType</td>
                <td align="left" colspan="1" rowspan="1">F</td>
                <td align="left" colspan="1" rowspan="1">T</td>
                <td align="left" colspan="1" rowspan="1">F</td>
                <td align="left" colspan="1" rowspan="1">Imm</td>
                <td align="left" colspan="1" rowspan="1">Def</td>
                <td align="left" colspan="1" rowspan="1">None</td>
              </tr>
              <tr>
                <td align="left" colspan="1" rowspan="1">applicationName</td>
                <td align="left" colspan="1" rowspan="1">F</td>
                <td align="left" colspan="1" rowspan="1">T</td>
                <td align="left" colspan="1" rowspan="1">F</td>
                <td align="left" colspan="1" rowspan="1">RW</td>
                <td align="left" colspan="1" rowspan="1">Def</td>
                <td align="left" colspan="1" rowspan="1">None</td>
              </tr>
              <tr>
                <td align="left" colspan="1" rowspan="1">clientToken</td>
                <td align="left" colspan="1" rowspan="1">F</td>
                <td align="left" colspan="1" rowspan="1">F</td>
                <td align="left" colspan="1" rowspan="1">T</td>
                <td align="left" colspan="1" rowspan="1">RO</td>
                <td align="left" colspan="1" rowspan="1">Def</td>
                <td align="left" colspan="1" rowspan="1">None</td>
              </tr>
              <tr>
                <td align="left" colspan="1" rowspan="1">certificateInfo</td>
                <td align="left" colspan="1" rowspan="1">F</td>
                <td align="left" colspan="1" rowspan="1">F</td>
                <td align="left" colspan="1" rowspan="1">F</td>
                <td align="left" colspan="1" rowspan="1">RW</td>
                <td align="left" colspan="1" rowspan="1">Def</td>
                <td align="left" colspan="1" rowspan="1">None</td>
              </tr>
              <tr>
                <td align="left" colspan="1" rowspan="1">rootCA</td>
                <td align="left" colspan="1" rowspan="1">F</td>
                <td align="left" colspan="1" rowspan="1">F</td>
                <td align="left" colspan="1" rowspan="1">T</td>
                <td align="left" colspan="1" rowspan="1">RW</td>
                <td align="left" colspan="1" rowspan="1">Def</td>
                <td align="left" colspan="1" rowspan="1">None</td>
              </tr>
              <tr>
                <td align="left" colspan="1" rowspan="1">subjectName</td>
                <td align="left" colspan="1" rowspan="1">F</td>
                <td align="left" colspan="1" rowspan="1">T</td>
                <td align="left" colspan="1" rowspan="1">T</td>
                <td align="left" colspan="1" rowspan="1">RW</td>
                <td align="left" colspan="1" rowspan="1">Def</td>
                <td align="left" colspan="1" rowspan="1">None</td>
              </tr>
              <tr>
                <td align="left" colspan="1" rowspan="1">groups</td>
                <td align="left" colspan="1" rowspan="1">T</td>
                <td align="left" colspan="1" rowspan="1">F</td>
                <td align="left" colspan="1" rowspan="1">T</td>
                <td align="left" colspan="1" rowspan="1">RO</td>
                <td align="left" colspan="1" rowspan="1">Def</td>
                <td align="left" colspan="1" rowspan="1">n/a</td>
              </tr>
            </tbody>
          </table>
          <dl indent="9" newline="false" spacing="normal" pn="section-6.3.1-4">
            <dt pn="section-6.3.1-4.1">Legend:</dt>
            <dd pn="section-6.3.1-4.2">Req = Required, T = True, F = False, RO = ReadOnly, RW = ReadWrite, N = No, Def = Default, Imm = Immutable</dd>
          </dl>
          <t indent="0" pn="section-6.3.1-5">If certificateInfo is provided by the client and is accepted by the server, the server <bcp14>MUST</bcp14> return that multivalued attribute in its response.  Otherwise, the server is expected to return a clientToken.  If the server returns neither certificateInfo nor a clientToken, then external authentication such as <xref target="RFC6749" format="default" sectionFormat="of" derivedContent="OAUTHv2"/> <bcp14>MUST</bcp14> be pre-arranged.  If the server accepts a certificate and produces a clientToken, then control and telemetry servers <bcp14>MUST</bcp14> validate both.</t>
          <t indent="0" pn="section-6.3.1-6">certificateInfo is preferred in situations where client functions
are federated such that different clients may connect for different
purposes.</t>
          <t keepWithNext="true" indent="0" pn="section-6.3.1-7">Example:</t>
          <figure anchor="eaExample" align="left" suppress-title="false" pn="figure-4">
            <name slugifiedName="name-endpoint-app-example">Endpoint App Example</name>
            <sourcecode markers="true" pn="section-6.3.1-8.1">
{
  "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/EndpointApps/e9e30dba-f08f-\
                                              4109-8486-d5c6a3316212"
  }
}</sourcecode>
          </figure>
        </section>
      </section>
    </section>
    <section anchor="extensions" numbered="true" removeInRFC="false" toc="include" pn="section-7">
      <name slugifiedName="name-scim-device-extensions">SCIM Device Extensions</name>
      <t indent="0" pn="section-7-1">SCIM provides various extension schemas and their attributes, along
      with JSON representations and example objects.  The core schema is
      extended with a new resource type, Device.  No schemaExtensions list is
      specified in that definition.  Instead, IANA registry entries have been
      created, where all values for "required" are set to false.  All
      extensions to the device schema <bcp14>MUST</bcp14> be registered via
      IANA, as described in <xref target="device-schema-extensions" format="default" sectionFormat="of" derivedContent="Section 9.2"/>.  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" numbered="true" removeInRFC="false" toc="include" pn="section-7.1">
        <name slugifiedName="name-bluetooth-low-energy-ble-ex">Bluetooth Low Energy (BLE) Extension</name>
        <t indent="0" pn="section-7.1-1">This schema extends the device schema to represent the devices
supporting BLE. The extension is identified using the following
	schema URI:</t>
        <t indent="0" pn="section-7.1-2">urn:ietf:params:scim:schemas:extension:ble:2.0:Device</t>
        <t indent="0" pn="section-7.1-3">The attributes are as follows.</t>
        <section anchor="singular-attributes-2" numbered="true" removeInRFC="false" toc="include" pn="section-7.1.1">
          <name slugifiedName="name-singular-attributes-3">Singular Attributes</name>
          <dl indent="3" newline="false" spacing="normal" pn="section-7.1.1-1">
            <dt pn="section-7.1.1-1.1">deviceMacAddress:</dt>
            <dd pn="section-7.1.1-1.2">
              <t indent="0" pn="section-7.1.1-1.2.1">A string value that represents a public MAC address assigned by the
 manufacturer. It is a unique 48-bit value. It is required, case
 insensitive, mutable, and returned by default. The ECMA
 regular expression pattern <xref target="ECMA" format="default" sectionFormat="of" derivedContent="ECMA"/> is the following:</t>
              <artwork align="left" pn="section-7.1.1-1.2.2">
^[0-9A-Fa-f]{2}(:[0-9A-Fa-f]{2}){5}$
</artwork>
            </dd>
            <dt pn="section-7.1.1-1.3">isRandom:</dt>
            <dd pn="section-7.1.1-1.4">
              <t indent="0" pn="section-7.1.1-1.4.1">A boolean flag. If false, the device is using a public MAC
              address. If true, the device uses a random address. If an
              Identifying 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.  See Volume 6, Part B, Section
              1.3 of <xref target="BLE54" format="default" sectionFormat="of" derivedContent="BLE54"/> for more information about different address
              types.</t>
            </dd>
            <dt pn="section-7.1.1-1.5">separateBroadcastAddress:</dt>
            <dd pn="section-7.1.1-1.6">
              <t indent="0" pn="section-7.1.1-1.6.1">When present, this string represents an address used for broadcasts/advertisements.
 This value <bcp14>MUST NOT</bcp14> be set when an IRK is provided. Its form is the
 same as deviceMacAddress. It is not required. It is multivalued, mutable, and returned by default.</t>
            </dd>
            <dt pn="section-7.1.1-1.7">irk:</dt>
            <dd pn="section-7.1.1-1.8">
              <t indent="0" pn="section-7.1.1-1.8.1">A string value that specifies the IRK, which
 is unique to each device. It is used to resolve a 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 Volume 1, Part A, Section 5.4.5 of <xref target="BLE54" format="default" sectionFormat="of" derivedContent="BLE54"/>.</t>
            </dd>
            <dt pn="section-7.1.1-1.9">mobility:</dt>
            <dd pn="section-7.1.1-1.10">
              <t indent="0" pn="section-7.1.1-1.10.1">A boolean attribute to enable BLE device mobility. If set to true, the
 device could be expected to move within a network of Access Points (APs).  For
 example, if a 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 connected
 with AP-2. It is returned by default and mutable.</t>
            </dd>
          </dl>
        </section>
        <section anchor="multivalued-attributes" numbered="true" removeInRFC="false" toc="include" pn="section-7.1.2">
          <name slugifiedName="name-multivalued-attributes">Multivalued Attributes</name>
          <dl indent="3" newline="false" spacing="normal" pn="section-7.1.2-1">
            <dt pn="section-7.1.2-1.1">versionSupport:</dt>
            <dd pn="section-7.1.2-1.2">
              <t indent="0" pn="section-7.1.2-1.2.1">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
 returned by default.</t>
            </dd>
            <dt pn="section-7.1.2-1.3">pairingMethods:</dt>
            <dd pn="section-7.1.2-1.4">
              <t indent="0" pn="section-7.1.2-1.4.1">A multivalued set of strings that specifies pairing methods associated with the BLE
 device. The pairing methods may require subattributes 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" numbered="true" removeInRFC="false" toc="include" pn="section-7.1.3">
          <name slugifiedName="name-ble-pairing-method-extensio">BLE Pairing Method Extensions</name>
          <t indent="0" pn="section-7.1.3-1">The details on pairing methods and their associated attributes are in
Volume 1, Part A, Section 5.2.4 of <xref target="BLE54" format="default" sectionFormat="of" derivedContent="BLE54"/>. This memo defines extensions for four
pairing methods that are nested inside the BLE extension schema. Each extension contains the common attributes in <xref target="commonatts" format="default" sectionFormat="of" derivedContent="Section 2.1"/>. These
extensions are as follows:</t>
          <dl newline="false" indent="3" spacing="normal" pn="section-7.1.3-2">
            <dt pn="section-7.1.3-2.1">pairingNull extension:</dt>
            <dd pn="section-7.1.3-2.2">
              <t indent="0" pn="section-7.1.3-2.2.1">Identified using the following schema URI:</t>
              <t indent="0" pn="section-7.1.3-2.2.2">urn:ietf:params:scim:schemas:extension:pairingNull:2.0:Device</t>
              <t indent="0" pn="section-7.1.3-2.2.3">pairingNull does not have any attribute. It allows pairing for BLE
devices that do not require a pairing method.</t>
            </dd>
          </dl>
          <dl newline="false" indent="3" spacing="normal" pn="section-7.1.3-3">
            <dt pn="section-7.1.3-3.1">pairingJustWorks extension:</dt>
            <dd pn="section-7.1.3-3.2">
              <t indent="0" pn="section-7.1.3-3.2.1">Identified using the following schema URI:</t>
              <t indent="0" pn="section-7.1.3-3.2.2">urn:ietf:params:scim:schemas:extension:pairingJustWorks:2.0:Device</t>
              <t indent="0" pn="section-7.1.3-3.2.3">The Just Works pairing method does not require a key to pair devices. For
  completeness, the key attribute is included and is set to 'null'. The key
  attribute is required, immutable, and returned by default.</t>
            </dd>
          </dl>
          <dl newline="false" indent="3" spacing="normal" pn="section-7.1.3-4">
            <dt pn="section-7.1.3-4.1">pairingPassKey extension:</dt>
            <dd pn="section-7.1.3-4.2">
              <t indent="0" pn="section-7.1.3-4.2.1">Identified using the following schema URI:</t>
              <t indent="0" pn="section-7.1.3-4.2.2">urn:ietf:params:scim:schemas:extension:pairingPassKey:2.0:Device</t>
              <t indent="0" pn="section-7.1.3-4.2.3">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>
              <artwork align="left" pn="section-7.1.3-4.2.4">^[0-9]{6}$</artwork>
            </dd>
          </dl>
          <dl newline="false" indent="3" spacing="normal" pn="section-7.1.3-5">
            <dt pn="section-7.1.3-5.1">pairingOOB extension:</dt>
            <dd pn="section-7.1.3-5.2">
              <t indent="0" pn="section-7.1.3-5.2.1">Identified using the following schema URI:</t>
              <t indent="0" pn="section-7.1.3-5.2.2">urn:ietf:params:scim:schemas:extension:pairingOOB:2.0:Device</t>
              <t indent="0" pn="section-7.1.3-5.2.3">The out-of-band (OOB) pairing method includes three singular attributes:
   key, randomNumber, and confirmationNumber.</t>
              <dl newline="true" indent="3" spacing="normal" pn="section-7.1.3-5.2.4">
                <dt pn="section-7.1.3-5.2.4.1">key:</dt>
                <dd pn="section-7.1.3-5.2.4.2">
                  <t indent="0" pn="section-7.1.3-5.2.4.2.1">A string value that is required and received from out-of-band
  sources such as Near Field Communication (NFC). It is case sensitive, mutable,
  and returned by default.</t>
                </dd>
                <dt pn="section-7.1.3-5.2.4.3">randomNumber:</dt>
                <dd pn="section-7.1.3-5.2.4.4">
                  <t indent="0" pn="section-7.1.3-5.2.4.4.1">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 pn="section-7.1.3-5.2.4.5">confirmationNumber:</dt>
                <dd pn="section-7.1.3-5.2.4.6">
                  <t indent="0" pn="section-7.1.3-5.2.4.6.1">An integer that some solutions require in a RESTful message
              exchange (where RESTful refers to the Representational State
              Transfer (REST) architecture). It is not required. It is mutable
              and returned by default if it exists.</t>
                </dd>
              </dl>
            </dd>
          </dl>
          <table anchor="tabBLE" align="center" pn="table-3">
            <name slugifiedName="name-characteristics-of-ble-exte">Characteristics of BLE Extension Schema Attributes</name>
            <thead>
              <tr>
                <th align="left" colspan="1" rowspan="1">Attribute</th>
                <th align="left" colspan="1" rowspan="1">Multi Value</th>
                <th align="left" colspan="1" rowspan="1">Req</th>
                <th align="left" colspan="1" rowspan="1">Case Exact</th>
                <th align="left" colspan="1" rowspan="1">Mutable</th>
                <th align="left" colspan="1" rowspan="1">Return</th>
                <th align="left" colspan="1" rowspan="1">Unique</th>
              </tr>
            </thead>
            <tbody>
              <tr>
                <td align="left" colspan="1" rowspan="1">deviceMacAddress</td>
                <td align="left" colspan="1" rowspan="1">F</td>
                <td align="left" colspan="1" rowspan="1">T</td>
                <td align="left" colspan="1" rowspan="1">F</td>
                <td align="left" colspan="1" rowspan="1">RW</td>
                <td align="left" colspan="1" rowspan="1">Def</td>
                <td align="left" colspan="1" rowspan="1">Manuf</td>
              </tr>
              <tr>
                <td align="left" colspan="1" rowspan="1">isRandom</td>
                <td align="left" colspan="1" rowspan="1">F</td>
                <td align="left" colspan="1" rowspan="1">F</td>
                <td align="left" colspan="1" rowspan="1">F</td>
                <td align="left" colspan="1" rowspan="1">RW</td>
                <td align="left" colspan="1" rowspan="1">Def</td>
                <td align="left" colspan="1" rowspan="1">None</td>
              </tr>
              <tr>
                <td align="left" colspan="1" rowspan="1">sepBroadcastAdd</td>
                <td align="left" colspan="1" rowspan="1">T</td>
                <td align="left" colspan="1" rowspan="1">F</td>
                <td align="left" colspan="1" rowspan="1">F</td>
                <td align="left" colspan="1" rowspan="1">RW</td>
                <td align="left" colspan="1" rowspan="1">Def</td>
                <td align="left" colspan="1" rowspan="1">None</td>
              </tr>
              <tr>
                <td align="left" colspan="1" rowspan="1">irk</td>
                <td align="left" colspan="1" rowspan="1">F</td>
                <td align="left" colspan="1" rowspan="1">F</td>
                <td align="left" colspan="1" rowspan="1">F</td>
                <td align="left" colspan="1" rowspan="1">WO</td>
                <td align="left" colspan="1" rowspan="1">Nev</td>
                <td align="left" colspan="1" rowspan="1">Manuf</td>
              </tr>
              <tr>
                <td align="left" colspan="1" rowspan="1">versionSupport</td>
                <td align="left" colspan="1" rowspan="1">T</td>
                <td align="left" colspan="1" rowspan="1">T</td>
                <td align="left" colspan="1" rowspan="1">F</td>
                <td align="left" colspan="1" rowspan="1">RW</td>
                <td align="left" colspan="1" rowspan="1">Def</td>
                <td align="left" colspan="1" rowspan="1">None</td>
              </tr>
              <tr>
                <td align="left" colspan="1" rowspan="1">mobility</td>
                <td align="left" colspan="1" rowspan="1">F</td>
                <td align="left" colspan="1" rowspan="1">F</td>
                <td align="left" colspan="1" rowspan="1">F</td>
                <td align="left" colspan="1" rowspan="1">RW</td>
                <td align="left" colspan="1" rowspan="1">Def</td>
                <td align="left" colspan="1" rowspan="1">None</td>
              </tr>
              <tr>
                <td align="left" colspan="1" rowspan="1">pairingMethods</td>
                <td align="left" colspan="1" rowspan="1">T</td>
                <td align="left" colspan="1" rowspan="1">T</td>
                <td align="left" colspan="1" rowspan="1">T</td>
                <td align="left" colspan="1" rowspan="1">RW</td>
                <td align="left" colspan="1" rowspan="1">Def</td>
                <td align="left" colspan="1" rowspan="1">None</td>
              </tr>
            </tbody>
          </table>
          <dl indent="9" newline="false" spacing="normal" pn="section-7.1.3-7">
            <dt pn="section-7.1.3-7.1">Legend:</dt>
            <dd pn="section-7.1.3-7.2">sepBroadcastAdd = separateBroadcastAddress, Req = Required, T = True, F = False, RW = ReadWrite, WO = WriteOnly, Def = Default, Nev = Never, Manuf = Manufacturer</dd>
          </dl>
          <t keepWithNext="true" indent="0" pn="section-7.1.3-8">Example:</t>
          <figure anchor="btExample" align="left" suppress-title="false" pn="figure-5">
            <name slugifiedName="name-ble-example">BLE Example</name>
            <sourcecode markers="true" pn="section-7.1.3-9.1">
{
  "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.4"],
    "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/Devices/e9e30dba-f08f-4109-\
                                                   8486-d5c6a3316111"
  }
}</sourcecode>
          </figure>
          <t indent="0" pn="section-7.1.3-10">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>
          <t keepWithNext="true" indent="0" pn="section-7.1.3-11">Example:</t>
          <figure anchor="btExample2" align="left" suppress-title="false" pn="figure-6">
            <name slugifiedName="name-ble-with-pairingoob">BLE with pairingOOB</name>
            <sourcecode markers="true" pn="section-7.1.3-12.1">
{
  "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.4"],
    "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/Devices/e9e30dba-f08f-4109-\
                                                   8486-d5c6a3316111"
  }
}</sourcecode>
          </figure>
          <t indent="0" pn="section-7.1.3-13">However, a device can have more than one pairing method. Support for multiple
pairing methods is also provided by the multivalued attribute pairingMethods.
In the example below, the BLE device can pair with both passkey and OOB pairing
methods.</t>
          <t keepWithNext="true" indent="0" pn="section-7.1.3-14">Example:</t>
          <figure anchor="btExample3" align="left" suppress-title="false" pn="figure-7">
            <name slugifiedName="name-ble-pairing-with-both-passk">BLE Pairing with Both Passkey and OOB</name>
            <sourcecode markers="true" pn="section-7.1.3-15.1">
{
  "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.4"],
    "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/Devices/e9e30dba-f08f-4109-\
                                                   8486-d5c6a3316111"
  }
}</sourcecode>
          </figure>
        </section>
      </section>
      <section anchor="wi-fi-easy-connect-extension" numbered="true" removeInRFC="false" toc="include" pn="section-7.2">
        <name slugifiedName="name-wi-fi-easy-connect-extensio">Wi-Fi Easy Connect Extension</name>
        <t indent="0" pn="section-7.2-1">This section describes a schema that extends the device schema to enable Wi-Fi Easy Connect
   (otherwise known as Device Provisioning Protocol (DPP)). Throughout this
specification, we use the term "DPP".  The extension
	is identified using the following schema URI:</t>
        <t indent="0" pn="section-7.2-2">urn:ietf:params:scim:schemas:extension:dpp:2.0:Device</t>
        <t indent="0" pn="section-7.2-3">The attributes in this extension are adopted from <xref target="DPP2" format="default" sectionFormat="of" derivedContent="DPP2"/>. The
attributes are as follows.</t>
        <section anchor="singular-attributes-3" numbered="true" removeInRFC="false" toc="include" pn="section-7.2.1">
          <name slugifiedName="name-singular-attributes-4">Singular Attributes</name>
          <dl indent="3" newline="false" spacing="normal" pn="section-7.2.1-1">
            <dt pn="section-7.2.1-1.1">dppVersion:</dt>
            <dd pn="section-7.2.1-1.2">
              <t indent="0" pn="section-7.2.1-1.2.1">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 pn="section-7.2.1-1.3">bootstrapKey:</dt>
            <dd pn="section-7.2.1-1.4">
              <t indent="0" pn="section-7.2.1-1.4.1">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, write only, and never returned.</t>
            </dd>
            <dt pn="section-7.2.1-1.5">deviceMacAddress:</dt>
            <dd pn="section-7.2.1-1.6">
              <t indent="0" pn="section-7.2.1-1.6.1">A MAC address stored as a string. It is a unique 48-bit value. This attribute
 is optional, case insensitive, mutable, and returned by default.  Its form
 is identical to that of the deviceMacAddress for BLE devices.</t>
            </dd>
            <dt pn="section-7.2.1-1.7">serialNumber:</dt>
            <dd pn="section-7.2.1-1.8">
              <t indent="0" pn="section-7.2.1-1.8.1">An alphanumeric serial number stored as a string. It 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" numbered="true" removeInRFC="false" toc="include" pn="section-7.2.2">
          <name slugifiedName="name-multivalued-attributes-2">Multivalued Attributes</name>
          <dl indent="3" newline="false" spacing="normal" pn="section-7.2.2-1">
            <dt pn="section-7.2.2-1.1">bootstrappingMethod:</dt>
            <dd pn="section-7.2.2-1.2">
              <t indent="0" pn="section-7.2.2-1.2.1">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 pn="section-7.2.2-1.3">classChannel:</dt>
            <dd pn="section-7.2.2-1.4">
              <t indent="0" pn="section-7.2.2-1.4.1">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>
          <table anchor="tabDPP" align="center" pn="table-4">
            <name slugifiedName="name-characteristics-of-dpp-exte">Characteristics of DPP Extension Schema Attributes</name>
            <thead>
              <tr>
                <th align="left" colspan="1" rowspan="1">Attribute</th>
                <th align="left" colspan="1" rowspan="1">Multi Value</th>
                <th align="left" colspan="1" rowspan="1">Req</th>
                <th align="left" colspan="1" rowspan="1">Case Exact</th>
                <th align="left" colspan="1" rowspan="1">Mutable</th>
                <th align="left" colspan="1" rowspan="1">Return</th>
                <th align="left" colspan="1" rowspan="1">Unique</th>
              </tr>
            </thead>
            <tbody>
              <tr>
                <td align="left" colspan="1" rowspan="1">dppVersion</td>
                <td align="left" colspan="1" rowspan="1">F</td>
                <td align="left" colspan="1" rowspan="1">T</td>
                <td align="left" colspan="1" rowspan="1">F</td>
                <td align="left" colspan="1" rowspan="1">RW</td>
                <td align="left" colspan="1" rowspan="1">Def</td>
                <td align="left" colspan="1" rowspan="1">None</td>
              </tr>
              <tr>
                <td align="left" colspan="1" rowspan="1">bootstrapKey</td>
                <td align="left" colspan="1" rowspan="1">F</td>
                <td align="left" colspan="1" rowspan="1">T</td>
                <td align="left" colspan="1" rowspan="1">T</td>
                <td align="left" colspan="1" rowspan="1">WO</td>
                <td align="left" colspan="1" rowspan="1">Nev</td>
                <td align="left" colspan="1" rowspan="1">None</td>
              </tr>
              <tr>
                <td align="left" colspan="1" rowspan="1">deviceMacAddress</td>
                <td align="left" colspan="1" rowspan="1">F</td>
                <td align="left" colspan="1" rowspan="1">F</td>
                <td align="left" colspan="1" rowspan="1">F</td>
                <td align="left" colspan="1" rowspan="1">RW</td>
                <td align="left" colspan="1" rowspan="1">Def</td>
                <td align="left" colspan="1" rowspan="1">Manuf</td>
              </tr>
              <tr>
                <td align="left" colspan="1" rowspan="1">serialNumber</td>
                <td align="left" colspan="1" rowspan="1">F</td>
                <td align="left" colspan="1" rowspan="1">F</td>
                <td align="left" colspan="1" rowspan="1">F</td>
                <td align="left" colspan="1" rowspan="1">RW</td>
                <td align="left" colspan="1" rowspan="1">Def</td>
                <td align="left" colspan="1" rowspan="1">None</td>
              </tr>
              <tr>
                <td align="left" colspan="1" rowspan="1">bootstrappingMethod</td>
                <td align="left" colspan="1" rowspan="1">T</td>
                <td align="left" colspan="1" rowspan="1">F</td>
                <td align="left" colspan="1" rowspan="1">F</td>
                <td align="left" colspan="1" rowspan="1">RW</td>
                <td align="left" colspan="1" rowspan="1">Def</td>
                <td align="left" colspan="1" rowspan="1">None</td>
              </tr>
              <tr>
                <td align="left" colspan="1" rowspan="1">classChannel</td>
                <td align="left" colspan="1" rowspan="1">T</td>
                <td align="left" colspan="1" rowspan="1">F</td>
                <td align="left" colspan="1" rowspan="1">F</td>
                <td align="left" colspan="1" rowspan="1">RW</td>
                <td align="left" colspan="1" rowspan="1">Def</td>
                <td align="left" colspan="1" rowspan="1">None</td>
              </tr>
            </tbody>
          </table>
          <dl indent="9" newline="false" spacing="normal" pn="section-7.2.2-3">
            <dt pn="section-7.2.2-3.1">Legend:</dt>
            <dd pn="section-7.2.2-3.2">Req = Required, T = True, F = False, RW = ReadWrite, WO = WriteOnly, Def = Default, Nev = Never, Manuf = Manufacturer</dd>
          </dl>
          <t keepWithNext="true" indent="0" pn="section-7.2.2-4">Example:</t>
          <figure anchor="dPPExample" align="left" suppress-title="false" pn="figure-8">
            <name slugifiedName="name-dpp-example">DPP Example</name>
            <sourcecode markers="true" pn="section-7.2.2-5.1">
{
        "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": "\
MDkwEwYHKoZIzj0CAQYIKoZIzj0DAQcDIgADURzxmttZoIRIPWGoQMV00XHWCAQIhXru\
                                                       VWOz0NjlkIA=",
                "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/Devices/e9e30dba-f08f-\
                                              4109-8486-d5c6a3316111"
        }
}</sourcecode>
          </figure>
        </section>
      </section>
      <section anchor="ethernet-mab-extension" numbered="true" removeInRFC="false" toc="include" pn="section-7.3">
        <name slugifiedName="name-ethernet-mab-extension">Ethernet MAB Extension</name>
        <t indent="0" pn="section-7.3-1">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 indent="0" pn="section-7.3-2">urn:ietf:params:scim:schemas:extension:ethernet-mab:2.0:Device</t>
        <t indent="0" pn="section-7.3-3">Note that this method is not likely to work properly with
MAC address randomization.</t>
        <section anchor="single-attribute" numbered="true" removeInRFC="false" toc="include" pn="section-7.3.1">
          <name slugifiedName="name-single-attribute">Single Attribute</name>
          <t indent="0" pn="section-7.3.1-1">This extension has a singular attribute:</t>
          <dl indent="3" newline="false" spacing="normal" pn="section-7.3.1-2">
            <dt pn="section-7.3.1-2.1">deviceMacAddress:</dt>
            <dd pn="section-7.3.1-2.2">
              <t indent="0" pn="section-7.3.1-2.2.1">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>
          <table anchor="tabMAB" align="center" pn="table-5">
            <name slugifiedName="name-characteristics-of-mab-exte">Characteristics of MAB Extension Schema Attributes</name>
            <thead>
              <tr>
                <th align="left" colspan="1" rowspan="1">Attribute</th>
                <th align="left" colspan="1" rowspan="1">Multi Value</th>
                <th align="left" colspan="1" rowspan="1">Req</th>
                <th align="left" colspan="1" rowspan="1">Case Exact</th>
                <th align="left" colspan="1" rowspan="1">Mutable</th>
                <th align="left" colspan="1" rowspan="1">Return</th>
                <th align="left" colspan="1" rowspan="1">Unique</th>
              </tr>
            </thead>
            <tbody>
              <tr>
                <td align="left" colspan="1" rowspan="1">deviceMacAddress</td>
                <td align="left" colspan="1" rowspan="1">F</td>
                <td align="left" colspan="1" rowspan="1">T</td>
                <td align="left" colspan="1" rowspan="1">F</td>
                <td align="left" colspan="1" rowspan="1">RW</td>
                <td align="left" colspan="1" rowspan="1">Def</td>
                <td align="left" colspan="1" rowspan="1">None</td>
              </tr>
            </tbody>
          </table>
          <dl indent="9" newline="false" spacing="normal" pn="section-7.3.1-4">
            <dt pn="section-7.3.1-4.1">Legend:</dt>
            <dd pn="section-7.3.1-4.2">Req = Required, T = True, F = False, RW = ReadWrite, Def = Default</dd>
          </dl>
          <t keepWithNext="true" indent="0" pn="section-7.3.1-5">Example:</t>
          <figure anchor="MABExample" align="left" suppress-title="false" pn="figure-9">
            <name slugifiedName="name-mab-example">MAB Example</name>
            <sourcecode markers="true" pn="section-7.3.1-6.1">
{
  "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/Devices/e9e30dba-f08f-4109-\
                                                   8486-d5c6a3316111"
  }
}</sourcecode>
          </figure>
        </section>
      </section>
      <section anchor="fido-device-onboard-extension" numbered="true" removeInRFC="false" toc="include" pn="section-7.4">
        <name slugifiedName="name-fido-device-onboard-extensi">FIDO Device Onboard Extension</name>
        <t indent="0" pn="section-7.4-1">This extension specifies a voucher to be used by the FDO Device
Onboard (FDO) protocols <xref target="FDO11" format="default" sectionFormat="of" derivedContent="FDO11"/> to complete a trusted transfer of
ownership and control of the device to the environment.  The SCIM
server <bcp14>MUST</bcp14> know how to process the voucher, either directly
or by forwarding it along to an owner process as defined in the FDO
specification. The extension is identified
   using the following schema URI:</t>
        <t indent="0" pn="section-7.4-2">urn:ietf:params:scim:schemas:extension:fido-device-onboard:2.0:Device</t>
        <section anchor="single-attribute-1" numbered="true" removeInRFC="false" toc="include" pn="section-7.4.1">
          <name slugifiedName="name-single-attribute-2">Single Attribute</name>
          <t indent="0" pn="section-7.4.1-1">This extension has a singular attribute:</t>
          <dl indent="3" newline="false" spacing="normal" pn="section-7.4.1-2">
            <dt pn="section-7.4.1-2.1">fdoVoucher:</dt>
            <dd pn="section-7.4.1-2.2">
              <t indent="0" pn="section-7.4.1-2.2.1">The voucher is formatted as a PEM-encoded object in accordance with <xref target="FDO11" format="default" sectionFormat="of" derivedContent="FDO11"/>.</t>
            </dd>
          </dl>
          <table anchor="tabFDO" align="center" pn="table-6">
            <name slugifiedName="name-characteristics-of-fdo-exte">Characteristics of FDO Extension Schema Attributes</name>
            <thead>
              <tr>
                <th align="left" colspan="1" rowspan="1">Attribute</th>
                <th align="left" colspan="1" rowspan="1">Multi Value</th>
                <th align="left" colspan="1" rowspan="1">Req</th>
                <th align="left" colspan="1" rowspan="1">Case Exact</th>
                <th align="left" colspan="1" rowspan="1">Mutable</th>
                <th align="left" colspan="1" rowspan="1">Return</th>
                <th align="left" colspan="1" rowspan="1">Unique</th>
              </tr>
            </thead>
            <tbody>
              <tr>
                <td align="left" colspan="1" rowspan="1">fdoVoucher</td>
                <td align="left" colspan="1" rowspan="1">F</td>
                <td align="left" colspan="1" rowspan="1">T</td>
                <td align="left" colspan="1" rowspan="1">F</td>
                <td align="left" colspan="1" rowspan="1">WO</td>
                <td align="left" colspan="1" rowspan="1">Nev</td>
                <td align="left" colspan="1" rowspan="1">None</td>
              </tr>
            </tbody>
          </table>
          <dl indent="9" newline="false" spacing="normal" pn="section-7.4.1-4">
            <dt pn="section-7.4.1-4.1">Legend:</dt>
            <dd pn="section-7.4.1-4.2">Req = Required, T = True, F = False, WO = WriteOnly, Nev = Never</dd>
          </dl>
          <t keepWithNext="true" indent="0" pn="section-7.4.1-5">Example:</t>
          <figure anchor="fdoExample" align="left" suppress-title="false" pn="figure-10">
            <name slugifiedName="name-fdo-example">FDO Example</name>
            <sourcecode markers="true" pn="section-7.4.1-6.1">
{
  "schemas": ["urn:ietf:params:scim:schemas:core:2.0:Device",
     "urn:ietf:params:scim:schemas:extension:fido-device-onboard:2.0\
                                                          :Device"],

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

  "meta": {
    "resourceType": "Device",
      "created": "2022-01-23T04:56:22Z",
    "lastModified": "2022-05-13T04:42:34Z",
    "version": "W\/\"a330bc54f0671c9\"",
    "location": "https://example.com/v2/Devices/e9e30dba-f08f-4109-\
                                                   8486-d5c6a3316111"
  }
}</sourcecode>
          </figure>
        </section>
      </section>
      <section anchor="zigbee-extension" numbered="true" removeInRFC="false" toc="include" pn="section-7.5">
        <name slugifiedName="name-zigbee-extension">Zigbee Extension</name>
        <t indent="0" pn="section-7.5-1">This section describes a schema that extends the device schema to
        enable the provisioning of Zigbee devices <xref target="Zigbee" format="default" sectionFormat="of" derivedContent="Zigbee"/>. The
        extension is identified using the following schema URI:</t>
        <t indent="0" pn="section-7.5-2">urn:ietf:params:scim:schemas:extension:zigbee:2.0:Device</t>
        <t indent="0" pn="section-7.5-3">It has one singular attribute and one multivalued
attribute. The attributes are as follows.</t>
        <section anchor="singular-attribute" numbered="true" removeInRFC="false" toc="include" pn="section-7.5.1">
          <name slugifiedName="name-singular-attribute">Singular Attribute</name>
          <dl indent="3" newline="false" spacing="normal" pn="section-7.5.1-1">
            <dt pn="section-7.5.1-1.1">deviceEui64Address:</dt>
            <dd pn="section-7.5.1-1.2">
              <t indent="0" pn="section-7.5.1-1.2.1">A 64-bit Extended Unique Identifier (EUI-64) 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" numbered="true" removeInRFC="false" toc="include" pn="section-7.5.2">
          <name slugifiedName="name-multivalued-attribute">Multivalued Attribute</name>
          <dl indent="3" newline="false" spacing="normal" pn="section-7.5.2-1">
            <dt pn="section-7.5.2-1.1">versionSupport:</dt>
            <dd pn="section-7.5.2-1.2">
              <t indent="0" pn="section-7.5.2-1.2.1">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>
          <table anchor="tabZigbee" align="center" pn="table-7">
            <name slugifiedName="name-characteristics-of-zigbee-e">Characteristics of Zigbee Extension Schema Attributes</name>
            <thead>
              <tr>
                <th align="left" colspan="1" rowspan="1">Attribute</th>
                <th align="left" colspan="1" rowspan="1">Multi Value</th>
                <th align="left" colspan="1" rowspan="1">Req</th>
                <th align="left" colspan="1" rowspan="1">Case Exact</th>
                <th align="left" colspan="1" rowspan="1">Mutable</th>
                <th align="left" colspan="1" rowspan="1">Return</th>
                <th align="left" colspan="1" rowspan="1">Unique</th>
              </tr>
            </thead>
            <tbody>
              <tr>
                <td align="left" colspan="1" rowspan="1">deviceEui64Address</td>
                <td align="left" colspan="1" rowspan="1">F</td>
                <td align="left" colspan="1" rowspan="1">T</td>
                <td align="left" colspan="1" rowspan="1">F</td>
                <td align="left" colspan="1" rowspan="1">RW</td>
                <td align="left" colspan="1" rowspan="1">Def</td>
                <td align="left" colspan="1" rowspan="1">None</td>
              </tr>
              <tr>
                <td align="left" colspan="1" rowspan="1">versionSupport</td>
                <td align="left" colspan="1" rowspan="1">T</td>
                <td align="left" colspan="1" rowspan="1">T</td>
                <td align="left" colspan="1" rowspan="1">F</td>
                <td align="left" colspan="1" rowspan="1">RW</td>
                <td align="left" colspan="1" rowspan="1">Def</td>
                <td align="left" colspan="1" rowspan="1">None</td>
              </tr>
            </tbody>
          </table>
          <dl indent="9" newline="false" spacing="normal" pn="section-7.5.2-3">
            <dt pn="section-7.5.2-3.1">Legend:</dt>
            <dd pn="section-7.5.2-3.2">Req = Required, T = True, F = False, RW = ReadWrite, Def = Default</dd>
          </dl>
          <t keepWithNext="true" indent="0" pn="section-7.5.2-4">Example:</t>
          <figure anchor="zigBeeExample" align="left" suppress-title="false" pn="figure-11">
            <name slugifiedName="name-zigbee-example">Zigbee Example</name>
            <sourcecode markers="true" pn="section-7.5.2-5.1">
{
  "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/Devices/e9e30dba-f08f-4109-\
                                                   8486-d5c6a3316111"
  }
}</sourcecode>
          </figure>
        </section>
      </section>
      <section anchor="endpointsappext-schema" numbered="true" removeInRFC="false" toc="include" pn="section-7.6">
        <name slugifiedName="name-the-endpoint-applications-e">The Endpoint Applications Extension Schema</name>
        <t indent="0" pn="section-7.6-1">Sometimes non-IP devices such as those using BLE or Zigbee require an
application gateway interface to manage them.</t>
        <t indent="0" pn="section-7.6-2">endpointAppsExt provides the list of applications that connect to
an enterprise gateway. endpointAppsExt has one multivalued attribute
and two singular attributes. The extension is identified using the
following schema URI:</t>
        <t indent="0" pn="section-7.6-3">urn:ietf:params:scim:schemas:extension:endpointAppsExt:2.0:Device</t>
        <section anchor="singular-attributes-4" numbered="true" removeInRFC="false" toc="include" pn="section-7.6.1">
          <name slugifiedName="name-singular-attributes-5">Singular Attributes</name>
          <dl indent="3" newline="false" spacing="normal" pn="section-7.6.1-1">
            <dt pn="section-7.6.1-1.1">deviceControlEnterpriseEndpoint:</dt>
            <dd pn="section-7.6.1-1.2">
              <t indent="0" pn="section-7.6.1-1.2.1">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, read-only, and returned by default. The uniqueness is
 enforced by the enterprise.</t>
            </dd>
            <dt pn="section-7.6.1-1.3">telemetryEnterpriseEndpoint:</dt>
            <dd pn="section-7.6.1-1.4">
              <t indent="0" pn="section-7.6.1-1.4.1">
A string representing a URL of the enterprise endpoint to reach 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, read-only, and returned by default. The uniqueness is enforced by the
enterprise. This attribute is populated when the enterprise provides a
telemetry endpoint (e.g., hosted by the enterprise gateway).  If a telemetry
service is not known by the SCIM server, the attribute will not be returned.
In such cases, if the application requires telemetry, separate arrangements
must be made.</t>
            </dd>
          </dl>
        </section>
        <section anchor="multivalued-attribute-1" numbered="true" removeInRFC="false" toc="include" pn="section-7.6.2">
          <name slugifiedName="name-multivalued-attribute-2">Multivalued Attribute</name>
          <dl indent="3" newline="false" spacing="normal" pn="section-7.6.2-1">
            <dt pn="section-7.6.2-1.1">applications:</dt>
            <dd pn="section-7.6.2-1.2">
              <t indent="0" pn="section-7.6.2-1.2.1">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 pn="section-7.6.2-1.3">value:</dt>
            <dd pn="section-7.6.2-1.4">
              <t indent="0" pn="section-7.6.2-1.4.1">A string containing the identifier of the endpoint
              application formatted as a Universally Unique Identifier
              (UUID). It is the same as the common attribute "$id" of the resource
              EndpointApp.  It is read/write, required, case insensitive,
              and returned by default.</t>
            </dd>
            <dt pn="section-7.6.2-1.5">$ref:</dt>
            <dd pn="section-7.6.2-1.6">
              <t indent="0" pn="section-7.6.2-1.6.1">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>
          <table anchor="tabEndpointAppsExt" align="center" pn="table-8">
            <name slugifiedName="name-characteristics-of-endpointa">Characteristics of endpointAppsExt Extension Schema Attributes</name>
            <thead>
              <tr>
                <th align="left" colspan="1" rowspan="1">Attribute</th>
                <th align="left" colspan="1" rowspan="1">Multi Value</th>
                <th align="left" colspan="1" rowspan="1">Req</th>
                <th align="left" colspan="1" rowspan="1">Case Exact</th>
                <th align="left" colspan="1" rowspan="1">Mutable</th>
                <th align="left" colspan="1" rowspan="1">Return</th>
                <th align="left" colspan="1" rowspan="1">Unique</th>
              </tr>
            </thead>
            <tbody>
              <tr>
                <td align="left" colspan="1" rowspan="1">devContEntEndpoint</td>
                <td align="left" colspan="1" rowspan="1">F</td>
                <td align="left" colspan="1" rowspan="1">T</td>
                <td align="left" colspan="1" rowspan="1">T</td>
                <td align="left" colspan="1" rowspan="1">RO</td>
                <td align="left" colspan="1" rowspan="1">Def</td>
                <td align="left" colspan="1" rowspan="1">Ent</td>
              </tr>
              <tr>
                <td align="left" colspan="1" rowspan="1">telEntEndpoint</td>
                <td align="left" colspan="1" rowspan="1">F</td>
                <td align="left" colspan="1" rowspan="1">F</td>
                <td align="left" colspan="1" rowspan="1">T</td>
                <td align="left" colspan="1" rowspan="1">RO</td>
                <td align="left" colspan="1" rowspan="1">Def</td>
                <td align="left" colspan="1" rowspan="1">Ent</td>
              </tr>
              <tr>
                <td align="left" colspan="1" rowspan="1">applications</td>
                <td align="left" colspan="1" rowspan="1">T</td>
                <td align="left" colspan="1" rowspan="1">T</td>
                <td align="left" colspan="1" rowspan="1">F</td>
                <td align="left" colspan="1" rowspan="1">RW</td>
                <td align="left" colspan="1" rowspan="1">Def</td>
                <td align="left" colspan="1" rowspan="1">None</td>
              </tr>
              <tr>
                <td align="left" colspan="1" rowspan="1">value</td>
                <td align="left" colspan="1" rowspan="1">F</td>
                <td align="left" colspan="1" rowspan="1">T</td>
                <td align="left" colspan="1" rowspan="1">F</td>
                <td align="left" colspan="1" rowspan="1">RW</td>
                <td align="left" colspan="1" rowspan="1">Def</td>
                <td align="left" colspan="1" rowspan="1">None</td>
              </tr>
              <tr>
                <td align="left" colspan="1" rowspan="1">$ref</td>
                <td align="left" colspan="1" rowspan="1">F</td>
                <td align="left" colspan="1" rowspan="1">T</td>
                <td align="left" colspan="1" rowspan="1">T</td>
                <td align="left" colspan="1" rowspan="1">RO</td>
                <td align="left" colspan="1" rowspan="1">Def</td>
                <td align="left" colspan="1" rowspan="1">None</td>
              </tr>
            </tbody>
          </table>
          <dl indent="9" newline="false" spacing="normal" pn="section-7.6.2-3">
            <dt pn="section-7.6.2-3.1">Legend:</dt>
            <dd pn="section-7.6.2-3.2">devContEntEndpoint = deviceControlEnterpriseEndpoint,
		telEntEndpoint = telemetryEnterpriseEndpoint, Req = Required,
		T = True, F = False, RO = ReadOnly, RW = ReadWrite, Ent = Enterprise, Def = Default</dd>
          </dl>
          <t keepWithNext="true" indent="0" pn="section-7.6.2-4">Example:</t>
          <figure anchor="eaExtension" align="left" suppress-title="false" pn="figure-12">
            <name slugifiedName="name-endpoint-applications-exten">Endpoint Applications Extension Example</name>
            <sourcecode markers="true" pn="section-7.6.2-5.1">
{
  "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.4"],
    "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/EndpointApps/e9e30dba-f08f-\
                                              4109-8486-d5c6a3316212"
      },
      {
        "value" : "e9e30dba-f08f-4109-8486-d5c6a3316333",
        "$ref" : "https://example.com/v2/EndpointApps/e9e30dba-f08f-\
                                              4109-8486-d5c6a3316333"
      }
    ],
      "deviceControlEnterpriseEndpoint": "https://example.com/\
                                       device_control_app_endpoint/",
      "telemetryEnterpriseEndpoint": "mqtts://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/Devices/e9e30dba-f08f-4109-\
                                                   8486-d5c6a3316111"
  }
}</sourcecode>
          </figure>
          <t indent="0" pn="section-7.6.2-6">The schema for the endpointAppsExt extension along with BLE extension is
presented in JSON format in <xref target="endpointappsext-extension-schema-json" format="default" sectionFormat="of" derivedContent="Appendix A.9"/>, while
the OpenAPI representation is provided in <xref target="endpointappsext-extension-schema-openapi-representation" format="default" sectionFormat="of" derivedContent="Appendix B.8"/>.</t>
        </section>
      </section>
    </section>
    <section anchor="security-considerations" numbered="true" removeInRFC="false" toc="include" pn="section-8">
      <name slugifiedName="name-security-considerations">Security Considerations</name>
      <t indent="0" pn="section-8-1">Because provisioning operations permit device access to a network,
each SCIM client <bcp14>MUST</bcp14> be appropriately authenticated.</t>
      <section anchor="scim-operations" numbered="true" removeInRFC="false" toc="include" pn="section-8.1">
        <name slugifiedName="name-scim-operations">SCIM Operations</name>
        <t indent="0" pn="section-8.1-1">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" numbered="true" removeInRFC="false" toc="include" pn="section-8.1.1">
          <name slugifiedName="name-unauthorized-object-creatio">Unauthorized Object Creation</name>
          <t indent="0" pn="section-8.1.1-1">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 indent="0" pn="section-8.1.1-2">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 <bcp14>SHOULD</bcp14> establish appropriate access-control
policies that follow the principle of least privilege to mitigate this
attack.</t>
        </section>
      </section>
      <section anchor="object-deletion" numbered="true" removeInRFC="false" toc="include" pn="section-8.2">
        <name slugifiedName="name-object-deletion">Object Deletion</name>
        <t indent="0" pn="section-8.2-1">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
<bcp14>RECOMMENDED</bcp14> that SCIM delete operations trigger a workflow in accordance
with local network policy.</t>
      </section>
      <section anchor="read-operations" numbered="true" removeInRFC="false" toc="include" pn="section-8.3">
        <name slugifiedName="name-read-operations">Read Operations</name>
        <t indent="0" pn="section-8.3-1">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 <bcp14>SHOULD</bcp14> have the ability to read those objects.</t>
      </section>
      <section anchor="update-operations" numbered="true" removeInRFC="false" toc="include" pn="section-8.4">
        <name slugifiedName="name-update-operations">Update Operations</name>
        <t indent="0" pn="section-8.4-1">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 <bcp14>RECOMMENDED</bcp14> here.</t>
      </section>
      <section anchor="higher-level-protection-for-certain-systems" numbered="true" removeInRFC="false" toc="include" pn="section-8.5">
        <name slugifiedName="name-higher-level-protection-for">Higher Level Protection for Certain Systems</name>
        <t indent="0" pn="section-8.5-1">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 <bcp14>MUST</bcp14> 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" numbered="true" removeInRFC="false" toc="include" pn="section-8.6">
        <name slugifiedName="name-logging">Logging</name>
        <t indent="0" pn="section-8.6-1">An attacker could learn what devices are on a network by examining
SCIM logs.  Due to the sensitive nature of SCIM operations, logs
<bcp14>SHOULD</bcp14> be encrypted both on the disk and in transit.</t>
      </section>
    </section>
    <section anchor="iana-considerations" numbered="true" removeInRFC="false" toc="include" pn="section-9">
      <name slugifiedName="name-iana-considerations">IANA Considerations</name>
      <section anchor="new-schemas" numbered="true" removeInRFC="false" toc="include" pn="section-9.1">
        <name slugifiedName="name-new-schemas">New Schemas</name>
        <t indent="0" pn="section-9.1-1">IANA has added the following additions to the "SCIM
	Schema URIs for Data Resources" registry:</t>
        <dl spacing="compact" newline="false" indent="3" pn="section-9.1-2">
          <dt pn="section-9.1-2.1">Schema URI:</dt>
          <dd pn="section-9.1-2.2">urn:ietf:params:scim:schemas:core:2.0:Device</dd>
          <dt pn="section-9.1-2.3">Name:</dt>
          <dd pn="section-9.1-2.4">Core Device Schema</dd>
          <dt pn="section-9.1-2.5">Reference:</dt>
          <dd pn="section-9.1-2.6">RFC 9944, <xref target="scim-core-device-schema" format="default" sectionFormat="of" derivedContent="Section 3"/></dd>
        </dl>
        <dl spacing="compact" newline="false" indent="3" pn="section-9.1-3">
          <dt pn="section-9.1-3.1">Schema URI:</dt>
          <dd pn="section-9.1-3.2">urn:ietf:params:scim:schemas:core:2.0:EndpointApp</dd>
          <dt pn="section-9.1-3.3">Name:</dt>
          <dd pn="section-9.1-3.4">Endpoint Application</dd>
          <dt pn="section-9.1-3.5">Reference:</dt>
          <dd pn="section-9.1-3.6">RFC 9944, <xref target="endpointapp-schema" format="default" sectionFormat="of" derivedContent="Section 6"/></dd>
        </dl>
      </section>
      <section anchor="device-schema-extensions" numbered="true" removeInRFC="false" toc="include" pn="section-9.2">
        <name slugifiedName="name-device-schema-extensions">Device Schema Extensions</name>
        <t indent="0" pn="section-9.2-1">IANA has created the following extensions in the "SCIM
        Server-Related Schema URIs" registry (omitting the "Resource Type"
        field) as described in <xref target="extensions" format="default" sectionFormat="of" derivedContent="Section 7"/>:</t>
        <dl spacing="compact" newline="false" indent="3" pn="section-9.2-2">
          <dt pn="section-9.2-2.1">Schema URI:</dt>
          <dd pn="section-9.2-2.2">urn:ietf:params:scim:schemas:extension:ble:2.0:Device</dd>
          <dt pn="section-9.2-2.3">Name:</dt>
          <dd pn="section-9.2-2.4">BLE Extension</dd>
          <dt pn="section-9.2-2.5">Resource Type:</dt>
          <dd pn="section-9.2-2.6">Device</dd>
          <dt pn="section-9.2-2.7">Reference:</dt>
          <dd pn="section-9.2-2.8">RFC 9944, <xref target="ble-extension" format="default" sectionFormat="of" derivedContent="Section 7.1"/></dd>
        </dl>
        <dl spacing="compact" newline="false" indent="3" pn="section-9.2-3">
          <dt pn="section-9.2-3.1">Schema URI:</dt>
          <dd pn="section-9.2-3.2">urn:ietf:params:scim:schemas:extension:ethernet-mab:2.0:Device</dd>
          <dt pn="section-9.2-3.3">Name:</dt>
          <dd pn="section-9.2-3.4">Ethernet MAB</dd>
          <dt pn="section-9.2-3.5">Resource Type:</dt>
          <dd pn="section-9.2-3.6">Device</dd>
          <dt pn="section-9.2-3.7">Reference:</dt>
          <dd pn="section-9.2-3.8">RFC 9944, <xref target="ethernet-mab-extension" format="default" sectionFormat="of" derivedContent="Section 7.3"/></dd>
        </dl>
        <dl spacing="compact" newline="false" indent="3" pn="section-9.2-4">
          <dt pn="section-9.2-4.1">Schema URI:</dt>
          <dd pn="section-9.2-4.2">urn:ietf:params:scim:schemas:extension:fido-device-onboard:2.0:Device</dd>
          <dt pn="section-9.2-4.3">Name:</dt>
          <dd pn="section-9.2-4.4">FIDO Device Onboard</dd>
          <dt pn="section-9.2-4.5">Resource Type:</dt>
          <dd pn="section-9.2-4.6">Device</dd>
          <dt pn="section-9.2-4.7">Reference:</dt>
          <dd pn="section-9.2-4.8">RFC 9944, <xref target="fido-device-onboard-extension" format="default" sectionFormat="of" derivedContent="Section 7.4"/></dd>
        </dl>
        <dl spacing="compact" newline="false" indent="3" pn="section-9.2-5">
          <dt pn="section-9.2-5.1">Schema URI:</dt>
          <dd pn="section-9.2-5.2">urn:ietf:params:scim:schemas:extension:dpp:2.0:Device</dd>
          <dt pn="section-9.2-5.3">Name:</dt>
          <dd pn="section-9.2-5.4">Wi-Fi Easy Connect</dd>
          <dt pn="section-9.2-5.5">Resource Type:</dt>
          <dd pn="section-9.2-5.6">Device</dd>
          <dt pn="section-9.2-5.7">Reference:</dt>
          <dd pn="section-9.2-5.8">RFC 9944, <xref target="wi-fi-easy-connect-extension" format="default" sectionFormat="of" derivedContent="Section 7.2"/></dd>
        </dl>
        <dl spacing="compact" newline="false" indent="3" pn="section-9.2-6">
          <dt pn="section-9.2-6.1">Schema URI:</dt>
          <dd pn="section-9.2-6.2">urn:ietf:params:scim:schemas:extension:endpointAppsExt:2.0:Device</dd>
          <dt pn="section-9.2-6.3">Name:</dt>
          <dd pn="section-9.2-6.4">Application Endpoint Extension</dd>
          <dt pn="section-9.2-6.5">Resource Type:</dt>
          <dd pn="section-9.2-6.6">Device</dd>
          <dt pn="section-9.2-6.7">Reference:</dt>
          <dd pn="section-9.2-6.8">RFC 9944, <xref target="endpointsappext-schema" format="default" sectionFormat="of" derivedContent="Section 7.6"/></dd>
        </dl>
        <dl spacing="compact" newline="false" indent="3" pn="section-9.2-7">
          <dt pn="section-9.2-7.1">Schema URI:</dt>
          <dd pn="section-9.2-7.2">urn:ietf:params:scim:schemas:extension:pairingJustWorks:2.0:Device</dd>
          <dt pn="section-9.2-7.3">Name:</dt>
          <dd pn="section-9.2-7.4">Just Works Auth BLE</dd>
          <dt pn="section-9.2-7.5">Resource Type:</dt>
          <dd pn="section-9.2-7.6">Device</dd>
          <dt pn="section-9.2-7.7">Reference:</dt>
          <dd pn="section-9.2-7.8">RFC 9944, <xref target="ble-pairing-method-extensions" format="default" sectionFormat="of" derivedContent="Section 7.1.3"/></dd>
        </dl>
        <dl spacing="compact" newline="false" indent="3" pn="section-9.2-8">
          <dt pn="section-9.2-8.1">Schema URI:</dt>
          <dd pn="section-9.2-8.2">urn:ietf:params:scim:schemas:extension:pairingOOB:2.0:Device</dd>
          <dt pn="section-9.2-8.3">Name:</dt>
          <dd pn="section-9.2-8.4">Out-of-Band Pairing for BLE</dd>
          <dt pn="section-9.2-8.5">Resource Type:</dt>
          <dd pn="section-9.2-8.6">Device</dd>
          <dt pn="section-9.2-8.7">Reference:</dt>
          <dd pn="section-9.2-8.8">RFC 9944, <xref target="ble-pairing-method-extensions" format="default" sectionFormat="of" derivedContent="Section 7.1.3"/></dd>
        </dl>
        <dl spacing="compact" newline="false" indent="3" pn="section-9.2-9">
          <dt pn="section-9.2-9.1">Schema URI:</dt>
          <dd pn="section-9.2-9.2">urn:ietf:params:scim:schemas:extension:pairingPassKey:2.0:Device</dd>
          <dt pn="section-9.2-9.3">Name:</dt>
          <dd pn="section-9.2-9.4">Passkey Pairing for BLE</dd>
          <dt pn="section-9.2-9.5">Resource Type:</dt>
          <dd pn="section-9.2-9.6">Device</dd>
          <dt pn="section-9.2-9.7">Reference:</dt>
          <dd pn="section-9.2-9.8">RFC 9944, <xref target="ble-pairing-method-extensions" format="default" sectionFormat="of" derivedContent="Section 7.1.3"/></dd>
        </dl>
        <dl spacing="compact" newline="false" indent="3" pn="section-9.2-10">
          <dt pn="section-9.2-10.1">Schema URI:</dt>
          <dd pn="section-9.2-10.2">urn:ietf:params:scim:schemas:extension:pairingNull:2.0:Device</dd>
          <dt pn="section-9.2-10.3">Name:</dt>
          <dd pn="section-9.2-10.4">Pairing Null</dd>
          <dt pn="section-9.2-10.5">Resource Type:</dt>
          <dd pn="section-9.2-10.6">Device</dd>
          <dt pn="section-9.2-10.7">Reference:</dt>
          <dd pn="section-9.2-10.8">RFC 9944, <xref target="ble-pairing-method-extensions" format="default" sectionFormat="of" derivedContent="Section 7.1.3"/></dd>
        </dl>
        <dl spacing="compact" newline="false" indent="3" pn="section-9.2-11">
          <dt pn="section-9.2-11.1">Schema URI:</dt>
          <dd pn="section-9.2-11.2">urn:ietf:params:scim:schemas:extension:zigbee:2.0:Device</dd>
          <dt pn="section-9.2-11.3">Name:</dt>
          <dd pn="section-9.2-11.4">Zigbee</dd>
          <dt pn="section-9.2-11.5">Resource Type:</dt>
          <dd pn="section-9.2-11.6">Device</dd>
          <dt pn="section-9.2-11.7">Reference:</dt>
          <dd pn="section-9.2-11.8">RFC 9944, <xref target="zigbee-extension" format="default" sectionFormat="of" derivedContent="Section 7.5"/></dd>
        </dl>
      </section>
    </section>
  </middle>
  <back>
    <displayreference target="I-D.ietf-asdf-nipc" to="NIPC"/>
    <displayreference target="RFC6749" to="OAUTHv2"/>
    <references anchor="sec-combined-references" pn="section-10">
      <name slugifiedName="name-references">References</name>
      <references anchor="sec-normative-references" pn="section-10.1">
        <name slugifiedName="name-normative-references">Normative References</name>
        <reference anchor="BLE54" target="https://www.bluetooth.org/DocMan/handlers/DownloadDoc.ashx?doc_id=587177" quoteTitle="true" derivedAnchor="BLE54">
          <front>
            <title>Bluetooth Core Specification</title>
            <author>
              <organization showOnFrontPage="true">Bluetooth SIG</organization>
            </author>
            <date year="2023"/>
          </front>
          <refcontent>Version 5.4</refcontent>
        </reference>
        <reference anchor="DPP2" target="https://www.wi-fi.org/system/files/Wi-Fi_Easy_Connect_Specification_v3.0.pdf" quoteTitle="true" derivedAnchor="DPP2">
          <front>
            <title>Wi-Fi Easy Connect Specification</title>
            <author>
              <organization showOnFrontPage="true">Wi-Fi Alliance</organization>
            </author>
            <date year="2020"/>
          </front>
          <refcontent>Version 3.0</refcontent>
        </reference>
        <reference anchor="ECMA" target="https://ecma-international.org/publications-and-standards/standards/ecma-262/" quoteTitle="true" derivedAnchor="ECMA">
          <front>
            <title>ECMAScript(R) 2025 Language Specification</title>
            <author>
              <organization showOnFrontPage="true">ECMA International</organization>
            </author>
            <date year="2025" month="June"/>
          </front>
          <refcontent>ECMA-262, 16th Edition</refcontent>
        </reference>
        <reference anchor="FDO11" target="https://fidoalliance.org/specs/FDO/FIDO-Device-Onboard-PS-v1.1-20220419/FIDO-Device-Onboard-PS-v1.1-20220419.html" quoteTitle="true" derivedAnchor="FDO11">
          <front>
            <title>FIDO Device Onboard Specification 1.1</title>
            <author>
              <organization showOnFrontPage="true">FIDO Alliance</organization>
            </author>
            <date year="2022" month="April"/>
          </front>
          <refcontent>Proposed Standard</refcontent>
        </reference>
        <reference anchor="RFC2119" target="https://www.rfc-editor.org/info/rfc2119" quoteTitle="true" derivedAnchor="RFC2119">
          <front>
            <title>Key words for use in RFCs to Indicate Requirement Levels</title>
            <author fullname="S. Bradner" initials="S." surname="Bradner"/>
            <date month="March" year="1997"/>
            <abstract>
              <t indent="0">In many standards track documents several words are used to signify the requirements in the specification. These words are often capitalized. This document defines these words as they should be interpreted in IETF documents. This document specifies an Internet Best Current Practices for the Internet Community, and requests discussion and suggestions for improvements.</t>
            </abstract>
          </front>
          <seriesInfo name="BCP" value="14"/>
          <seriesInfo name="RFC" value="2119"/>
          <seriesInfo name="DOI" value="10.17487/RFC2119"/>
        </reference>
        <reference anchor="RFC4648" target="https://www.rfc-editor.org/info/rfc4648" quoteTitle="true" derivedAnchor="RFC4648">
          <front>
            <title>The Base16, Base32, and Base64 Data Encodings</title>
            <author fullname="S. Josefsson" initials="S." surname="Josefsson"/>
            <date month="October" year="2006"/>
            <abstract>
              <t indent="0">This document describes the commonly used base 64, base 32, and base 16 encoding schemes. It also discusses the use of line-feeds in encoded data, use of padding in encoded data, use of non-alphabet characters in encoded data, use of different encoding alphabets, and canonical encodings. [STANDARDS-TRACK]</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="4648"/>
          <seriesInfo name="DOI" value="10.17487/RFC4648"/>
        </reference>
        <reference anchor="RFC5280" target="https://www.rfc-editor.org/info/rfc5280" quoteTitle="true" derivedAnchor="RFC5280">
          <front>
            <title>Internet X.509 Public Key Infrastructure Certificate and Certificate Revocation List (CRL) Profile</title>
            <author fullname="D. Cooper" initials="D." surname="Cooper"/>
            <author fullname="S. Santesson" initials="S." surname="Santesson"/>
            <author fullname="S. Farrell" initials="S." surname="Farrell"/>
            <author fullname="S. Boeyen" initials="S." surname="Boeyen"/>
            <author fullname="R. Housley" initials="R." surname="Housley"/>
            <author fullname="W. Polk" initials="W." surname="Polk"/>
            <date month="May" year="2008"/>
            <abstract>
              <t indent="0">This memo profiles the X.509 v3 certificate and X.509 v2 certificate revocation list (CRL) for use in the Internet. An overview of this approach and model is provided as an introduction. The X.509 v3 certificate format is described in detail, with additional information regarding the format and semantics of Internet name forms. Standard certificate extensions are described and two Internet-specific extensions are defined. A set of required certificate extensions is specified. The X.509 v2 CRL format is described in detail along with standard and Internet-specific extensions. An algorithm for X.509 certification path validation is described. An ASN.1 module and examples are provided in the appendices. [STANDARDS-TRACK]</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="5280"/>
          <seriesInfo name="DOI" value="10.17487/RFC5280"/>
        </reference>
        <reference anchor="RFC7643" target="https://www.rfc-editor.org/info/rfc7643" quoteTitle="true" derivedAnchor="RFC7643">
          <front>
            <title>System for Cross-domain Identity Management: Core Schema</title>
            <author fullname="P. Hunt" initials="P." role="editor" surname="Hunt"/>
            <author fullname="K. Grizzle" initials="K." surname="Grizzle"/>
            <author fullname="E. Wahlstroem" initials="E." surname="Wahlstroem"/>
            <author fullname="C. Mortimore" initials="C." surname="Mortimore"/>
            <date month="September" year="2015"/>
            <abstract>
              <t indent="0">The System for Cross-domain Identity Management (SCIM) specifications are designed to make identity management in cloud-based applications and services easier. The specification suite builds upon experience with existing schemas and deployments, placing specific emphasis on simplicity of development and integration, while applying existing authentication, authorization, and privacy models. Its intent is to reduce the cost and complexity of user management operations by providing a common user schema and extension model as well as binding documents to provide patterns for exchanging this schema using HTTP.</t>
              <t indent="0">This document provides a platform-neutral schema and extension model for representing users and groups and other resource types in JSON format. This schema is intended for exchange and use with cloud service providers.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="7643"/>
          <seriesInfo name="DOI" value="10.17487/RFC7643"/>
        </reference>
        <reference anchor="RFC7644" target="https://www.rfc-editor.org/info/rfc7644" quoteTitle="true" derivedAnchor="RFC7644">
          <front>
            <title>System for Cross-domain Identity Management: Protocol</title>
            <author fullname="P. Hunt" initials="P." role="editor" surname="Hunt"/>
            <author fullname="K. Grizzle" initials="K." surname="Grizzle"/>
            <author fullname="M. Ansari" initials="M." surname="Ansari"/>
            <author fullname="E. Wahlstroem" initials="E." surname="Wahlstroem"/>
            <author fullname="C. Mortimore" initials="C." surname="Mortimore"/>
            <date month="September" year="2015"/>
            <abstract>
              <t indent="0">The System for Cross-domain Identity Management (SCIM) specification is an HTTP-based protocol that makes managing identities in multi-domain scenarios easier to support via a standardized service. Examples include, but are not limited to, enterprise-to-cloud service providers and inter-cloud scenarios. The specification suite seeks to build upon experience with existing schemas and deployments, placing specific emphasis on simplicity of development and integration, while applying existing authentication, authorization, and privacy models. SCIM's intent is to reduce the cost and complexity of user management operations by providing a common user schema, an extension model, and a service protocol defined by this document.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="7644"/>
          <seriesInfo name="DOI" value="10.17487/RFC7644"/>
        </reference>
        <reference anchor="RFC8174" target="https://www.rfc-editor.org/info/rfc8174" quoteTitle="true" derivedAnchor="RFC8174">
          <front>
            <title>Ambiguity of Uppercase vs Lowercase in RFC 2119 Key Words</title>
            <author fullname="B. Leiba" initials="B." surname="Leiba"/>
            <date month="May" year="2017"/>
            <abstract>
              <t indent="0">RFC 2119 specifies common key words that may be used in protocol specifications. This document aims to reduce the ambiguity by clarifying that only UPPERCASE usage of the key words have the defined special meanings.</t>
            </abstract>
          </front>
          <seriesInfo name="BCP" value="14"/>
          <seriesInfo name="RFC" value="8174"/>
          <seriesInfo name="DOI" value="10.17487/RFC8174"/>
        </reference>
        <reference anchor="RFC8520" target="https://www.rfc-editor.org/info/rfc8520" quoteTitle="true" derivedAnchor="RFC8520">
          <front>
            <title>Manufacturer Usage Description Specification</title>
            <author fullname="E. Lear" initials="E." surname="Lear"/>
            <author fullname="R. Droms" initials="R." surname="Droms"/>
            <author fullname="D. Romascanu" initials="D." surname="Romascanu"/>
            <date month="March" year="2019"/>
            <abstract>
              <t indent="0">This memo specifies a component-based architecture for Manufacturer Usage Descriptions (MUDs). The goal of MUD is to provide a means for end devices to signal to the network what sort of access and network functionality they require to properly function. The initial focus is on access control. Later work can delve into other aspects.</t>
              <t indent="0">This memo specifies two YANG modules, IPv4 and IPv6 DHCP options, a Link Layer Discovery Protocol (LLDP) TLV, a URL, an X.509 certificate extension, and a means to sign and verify the descriptions.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="8520"/>
          <seriesInfo name="DOI" value="10.17487/RFC8520"/>
        </reference>
        <reference anchor="Zigbee" target="https://zigbeealliance.org/wp-content/uploads/2019/11/docs-05-3474-21-0csg-zigbee-specification.pdf" quoteTitle="true" derivedAnchor="Zigbee">
          <front>
            <title>Zigbee Specification</title>
            <author>
              <organization showOnFrontPage="true">Zigbee Alliance</organization>
            </author>
            <date year="2015" month="August"/>
          </front>
          <refcontent>ZigBee Document 05-3474-21</refcontent>
        </reference>
      </references>
      <references anchor="sec-informative-references" pn="section-10.2">
        <name slugifiedName="name-informative-references">Informative References</name>
        <reference anchor="JSONSchema" target="https://json-schema.org/draft/2020-12/json-schema-core" quoteTitle="true" derivedAnchor="JSONSchema">
          <front>
            <title>JSON Schema: A Media Type for Describing JSON Documents</title>
            <author initials="A." surname="Wright" fullname="Austin Wright" role="editor">
              <organization showOnFrontPage="true"/>
            </author>
            <author initials="H. A." surname="Andrews" fullname="Henry Andrews" role="editor">
              <organization showOnFrontPage="true"/>
            </author>
            <author initials="B." surname="Hutton" fullname="Ben Hutton" role="editor">
              <organization showOnFrontPage="true">Postman</organization>
            </author>
            <author initials="G." surname="Dennis" fullname="Greg Dennis">
              <organization showOnFrontPage="true"/>
            </author>
            <date year="2022" month="December"/>
          </front>
        </reference>
        <reference anchor="I-D.ietf-asdf-nipc" target="https://datatracker.ietf.org/doc/html/draft-ietf-asdf-nipc-19" quoteTitle="true" derivedAnchor="NIPC">
          <front>
            <title>An Application Layer Interface for Non-Internet-Connected Physical Components (NIPC)</title>
            <author fullname="Bart Brinckman" initials="B." surname="Brinckman">
              <organization showOnFrontPage="true">Cisco Systems</organization>
            </author>
            <author fullname="Rohit Mohan" initials="R." surname="Mohan">
              <organization showOnFrontPage="true">Cisco Systems</organization>
            </author>
            <author fullname="Braeden Sanford" initials="B." surname="Sanford">
              <organization showOnFrontPage="true">Philips</organization>
            </author>
            <date day="21" month="April" year="2026"/>
            <abstract>
              <t indent="0">This document describes an API that allows applications to perform operations against a gateway serving one or more devices described by an SDF model. The API consists of a RESTful application layer interface that performs operations on those devices, as well as a CBOR-based publish-subscribe interface for streaming data.</t>
            </abstract>
          </front>
          <seriesInfo name="Internet-Draft" value="draft-ietf-asdf-nipc-19"/>
          <refcontent>Work in Progress</refcontent>
        </reference>
        <reference anchor="RFC6749" target="https://www.rfc-editor.org/info/rfc6749" quoteTitle="true" derivedAnchor="OAUTHv2">
          <front>
            <title>The OAuth 2.0 Authorization Framework</title>
            <author fullname="D. Hardt" initials="D." role="editor" surname="Hardt"/>
            <date month="October" year="2012"/>
            <abstract>
              <t indent="0">The OAuth 2.0 authorization framework enables a third-party application to obtain limited access to an HTTP service, either on behalf of a resource owner by orchestrating an approval interaction between the resource owner and the HTTP service, or by allowing the third-party application to obtain access on its own behalf. This specification replaces and obsoletes the OAuth 1.0 protocol described in RFC 5849. [STANDARDS-TRACK]</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="6749"/>
          <seriesInfo name="DOI" value="10.17487/RFC6749"/>
        </reference>
        <reference anchor="OpenAPI" target="https://swagger.io/specification/" quoteTitle="true" derivedAnchor="OpenAPI">
          <front>
            <title>OpenAPI Specification</title>
            <author>
              <organization showOnFrontPage="true">Swagger</organization>
            </author>
            <date year="2024" month="October"/>
          </front>
          <refcontent>Version 3.1.1</refcontent>
        </reference>
        <reference anchor="RFC6241" target="https://www.rfc-editor.org/info/rfc6241" quoteTitle="true" derivedAnchor="RFC6241">
          <front>
            <title>Network Configuration Protocol (NETCONF)</title>
            <author fullname="R. Enns" initials="R." role="editor" surname="Enns"/>
            <author fullname="M. Bjorklund" initials="M." role="editor" surname="Bjorklund"/>
            <author fullname="J. Schoenwaelder" initials="J." role="editor" surname="Schoenwaelder"/>
            <author fullname="A. Bierman" initials="A." role="editor" surname="Bierman"/>
            <date month="June" year="2011"/>
            <abstract>
              <t indent="0">The Network Configuration Protocol (NETCONF) defined in this document provides mechanisms to install, manipulate, and delete the configuration of network devices. It uses an Extensible Markup Language (XML)-based data encoding for the configuration data as well as the protocol messages. The NETCONF protocol operations are realized as remote procedure calls (RPCs). This document obsoletes RFC 4741. [STANDARDS-TRACK]</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="6241"/>
          <seriesInfo name="DOI" value="10.17487/RFC6241"/>
        </reference>
        <reference anchor="RFC7950" target="https://www.rfc-editor.org/info/rfc7950" quoteTitle="true" derivedAnchor="RFC7950">
          <front>
            <title>The YANG 1.1 Data Modeling Language</title>
            <author fullname="M. Bjorklund" initials="M." role="editor" surname="Bjorklund"/>
            <date month="August" year="2016"/>
            <abstract>
              <t indent="0">YANG is a data modeling language used to model configuration data, state data, Remote Procedure Calls, and notifications for network management protocols. This document describes the syntax and semantics of version 1.1 of the YANG language. YANG version 1.1 is a maintenance release of the YANG language, addressing ambiguities and defects in the original specification. There are a small number of backward incompatibilities from YANG version 1. This document also specifies the YANG mappings to the Network Configuration Protocol (NETCONF).</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="7950"/>
          <seriesInfo name="DOI" value="10.17487/RFC7950"/>
        </reference>
        <reference anchor="RFC8040" target="https://www.rfc-editor.org/info/rfc8040" quoteTitle="true" derivedAnchor="RFC8040">
          <front>
            <title>RESTCONF Protocol</title>
            <author fullname="A. Bierman" initials="A." surname="Bierman"/>
            <author fullname="M. Bjorklund" initials="M." surname="Bjorklund"/>
            <author fullname="K. Watsen" initials="K." surname="Watsen"/>
            <date month="January" year="2017"/>
            <abstract>
              <t indent="0">This document describes an HTTP-based protocol that provides a programmatic interface for accessing data defined in YANG, using the datastore concepts defined in the Network Configuration Protocol (NETCONF).</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="8040"/>
          <seriesInfo name="DOI" value="10.17487/RFC8040"/>
        </reference>
        <reference anchor="RFC8792" target="https://www.rfc-editor.org/info/rfc8792" quoteTitle="true" derivedAnchor="RFC8792">
          <front>
            <title>Handling Long Lines in Content of Internet-Drafts and RFCs</title>
            <author fullname="K. Watsen" initials="K." surname="Watsen"/>
            <author fullname="E. Auerswald" initials="E." surname="Auerswald"/>
            <author fullname="A. Farrel" initials="A." surname="Farrel"/>
            <author fullname="Q. Wu" initials="Q." surname="Wu"/>
            <date month="June" year="2020"/>
            <abstract>
              <t indent="0">This document defines two strategies for handling long lines in width-bounded text content. One strategy, called the "single backslash" strategy, is based on the historical use of a single backslash ('\') character to indicate where line-folding has occurred, with the continuation occurring with the first character that is not a space character (' ') on the next line. The second strategy, called the "double backslash" strategy, extends the first strategy by adding a second backslash character to identify where the continuation begins and is thereby able to handle cases not supported by the first strategy. Both strategies use a self-describing header enabling automated reconstitution of the original content.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="8792"/>
          <seriesInfo name="DOI" value="10.17487/RFC8792"/>
        </reference>
        <reference anchor="RFC8995" target="https://www.rfc-editor.org/info/rfc8995" quoteTitle="true" derivedAnchor="RFC8995">
          <front>
            <title>Bootstrapping Remote Secure Key Infrastructure (BRSKI)</title>
            <author fullname="M. Pritikin" initials="M." surname="Pritikin"/>
            <author fullname="M. Richardson" initials="M." surname="Richardson"/>
            <author fullname="T. Eckert" initials="T." surname="Eckert"/>
            <author fullname="M. Behringer" initials="M." surname="Behringer"/>
            <author fullname="K. Watsen" initials="K." surname="Watsen"/>
            <date month="May" year="2021"/>
            <abstract>
              <t indent="0">This document specifies automated bootstrapping of an Autonomic Control Plane. To do this, a Secure Key Infrastructure is bootstrapped. This is done using manufacturer-installed X.509 certificates, in combination with a manufacturer's authorizing service, both online and offline. We call this process the Bootstrapping Remote Secure Key Infrastructure (BRSKI) protocol. Bootstrapping a new device can occur when using a routable address and a cloud service, only link-local connectivity, or limited/disconnected networks. Support for deployment models with less stringent security requirements is included. Bootstrapping is complete when the cryptographic identity of the new key infrastructure is successfully deployed to the device. The established secure connection can be used to deploy a locally issued certificate to the device as well.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="8995"/>
          <seriesInfo name="DOI" value="10.17487/RFC8995"/>
        </reference>
      </references>
    </references>
    <section anchor="json-schema-representation" numbered="true" removeInRFC="false" toc="include" pn="section-appendix.a">
      <name slugifiedName="name-json-schema-representation">JSON Schema Representation</name>
      <section anchor="resource-schema" numbered="true" removeInRFC="false" toc="include" pn="section-appendix.a.1">
        <name slugifiedName="name-resource-schema">Resource Schema</name>
        <sourcecode markers="true" pn="section-appendix.a.1-1">
[
  {
    "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": "/EndpointApps",
    "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/EndpointApps",
     "resourceType": "ResourceType"
    }
  }
]</sourcecode>
      </section>
      <section anchor="device-schema-json" numbered="true" removeInRFC="false" toc="include" pn="section-appendix.a.2">
        <name slugifiedName="name-core-device-schema">Core Device Schema</name>
        <sourcecode markers="true" pn="section-appendix.a.2-1">
{
  "id": "urn:ietf:params:scim:schemas:core:2.0:Device",
  "name": "Device",
  "description": "Entry containing attributes about a device.",
  "attributes" : [
    {
      "name": "displayName",
      "type": "string",
      "description": "Human-readable name of the device, suitable \
 for displaying to end users, for example, 'BLE Heart Monitor' etc.",
      "multiValued": 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 true, the commands (such as connect, \
disconnect, subscribe) that control app sends to the controller for \
the devices will be processed by the controller. If false, any \
command coming from the control app for the device will be \
                                        rejected by the controller.",
      "multiValued": 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).",
      "multiValued": false,
      "required": false,
      "caseExact": true,
      "mutability": "readWrite",
      "returned": "default",
      "uniqueness": "none"
    },
    {
      "name": "groups",
      "type": "complex",
      "multiValued": true,
      "description": "A list of groups to which the device belongs, \
either through direct membership, through nested groups, or \
                                            dynamically calculated.",
      "required": false,
      "subAttributes": [
        {
          "name": "value",
          "type": "string",
          "multiValued": false,
          "description": "The identifier of the device's group.",
          "required": false,
          "caseExact": false,
          "mutability": "readOnly",
          "returned": "default",
          "uniqueness": "none"
        },
        {
          "name": "$ref",
          "type": "reference",
          "referenceTypes": [
            "Group"
          ],
          "multiValued": false,
          "description": "The URI of the corresponding 'Group' \
                              resource to which the device belongs.",
          "required": false,
          "caseExact": false,
          "mutability": "readOnly",
          "returned": "default",
          "uniqueness": "none"
        },
        {
          "name": "display",
          "type": "string",
          "multiValued": false,
          "description": "A human-readable name, primarily used for \
                                      display purposes.  READ-ONLY.",
          "required": false,
          "caseExact": false,
          "mutability": "readOnly",
          "returned": "default",
          "uniqueness": "none"
        },
        {
          "name": "type",
          "type": "string",
          "multiValued": false,
          "description": "A label indicating the attribute's \
                            function, e.g., 'direct' or 'indirect'.",
          "required": false,
          "caseExact": false,
          "canonicalValues": [
            "direct",
            "indirect"
          ],
          "mutability": "readOnly",
          "returned": "default",
          "uniqueness": "none"
        }
      ],
      "mutability": "readOnly",
      "returned": "default"
    }
],
  "meta" : {
    "resourceType" : "Schema",
    "location" :
      "/v2/Schemas/urn:ietf:params:scim:schemas:core:2.0:Device"
  }
}</sourcecode>
      </section>
      <section anchor="endpointapp-schema-json" numbered="true" removeInRFC="false" toc="include" pn="section-appendix.a.3">
        <name slugifiedName="name-endpointapp-schema">EndpointApp Schema</name>
        <sourcecode markers="true" pn="section-appendix.a.3-1">
{
  "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.",
      "multiValued": false,
      "required": true,
      "caseExact": false,
      "mutability": "readOnly",
      "returned": "default",
      "uniqueness": "none"
    },
    {
      "name": "applicationName",
      "type": "string",
      "description": "Human-readable name of the application.",
      "multiValued": false,
      "required": true,
      "caseExact": false,
      "mutability": "readWrite",
      "returned": "default",
      "uniqueness": "none"
    },
    {
      "name": "certificateInfo",
      "type": "complex",
      "description": "Contains X.509 certificate's subject name and \
root CA information associated with the device control or telemetry \
                                                               app.",
      "multiValued": 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.",
      "multiValued": false,
      "required": false,
      "caseExact": true,
      "mutability": "readOnly",
      "returned": "default",
      "uniqueness": "none"
    },
    {
      "name": "groups",
      "type": "complex",
      "multiValued": true,
      "description": "A list of groups to which an endpoint \
application belongs, either through direct membership, through \
                          nested groups, or dynamically calculated.",
      "required": false,
      "subAttributes": [
        {
          "name": "value",
          "type": "string",
          "multiValued": false,
          "description": "The identifier of the endpoint application\
                                                          's group.",
          "required": false,
          "caseExact": false,
          "mutability": "readOnly",
          "returned": "default",
          "uniqueness": "none"
        },
        {
          "name": "$ref",
          "type": "reference",
          "referenceTypes": [
            "Group"
          ],
          "multiValued": false,
          "description": "The URI of the corresponding 'Group' \
                resource to which the endpoint application belongs.",
          "required": false,
          "caseExact": false,
          "mutability": "readOnly",
          "returned": "default",
          "uniqueness": "none"
        },
        {
          "name": "display",
          "type": "string",
          "multiValued": false,
          "description": "A human-readable name, primarily used for \
                                      display purposes.  READ-ONLY.",
          "required": false,
          "caseExact": false,
          "mutability": "readOnly",
          "returned": "default",
          "uniqueness": "none"
        },
        {
          "name": "type",
          "type": "string",
          "multiValued": false,
          "description": "A label indicating the attribute's \
                            function, e.g., 'direct' or 'indirect'.",
          "required": false,
          "caseExact": false,
          "canonicalValues": [
            "direct",
            "indirect"
          ],
          "mutability": "readOnly",
          "returned": "default",
          "uniqueness": "none"
        }
      ],
      "mutability": "readOnly",
      "returned": "default"
    }
  ],
  "meta" : {
    "resourceType" : "Schema",
    "location" :
      "/v2/Schemas/urn:ietf:params:scim:schemas:core:2.0:EndpointApp"
  }
}</sourcecode>
      </section>
      <section anchor="ble-extension-schema-json" numbered="true" removeInRFC="false" toc="include" pn="section-appendix.a.4">
        <name slugifiedName="name-ble-extension-schema">BLE Extension Schema</name>
        <sourcecode markers="true" pn="section-appendix.a.4-1">
[
  {
    "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.4]\
                                                                  .",
        "multiValued": 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.",
        "multiValued": 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.4. If true, device is using a random address\
                                         .  Default value is false.",
        "multiValued": 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 deviceMacAddress.",
        "multiValued": true,
        "required": false,
        "caseExact": false,
        "mutability": "readWrite",
        "returned": "default",
        "uniqueness": "none"
      },
      {
        "name": "irk",
        "type": "string",
        "description": "Identity Resolving Key (IRK), which is \
unique for every device. It is used to resolve a random address. \
  This value MUST NOT be set when separateBroadcastAddress is set.",
        "multiValued": false,
        "required": false,
        "caseExact": false,
        "mutability": "writeOnly",
        "returned": "never",
        "uniqueness": "Manufacturer"
      },
      {
        "name": "mobility",
        "type": "boolean",
        "description": "If set to true, the BLE device will \
automatically connect to the closest AP. For example, if a 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 \
       connected with AP-2.",
        "multiValued": 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.",
        "multiValued": 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'.",
        "multiValued": false,
        "required": false,
        "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 a device. The \
                                      pattern of key is ^[0-9]{6}$.",
        "multiValued": 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": "Out-of-band pairing method for BLE.",
    "attributes" : [
      {
        "name": "key",
        "type": "string",
        "description": "A key value retrieved from out-of-band \
                                                source such as NFC.",
        "multiValued": false,
        "required": true,
        "caseExact": true,
        "mutability": "readWrite",
        "returned": "default",
        "uniqueness": "none"
      },
      {
        "name": "randomNumber",
        "type": "integer",
        "description": "Nonce added to the key.",
        "multiValued": 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.",
        "multiValued": 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"
    }
  }
]</sourcecode>
      </section>
      <section anchor="dpp-extension-schema-json" numbered="true" removeInRFC="false" toc="include" pn="section-appendix.a.5">
        <name slugifiedName="name-dpp-extension-schema">DPP Extension Schema</name>
        <sourcecode markers="true" pn="section-appendix.a.5-1">
{
    "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.",
        "multiValued": 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].",
        "multiValued": 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).",
        "multiValued": false,
        "required": true,
        "caseExact": true,
        "mutability": "writeOnly",
        "returned": "never",
        "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.",
        "multiValued": 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'.",
        "multiValued": 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.",
        "multiValued": 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"
    }
  }</sourcecode>
      </section>
      <section anchor="ethernet-mab-extension-schema-json" numbered="true" removeInRFC="false" toc="include" pn="section-appendix.a.6">
        <name slugifiedName="name-ethernet-mab-extension-sche">Ethernet MAB Extension Schema</name>
        <sourcecode markers="true" pn="section-appendix.a.6-1">
{
  "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.",
        "multiValued": 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"
  }
}</sourcecode>
      </section>
      <section anchor="fdo-extension-schema-json" numbered="true" removeInRFC="false" toc="include" pn="section-appendix.a.7">
        <name slugifiedName="name-fdo-extension-schema">FDO Extension Schema</name>
        <sourcecode markers="true" pn="section-appendix.a.7-1">
{
  "id": "urn:ietf:params:scim:schemas:extension:fido-device-onboard:\
                                                        2.0:Device",
  "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.",
        "multiValued": false,
        "required": true,
        "caseExact": false,
        "mutability": "writeOnly",
        "returned": "never",
        "uniqueness": "Manufacturer"
      }
  ],
  "meta" : {
    "resourceType" : "Schema",
    "location" : "/v2/Schemas/urn:ietf:params:scim:schemas:extension\
                                    :fido-device-onboard:2.0:Device"
  }
}</sourcecode>
      </section>
      <section anchor="zigbee-extension-schema-json" numbered="true" removeInRFC="false" toc="include" pn="section-appendix.a.8">
        <name slugifiedName="name-zigbee-extension-schema">Zigbee Extension Schema</name>
        <sourcecode markers="true" pn="section-appendix.a.8-1">
{
  "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].",
      "multiValued": 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 64-bit Extended Unique Identifier \
                                          (EUI-64) device address.",
      "multiValued": 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"
  }
}</sourcecode>
      </section>
      <section anchor="endpointappsext-extension-schema-json" numbered="true" removeInRFC="false" toc="include" pn="section-appendix.a.9">
        <name slugifiedName="name-endpointappsext-extension-s">endpointAppsExt Extension Schema</name>
        <sourcecode markers="true" pn="section-appendix.a.9-1">
{
  "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 \
applications that connect with enterprise, i.e., deviceControl and \
                                                         telemetry.",
      "multiValued": 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 that will control or obtain data from the device.",
          "multiValued" : false,
          "required" : true,
          "caseExact" : true,
          "mutability" : "readOnly",
          "returned" : "default",
          "uniqueness" : "none"
        }
      ]
    },
    {
      "name": "deviceControlEnterpriseEndpoint",
      "type": "reference",
      "description": "The URL of the enterprise endpoint that \
       device control apps use to reach enterprise network gateway.",
      "multiValued": false,
      "required": true,
      "caseExact": true,
      "mutability": "readOnly",
      "returned": "default",
      "uniqueness": "Enterprise"
    },
    {
      "name": "telemetryEnterpriseEndpoint",
      "type": "reference",
      "description": "The URL of the enterprise endpoint that \
            telemetry apps use to reach enterprise network gateway.",
      "multiValued": 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"
  }
}</sourcecode>
      </section>
    </section>
    <section anchor="openapi-representation" numbered="true" removeInRFC="false" toc="include" pn="section-appendix.b">
      <name slugifiedName="name-openapi-representation">OpenAPI Representation</name>
      <t indent="0" pn="section-appendix.b-1">The following sections are provided for informational purposes.</t>
      <section anchor="device-schema-openapi-representation" numbered="true" removeInRFC="false" toc="include" pn="section-appendix.b.1">
        <name slugifiedName="name-core-device-schema-openapi-">Core Device Schema OpenAPI Representation</name>
        <t indent="0" pn="section-appendix.b.1-1">OpenAPI representation of core device schema is as follows:</t>
        <sourcecode markers="true" pn="section-appendix.b.1-2">
openapi: 3.1.0
info:
  title: SCIM Device Schema
  version: 1.0.0

components:
  schemas:
    Group:
      type: object
      description: A list of groups to which the device belongs,
                   either through direct membership, through nested
                   groups, or dynamically calculated.
      properties:
        value:
          type: string
          description: The unique identifier of a group,
                       typically a UUID.
          readOnly: true
          writeOnly: false
        display:
          type: string
          description: A display string for the group.
          readOnly: true
          writeOnly: false
        $ref:
          type: string
          format: uri
          description: Reference to the group object.
          readOnly: true
          writeOnly: true
    Device:
      description: Entry containing attributes about a device.
      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."
          readOnly: false
          writeOnly: false
        active:
          type: boolean
          description: A mutable boolean value indicating the device
                       administrative status. If true, the
                       commands (such as connect, disconnect,
                       subscribe) that control app sends to the
                       controller for the devices will be processed
                       by the controller. If false, any command
                       coming from the control app for the device
                       will be rejected by the controller.
          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.
          readOnly: false
          writeOnly: false
        groups:
          type: array
          description: List of groups to which a device belongs to.
          items:
            $ref: '#/components/schemas/Group'

      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.
        id:
          type: string
          format: uri
          description: The unique identifier for a resource.
          readOnly: true
          writeOnly: false
        externalId:
          type: string
          description: An identifier for the resource that is
                       defined by the provisioning client.
          readOnly: false
          writeOnly: false
        meta:
          type: object
          readOnly: true
          properties:
            resourceType:
              type: string
              description: The name of the resource type of the
                           resource.
              readOnly: true
              writeOnly: false
            location:
              type: string
              format: uri
              description: The URI of the resource being returned.
              readOnly: true
              writeOnly: false
            created:
              type: string
              format: date-time
              description: The date and time the resource was added
                           to the service provider.
              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.
              readOnly: true
              writeOnly: false
            version:
              type: string
              description: The version of the resource.
              readOnly: true
              writeOnly: false
          additionalProperties: false</sourcecode>
      </section>
      <section anchor="endpointapp-schema-openapi-representation" numbered="true" removeInRFC="false" toc="include" pn="section-appendix.b.2">
        <name slugifiedName="name-endpointapp-schema-openapi-">EndpointApp Schema OpenAPI Representation</name>
        <t indent="0" pn="section-appendix.b.2-1">OpenAPI representation of EndpointApp schema is as follows:</t>
        <sourcecode markers="true" pn="section-appendix.b.2-2">
openapi: 3.1.0
info:
  title: SCIM Endpoint App Schema
  version: 1.0.0

components:
  schemas:
    Group:
      type: object
      description: A list of groups to which the endpoint
                   application belongs, either through
                   direct membership, through nested
                   groups, or dynamically calculated.
      properties:
        value:
          type: string
          description: The unique identifier of a group,
                       typically a UUID.
          readOnly: true
          writeOnly: false
        display:
          type: string
          description: A display string for the group.
          readOnly: true
          writeOnly: false
        $ref:
          type: string
          format: uri
          description: Reference to the group object.
          readOnly: true
          writeOnly: true
    EndpointApp:
      title: EndpointApp
      description: Endpoint application resource.
      type: object
      properties:
        applicationType:
          type: string
          description: This attribute will only contain two values:
                       deviceControl or telemetry.
          readOnly: false
          writeOnly: false

        applicationName:
          type: string
          description: Human-readable name of the application.
          readOnly: false
          writeOnly: false
        groups:
          type: array
          description: List of groups to which the EndpointApp
                       belongs.
          items:
            $ref: '#/components/schemas/Group'

      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."
      readOnly: true
      writeOnly: false

    certificateInfo:
      type: object
      description: "Contains X.509 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."
          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."
          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.
        id:
          type: string
          format: uri
          description: The unique identifier for a resource.
          readOnly: true
          writeOnly: false
        meta:
          type: object
          readOnly: true
          properties:
            resourceType:
              type: string
              description: The name of the resource type of the
                           resource.
              readOnly: true
              writeOnly: false
            location:
              type: string
              format: uri
              description: The URI of the resource being returned.
              readOnly: true
              writeOnly: false
            created:
              type: string
              format: date-time
              description: The date and time the resource was added
                           to the service provider.
              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.
              readOnly: true
              writeOnly: false
            version:
              type: string
              description: The version of the resource.
              readOnly: true
              writeOnly: false
          additionalProperties: false</sourcecode>
      </section>
      <section anchor="ble-extension-schema-openapi-representation" numbered="true" removeInRFC="false" toc="include" pn="section-appendix.b.3">
        <name slugifiedName="name-ble-extension-schema-openap">BLE Extension Schema OpenAPI Representation</name>
        <t indent="0" pn="section-appendix.b.3-1">OpenAPI representation of BLE extension schema is as follows:</t>
        <sourcecode markers="true" pn="section-appendix.b.3-2">
openapi: 3.1.0
info:
  title: SCIM Bluetooth Extension Schema
  version: 1.0.0

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.4].
          readOnly: false
          writeOnly: false

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

        isRandom:
          type: boolean
          description: AddressType flag is taken from the BLE core
                       specifications 5.4.  If false, the device is
                       using a public MAC address.  If true, device
                       is using a random address.
          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 deviceMacAddress."
          readOnly: false
          writeOnly: false

        irk:
          type: string
          description: Identity Resolving Key (IRK), which is unique
                       for every device. It is used to resolve a
                       random address.
          readOnly: false
          writeOnly: true
        mobility:
          type: boolean
          description: If set to true, the BLE device will
                       automatically connect to the closest AP. For
                       example, if a 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 connected with AP-2.
          readOnly: false
          writeOnly: false
        pairingMethods:
          type: array
          items:
            type: string
          description: List of pairing methods associated with the
                       BLE device, stored as schema URI.
          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'.
          readOnly: false
          writeOnly: false
      required:
        - key

    PairingPassKey:
      type: object
      description: Passkey pairing method for BLE.
      properties:
        key:
          type: integer
          description: A six-digit passkey for a BLE device.
                       The pattern of key is ^[0-9]{6}$.
          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 a BLE device.
          readOnly: false
          writeOnly: false
        randomNumber:
          type: integer
          description: Nonce added to the key.
          readOnly: false
          writeOnly: true
        confirmationNumber:
          type: integer
          description: Some solutions require a confirmation number
                       in the RESTful message exchange.
          readOnly: false
          writeOnly: true
      required:
        - key
        - randomNumber</sourcecode>
      </section>
      <section anchor="dpp-extension-schema-openapi-representation" numbered="true" removeInRFC="false" toc="include" pn="section-appendix.b.4">
        <name slugifiedName="name-dpp-extension-schema-openap">DPP Extension Schema OpenAPI Representation</name>
        <t indent="0" pn="section-appendix.b.4-1">OpenAPI representation of DPP extension schema is as follows:</t>
        <sourcecode markers="true" pn="section-appendix.b.4-2">
openapi: 3.1.0
info:
  title: SCIM Device Provisioning Protocol Extension Schema
  version: 1.0.0

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.
          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].
          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.
          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}.
          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'.
          readOnly: false
          writeOnly: false
        serialNumber:
          type: string
          description: An alphanumeric serial number that may also
                       be passed as bootstrapping information.
          readOnly: false
          writeOnly: false
      required:
        - dppVersion
        - bootstrapKey
      additionalProperties: false</sourcecode>
      </section>
      <section anchor="ethernet-mab-extension-schema-openapi-representation" numbered="true" removeInRFC="false" toc="include" pn="section-appendix.b.5">
        <name slugifiedName="name-ethernet-mab-extension-schem">Ethernet MAB Extension Schema OpenAPI Representation</name>
        <t indent="0" pn="section-appendix.b.5-1">OpenAPI representation of Ethernet MAB extension schema is as follows:</t>
        <sourcecode markers="true" pn="section-appendix.b.5-2">
openapi: 3.1.0
info:
  title: SCIM MAC Authentication Bypass Extension Schema
  version: 1.0.0

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 a unique 48-bit value.
                       The regex pattern is
                       ^[0-9A-Fa-f]{2}(:[0-9A-Fa-f]{2}){5}.
          readOnly: false
          writeOnly: false
      required:
        - deviceMacAddress
      description: Device extension schema for Ethernet-MAB.</sourcecode>
      </section>
      <section anchor="fdo-extension-schema-openapi-representation" numbered="true" removeInRFC="false" toc="include" pn="section-appendix.b.6">
        <name slugifiedName="name-fdo-extension-schema-openap">FDO Extension Schema OpenAPI Representation</name>
        <t indent="0" pn="section-appendix.b.6-1">OpenAPI representation of FDO extension schema is as follows:</t>
        <sourcecode markers="true" pn="section-appendix.b.6-2">
openapi: 3.1.0
info:
  title: SCIM FIDO Device Onboarding Extension Schema
  version: 1.0.0

components:
  schemas:
    FDODevice:
      type: object
      description: FIDO Device Onboarding (FDO) extension.
      properties:
        schemas:
          type: array
          items:
            type: string
            enum:
              - urn:ietf:params:scim:schemas:extension:fido-device
                 -onboard:2.0:Device
        urn:ietf:params:scim:schemas:extension:fido-device-onboard
           :2.0:Device:
          $ref: '#/components/schemas/FDODeviceExtension'
          required: true
    FDODeviceExtension:
      type: object
      properties:
        fdoVoucher:
          type: string
          description: A FIDO Device Onboard (FDO) voucher.
          readOnly: false
          writeOnly: false
      required:
        - fdoVoucher
      description: Device extension for a FIDO Device Onboard (FDO).</sourcecode>
      </section>
      <section anchor="zigbee-extension-schema-openapi-representation" numbered="true" removeInRFC="false" toc="include" pn="section-appendix.b.7">
        <name slugifiedName="name-zigbee-extension-schema-ope">Zigbee Extension Schema OpenAPI Representation</name>
        <t indent="0" pn="section-appendix.b.7-1">OpenAPI representation of Zigbee extension schema is as follows:</t>
        <sourcecode markers="true" pn="section-appendix.b.7-2">
openapi: 3.1.0
info:
  title: SCIM Zigbee Extension Schema
  version: 1.0.0

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].
          readOnly: false
          writeOnly: false
        deviceEui64Address:
          type: string
          description: The 64-bit Extended Unique Identifier (EUI-64)
                       device address.  The regex pattern is
                       ^[0-9A-Fa-f]{16}$.
          readOnly: false
          writeOnly: false
      required:
        - versionSupport
        - deviceEui64Address
      description: Device extension schema for Zigbee.</sourcecode>
      </section>
      <section anchor="endpointappsext-extension-schema-openapi-representation" numbered="true" removeInRFC="false" toc="include" pn="section-appendix.b.8">
        <name slugifiedName="name-endpointappsext-extension-sc">endpointAppsExt Extension Schema OpenAPI Representation</name>
        <t indent="0" pn="section-appendix.b.8-1">OpenAPI representation of endpointAppsExt extension schema
is as follows:</t>
        <sourcecode markers="true" pn="section-appendix.b.8-2">
openapi: 3.1.0
info:
  title: SCIM Endpoint Extension Schema
  version: 1.0.0


components:
  schemas:
    EndpointAppsExt:
      type: object
      properties:
        applications:
          $ref: '#/components/schemas/applications'

        deviceControlEnterpriseEndpoint:
          type: string
          format: url
          description: The URL of the enterprise endpoint that
                       device control apps use to reach an
                       enterprise network gateway.
          readOnly: true
          writeOnly: false

        telemetryEnterpriseEndpoint:
          type: string
          format: url
          description: The URL of the enterprise endpoint that
                       telemetry apps use to reach an enterprise
                       network gateway.
          readOnly: true
          writeOnly: false

      required:
        - applications
        - deviceControlEnterpriseEndpoint

    applications:
      type: array
      items:
        value:
          type: string
          description: The identifier of the EndpointApp.
          readOnly: false
          writeOnly: false
        ref:
          type: string
          format: uri
          description: The URI of the corresponding EndpointApp
                       resource that will control or obtain data
                       from the device.
          readOnly: true
          writeOnly: false
      required:
        - value
        - ref</sourcecode>
      </section>
    </section>
    <section anchor="fido-device-onboarding-example-flow" numbered="true" removeInRFC="false" toc="include" pn="section-appendix.c">
      <name slugifiedName="name-fido-device-onboarding-exam">FIDO Device Onboarding Example Flow</name>
      <t indent="0" pn="section-appendix.c-1">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>
      <artset pn="section-appendix.c-2">
        <artwork type="svg" align="left" pn="section-appendix.c-2.1"><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">"ok"</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">"ok"</text>
              <text x="96" y="532">7</text>
              <text x="120" y="532">200</text>
              <text x="156" y="532">"ok"</text>
            </g>
          </svg>
        </artwork>
        <artwork type="ascii-art" align="left" pn="section-appendix.c-2.2">
 ,------.               ,------.               ,-------.
 |SCIM  |               |SCIM  |               |Owner  |   ,---.
 |Client|               |Server|               |Service|   |AAA|
 `---+--'               `---+--'               `---+---'   `-+-'
,------------------------------!.                  |         |
|Voucher contains              |_\                 |         |
|an X.509 cert chain             |                 |         |
`--------------------------------'                 |         |
     |1 POST [FDO(voucher)] |                      |         |
     |/HTTP                 |                      |         |
     |---------------------&gt;|                      |         |
     |                      |                      |         |
     |                      |----.                 |         |
     |                      |    | 2 Recover X.509 |         |
     |                      |&lt;---' cert chain      |         |
     |                      |      from voucher    |         |
     |                      |                      |         |
     |                      |                      |         |
     |                      |3 Add device(voucher) |         |
     |                      |/HTTP                 |         |
     |                      |---------------------&gt;|         |
     |                      |                      |         |
     |                      |     4 200 "ok"       |         |
     |                      |&lt;---------------------|         |
     |                      |                      |         |
     |                      |            5 Add identity      |
     |                      |-------------------------------&gt;|
     |                      |                      |         |
     |                      |              6 200 "ok"        |
     |                      |&lt;-------------------------------|
     |                      |                      |         |
     |     7 200 "ok"       |                      |         |
     |&lt;---------------------|                      |         |
     |                      |                      |         |
     |                      |                      |         |
</artwork>
      </artset>
      <t indent="0" pn="section-appendix.c-3">After this flow is complete, the device can then first provisionally
      onboard and then later receive a trust anchor through FDO's Transfer
      Ownership Protocol 2 (TO2) process.  This is shown below.</t>
      <artset pn="section-appendix.c-4">
        <artwork type="svg" align="left" pn="section-appendix.c-4.1"><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" align="left" pn="section-appendix.c-4.2">
 ,-------.                          ,------.
 |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  |
     |                |                 |&lt;-----------------|
     |                |                 |                  |
     |                |2 EAP-TLS/Radius |                  |
     |                |&lt;----------------|                  |
     |                |                 |                  |
     |                |            ,--------------------------!.
     |                |            |Device skips              |_\
     |                |            |server authentication       |
     |                |            `----------------------------'
     |                |3 Result=Success |                  |
     |                |----------------&gt;|                  |
     |                |                 |                  |
     |            ,-----------------------!.               |
     |            |Limited access         |_\              |
     |            |for now                  |              |
     |            `-------------------------'              |
     |                |                 |4 Result=Success  |
     |                |                 |-----------------&gt;|
     |                |                 |                  |
     |                |    5 FDO TO2    |                  |
     |&lt;----------------------------------------------------|
     |                |                 |                  |
,-------------------------------------------------------------!.
|FSIM, Runtime SSID,                                          |_\
|Credentials incl.                                              |
|local trust anchor                                             |
`---------------------------------------------------------------'
     |                |                 | 6 dissasociate   |
     |                |                 |&lt;-----------------|
     |                |                 |                  |
     |                |                 |7 EAP-TLS w/ LSC  |
     |                |                 |&lt;-----------------|
     |                |                 |                  |
     |                |                 |                  |
     .                .        etc      .                  .

</artwork>
      </artset>
    </section>
    <section anchor="acknowledgments" numbered="false" removeInRFC="false" toc="include" pn="section-appendix.d">
      <name slugifiedName="name-acknowledgments">Acknowledgments</name>
      <t indent="0" pn="section-appendix.d-1">The authors would like to thank <contact fullname="Sriram Sekar"/>, <contact fullname="Bart Brinckman"/>,
      <contact fullname="Rohit Mohan"/>, <contact fullname="Lars       Streubesand"/>, <contact fullname="Christian Amsüss"/>, <contact fullname="Jason Livingwood"/>, <contact fullname="Mike Ounsworth"/>,
      <contact fullname="Monty Wiseman"/>, <contact fullname="Geoffrey       Cooper"/>, <contact fullname="Paulo Jorge N. Correia"/>, <contact fullname="Phil Hunt"/>, and <contact fullname="Elwyn Davies"/> for their
      reviews and <contact fullname="Nick Ross"/> for his contribution to the
      appendix.</t>
    </section>
    <section anchor="authors-addresses" numbered="false" removeInRFC="false" toc="include" pn="section-appendix.e">
      <name slugifiedName="name-authors-addresses">Authors' Addresses</name>
      <author initials="M." surname="Shahzad" fullname="Muhammad Shahzad">
        <organization showOnFrontPage="true">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</city>
            <region>NC</region>
            <code>27695-8206</code>
            <country>United States of America</country>
          </postal>
          <email>mshahza@ncsu.edu</email>
        </address>
      </author>
      <author initials="H." surname="Iqbal" fullname="Hassan Iqbal">
        <organization showOnFrontPage="true">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</city>
            <region>NC</region>
            <code>27695-8206</code>
            <country>United States of America</country>
          </postal>
          <email>hassaniqbal931@gmail.com</email>
        </address>
      </author>
      <author initials="E." surname="Lear" fullname="Eliot Lear">
        <organization showOnFrontPage="true">Cisco Systems</organization>
        <address>
          <postal>
            <street>Richtistrasse 7</street>
            <city>Wallisellen</city>
            <code>8304</code>
            <country>Switzerland</country>
          </postal>
          <phone>+41 44 878 9200</phone>
          <email>lear@cisco.com</email>
        </address>
      </author>
    </section>
  </back>
</rfc>
