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


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

]>


<rfc ipr="trust200902" docName="draft-ietf-scim-device-model-04" category="std" consensus="true" submissionType="IETF" tocInclude="true" sortRefs="true" symRefs="true">
  <front>
    <title abbrev="SCIM Device Schema Extensions">Device Schema Extensions to the SCIM model</title>

    <author initials="M." surname="Shahzad" fullname="Muhammad Shahzad">
      <organization>North Carolina State University</organization>
      <address>
        <postal>
          <street>Department of Computer Science</street> <street>890 Oval Drive</street> <street>Campus Box 8206</street>
          <city>Raleigh, NC</city>
          <code>27695-8206</code>
          <country>USA</country>
        </postal>
        <email>mshahza@ncsu.edu</email>
      </address>
    </author>
    <author initials="H." surname="Iqbal" fullname="Hassan Iqbal">
      <organization>North Carolina State University</organization>
      <address>
        <postal>
          <street>Department of Computer Science</street> <street>890 Oval Drive</street> <street>Campus Box 8206</street>
          <city>Raleigh, NC</city>
          <code>27695-8206</code>
          <country>USA</country>
        </postal>
        <email>hassaniqbal931@gmail.com</email>
      </address>
    </author>
    <author initials="E." surname="Lear" fullname="Eliot Lear">
      <organization>Cisco Systems</organization>
      <address>
        <postal>
          <street>Richtistrasse 7</street>
          <city>Wallisellen</city>
          <code>CH-8304</code>
          <country>Switzerland</country>
        </postal>
        <phone>+41 44 878 9200</phone>
        <email>lear@cisco.com</email>
      </address>
    </author>

    <date year="2024" month="May" day="15"/>

    
    
    <keyword>Internet-Draft</keyword>

    <abstract>


<?line 71?>

<t>The initial core schema for SCIM (System for Cross Identity
Management) was designed for provisioning users.  This memo specifies
schema extensions that enables provisioning of devices, using various
underlying bootstrapping systems, such as Wifi EasyConnect, FIDO
device onboarding vouchers, BLE passcodes, and MAC authenticated bypass.</t>



    </abstract>



  </front>

  <middle>


<?line 79?>

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

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

<t>SCIM (System for Cross Identity Management) <xref target="RFC7643"/> <xref target="RFC7644"/>
defines a protocol and a schema for provisioning of users.  However,
it can easily be extended to provision devices.  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>

<section anchor="why-scim-for-devices"><name>Why SCIM for devices?</name>
<t>Some might ask why SCIM is well suited for this purpose and not, for
example, NETCONF or RESTCONF with YANG.  After all, there are all sorts
of existing models available.  The answer is that the only information
being passed about the device is neither state nor device configuration
information, but only information necessary to bootstrap trust so that
the device may establish connectivity.</t>

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

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

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

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

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

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

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

]]></artwork></figure>

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

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

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

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

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

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

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

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

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

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

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

<t>id</t>

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

<t>externalID</t>

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

<t>meta</t>

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

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

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

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

<t>deviceDisplayName</t>

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

<t>adminState</t>

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

<t>mudUrl</t>

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

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

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

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

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

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

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

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

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

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

</section>
<section anchor="endpointapp-schema"><name>SCIM EndpointApp Schema</name>
<t>The schema for "EndpointApp" is identified using the schema URI:
"urn:ietf:params:scim:schemas:core:2.0:EndpointApp". The following
attributes are defined in this schema.</t>

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

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

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

<t>applicationType</t>

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

<t>applicationName</t>

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

<t>clientToken</t>

<t>This attribute type string contains a token that the client will use 
to authenticate itself.  Each token may be a string up to 500 
characters in length. It is mutable, required, case sensitive 
and returned by default if it exists.</t>

</section>
<section anchor="complex-attribute"><name>Complex Attribute</name>

<t>certificateInfo</t>

<t>It is the complex attribute that Contains x509 certificate's subject
name and root CA information associated with the device control or 
telemetry app. It further has three attributes that are described 
below.</t>

<t>rootCN</t>

<t>It is the root certificate common name. This attribute is required,
read only, singular and case sensitive.</t>

<t>subjectName</t>

<t>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. This attribute is not required,
read only, singular and case sensitive.</t>

<t>subjectAlternativeName</t>

<t>This attribute allows for the inclusion of multiple domain names and
IP addresses in a single certificate. This enables the certificate to
be used for multiple related domains or IPs without the need for 
separate certificates for each. This attribute is not required,
read only, multivalued and case sensitive.</t>

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

<t>Note that attributes clientToken and certificateInfo are used for the
authentication of the application. Both SHALL NOT exist together in the
SCIM object. Either clientToken or certificateInfo SHALL be present
in the SCIM object.</t>

<t>An example of a endpointApp SCIM object is as follows. Note that since
certificateInfo is present in the example, clientToken attribute is 
NULL.</t>

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

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

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

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

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

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

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

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

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

<t>deviceMacAddress</t>

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

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

<t>isRandom</t>

<t>A boolean flag taken from the BLE core specification, 5.3. If FALSE, the
device is using a public MAC address. If TRUE, the device uses a
Random address resolved using IRK. This attribute is not required, it is 
mutable, and returned by default.  Its default value is FALSE.</t>

<t>separateBroadcastAddress</t>

<t>When present, this address is used for broadcasts/advertisements.
This value MUST NOT be set when an IRK is provided.  Its form is the
same as deviceMacAddress.  It is not required, multivalued, mutable,
and returned by default.</t>

<t>irk</t>

<t>A string value, Identity resolving key, which is unique for every 
device. It is used to resolve the random address. It is required when 
addressType is TRUE. It is mutable and return by default.</t>

<t>mobility</t>

<t>A boolean attribute to enable mobility on BLE device. If set to True, 
the BLE device will automatically connect to the closest AP. For 
example, BLE device is connected with AP-1 and moves out of range but 
comes in range of AP-2, it will be disconnected with AP-1 and connects 
with AP-2. It is returned by default and mutable.</t>

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

<t>versionSupport</t>

<t>A multivalued attribute that provides all the BLE versions supported by the
device in the form of an array. For example, 
[4.1, 4.2, 5.0, 5.1, 5.2, 5.3]. It is required, mutable, and 
return as default.</t>

<t>pairingMethods</t>

<t>An array of pairing methods associated with the BLE
device. The pairing methods may require sub-attributes, such as
key/password, for the device pairing process. To enable the
scalability of pairing methods in the future, they are represented as
extensions to incorporate various attributes that are part of the
respective pairing process. Pairing method extensions are nested
inside the BLE extension. It is required, case sensitive, mutable, and 
returned by default.</t>

</section>
<section anchor="ble-pairing-method-extensions"><name>BLE Pairing Method Extensions</name>

<t>The details on pairing methods and their associated attributes are in
section 2.3 of <xref target="BLE53"/>.  This memo defines extensions for four
pairing methods that are nested insided the BLE extension schema. Each 
extension contains the common attributes <xref target="common-attributes"></xref>. These 
extension are are as follows.</t>

<t>(i) pairingNull extension is identified using the following schema URI:</t>

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

<t>pairingNull does not have any attribute. It allows pairing for BLE
devices that do not require a pairing method.</t>

<t>(ii) pairingJustWorks extension is identified using the following 
schema URI:</t>

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

<t>Just works pairing method does not require a key to pair devices. For
completeness, the key attribute is included and is set to 'null'. Key 
attribute is required, immutable, and return by default.</t>

<t>(iii) pairingPassKey extension is identified using the following 
schema URI:</t>

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

<t>The pass key pairing method requires a 6-digit key to pair devices.
This extension has one singular integer attribute, "key", which is 
required, mutable and returned by default. The key pattern is
as follows:</t>

<figure><artwork><![CDATA[
^[0-9]{6}$
]]></artwork></figure>

<t>(iv) pairingOOB extension is identified using the following 
schema URI:</t>

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

<t>The out-of-band pairing method includes three singular attributes,
i.e., key, randomNumber, and confirmationNumber.</t>

<t>key  The key is string value, required and received from out-of-bond 
sources such as NFC. It is case sensitive, mutable, and returned 
by default.</t>

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

<t>confirmationNumber  An integer which some solutions require in RESTful
message exchange. It is not required. It is mutable and returned by 
default if it exists.</t>

<texttable title="Characteristics of BLE extension schema attributes. 
sepBroadcastAdd is short for separateBroadcastAddress. (Req = Required,
T = True, F = False, RW = ReadWrite, Def = Default, and 
Manuf = Manufacturer)." anchor="tabBLE">
      <ttcol align='left'>Attribute</ttcol>
      <ttcol align='left'>Multi Value</ttcol>
      <ttcol align='left'>Req</ttcol>
      <ttcol align='left'>Case Exact</ttcol>
      <ttcol align='left'>Mutable</ttcol>
      <ttcol align='left'>Return</ttcol>
      <ttcol align='left'>Unique</ttcol>
      <c>deviceMacAddress</c>
      <c>F</c>
      <c>T</c>
      <c>F</c>
      <c>RW</c>
      <c>Def</c>
      <c>Manuf</c>
      <c>isRandom</c>
      <c>F</c>
      <c>T</c>
      <c>F</c>
      <c>RW</c>
      <c>Def</c>
      <c>None</c>
      <c>sepBroadcastAdd</c>
      <c>T</c>
      <c>T</c>
      <c>F</c>
      <c>RW</c>
      <c>Def</c>
      <c>None</c>
      <c>irk</c>
      <c>F</c>
      <c>F</c>
      <c>F</c>
      <c>RW</c>
      <c>Def</c>
      <c>Manuf</c>
      <c>versionSupport</c>
      <c>T</c>
      <c>T</c>
      <c>F</c>
      <c>RW</c>
      <c>Def</c>
      <c>None</c>
      <c>mobility</c>
      <c>F</c>
      <c>F</c>
      <c>F</c>
      <c>RW</c>
      <c>Def</c>
      <c>None</c>
      <c>pairingMethods</c>
      <c>T</c>
      <c>T</c>
      <c>T</c>
      <c>RW</c>
      <c>Def</c>
      <c>None</c>
</texttable>

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

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

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

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

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

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

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

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

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

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

</section>
</section>
<section anchor="easyconnect-extension"><name>EasyConnect Extension</name>

<t>A schema that extends the device schema to enable WiFi EasyConnect
(otherwise known as Device Provisioning Protocol or DPP). The extension
is identified using the following schema URI:</t>

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

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

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

<t>dppVersion</t>

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

<t>bootstrapKey</t>

<t>A string value representing Elliptic-Curve Diffie–Hellman (ECDH) public 
key. The base64 encoded lengths for P-256, P-384, and P-521 are 
80, 96, and 120 characters. This attribute is required, case-sensitive,
mutable, and returned by default.</t>

<t>deviceMacAddress</t>

<t>The manufacturer assigns the MAC address stored as string. It is a 
unique 48-bit value. This attribute is optional, case insensitive, 
mutable, and returned by default. The regex pattern is as follows:</t>

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

<t>serialNumber</t>

<t>An alphanumeric serial number, stored as string, may also be passed 
as bootstrapping information. This attribute is optional, case 
insensitive, mutable, and returned by default.</t>

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

<t>bootstrappingMethod</t>

<t>It is the array of strings of all the bootstrapping methods available 
on the enrollee device. For example, [QR, NFC]. This attribute is 
optional, case insensitive, mutable, and returned by default.</t>

<t>classChannel</t>

<t>This attribute is an array of strings of global operating class and 
channel shared as bootstrapping information. It is formatted as 
class/channel. For example, ['81/1','115/36']. This attribute 
is optional, case insensitive, mutable, and returned by default.</t>

<figure title="Characteristics of DPP extension schema attributes. 
(Req = Required, T = True, F = False, RW = ReadWrite, Def = Default,
and Manuf = Manufacturer)." anchor="tabDPP"><artwork><![CDATA[
+====================+=====+===+======+=========+========+========+
| Attribute          |Multi|Req| Case | Mutable | Return | Unique |
|                    |Value|   | Exact|         |        |        |
+====================+=====+===+======+=========+========+========+
| dppVersion         |  F  | T |  F   |   RW    |  Def   | None   |
+--------------------+-----+---+------+---------+--------+--------+
| bootstrapKey       |  F  | T |  T   |   RW    |  Def   | None   |
+--------------------+-----+---+------+---------+--------+--------+
| deviceMacAddress   |  F  | F |  F   |   RW    |  Def   | Manuf  |
+--------------------+-----+---+------+---------+--------+--------+
| serialNumber       |  F  | F |  F   |   RW    |  Def   | None   |
+--------------------+-----+---+------+---------+--------+--------+
| bootstrappingMethod|  T  | F |  F   |   RW    |  Def   | None   |
+--------------------+-----+---+------+---------+--------+--------+
| classChannel       |  T  | F |  F   |   RW    |  Def   | None   |
+--------------------+-----+---+------+---------+--------+--------+
]]></artwork></figure>

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

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

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

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

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

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

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

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

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

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

<t>deviceMacAddress</t>

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

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

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

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

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

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

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

</section>
</section>
<section anchor="fido-device-onboarding-extension"><name>Fido Device Onboarding Extension</name>

<t>This extension specifies a voucher to be used by a Fido Device Onboarding
(FDO) owner process <xref target="FDO11"/>, so that a trusted introduction can be made using that mechanism.</t>

<t>urn:ietf:params:scim:schemas:extension:fido-device-onboard:2.0:Device</t>

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

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

<t>fdoVoucher</t>

<t>The voucher is formated as a PEM-encoded object in accordance with the FDO
specification (citation needed).</t>

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

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

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

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

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

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

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

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

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

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

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

<t>deviceEui64Address</t>

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

<figure><artwork><![CDATA[
^[0-9A-Fa-f]{16}$
]]></artwork></figure>

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

<t>versionSupport</t>

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

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

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

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

  "id": "e9e30dba-f08f-4109-8486-d5c6a3316111",
  "displayName": "Zigbee Heart Monitor",
  "adminState": true,
  "urn:ietf:params:scim:schemas:extension:zigbee:2.0:Device" : {
    "versionSupport": ["3.0"],
    "deviceEui64Address": "50325FFFFEE76728"
  },

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

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

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

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

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

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

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

<t>deviceControlEnterpriseEndpoint</t>

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

<t>telemetryEnterpriseEndpoint</t>

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

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

<t>applications</t>

<t>This is a complex multivalued attribute. It represents a list of 
endpoint applications i.e., deviceControl and telemetry. Each entry in
the list comprises two attributes including "value" and "$ref".</t>

<t>value</t>

<t>It is the identifier of the endpoint application formated as UUID. It
is same as the common attribute "$id" of the resource "endpointApp".
It is readOnly, required, case insensitive and returned by default.</t>

<t>$ref</t>

<t>It is the reference to the respective endpointApp resource object 
stored in the SCIM server. It is readOnly, required, case sensitive
and returned by default.</t>

<texttable title="Characteristics of EndpointAppsExt extension schema 
attributes. DevContEntEndpoint represents attribute 
deviceControlEnterpriseEndpoint and telEntEndpoint represents 
telemetryEnterpriseEndpoint. (Req = Required, T = True, F = False, 
R = ReadOnly, RW = ReadWrite, Ent = Enterprise, and Def = Default)." anchor="tabEndpointAppsExt">
      <ttcol align='left'>Attribute</ttcol>
      <ttcol align='left'>Multi Value</ttcol>
      <ttcol align='left'>Req</ttcol>
      <ttcol align='left'>Case Exact</ttcol>
      <ttcol align='left'>Mutable</ttcol>
      <ttcol align='left'>Return</ttcol>
      <ttcol align='left'>Unique</ttcol>
      <c>devContEntEndpoint</c>
      <c>F</c>
      <c>T</c>
      <c>T</c>
      <c>R</c>
      <c>Def</c>
      <c>Ent</c>
      <c>telEntEndpoint</c>
      <c>F</c>
      <c>T</c>
      <c>T</c>
      <c>R</c>
      <c>Def</c>
      <c>Ent</c>
      <c>applications</c>
      <c>T</c>
      <c>T</c>
      <c>F</c>
      <c>RW</c>
      <c>Def</c>
      <c>None</c>
      <c>value</c>
      <c>F</c>
      <c>T</c>
      <c>F</c>
      <c>R</c>
      <c>Def</c>
      <c>None</c>
      <c>$ref</c>
      <c>F</c>
      <c>T</c>
      <c>F</c>
      <c>R</c>
      <c>Def</c>
      <c>None</c>
</texttable>

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

<figure><artwork><![CDATA[
<CODE BEGINS>
{
  "schemas": ["urn:ietf:params:scim:schemas:core:2.0:Device",
     "urn:ietf:params:scim:schemas:extension:ble:2.0:Device",
     "urn:ietf:params:scim:schemas:extension:endpointAppsExt:2.0
        :Device"],
  "id": "e9e30dba-f08f-4109-8486-d5c6a3316111",
  "deviceDisplayName": "BLE Heart Monitor",
  "adminState": true,
  "urn:ietf:params:scim:schemas:extension:ble:2.0:Device" : {
    "versionSupport": ["5.3"],
    "deviceMacAddress": "2C:54:91:88:C9:E2",
    "isRandom": false,
    "separateBroadcastAddress": ["AA:BB:88:77:22:11", "AA:BB:88:77
       :22:12"],
    "mobility": false,
    "pairingMethods": [
        "urn:ietf:params:scim:schemas:extension:pairingNull:2.0
           :Device",
        "urn:ietf:params:scim:schemas:extension:pairingJustWorks
           :2.0:Device",
        "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:pairingNull:2.0:Device"
       : null,
    "urn:ietf:params:scim:schemas:extension:pairingJustWorks:2.0
       :Device": {
      "key": null
    },
    "urn:ietf:params:scim:schemas:extension:pairingPassKey:2.0
       :Device" : {
      "key": 123456
    },
    "urn:ietf:params:scim:schemas:extension:pairingOOB:2.0:Device":
        {
      "key": "TheKeyvalueRetrievedFromOOB",
      "randNumber": 238796813516896
    }
  },

  "urn:ietf:params:scim:schemas:extension:endpointAppsExt:2.0
     :Device": {

    "applications": [
      {
        "value" : "e9e30dba-f08f-4109-8486-d5c6a3316212",
        "$ref" : "https://example.com/v2/EndpointApp/e9e30dba-f08f
           -4109-8486-d5c6a3316212"
      },
      {
        "value" : "e9e30dba-f08f-4109-8486-d5c6a3316333",
        "$ref" : "https://example.com/v2/EndpointApp/e9e30dba-f08f
           -4109-8486-d5c6a3316333"
      }
    ],
    "deviceControlEnterpriseEndpoint":
        "https//enterprise.com/device_control_app_endpoint/",
    "telemetryEnterpriseEndpoint":
        "https//enterprise.com/telemetry_app_endpoint/"
  },


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

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

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

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

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

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

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

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

<figure><artwork><![CDATA[
<CODE BEGINS>
{
  "id": "urn:ietf:params:scim:schemas:core:2.0:EndpointApp",
  "name": "EndpointApp",
  "description": "Endpoint application and their credentials",
  "attributes" : [
    {
      "name": "applicationType",
      "type": "string",
      "description": "This attribute will only contain two values;
          'deviceControl' or 'telemetry'.",
      "multivalues": false,
      "required": true,
      "caseExact": false,
      "mutability": "readOnly",
      "returned": "default",
      "uniqueness": "none"
    },
    {
      "name": "applicationName",
      "type": "string",
      "description": "Human readable name of the application.",
      "multivalues": false,
      "required": true,
      "caseExact": false,
      "mutability": "readWrite",
      "returned": "default",
      "uniqueness": "none"
    },
    {
      "name": "certificateInfo",
      "type": "complex",
      "description": "Contains x509 certificate's subject name and
          root CA information associated with the device control or
          telemetry app.",
      "multivalues": false,
      "required": false,
      "caseExact": false,
      "mutability": "readWrite",
      "returned": "default",
      "uniqueness": "none",
      "subAttributes" : [
        {
          "name" : "rootCN",
          "type" : "string",
          "description" : "A root certificate common name.",
          "multiValued" : false,
          "required" : true,
          "caseExact" : true,
          "mutability" : "readOnly",
          "returned" : "default",
          "uniqueness" : "none"
        },
        {
          "name" : "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.",
          "multiValued" : false,
          "required" : false,
          "caseExact" : true,
          "mutability" : "readOnly",
          "returned" : "default",
          "uniqueness" : "none"
        },
        {
          "name" : "subjectAlternativeName",
          "type" : "string",
          "description" : "This attribute allows for the inclusion
              of multiple domain names and IP addresses in a single
              certificate. This enables the certificate to be used
              for multiple related domains or IPs without the need
              for separate certificates for each.",
          "multiValued" : true,
          "required" : false,
          "caseExact" : true,
          "mutability" : "readOnly",
          "returned" : "default",
          "uniqueness" : "none"
        }
      ]
    },
    {
      "name": "clientToken",
      "type": "string",
      "description": "This attribute contains a token that the
          client will use to authenticate itself.  Each token may
          be a string up to 500 characters in length.",
      "multivalues": false,
      "required": false,
      "caseExact": true,
      "mutability": "readOnly",
      "returned": "default",
      "uniqueness": "none"
    }
  ],
  "meta" : {
    "resourceType" : "Schema",
    "location" :
      "/v2/Schemas/urn:ietf:params:scim:schemas:core:2.0:Device"
  }
}
<CODE ENDS>
]]></artwork></figure>

</section>
<section anchor="ble-extension-schema-json"><name>BLE Extension Schema JSON</name>
<figure><artwork><![CDATA[
<CODE BEGINS>
[
  {
    "id": "urn:ietf:params:scim:schemas:extension:ble:2.0:Device",
    "name": "bleExtension",
    "description": "Ble extension for device account",
    "attributes" : [
      {
        "name": "versionSupport",
        "type": "string",
        "description": "Provides a list of all the BLE versions
            supported by the device. For example, [4.1, 4.2, 5.0,
            5.1, 5.2, 5.3].",
        "multivalues": true,
        "required": true,
        "caseExact": false,
        "mutability": "readWrite",
        "returned": "default",
        "uniqueness": "none"
      },
      {
        "name": "deviceMacAddress",
        "type": "string",
        "description": "It is the public MAC address assigned by
            the manufacturer. It is unique 48 bit value. The regex
            pattern is ^[0-9A-Fa-f]{2}(:[0-9A-Fa-f]{2}){5}.",
        "multivalues": false,
        "required": true,
        "caseExact": false,
        "mutability": "readWrite",
        "returned": "default",
        "uniqueness": "Manufacturer"
      },
      {
        "name": "isRandom",
        "type": "boolean",
          "description": "The isRandom flag is taken from the BLE
              core specifications 5.3. If TRUE, device is using
              Random address which is resolved using IRK.  If not
              present, the value is FALSE.",
        "multivalues": false,
        "required": false,
        "caseExact": false,
        "mutability": "readWrite",
        "returned": "default",
        "uniqueness": "none"
      },
      {
        "name": "separateBroadcastAddress",
        "type": "string",
        "description": "When present, this address is used for
            broadcasts/advertisements.  This value MUST NOT be set
            when an IRK is provided.  Its form is the same as
            deviceMa`cAddress.",
        "multivalues": true,
        "required": false,
        "caseExact": false,
        "mutability": "readWrite",
        "returned": "default",
        "uniqueness": "none"
      },
      {
        "name": "irk",
        "type": "string",
        "description": "Identity resolving key, which is unique for
            every device. It is used to resolve random address. 
            This value MUST NOT be set when
            separateBroadcastAddress is set.",
        "multivalues": false,
        "required": false,
        "caseExact": false,
        "mutability": "readWrite",
        "returned": "default",
        "uniqueness": "Manufacturer"
      },
      {
        "name": "mobility",
        "type": "bool",
        "description": "If set to True, the BLE device will
            automatically connect to the closest AP. For example,
            BLE device is connected with AP-1 and moves out of
            range but comes in range of AP-2, it will be
            disconnected with AP-1 and connects with AP-2.",
        "multivalues": false,
        "required": false,
        "caseExact": false,
        "mutability": "readWrite",
        "returned": "default",
        "uniqueness": "none"
      },
      {
        "name": "pairingMethods",
        "type": "string",
        "description": "List of pairing methods associated with the
            ble device, stored as schema URI.",
        "multivalues": true,
        "required": true,
        "caseExact": true,
        "mutability": "readWrite",
        "returned": "default",
        "uniqueness": "none"
      }
    ],
    "meta" : {
      "resourceType" : "Schema",
      "location" : "/v2/Schemas/urn:ietf:params:scim:schemas
         :extension:ble:2.0:Device"
    }
  },
  {
    "id": "urn:ietf:params:scim:schemas:extension:pairingNull:2.0
       :Device",
    "name": "nullPairing",
    "description": "Null pairing method for ble. It is included for
        the devices that do not have a pairing method.",
    "meta" : {
      "resourceType" : "Schema",
      "location" : "/v2/Schemas/urn:ietf:params:scim:schemas
         :extension:pairingNull:2.0:Device"
    }
  },
  {
    "id": "urn:ietf:params:scim:schemas:extension:pairingJustWorks
       :2.0:Device",
    "name": "pairingJustWorks",
    "description": "Just works pairing method for ble.",
    "attributes" : [
      {
        "name": "key",
        "type": "integer",
        "description": "Just works does not have any key value. For
            completeness, it is added with a key value 'null'.",
        "multivalues": false,
        "required": true,
        "caseExact": false,
        "mutability": "immutable",
        "returned": "default",
        "uniqueness": "none"
      }
    ],
    "meta" : {
      "resourceType" : "Schema",
      "location" : "/v2/Schemas/urn:ietf:params:scim:schemas
         :extension:pairingJustWorks:2.0:Device"
    }
  },
  {
    "id": "urn:ietf:params:scim:schemas:extension:pairingPassKey
       :2.0:Device",
    "name": "pairingPassKey",
    "description": "Pass key pairing method for ble.",
    "attributes" : [
      {
        "name": "key",
        "type": "integer",
        "description": "A six digit passkey for ble device. The
            pattern of key is ^[0-9]{6}$.",
        "multivalues": false,
        "required": true,
        "caseExact": false,
        "mutability": "readWrite",
        "returned": "default",
        "uniqueness": "none"
      }
    ],
    "meta" : {
      "resourceType" : "Schema",
      "location" : "/v2/Schemas/urn:ietf:params:scim:schemas
         :extension:pairingPassKey:2.0:Device"
    }
  },
  {
    "id": "urn:ietf:params:scim:schemas:extension:pairingOOB:2.0
       :Device",
    "name": "pairingOOB",
    "description": "Pass key pairing method for ble.",
    "attributes" : [
      {
        "name": "key",
        "type": "string",
        "description": "A key value retrieved from out of band
            source such as NFC.",
        "multivalues": false,
        "required": true,
        "caseExact": true,
        "mutability": "readWrite",
        "returned": "default",
        "uniqueness": "none"
      },
      {
        "name": "randomNumber",
        "type": "integer",
        "description": "Nonce added to the key.",
        "multivalues": false,
        "required": true,
        "caseExact": false,
        "mutability": "readWrite",
        "returned": "default",
        "uniqueness": "none"
      },
      {
        "name": "confirmationNumber",
        "type": "integer",
        "description": "Some solutions require confirmation number
            in RESTful message exchange.",
        "multivalues": false,
        "required": false,
        "caseExact": false,
        "mutability": "readWrite",
        "returned": "default",
        "uniqueness": "none"
      }
    ],
    "meta" : {
      "resourceType" : "Schema",
      "location" : "/v2/Schemas/urn:ietf:params:scim:schemas
         :extension:pairingOOB:2.0:Device"
    }
  }
]
<CODE ENDS>
]]></artwork></figure>

</section>
<section anchor="dpp-extension-schema-json"><name>DPP Extension Schema JSON</name>
<figure><artwork><![CDATA[
<CODE BEGINS>
{
    "id": "urn:ietf:params:scim:schemas:extension:dpp:2.0:Device",
    "name": "dppExtension",
    "description": "Device extension schema for DPP",
    "attributes" : [
      {
        "name": "dppVersion",
        "type": "integer",
        "description": "Version of DPP this device supports.",
        "multivalues": false,
        "required": true,
        "caseExact": false,
        "mutability": "readWrite",
        "returned": "default",
        "uniqueness": "none"
      },
      {
        "name": "bootstrappingMethod",
        "type": "string",
        "description": "The list of all the bootstrapping methods
            available on the enrollee device. For example, [QR,
            NFC].",
        "multivalues": true,
        "required": false,
        "caseExact": false,
        "mutability": "readWrite",
        "returned": "default",
        "uniqueness": "none"
      },
      {
        "name": "bootstrapKey",
        "type": "string",
        "description": "This key is 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.",
        "multivalues": false,
        "required": true,
        "caseExact": true,
        "mutability": "readWrite",
        "returned": "default",
        "uniqueness": "none"
      },
      {
        "name": "deviceMacAddress",
        "type": "string",
        "description": "The MAC address assigned by the
            manufacturer. It is unique 48 bit value. The regex
            pattern is ^[0-9A-Fa-f]{2}(:[0-9A-Fa-f]{2}){5}.",
        "multivalues": false,
        "required": false,
        "caseExact": false,
        "mutability": "readWrite",
        "returned": "default",
        "uniqueness": "Manufacturer"
      },
      {
        "name": "classChannel",
        "type": "string",
        "description": "A list of global operating class and
            channel shared as bootstrapping information. It is
            formatted as class/channel. For example, '81/1',
            '115/36'.",
        "multivalues": true,
        "required": false,
        "caseExact": false,
        "mutability": "readWrite",
        "returned": "default",
        "uniqueness": "none"
      },
      {
        "name": "serialNumber",
        "type": "string",
        "description": "An alphanumeric serial number that may also
            be passed as bootstrapping information.",
        "multivalues": false,
        "required": false,
        "caseExact": false,
        "mutability": "readWrite",
        "returned": "default",
        "uniqueness": "none"
      }

    ],
    "meta" : {
      "resourceType" : "Schema",
      "location" : "/v2/Schemas/urn:ietf:params:scim:schemas
         :extension:dpp:2.0:Device"
    }
  }
<CODE ENDS>
]]></artwork></figure>

</section>
<section anchor="ethernet-mab-extension-schema-json"><name>Ethernet MAB Extension Schema JSON</name>
<figure><artwork><![CDATA[
<CODE BEGINS>
{
  "id": "urn:ietf:params:scim:schemas:extension:ethernet-mab:2.0
     :Device",
  "name": "ethernetMabExtension",
  "description": "Device extension schema for MAC authentication
      Bypass.",
  "attributes" : [
      {
        "name": "deviceMacAddress",
        "type": "string",
        "description": "A MAC address assigned by the manufacturer.
            It is unique 48 bit value. The regex pattern is ^[0-9A
           -Fa-f]{2}(:[0-9A-Fa-f]{2}){5}.",
        "multivalues": false,
        "required": true,
        "caseExact": false,
        "mutability": "readWrite",
        "returned": "default",
        "uniqueness": "Manufacturer"
      }
  ],
  "meta" : {
    "resourceType" : "Schema",
    "location" : "/v2/Schemas/urn:ietf:params:scim:schemas
       :extension:ethernet-mab:2.0:Device"
  }
}
<CODE ENDS>
]]></artwork></figure>

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

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

</section>
<section anchor="endpointappsext-extension-schema-json"><name>EndpointAppsExt JSON Extension Schema</name>
<figure><artwork><![CDATA[
<CODE BEGINS>
{
  "id": "urn:ietf:params:scim:schemas:extension:endpointAppsExt:2.0
     :Device",
  "name": "endpointAppsExt",
  "description": "Extension for partner endpoint applications that
      can onboard, control, and communicate with the device.",
  "attributes" : [
    {
      "name": "applications",
      "type": "complex",
      "description": "Includes references to two types of
          application that connect with entrprise, i.e.,
          deviceControl and telemetry.",
      "multivalues": true,
      "required": true,
      "caseExact": false,
      "mutability": "readWrite",
      "returned": "default",
      "uniqueness": "none",
      "subAttributes" : [
        {
          "name" : "value",
          "type" : "string",
          "description" : "The identifier of the endpointApp.",
          "multiValued" : false,
          "required" : true,
          "caseExact" : false,
          "mutability" : "readOnly",
          "returned" : "default",
          "uniqueness" : "none"
        },
        {
          "name" : "$ref",
          "type" : "reference",
          "referenceTypes" : "EndpointApps",
          "description" : "The URI of the corresponding
              'EndpointApp' resource which will control or obtain
              data from the device.",
          "multiValued" : false,
          "required" : false,
          "caseExact" : true,
          "mutability" : "readOnly",
          "returned" : "default",
          "uniqueness" : "none"
        }
      ]
    },
    {
      "name": "deviceControlEnterpriseEndpoint",
      "type": "reference",
      "description": "The URL of the enterprise endpoint which
          device control apps use to reach enterprise network
          gateway.",
      "multivalues": false,
      "required": true,
      "caseExact": true,
      "mutability": "readOnly",
      "returned": "default",
      "uniqueness": "Enterprise"
    },
    {
      "name": "telemetryEnterpriseEndpoint",
      "type": "reference",
      "description": "The URL of the enterprise endpoint which
          telemetry apps use to reach enterprise network gateway.",
      "multivalues": false,
      "required": true,
      "caseExact": true,
      "mutability": "readOnly",
      "returned": "default",
      "uniqueness": "Enterprise"
    }
  ],
  "meta" : {
    "resourceType" : "Schema",
    "location" : "/v2/Schemas/urn:ietf:params:scim:schemas
       :extension:endpointAppsExt:2.0:Device"
  }
}
<CODE ENDS>
]]></artwork></figure>

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

<t>Because provisioning operations are senstive, each client must be
appropriately authenticated.  Certain objects may be read-only or
not visible based on who is connected.</t>

<t>Devices provisioned with this model may be completely controlled by
the administrator of the SCIM server, depending on how those systems
are defined.  For instance, if BLE passkeys are provided, the device
can be connected to, and perhaps paired with.  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="iana-considerations"><name>IANA Considerations</name>

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

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

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

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

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

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

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

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

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

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

</section>
</section>


  </middle>

  <back>


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

<reference anchor="BLE53" >
  <front>
    <title>Bluetooth Core Specification, Version 5.3</title>
    <author >
      <organization>Bluetooth SIG</organization>
    </author>
    <date year="2021"/>
  </front>
</reference>
<reference anchor="DPP2" >
  <front>
    <title>Wi-Fi Easy Connect Specification, Version 2.0</title>
    <author >
      <organization>Wi-Fi Alliance</organization>
    </author>
    <date year="2020"/>
  </front>
</reference>
<reference anchor="FDO11" >
  <front>
    <title>FIDO Device Onboading Specification 1.1</title>
    <author >
      <organization>FIDO Alliance</organization>
    </author>
    <date year="2022" month="April"/>
  </front>
</reference>


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

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


<reference anchor="I-D.bhutton-json-schema">
   <front>
      <title>JSON Schema: A Media Type for Describing JSON Documents</title>
      <author fullname="Austin Wright" initials="A." surname="Wright">
         </author>
      <author fullname="Henry Andrews" initials="H." surname="Andrews">
         </author>
      <author fullname="Ben Hutton" initials="B." surname="Hutton">
         <organization>Postman</organization>
      </author>
      <author fullname="Greg Dennis" initials="G." surname="Dennis">
         </author>
      <date day="10" month="June" year="2022"/>
      <abstract>
	 <t>   JSON Schema defines the media type &quot;application/schema+json&quot;, a JSON-
   based format for describing the structure of JSON data.  JSON Schema
   asserts what a JSON document must look like, ways to extract
   information from it, and how to interact with it.  The &quot;application/
   schema-instance+json&quot; media type provides additional feature-rich
   integration with &quot;application/schema+json&quot; beyond what can be offered
   for &quot;application/json&quot; documents.

	 </t>
      </abstract>
   </front>
   <seriesInfo name="Internet-Draft" value="draft-bhutton-json-schema-01"/>
   
</reference>

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

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

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

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




    </references>

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



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


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

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




    </references>


<?line 1985?>

<section anchor="changes-from-earlier-versions"><name>Changes from Earlier Versions</name>

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

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

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

<t>Draft -00:</t>

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

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

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

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

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

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

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

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

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

      required:
        - applicationType
        - applicationName

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

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

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

    certificateInfo:
      type: object
      description: "Contains x509 certificate's subject name and
                    root CA information associated with the device
                    control or telemetry app."
      properties:
        rootCN:
          type: string
          description: "A root certificate common name."
          nullable: false
          readOnly: true
          writeOnly: false

        subjectName:
          type: string
          description: "Also known as the Common Name (CN), the
                        Subject Name is a field in the X.509
                        certificate that identifies the primary
                        domain or IP address for which the
                        certificate is issued."
          nullable: false
          readOnly: true
          writeOnly: false

        subjectAlternativeName:
          type: array
          items:
            type: string
          description: "This attribute allows for the inclusion of
                        multiple domain names and IP addresses in a
                        single certificate. This enables the
                        certificate to be used for multiple related
                        domains or IPs without the need for
                        separate certificates for each. "
          nullable: true
          readOnly: true
          writeOnly: false
      required:
      - rootCN

    CommonAttributes:
      type: object
      properties:
        schemas:
          type: array
          items:
            type: string
            enum:
              - urn:ietf:params:scim:schemas:core:2.0:EndpointApp
          description: The list of schemas that define the resource.
          nullable: false
        id:
          type: string
          format: uri
          description: The unique identifier for a resource.
          nullable: false
          readOnly: true
          writeOnly: false
        meta:
          type: object
          readOnly: true
          properties:
            resourceType:
              type: string
              description: The name of the resource type of the
                           resource.
              nullable: false
              readOnly: true
              writeOnly: false
            location:
              type: string
              format: uri
              description: The URI of the resource being returned.
              nullable: false
              readOnly: true
              writeOnly: false
            created:
              type: string
              format: date-time
              description: The date and time the resource was added
                           to the service provider.
              nullable: false
              readOnly: true
              writeOnly: false
            lastModified:
              type: string
              format: date-time
              description: The most recent date and time that the
                           details of this resource were updated at
                           the service provider.
              nullable: false
              readOnly: true
              writeOnly: false
            version:
              type: string
              description: The version of the resource.
              nullable: true
              readOnly: true
              writeOnly: false
          additionalProperties: false
<CODE ENDS>
]]></artwork></figure>

</section>
<section anchor="ble-extension-schema-openapi-representation"><name>BLE Extension Schema OpenAPI Representation</name>
<t>OpenAPI representation of BLE extension schema is as follows:</t>

<figure><artwork><![CDATA[
<CODE BEGINS>
components:
  schemas:
    BleDevice:
      type: object
      description: BLE Device schema.
      properties:
        schemas:
          type: array
          items:
            type: string
            enum:
              - urn:ietf:params:scim:schemas:extension:ble:2.0
                 :Device
        urn:ietf:params:scim:schemas:extension:ble:2.0:Device:
          $ref: '#/components/schemas/BleDeviceExtension'
          required: true
    BleDeviceExtension:
      type: object
      properties:
        versionSupport:
          type: array
          items:
            type: string
          description: Provides a list of all the BLE versions
                       supported by the device. For example,
                       [4.1, 4.2, 5.0, 5.1, 5.2, 5.3].
          nullable: false
          readOnly: false
          writeOnly: false

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

        isRandom:
          type: boolean
          description: AddressType flag is taken from the BLE core
                       specifications 5.3. If FALSE, the device is
                       using public MAC address. If TRUE, device is
                       using Random address which is resolved using
                       the IRK.
          nullable: false
          readOnly: false
          writeOnly: false

        separateBroadcastAddress:
          type: string
          description: "When present, this address is used for
                        broadcasts/advertisements.  This value MUST
                            NOT
                        be set when an IRK is provided.  Its form is
                        the same as deviceMa`cAddress."
          nullable: false
          readOnly: false
          writeOnly: false

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

    NullPairing:
      type: object
      properties:
        id:
          type: string
          description: The id of the null pairing schema.
          nullable: false
          readOnly: true
          writeOnly: false

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

    PairingPassKey:
      type: object
      description: Pass key pairing method for ble
      properties:
        key:
          type: integer
          description: A six digit passkey for ble device.
                       The pattern of key is ^[0-9]{6}$.
          nullable: false
          readOnly: false
          writeOnly: false
      required:
        - key

    PairingOOB:
      type: object
      description: Out-of-band pairing method for BLE
      properties:
        key:
          type: string
          description: The OOB key value for ble device.
          nullable: false
          readOnly: false
          writeOnly: false
        randomNumber:
          type: integer
          description: Nonce added to the key
          nullable: false
          readOnly: false
          writeOnly: false
        confirmationNumber:
          type: integer
          description: Some solutions require a confirmation number
                       in the RESTful message exchange.
          nullable: true
          readOnly: false
          writeOnly: false
      required:
        - key
        - randomNumber
<CODE ENDS>
]]></artwork></figure>

</section>
<section anchor="dpp-extension-schema-openapi-representation"><name>DPP Extension Schema OpenAPI Representation</name>
<t>OpenAPI representation of DPP extension schema is as follows:</t>

<figure><artwork><![CDATA[
<CODE BEGINS>
components:
  schemas:
    DppDevice:
      type: object
      description: DPP device extension schema
      properties:
        schemas:
          type: array
          items:
            type: string
            enum:
              - urn:ietf:params:scim:schemas:extension:dpp:2.0
                 :Device
        urn:ietf:params:scim:schemas:extension:dpp:2.0:Device:
          $ref: '#/components/schemas/DppDeviceExtension'
          required: true
    DppDeviceExtension:
      type: object
      properties:
        dppVersion:
          type: integer
          description: Version of DPP this device supports.
          nullable: false
          readOnly: false
          writeOnly: false
        bootstrappingMethod:
          type: array
          items:
            type: string
          description: The list of all the bootstrapping methods
                       available on the enrollee device. For
                       example, [QR, NFC].
          nullable: true
          readOnly: false
          writeOnly: false
        bootstrapKey:
          type: string
          description: This key is Elliptic-Curve Diffie–Hellman
                       (ECDH) public key. The base64 encoded length
                       for P-256, P-384, and P-521 is 80, 96, and
                           120
                       characters.
          nullable: false
          readOnly: false
          writeOnly: false
        deviceMacAddress:
          type: string
          description: The MAC address assigned by the manufacturer.
                       The regex pattern is
                       ^[0-9A-Fa-f]{2}(:[0-9A-Fa-f]{2}){5}.
          nullable: false
          readOnly: false
          writeOnly: false
        classChannel:
          type: array
          items:
            type: string
          description: A list of global operating class and channel
                       shared as bootstrapping information. It is
                       formatted as class/channel. For example,
                       '81/1', '115/36'.
          nullable: false
          readOnly: false
          writeOnly: false
        serialNumber:
          type: string
          description: An alphanumeric serial number that may also
              be
                       passed as bootstrapping information.
          nullable: false
          readOnly: false
          writeOnly: false
      required:
        - dppVersion
        - bootstrapKey
      additionalProperties: false
<CODE ENDS>
]]></artwork></figure>

</section>
<section anchor="ethernet-mab-extension-schema-openapi-representation"><name>Ethernet MAB Extension Schema OpenAPI Representation</name>
<t>OpenAPI representation of Ethernet MAB extension schema is as follows:</t>

<figure><artwork><![CDATA[
<CODE BEGINS>
components:
  schemas:
    EthernetMABDevice:
      type: object
      description: Ethernet MAC Authenticated Bypass
      properties:
        schemas:
          type: array
          items:
            type: string
            enum:
              - urn:ietf:params:scim:schemas:extension:ethernet-mab
                 :2.0:Device
        urn:ietf:params:scim:schemas:extension:ethernet-mab:2.0
           :Device:
          $ref: '#/components/schemas/EthernetMABDeviceExtension'
          required: true
    EthernetMABDeviceExtension:
      type: object
      properties:
        deviceMacAddress:
          type: string
          description: It is the public MAC address assigned by the
                       manufacturer. It is unique 48 bit value. The
                       regex pattern is
                       ^[0-9A-Fa-f]{2}(:[0-9A-Fa-f]{2}){5}.
          nullable: false
          readOnly: false
          writeOnly: false
      required:
        - deviceMacAddress
      description: Device extension schema for Ethernet-MAB
<CODE ENDS>
]]></artwork></figure>

</section>
<section anchor="fdo-extension-schema-openapi-representation"><name>FDO Extension Schema OpenAPI Representation</name>
<t>OpenAPI representation of FDO extension schema is as follows:</t>

<figure><artwork><![CDATA[
<CODE BEGINS>
components:
  schemas:
    FDODevice:
      type: object
      description: Fido Device Onboarding Voucher Extension
      properties:
        schemas:
          type: array
          items:
            type: string
            enum:
              - urn:ietf:params:scim:schemas:extension:ethernet-mab
                 :2.0:Devices
        urn:ietf:params:scim:schemas:extension:ethernet-mab:2.0
           :Devices:
          $ref: '#/components/schemas/FDODeviceExtension'
          required: true
    FDODeviceExtension:
      type: object
      properties:
        fdoVoucher:
          type: string
          description: A Fido Device Onboarding Voucher
          nullable: false
          readOnly: false
          writeOnly: false
      required:
        - fdoVoucher
      description: Device Extension for a Fido Device Onboarding
          Voucher
<CODE ENDS>
]]></artwork></figure>

</section>
<section anchor="zigbee-extension-schema-openapi-representation"><name>Zigbee Extension Schema OpenAPI Representation</name>
<t>OpenAPI representation of zigbee extension schema is as follows:</t>

<figure><artwork><![CDATA[
<CODE BEGINS>
components:
  schemas:
    ZigbeeDevice:
      type: object
      description: Zigbee Device schema.
      properties:
        schemas:
          type: array
          items:
            type: string
            enum:
              - urn:ietf:params:scim:schemas:extension:zigbee:2.0
                 :Device
        urn:ietf:params:scim:schemas:extension:zigbee:2.0:Device:
          $ref: '#/components/schemas/ZigbeeDeviceExtension'
          required: true
    ZigbeeDeviceExtension:
      type: object
      properties:
        versionSupport:
          type: array
          items:
            type: string
          description: Provides a list of all the Zigbee versions
                       supported by the device. For example, [3.0].
          nullable: false
          readOnly: false
          writeOnly: false
        deviceEui64Address:
          type: string
          description: The EUI-64 (Extended Unique Identifier)
              device
                       address. The regex pattern is
                       ^[0-9A-Fa-f]{16}$.
          nullable: false
          readOnly: false
          writeOnly: false
      required:
        - versionSupport
        - deviceEui64Address
      description: Device extension schema for Zigbee.
<CODE ENDS>
]]></artwork></figure>

</section>
<section anchor="endpointappsext-extension-schema-openapi-representation"><name>EndpointAppsExt Extension Schema OpenAPI Representation</name>
<t>OpenAPI representation of endpoint Apps extension schema 
is as follows:</t>

<figure><artwork><![CDATA[
<CODE BEGINS>
components:
  schemas:
    EndpointAppsExt:
      type: object
      properties:
        applications:
          $ref: '#/components/schemas/applications'

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

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

      required:
        - applications
        - deviceControlEnterpriseEndpoint
        - telemetryEnterpriseEndpoint

    applications:
      type: array
      items:
        value:
          type: string
          description: The identifier of the endpointApp.
          nullable: false
          readOnly: true
          writeOnly: false
        ref:
          type: string
          format: uri
          description: The URI of the corresponding 'EndpointApp'
                      resource which will control or obtain data
                          from
                      the device.
          nullable: false
          readOnly: true
          writeOnly: false
      required:
        - value
        - ref


<CODE ENDS>
]]></artwork></figure>

</section>
</section>


  </back>

<!-- ##markdown-source:
H4sIAAAAAAAAA+196XrbSJLg/3yKbNZ8n+wpktbpQzM907SOsqaso2S53Fdt
L0iCEsogwAZAySrL8+077Bvuk2xE5I2LAHXYrjG+bheFI4/IuDMyotfrsSzI
Qn+b7/qXwcjnb0YX/tTjex8yP0qDOEp5FvPsAh7sHBzyaTz2Q+YNh4l/uS1u
VX3HxvEo8qbQ8jjxJlkv8LNJLx0F096YvuhRW73VTZbOh9MgxY/Ormfw/sHe
2T4beZl/HifX2zzNxowFs2SbZ8k8zdZXV1+srrP3/vVVnIzh7Sjzk8jPervY
DWNp5kXjf3hhHEFT137KZsE2/1sWj7o8jZMs8Scp/Lqe4o9fGPPm2UWcbDPe
4zyI0m1+2OdvLryL37wx43CJKRzOL7zp1Bs7j+LkfJsfQZsXfMdL4jCIPP4m
g3Hzt1Fw6SdpkF3Tiyn06mfb9LsHAJt5STb1o4zHE74TT2dzmAEAMPCjkS9f
ev5ilR9feiHfTaApeXPHg3dT/jL+wJ+vrz6luyPoZJufeqEfnF90+dGOuAuw
3ebrz56+2OqZV+N5lCFE374Z0A1YsCDc5tOUJvWnaJTO+/54DrCgxwSOV31+
8M+hF1rAeOWlqRdZt38vgLigiQU4rxcba386x7v9UTx1ALLX5699L7HgsRcG
cWZuEjR2gnQU8zfXaeZPU3vu/DQYXWQB/AWd+fyZNcqdV73nG0APZjbvvDAM
Uj8M/cgd+JurIPvNT0JAdXowuyB0/35zjW9u8ufPnvMXQCf23EIY3p9GOCqa
EYviZOplAFJcjZev97Y2xLJIbvAynPtZHOOKxglQ98wfBZMAiBKotMt/xjWN
I77V36CPNBHR1ZP/laAwTb05+IEejQE1YFFW19cY/L17crLu9P0u6O0HfM9L
r6HzKPJHWVX/6/3Vxf2L5gYASU+hlR7AKg5gf/d4bc0Zwf7B7rFibMfRMPbG
QXTuDoKv9deKfeuuqWdqpqTjwSwJQr72ootDWGes1+txb4goMQIGdgbMNoiC
LACkHyHwU8FaJ3EiOO4jgVZ0YyeJ05QfjIGIkMgOvcg795GkHvMrL+VjPw3O
I39M786S+DJAuOFk5inAsM/52UWQ8qk/jXkqpgccU3boWzLgwsu4H3nD0E/d
doByBT8HrjpP8c6llwTxPGXzaAwYeo23hrD8OL3ZDP9KBVUAF56PLjiM8h10
S+stl7tLkGOiXR7jAiS0ApcxfAHj7iLG8hlQEFIO/Al0wA8HO7QYCAqUHmM+
vMZX+gLA02A8Dn3GQF4k8Xg+wkVkf7QuAXklTnBiAJvoHOfrp9Boyj0+1fDl
owsP6fIcFwvvX7NxMJXwArgeRz42AcOZ8iAlCeoNgxAWCQWqnBONW7TJQy85
91k0nw6BBxqo0hL5gAUe/B+7ETI4pRV14UrikQ397Mr3I/U9dQHzAWH5Hu7N
wvgah4/tHsACAZSCDAfof4DlR6DhUsNUJhPoFKYJXc4ngJfzBODOr4IwhFvv
fcQfGqV50Qc6GCO0FyApt5H048c/nO7vPHu6ufHpk/lj89MnWP1JEOH4Ed9A
fMchTcWzySGPiQqpX8VXPsidLoO5jUBU+V4ahNd86AucHuM0Y/O1C2u3P6RA
RRBXuA6apLAFP5lCF78C3AUyG5KBtl7Ow/c8hneIYaQMVzCdz2YgKP2xIj34
33kcA676I0/ANLMXL6HhjAD6sFARG0KTAOF3F9eCFSAQ5Lv/iVhevNibeAqI
AzIxA1J7z6/Up9DxFUgWGFGQSQaR4YBm82QWw0AIb2KgRXjC/A8gcUMfxOre
2c7x0T7wN36690b8Bll0wf8yOPoB5jSYoAgHyugiyku09bAbmHXKYI38DyD8
cL0kHnuXIJ+QsUjoe1EKcBY0A0wHCSeOYPGCaCJEFpDt0McGkLhh5N4wnov3
JMOATyM/wO5B6KIWEmkowXJGk+B8LpaEWW12+RBayfcEDQFoUy8hqtXkJkgN
5iSoxep76l1zH3odgty+wN6QnwWXgPawbCcKsU5A7wlGwcwDQqxYNuBTNCeS
06GlfXeRYJG3I1uaTyXFCvbBJ/4Y0c0fM4vU+VU8DxHDRCujMBB3L2wSwOVO
QAxcAo1M8VMfBIEggIgEUwzk7xEju6ZF9SNaaXhjTHocPEG0sfoltsz0kDgQ
p8BqxfdTUNbgrZlH73cRqXB9kJ+MSFDID5ieAEIE7yKZaxAp0Avo4B3QQSXx
JMgHAEu6ktUSE0iBJK4QaFMkbpRXRI8Da/CaZVocX8gtfg6TuYKGHh0dvlF/
PGaz0LtOdeeS9cuxdmEYIx+wAOZkI5fAXEXrhEoEWc2KYxytRCLxd5ClamhE
LzAJ0YdgzSAJwmsG/yYx6BiI+2E8AvSZgVIOanUKAzmXsvTqwkcSeXIRX9lQ
TC8krJnuty8ko8AbBcNYyDePG4lF7B062WZoTQ34JXBaWFLEMyBJoScFv4l5
eOOxmXiMzUh4I2IjNsUTVJg8gSNAb8AWPJLZFuNMgymwjkRZqOLVAPDyXNI3
qt2w1hkIZpBwkUB1UgzAdrBF5ylgPgDrR8Dtg2gCqjkQOMk8bOLRy9M3Px6g
rPpPEE/PX7zY+vSpL+cogYJwV4ohkaM3noIOhx0Q4QAYNFWR6BQg6GLzguoI
+89B76hEEMRQEGWCE0uOPkR+iY0gx0GlJRGmAA5IDCQF+ZeSciXXk/90SvYG
EtB/48WY1pfLru9L+ZN7fV/bwk3dQ/UOy/f1Pfx96v9zDtwUW/jeeVDZwo2l
Lt44Y/wPaIT4X+WAVAtwIfjw9787TdzwN4LW6lvIzWInS0K+F41nWeNZVEKp
7mHdGOwWnAU1z77XdzQcdpD1g7jiN31zwW8axuD1D6JF80SykBsbkgMJyaXG
UDOLhnCofHrrFprRhSSxj9v8Oy8BqUcG5h87L0EhHfEB3AHlixhN5xPJs48f
8bVPn7pS8dGmD2IkSeuxn9r8ekaqxBzYIDGIlEnuKUSRn85A8/S7xoMnpYVg
H7JBZEUBMhwvdFUin2xCUN9QKaI2Rp7Q+6M46h2cGNPvSih7EbM4YQ9EInSl
5CUKjsjXYm2eip+jeDqdR2SxkSZpaVNSIxxJNARxMouBvSPrJx43jREwlgSK
h78CNFNGnE8KqsQH8EYkxaSPctdPR0kwIwlRXDPGgMlztEj4OAZYgw5MqhZ8
gtwWFK3ofI4GG4x9bG4LE6HP3/n8wrsE6YnakIDZf705PlJWi/4abJ2D3m5/
eDHPMgDVryn8I94BQ0gp40wq4wAIbEjaXH8+fG3UdVpUJUkDMVxjZMCcUQEC
DcAssRxKKg3+a2X4j2x0m/pg34IAAzOdKXUNbW7UorS5rtwz0M133ykP8Kkv
7WUhgtkgywBE88xHbwSadGOFS1olNz4ObN5yOwBugBqTIjQ91EH9BG2HkTBq
xcw96Od65jb+xidNIeXr/XV6db2/gQoFdmobnH2hSYj5A56TzNWLLhoElL0q
7d70LNZC0penp4tqE9qHURzG59c2ppE69R50DfRgp7xz+PbNWacr/suPjun3
6d5Pbw9O93bx95tXg9ev9Q8m33jz6vjt613zy3y5c3x4uHe0Kz6Gu9y5xTqH
g790hELcOT45Ozg+GrzuiEUBaIzB2iR1F1VRQaqoUiWwqqiDeilTWE+wfrlz
wtc2JVjX19ZeaDv++dozsOORM0SiMzKuxJ9oRSCr8EF7g0bQQBx5syDzQrQa
UtRCryKOPAWgyE79NJ4nIx+3B6RbzvHcGA/OAJcL2R69z3F9+Ir4YoXrpSZ1
H9egY7fc4crO154wWlbQHz1cbKmNebnmH6U+6vmEcfwp0iezceyx6El/0xGj
STsaudHFQTSgNHAxCDK+Ukm9miYU8fYlZzSko4WDx1H1RKOR6V4Thyglu/bS
YrvSQSJ4PbauYAKmEdwnP4tNvSspLpz0bIlB2ewOSUMumAs1VOBR2qm7mvfh
egMz2QGpAB0Z5iFskF0HRCgYvIDck4nvkyRBpdkwHC/Pc5ylga6CMeBMxIMx
WSgApn/OA3S1IOxBKIH2aZpTQrXItpiDAxv9NXzVRQLGELAJsN+DXerS/Eld
RzyeSfZsOmzSLGInY4fwr5gCYlXof7BawbkEqZlbk1alE498/84GXyndaedp
CRo7OotCTBcdyY5keQrp9PlBZpaYmIdwMVgLLGyt6Fp2ypSOYTEc0hQ0MCxA
aO3CcbEz1T2hKLkskV9I3zaZmeLdt6cH26wDqsU27mxug9rlTdNt3ODclrS0
jU1vr/dXt/WMsMNJHIbxFbTGbEwlwC0Qj1LOwqeo7znEIV7eDVL0Qxx5Ux8X
BBHCnjkiMBJfB+xSaKRDQLL4xsV86kU9YAxjtCZpd4szJGFPK2QHmSBd40UF
+TAW3Yq/4UGP/LDUunEnoJ+RmhXiEtZNKzfk9rMHiuJXLVNXITDeZKh/9lLk
Wbh3ReORet40HouVIt1ASERL/eNsiFgy8eZh1udHsSTvyE9RzYjQUg/Ixw/Q
DqY4rrHgdDYQYQHIsKfNTYHyHXOjUwHtYRyHvhd11ESAQc8JFAYBunkqhZlN
gEgzhOjZ6ds98vpNfS/SblEU1QLpiwuinc5eiEZBlvnTWZYKbVvo0rioI3Rt
6rVlQoWnhi+9cE5zkCPYH7x+s0eAnuCWKOf76NBQPmEU6UKdDyL0Gv06jwRz
Icfw0cHJDrpOSNsFtBu9RySLgtkIrRzk2TB17RNUXqcuIpX+nc6HUtGmyatJ
oE0EuDBWMQpMPgjBGlBKmdkGuVad4X+RmCdJPJWCzrSHLMCiPvKqERr9Knxw
w2v7E+gJefB8/DYJBT6I3xYmaF4nWODb09fKX3X4dpdPAqAIL01jVD/9MSOQ
WYsrVVQXsbSkQJemQCVBRHIgevnIWtPUolz6EvXBVsGFk6Pr5lCdSbKidRU7
iUbpkwre1vqqVqKdEVK/zO1YE6JFhyBnbgwbQ6v8EG4H/GeawA36f+DfHWxt
7wMo4PhcMBF8hu3Bj7dCTt+wm6Ixd+P898a9af0yP2BABV5K3oJ94TXYV//S
zdN30pmw60/EjyOUN3c4GMNeLM+F7P7sgccicdv1ojhwOVs4FvSEwBJKpUK6
Q3Zy9pXe/tR2obGq+CPEij+Sb5DkAzuDv86SOXCiffi1DzYE/IQR4Dve+F0S
KP6Kg/kj/ovI9xg9LpZDlZzZsldSfoQzgRh2KoU2urb/W13s33eOd/f4y70f
Do7e/Af7qL1FHSn/O9v8b+0UhF+6ppFgDN93/Bf+xup46PUmq88nvc211Re9
55vPn/bGW6On3sbG2tO1tbWO9VUBd7ERNNxf+egXOoyjIIsT+wtLflGElW89
Q+US7n60HGGdxDaZtrW2pr7qjEB/AE6GjzC6obe61lvfOFvd3N56ur2+/ler
a3g59NLsUApu88VWb42+2Fzf3tjMfXEpQj/w5Xd/f/L3DgBhdTja2pysPn22
Nnrx906ug1j4ovD9iyybpdtPnsgVxziYJ5frT8QEnjiQdj1/VXDXb31inyQ2
gI0NuGBwhGSCZQy525SS9wqmSnaTcL5ZTgywWGS8nGiFPEUoOa8uUHSQlxAs
s8HJQV6rDlKl21HzTDbI8w3i52B799zPyTySVPpDEs9nKcsp/PLhOT0kvUku
vaUrEyGpN2xjzDHE1Fz5Zn/dtvc5Gfx70u03mM2qrA9hf5C+IhoywQMFf0CX
r1gtrgjByXKegGUcAazoCah1BFij6FhaAituKUmdDyMZtKoSjZ8AOol9RZ+c
UVqfYXrDqMwct7rlzW1yR0XXjjlcZtVeig0iFoTAxJWaoFy2MBmrNdKbnemT
1h2NwvnY2D/a3etAwngs2KOOb9pI9z5kncdWlym6lz5kjmOB0NEGgPRZfvyu
ZKCVpm6OpN2Z3KHVaLfbxnREOrDsxQpXig2GO/OnVJmn1hIigTU2TnPKM72A
HjarPbIBSU0nc1/OgWdXsTBj0n/jK4Ig5HbWCmewaiuZH/pA0ck1sID8Cypg
K7+rK4wNZbMwy56yNy2spitbkoSbModyLaW/wmlRbw1T6GDqGB/e+BjB4tji
d28Um+kp3wNaxu7dKvO4Yr09Ru4I7rojlAx1EKCITLYjjzkmknmtBBwGGjQa
EcFEwObMBY2AjPKF2rAQ7Pssfu9HBTSnCYv5GmLzwB5870cm3EkKAMJp3PJB
PLMDGzEIxA8nYIbvebilSF9Lc81Tzc9naGZura5ys3tB/B1jFrML5cmRsOla
CJYzGlmF8caDCfokKJwr1ZyGfI+a8gEafpKJmFn/IJrEjIluhQmd91QSBHYU
XD5srb7g1vcr6CQgnZwRKtC4YiCDnYEbNKGtaS6tacuXpr0fTBMp4hKBYzJP
KGjswlMcsOBpFPF/0hBmQx+4MUwdR7FzZM+NxmWNXfFSHHgdvnYZojtxsi5P
FScln4WzKtCphIWgt0GYxvx9hJsmIkZLcX0yXx/tHD2WW8DiI3GbXFEgpkLN
zf/cz8FcTFsLNNE0SP4pRsSN4ylyWgDmwQnuLyZIG+g/AdV0JOBuN0UxO+lc
7L3kAeB4/FoDYRCSMx1vlvo+PTLeNPMgTSOVnucpehzQAJTTwSUi3yUzs6Kw
IqQtGEzozErORYVG5+ecxUz5ULBz3Vfih4Sgos9UwDAlfFXBjLRVjh+xFOPr
CIlMy2IyPtB/K2jSAEgsjssBarlj2jtj7sEXk1Mcqp0fyh9xf44YV5p9RjeM
JWFKHUJnDwaTHHf/jG4ywYK1xf4ZYWLx5dxI9j/PSIA5aifmWbuRSGedbSpU
e+xKDIol3HbSa3dM7CrvxDvEwwhw61AeSoCGElbu2TuKlfSyzVaLcoj9ufhL
8l0zaxSIltolxUVB+XxJJ5swMAMDMIQ+BHz/nKJrlWC1HIp9vidi0+3BYORz
biyiyaGvnERMmsV2U0UHpm8bt1VeTFT1FXRApI38vJpm+aa0Na52exwY2kKH
Hb19/brP6z2kS/hGbTOYHKRNXaPra+vkDOzkhAh+7Bh8hbeU41S6uFQcJAJV
eFs7OYBZTtKOYEX0eXAe7MCL/IcwHnohPxXaqvGVWrwC37+Cq295Jwsv5vQc
AuKH699Kv6HvvOHIefgLPPwkJmCWEZqJ5mFItx2Pb8HXay+F6Kehu7eNo7ex
i7eJc9cacbmHtwpxWFuvrk15jV27RbfTXfh3S1qtcfIy+xi3de7743cmEq/K
GSY/1jEE8uxfMa6IzI8gsZhxl6DC8pFJIgJQcjTJMPNhGkFqznGRieexEjdv
cdOy6NhEUScjnKyZowfTiRYTTNCTMYGBPIZwEKUZyCYcMzsYHA3wcAWG/F/T
FqigCx0ZC7a8cEcJn6HSzoXrU2yzswnKQNywD0M7CjKILuOQDo/I2DFOgYLk
uMAOfXR0XAYex0F0WX7ef/vl0Xeux9+0/VgGwajoL7Jo4fOpcP4AY7+Irxj5
e+h4Ddm3MafjJ2Ty49aShpxywlvHR8dOsLJ8Ai3oZbc36ZkMXMWpQsNi4Q0q
VblWtVdUB6uRl5XVihfd7DZYMNYeXMHVTQfY7A3A7+pjcA690UBYjRiOKL0x
Ykdeev7UzD0+mw9B5IiTq9J+9lJ5vFAGGjD7AKby2ngqOI1vPu8Ng0y0D08T
11co9uHBwFQWnnQf2q4fa3Ne+neFN1BsVpz7HzibAThA7ijnhoa33g1l/+tv
q70Xg94+8NZfPq5/erTt/v3449Yn9SoL0lPoEs+gD7gMjeGT0IO19FCn0L5Q
RC1B9e7h763+BkXHUFBK19rwwPEJrCiDLH0jQmksjJxT/CUTI9KLgIwivNRI
dnD640IrWwKVaYdaVcwD8I1Mg9lE2tBs0KMhjf2XSeyNYf0yjUxl0RpyvDRx
qbYO1YfpE298iWpK6osTv4I6RY8q1JiOwwH3oRgeTOpw+qMtWORoUXTJ1Wcp
+d5UfIrBdnq1CBbL49DV3sYqnyJGZCbv83TTNUeHxcLgk/f+NcnI0QXNXpAD
+URgztecuQFr6rCBXFjho3PWXL2pPccEESafnsn9McSfnOvUph9nJtNYRMXa
eG75OmPpNOLqPXQmI87rkZsAMLKSmCIKOzQJDJQY/Z4jOqShjnjJAKNRGKd4
fGpw0qeILXOM12omSK0ThiRNBye9NRFbFF8CdaBDCmwLANe5T4dkGehWwiMm
7sFD+GRdHEyV8VImeqvQqrwPtKLurxvglzvilQdfMN9Dy4ll81+pN74RQgTB
7ri7XDezCXsMQ81uZAupOUEh2bDmMJHkgEAPaG/BiiaJd913A+LY3/+22V/r
4nY2sqtV/GcN/6E/N/7+Sx7ZDGXQdFmRHTNgwgGSxKE4Zk+WH/WN45DP1Bn8
Uhc4zI/Z20v5b3ADQY4HPQc9W1NTwXlAdE/w1DWeW+jm4xlUg3henQjqTKM4
8Q1AUZUBoWTICrJzFHRdc8xYi0tx9sB38hKB7RonsFCoqCjVs8xnb52Jwjjj
GZ3JLhnxiTMoWwfDViIfN7ZRnOKZKYUz+qXiorre1fJFzvO/76RSpYYi1tvO
q0QKyhjstCDEsOji4oudK1S2DRrkFJogYipQQZyNAe2YksCQTmxygqg4CgsS
uOoTUKNZvl8NbQEnLuA0LgJKn5Wi7SuzpPb+c9nuMyqy4q6FnCKsAtUc046n
8g4Yjwdjj4LHClRHc1vBbqBXLqNWWn056qU9Bn3WCI+MUYiq2UlEbJL7FgrS
CHpDxhLi49iWuKj6OOtCMzdT/695mr0D7T29f70636MDBbxLZkSaG6+BiZkR
HpXCbBvwojkMDRyXiS3EjHZlhVqHrzpKmo4qkfvmUqSuoMdjpU8nvln5VhwP
piXKXC58FWBrgHsCBIcNPhRoZX8F6wVZNEEiB1o5NbQfnvbGwTnI6zLQCj3R
TAL3Q9EhrLfi6Ii9bxnzXd6BhjqWQsYKoq1aIVan4YyZwYoRl8LE+OXj00//
oo6tPwouNeiPj18+GNihrwLIQUnqxZPekE5UuFCXGKj2lM2GphGwLOj7/a7Q
aYVaekRnWrtKYZoEcndb3EcvK0JMgw4R29GYnZNMMthkLGwrNdQYhZBwiJiU
HEf7O0qO1Uqv0ggSxuzBkz1gB3QAVc+jEZ02Ftq4JFht1eKAFG5ZFrMTz+Hw
x5wWXiFSi/CjTAqqJ4GzmCcC/gnnIsxMMR9QSzDPzWQesikmgjlHhwQejT3X
I7DtnWrbQAyKVQRPfGnbrnnjrvlup9iiucOhKHdB5dZe5VDELtZdbqj5M9ss
t3fUHnooYCZz+2q+9XrnC+SaXfxzQkWb0q2hcudDcc21EqhUHpXQQ5G7r6g7
V++6lmnWzr4ry2NtQMerYaVQnaxyNy17zMLZiJWGTn7XFj2Zj/s1xy/kniWZ
ru78qg5j3M1Oo3uUof6jKv8xblG22KNUxzfaHNwoP7Kx5HC53uxz6ZjAttXf
UGdSOnmRQLt4O9tbm9sv1rafP9/eebG9t6525hTThpdoU0PersI26mww2H75
Elt69mx7fX0bAcPtm2rHjh6u63EpmndOr3Rc8luMAxo+updKHVv3vLSyrvvI
rwEXevQ2X1vf2NwSyWo/6S3b+r3Z5c7hfLaN2bJTN0QgemO29LxN1Z6sTgbn
DSmFnXLFZQVPF/KQjrsmxnCBjzABqjliazlK8Ru1wUCh5h4ZWkKBRed5TGEd
iqHRVlqX1Q8ATIluh7q9FjZKSb+0RYGeq2obo/+NE37jhPfNCV2zd0kumGtE
pWzmeQbYAcsWKJOsQLByksAH+3UfzFdowPA4NDeFRQefrG88f/bi6fO1ja21
p89ffGOebZinSphrdDA8bEZeScyRiYwpIh9Qju9wpfXb0c0FzzBqbRigrsNV
5N42fdAr7M+4GNtXnN1lrNqtbI2XvFikNQ4xKE9yZ1JC0T8k22UmU/E3pvmN
aT64+midr16Kd9pnkz+TSvqN9f9+WH9pMGPB6m4QzsgZbtABfzDxZXZM4+Nb
hDRWNlwe1vhYxKZZFQXsGDWMLpFxaFTVoC5MTe5fvwv2nQIF7BHp+ldB6ptT
VzKC8sTOSa8zfmMetJOTx7mQNnY/W4/j2awuok0dEs5tmI7jWab2CD5+xKoc
IrmLz/OnjR0XTE083GwmC3WIJGvS3+5GwQnASwpBLxB07KyFkCfoyKo5Nic2
K5xAtyab7TqhO/CbQrSeHiKdcg9DzBg66u3ME1CKdoMJrNj/+z//95UfhnhK
9dHezu6rxyrsjJFRiKAbwriebgIeYcrlsTx8KTbRT3rrW0+78J+N55tilCe9
rfU1gjB7vtrlL56K22vrq9yc4aw9PsjdE8HdxeFoZWGLlErIctbJoESxVHaw
Ygo6hUgPJCBn4hPlcdlcfGJ1LqOyFWwQS2eCFK0YxarNw/r4xL7aVkz9JPBC
IVtEmE04A/V3PoX7Iy6eypyz3QIEuhRHQ9ru0FcVCnA70y3VYZ1XbQAVVo3Y
FVmV6sKknJEIDcc+uqqDisSEyMmsYqTcSeiAE1XBgbNYpW6g3FjmPLsTHvX3
v/102sWdRgyEKk6e1eFEg8mPQDSnO7BikR+WJRrwotI5noszGjJ1Gh7QxnYE
9xiJ1ngKVChWu2Y5BSjFDRG1xMWYnshmCuBYeb72ZG2lu7K2tvVk4+lKCVjY
AlJpABbE7e/LYvi/1/9+b99wfpkfbsIudd0Qst2c+v+UW5ULMnXxkuuGdjzx
0Y3a6dSPij/uaC5GRtmd0WbRWbMNo9I84N/rf7+3bzi/zA8Yhy2JysaxeLfo
bsaRFwbWOPabbSvezThsJpyDR/047mtdDLNUO3gPOg6bqRl4PPQ4VCp7TOCG
alrlriQ+rd+VzG8v8iW2FymM/Fa7i+44A3kApn5jUdqJt/UP2VdTS1oq9qV1
CVwHkmx3ySRyrhuJrJ+l8sctZa/YvgcLRIZTo8FfBGKnhFRpcX46tfPqFV/H
DaDtUpB2DnffX+1d/eXVj/FfD377dXVn8NNfDuTv3cFPo92D88Hu29PfPkyz
su+zv8YHpwcn736Ifzr8eXX1z6/eQQMHF39O5j+/O/5t9ejX8P3B4I8l+NDE
Wba/XvahzSZo8qhZoCNMqBalgLBZLXa0+ezZ5utX68PN1c1NK8WdjVbf8gLS
tXRewFKfS4EXNfa5AGncjc+FWS1XNlzvc0G/CJZPPBy8LBwMNLNT+VI8sIjP
vdG1TG0MbPoRHt95zK987z13T993mXa1oA06cEo9vqRSj/wRdEupbkTYoDnG
IWs0AtcHYcN8NUod8IenlyYF+xaaoD5pt8EtNuZdY2YXUQAQO3gEPy+8GR4e
nWJBvccyv7I8YFkRm8rkTojx97Ry9Kh59Kbe0PH4KJ8MLL2VjKkkrtcriUfd
LvcJUP4eGq1eZAUnkXVaF5OjLGEyvtMUKzvIGJ7wE00IEGBpMjpLQyb7PKJ1
or0b5YSk5A42Yfy+oiXzsV5INdVaFT6t0aqW1KnIwm2cGtfWnhQeuOMKVPmO
BrrUg+2y5SlFs+jb7ru5qhIV25QHCzWVWCO+3d5bBbl3uJiN3uJovtcmpPq3
HZLaHZISWV2J+TUy29nNsJeyuexm9fslzTuoleH7wTh2ql+LklDV0tykyfVU
iWa7yNcQQ6XKG2WP9nePH3PgFn6ijuHxjx+pIjcmwZAVVjFHIlZcpWma8s20
6Y+lH7yxrzdPsPKXKl7VbyxJJzC8nsySIMtg3alAnYzjnwVkBD4pMGlPoXAU
evxk77CndgtU7p4IdYk4GWMZcXOgE4DEnKPx/NEoyFTZWh8aePwFykoDCEGM
y8tKmH+NrMSnX5KsdMfzIDIybSskS4jAyEm73a9BWFZQNLOlfmr5GjoGM3Fw
H/v9vqZS+P3pm7y8hbwsYH9TOQmLci/isbTdaqmIYvGvwfnQ920x2D6QQKRP
dYvWM9mwk7V9+bOMTSXeb9SrI+QOsuJZT7eOGD6ykyow6zzeorw5FYECytjc
mwdPN03mnIjvvT3oPd3kj/ZUqicpiw4UNJLHCs6V+9G3iRmwttHY7Tac16xD
q5U7syX5K8o3KtVmrESbYs4K5VSo2Hzd6K+Wb7zW5g1qsMP4pakaRbyyU18+
6Gmw/Bk59xxYG61Hrnq14iNfqNt9eXDlpzCmL9JHUOCId6TnyNnfdSRucbi1
wbhA9rlgXJsycJxbqxvrW/tw7e09e/ps/Xnnm8KztMJThvF1/nxH6REr28Kl
30LxqWq7RvdB5efMqhiCeVBNQRatDxWLqeRKsDCGGn8WTCnBh10/XKcfEAU+
hZKD7l+ApoSkzgbilBjXxcWpRPHEG1FirakXUYFu6LUvsuCKbKepTnvGVO1r
CoS0K3mL7Kr84KSHoXtjkxSD5YrNuJVNKWVkocqHlY+L+aKIMoaMykFLTS/X
rNLAynNX0ZY31jYpSSPRUHNktwsuzY231EtSCAVlTr7dPQ0KhVK6mpRVipGy
tokFwqKJMveyBUZdIIgSu3kjUTq+DM7v1O6N9VBVYMknVaYAWGrJKocOw6H0
ZqBopjzLFfWI6QlVa0b9H/4YeqP3mK2KSkTNgEp8le7CbbO+FEQulnOxCkbr
b9UpCVLAOuAxI3PkxgAAMFqXwChbkDO7Psa3tbjvtagzDOwCWGYnztR6LmUV
/UL6FeJRaHCWV9YSOWgcQhW5xBQiyIRd0BqmuI2Y5numkjlyJifSHFPfIIA7
NDxR5KfzL4k/6WAOG7ppB59qfpUYHCuO1XGZvn17sItzxRBJlZuyLH8YdAt6
nGrWlGHz7SpbTKVwUxnoq63FGkMI5+dUg/EnfuJHI415Vg46O220HpTEfibt
WTvze+onlyYRbOVA9TBrUm1+gfYa4t0e/k8ues5gq6xYAN/wOzXYAOntccju
Ps9YHCrVXvN21uOdGbKEIM5VZVTn4XLnY0Ey47ccS7HCBSlhjapc0JsFO5vZ
CtluEaVtlmzUugX6kWLEFQ3VSfJiJpdya5/Vl95ArP4jN82XVdRtGnWZV3nb
RmB+rrO5bWMOippyWdjBt9O+n+W0r91V8bjvsmd0VbrPskO6Sx/81Sk0nVbv
4khxyQngOxnxnR9VzqVR1SGWpnTJ8lAtO/9cOP6M3dzi8PP/hKPWbSKZqlij
DX8xc1v7sSjTisSXpkWbkkDySzJE+C2qx+BVU0HGWsFlR7yxsfEgI8Z+1Ijp
vy4rr9RMLOQSY4IhGbsWRyUa+If07PwD1vMfavmfKBFQo78s7kB/nGtbYuU3
//US/utqFc0LY7Dny3PzsSYh6059ohT9w6WOblMDiTXPGNCij9qKSAIYNIFT
53l1BXpRDum777iuXq/94fm6Q9Ul0pC7SSRtreNqueKUsldkLFRMB9M7kVPm
TN31NeHxzhM3kqgj3OQzhaDSaTsYjeI5fNC1R47Pl9DN82dLmhCEPeH0SZ6a
89TugMeWX/cL+pLaaQr+JY+cRSh5nluIvTIvmdpUGedc65GJ6jK+vWUXr2Rs
C1fQyKJFa1lsvfmCsl+qqrcBkUrM3cHkVja1f8yVyiJOxBbUNBQL3BrZy+iv
gsI8i8I6xsGAmoBQiDSwVZtFE1HDL5Nwk4XX9f1c169Kyq9L76loHOuCBOQV
tJQLFCBy/5v2mzD0adybp5S5wolEWdEGq/W5NF1XuJ+N+mZoxsOduqYbt0qp
5R+gI5S8l4Un5L1XhmAnUV4OG8WEw1RAkrwb5qHx6uPjKI4U1nXLl8KywAtr
IAsDVS7CQKcSVyWEZMWoaExkLoPBxIJYcKQ+A6rhhl7mFHqfp7qmkCmDhV5y
D3dKHqkaL6YNuXvZtYr54JIPxU7pY73FqTbs5J5LFlttiD7oldBPciVjUl0u
SIZ++6bgjjMM+bkevyz9hQe65ATov1QjQ5YPKzZAQ8zVrFH9J/6volRRXe+t
0dE+DfvFYON0Pn6bhEVM1JsUNbiIe39A0Ydvd/kkCHPsgD863d/hz7fWVx/f
JeU6QLwnUDFp7gjRxcsNBbS6hKgo6Opc2SgdFGHipfRJK4FQo6ALiWWXV3Yl
VlUR0TuUWnk5XKm6NFJMTIUisLRoxw9Wv4Vsy9fzbSvZchu9xAQoo68sQETb
mAJn/81iBSuOKbyCwSkrWoFaeUD2gB76+5JVuSLId6g02FWzfx+sNF8EugAs
uUFfCa0dVfDqw9bqC7sC+EqqqrcLENo6O6di93xnYKcdKi35llP848QWzHZ4
x1ekaelnAJ9BCbOwF8osFvJuWZe7az/MFGPPoXVhsTjJPwK8tUwqyAD76Lsf
ExxpO32MHztQcYHJ82kzHICWPbWAystYggtYXgLZPHS5g+94feouAKddu/wW
MMVMafpcPyLtjgAptssf7Rw97uYUMrzeSNqglygUZhL4oQ6U+HM/R06kquba
0KEmqTyVEUw9oIZxPEUJALz94ESfK0CtkTLE59og7dbqhgJzUljy2yBD8enX
gw35AvXLI0ZORstKeEp9p8AiO9+uvEDUqCzUaiVxiCKNm1lQkQRTHNUM88hl
LaiMCVPZKvLLbc645pqws2GDMAyJLYvxpAK1UuLSWFpVJEkobULtgNqdChhg
hF09jhXQ5ItHMfnrl3qRS4G8Z/F7P7qt2qerTeIBrfd+pKovONYfdSc0xLmI
HLSSkgAeZqkfTvpcRMaJZjA1iGlhiAUMZV7R+Qwb2Fq103kiIoqsoA9oNN2F
AvnF20yF8vS22dTEA9/AQFoQKqLRFp7qYVS4cF+Gduw2udGKvr8KC8nZXFR9
5kI0rE3ECnopjulEF0nWwaNl5ZId1pUvnVx+DC1XINlpwSmW/IvN5nKEkcs2
VmEu1OmnDTTUBQRSQyLle7+ug9YKkVlmgUyMabHgvczaKw4w2vDNcul9dZF0
lbKXOyl75YFHpwnr8GOT1LrVS5hfjS9jDe1cgk3WUkcwlaxh3sNbtowIZF3n
cBJ657SqHkoT5c+kwr/cuZAdcicDRIoUQ15S4eGVHCSQZYty38v+FLro2q3I
wcNLfWTk4PRHkR0rivM6tNwZFa5k6ZhOhXd2uTXPP/oSCbcyLm0ZAqbTEBYY
UUMxyccofcrEsdtBo1D9pk+88SVqhilY8lGWqsrdYiHUUSfUQFLfXbkr7NWL
cGntHXRK0iUSkii2IiPqna8V5/rfinUtxaK/hqUOkvfLsWWyLbNrSUpIRVTb
V5OYZLX5pcUaPNdaYEqunIpiuZIqVcIMT9VpdBqoXn9ac1dQV+CxrJL99RFw
W66tg0EruHbdAk9UIXERR600ImtbyYE1GA0xOupGoD5d28cCyaQMY7BIMz44
cZUkpwWrdazNLFpQzr7BSW+NTNxpjKeo0KyM3VyVCVYs5qA2ostKmL/iFqh0
8PU6naiSu2Euseu9v0Jn8n6qb69/fTjTlBPkIoSXYQqvpQadr45V4rl1+X1o
bbibBBf66OZdK8i5R/cKcfqvDs52DMmFpqRrTDY3Iw1wq803beLaYUGt7MGK
ePAK+xCji0/EFxXmITaULySJRiIMXEkKWWje1Rjs3XZycIxjqlhOtd28fD23
zhewFHUR33exJIVo+hq7Pf9JxeLgc45pTtOqJWptvWOAdgmXkUV0atiMNZZx
7KfWYkfXqIUow24/p3uIvaqM6JSkgVBFFVfyzLd8BdF15YGtumAqI2F+Z5yn
7DTCneO8PH7QHON1ZdxSfMenhA+fHdsHPA0+gJJyDgir6j3KUWg9+iwnUJXz
AmQxvq58GL98fPrpX746V8UXjdQl1Q/vDKVzR4zq0dmcZ/lcqLxQPRxYDDZR
Z3GE+0fo83zoRgGABSfizFWc79H+zp2j70MqgzXqtzB65SGkpRjFURyJRHHC
mka1CIu0fdXkXgMwsM0mgYwNuQ3YKEenzpKvs/DYzctaaA5mgnl5uvfmbDIP
gZ7SFLPx+B8wKe+5/5XbiF8ai80d9TPstT78/eSk5b7YMpw6V9clx5rh6aI9
MRn9XjhjPxHlNFvzZquGzFLU8HO+TGWgT1foOpW/V45SVl5nGTl3prLGLKor
6DAUU2OwUYlBrDDofA+ycbmdxC+G8TRZmh+X1D3IbSx14UWVTm2wulVP64ue
WjVPnZUp1D+FMdRUP/2dKjh3sht8litfY20AF7yKX8EG8Ne0l+AU3lpO/VdM
sboQqbMC7WuSOp879UnrypPK4qTOx6pS6e+Wozo10ZZazrqywbJKhSwU7EDW
FA2uXdCvjp5cHfqLUaJzGqqlPdccxCktcVZUopc8c7OoZlHpCVL16qE3dHXq
Nho1iQ6n5JqEmSiuJpCuhbJ9FyJtUCfQXCHm0FETgVYUYnYT/wMimtitQzjb
k1+DclasIqxTFCfaPb5XoqusgVIorKIRHYa0PNGV1EVqS2hW4ZLlSIzGoKry
gNzZ9SdBZPJOYqEhm7ackLPONzq4LR3U155K6+khX5WksTOnHVkUk807JCAe
L08F4vsaxC8cBKiIbm56FqAmsvk3t66GhfoNQ5s3+quWr6FGL/7iDziW1Alo
C2hKHL+4kosFZbemS628tuqrfG1HSj8zzynScxWXKTuATimh6PR5Tfb/+uxO
d8ibFiaTc1Vl9+1SVmVmhcwJes+wPmF52mzraCGWI5QMvKtO3Xa5yk4BqEBn
hnLHc9swPScXXoESF502PhDxQanJR02lD/CwOzaRujGDlcUMZArXTOWBpbzh
BfotzyD+tXBF/az1KWOR2s+GR9tzj3VZ0Af2WW0Dx7s5Z1z89os4WkopD8sB
WsxZIkckb1MSKXrTZl6LF+Dt6YGC/ChORN2AcfEAxYrV6orJ3i6ivCmY1hy9
5/EQTxvmWhh7mWeOeNgMYbkF/noPdi5KM1ngdovz1YiVrK1WkT/UnU+Vpitf
yKoWdiOysrn1tapxcXeqyH2d4zQArlcA6/JyPsyKZCVlSKoX42tegs+sEVbX
9VmgGr7xR/MED7sA8aYguhJZqKQyR+ZLf+ThOrqFMGfqQ6ocifUrRKUVWml5
DnuKsa1DHwuiJDHADhY7vHZOZOMZph0/oSw+IuV8So52yvHljXuU5idOGEbF
YueUWY0KPYGac3URO4cr+qosUWrGaqL04c1pPPZD1b4KoJV5hGh7ms5eUvIb
k48t1lLdKuiBZ/VmPgkZHMlFfCVrYaXXaeZPU4ZAGQu/DEwRDc4AIIQVoUED
m9DxEBn/KACoznR17fxwsl62OdCRxUI/BeBfeDMRvSxnCL0Moms0wwJcFi+E
kYqFZnIZTOZV0A4vgnPyHllaY+hdU9Y/1zyGwYrVdMraQJcpHqDn731/hsk4
Lul4vZXgBo/eR+O8sOwidK+xmOA8HOOOc3I9y4S+an8cA4h78GYvi2ewqgeD
o0EDdGXsyL+Shk3KrHIVImUutSKrBPmpACfCK1eeVUEwVXFnHVx3lWMWVA2R
0mEXVQGVyhLkKJi8iC/XbnXRG/jgCAtY4Lk8rMWiKstgQQwYGRf/iv/Qhb/h
2eKD9dxQ/I1IjCk9NnKkN+J02dSfAtJgKTlsooefKueVaO4xDKVhb5b+dFNW
Xe7G6tFJ6asy6X66gTWKZYIXWYgtAooGWn+P7ksAVqqQg1gAHpACmvD0XaJj
NM8AIzW9qylrO9BZfeeSyJRHA5FCGlM/qBweIosjrXRFH11GyVpFekXyvsKc
9VPKh6xMR4NdozicTyNEjX+VDjXdIKAW3HxzgRVHd40ghnsabQQiz2IAuIib
RrsuoPNhhKx0DBnHnV54IlPiMIYhgIEMHCODdi4D/6pDNYY6b5xa9KraSEcA
WzxTs/rD6f7O87X1p58+AXcQjQCnYKITmMTovSypjLxfugnFOdXxfGQc0zK3
tA0yJhp/9nRzAwEmMs1J1EihmUjVcclMzmtkl6PQx1p60ZjNQfcZBufzGPNl
yn0k3Kblp3s7x4eHIP72dkWbEp8RKlNv7FsxSjCOY5Gvui8gDLwfk9xJYCog
a6CWkri1ZHlKz5XHyf91s4jejdTn7sEn6MhNmVEgenjfeHQe8zZdVez33Lg7
qoUe7c+W7brexQ59lmzDFEdS0gqQoDWmNkNyt56hs3dAIHzPS693pKOlCAl4
KGX30mtQqeXd2IzX1PpcgAoyCrUnYvbMqNJWsKg5AwPd0okmus8Hc5l2/ua+
x+LG1d7wYxGD/5Li1ORRAWSYDzKY4jkKAMuJPO5y29GgaKMqiYztUIR2KpSs
PS8J0QX1s9oIWZD6fjfxJhnvrW5gYp9/5QNQhICeu3L7EAQRhpKfw3SnwGmD
KSqPIm8BPQX+N+aSadINEqsjV0fTfayLPvgOpUSez5R6Kdrih9A0lwn+SSmb
kW79QX+/ts3Em7vxxR/4OxIl53GmPD46dSItif8H0/Gq/PBAMvTEF2YBphtS
w8/VKBASwCq6KmoUuGo6rZ6lsULTs3kyw4Ph/aqE5ao7t0JBIYV5RaEDxsqH
i1iu3SCJb4nfYpn7Evc9WkFgJcGy4hIplCZ7U0xBpX2iEmvb8iZT7hct8tQT
lf5IfQVG8La07OQtNAUxC4afmkohhezn27ZLgdoQzljH92N1vmT2c/dqnAu9
qoWVQk0vmRjd+gDPYuIohKfCeqC8E9LpYT25Qud42SOTqbwIL5nHpgpgyyYq
d66GWcurPi8kMy9NYV71dZPM5vW9t0hzXtWI3Fi2c55XJz2vg4OdC70mA3pV
ExWJ0e2BleJgHtWWQEKRoLwBwQpmuQ3CNKjGysYpy3OQOMjnOtKXPheNkJzM
MZQE3ZJ9vjNPEvRSzem8U5CWJEyyRilCbK79rByQtyVm5do0cOxZ5C1vGufO
iWGiTjNgoBxP7DZwN2abr3z3xDD6J5LLPxGpW81+2Qp9l7+rBUAzVu6IEPtL
L0mcTIsB+sm2HYBXIA4HPjyfbufWptfAR2IVO7fX0sI4+3iLMhBF3gVacaf4
cBMSCsZ3QwmmHLW9vYgo7LUaj42KORytpGhUNxNAsoMmc3HpN8qP1ineLPx8
aW4hJW0tYLGO91l4JO+HEjkeaPKKM3cwvxawZWQhPjA7A3lsrkT9ErywlRsD
W2hA3qxUcKwx5PlnNf7UTrUWjnip7Y4W8y2njlJIWBu/GhBDHzFE7ew81Dxl
DbolpjmG73pZMM13V5jsmDyU6CGDl905X3lSyNUtvXRn4wYGylJpyiQPhglW
+b37BNM0TrHY8ghFex5khYTBhWsMtB+E0uUokysKEPuoN8zGoo59paJAs/mM
UJZhkLdhL5fm1GyV9HNnUDLGZSdQp+HU5A0uKbZSaW2XlF+pMrmrLW7LL7fI
4m5ucFuzyFnd1pMy07u0aotat3bqW65WS2s7fMlaLc61qHDLXVsyZZNfxgnR
sJjKPQ2/1IJwV7P8CU5VNVJOfxYNA+o2NzCs7O8rTT9xa7Ss6IHdzrChD63h
uEaNs6y1+FyZhF5tkvOSa2E6+sps9OZqk5ee5ZHLWr9SxlyOUrmlqLEDXZAt
WSXHXO3q5ZQ2YQXy5Srn1PA+UXGmNctbVGfmjq00Y2mbii7tx7xUHRdzNano
UvlxvtJLRW2Xyu/ra77Ujrui+ss9L1GuzMpd+kZquVVVFZZ8tln7alGPpbIN
UaelvjJLM+zQFVtKa7QswJDK2i2FRM7O4OuruPCWzvxmTpe88O5JZiRQ6ffm
kiuqs7Ro3/xydH3zS1nXN7/U7eb5zS+1CELf/FL29c0vdSd+qZpyVuWOqRpf
E7ZSOIV9e2/Ty9DPRXgsMOxwHLtWnI2nIP8l6xyFlPFFAsnvEC5VQcweVp1r
QkNd48WK9aVWAw16Fj9oqf25J+/vzfZYpvaYdTU6q1/1ca46Wb4iWUt1rLm/
MJ8yp60Z3rQcWJ1waJMYrqqN/HH9qveapI67N2CrglvtQ50EQFG7rSnWRdFz
ldhZXrVLhvhYASrVsBPFuYrrXFb+q76NZnXAqtrAwWKJsHtbp6o6Ra19VEvU
2rKvFnW36pQmrMlU3Yep1bSwPldlI1bdrrJaXfdHUMn71gxryUJZ1tW8ZlZV
C4pw2vlhmkd/yDJTrflM2yJT9pRa1JuqBKw6sbew9FQduteEKdrFqhYUqKrp
obdeKcZNSauaMlZ1g1cVrqreMYWv7pqo1AO37tS9KVvL1qayroVlqu6JvG5X
jwmvlhr3kanVVK5q32Z8zhGYWwzyJNfc3Y/UOpNy+3HKxu5+lLkqIcuPEBpa
PLqyLXPXXLIe5JV965GlYVp3XV4gH9Q5EugVC11bGnqNXNwFr0owVg6VyC5Z
5lr4eN3Zxlge15v6HxZW7aqBDWgpReDIAgJV0Fm2Mpd1NS/SVdWCrN11P/Kq
DP9hRM4yKb7RcJEW1Oe54yVqUE6qCrB0kLqustTnAzkywYbgPp5nvXjSG1JS
iCLETRHqxhBfzDFgeFbto2pw36liZVcUao0m5cWE7muoxVo+rQdcUcbHW1jI
x7pkKEZlXZ970e+q0Nv8ZS9kheu8quBNa885tnIPnvPd2ayd5xzHMS5Pp1pD
nl+eC12egS9i3JIudPdMfVMNT4O/qQu9+EFLzcrUIWpNyU1KEN0XIyopAXRv
FulyZYKsq1HFoKqPnUJConjQPZmvdu2e9sKzcdmeqom2qeBT1YYp7LOomE9V
C3itrZfwAXFZ5X/uC7Vvu/OyoPROTaUC6yrLdFz17ufYOtHrYRW7uTcG0KQg
jiqCUwWkJWvjWFfTMjmV5paonmMq5tzXmtgVa5Y4ZblUsRrcr6iaeJMqNg9n
ERmBa920Wa+83T4sY2FBmNZKptPcPWibqn1ovp3WaQ1shzLx6KSLskLMV6V7
2mmlShTQkpPetyrbI5ttp5kWlqqphlr9YVtN9VtEwgOJ1VK2Ve4iLkuTU1pW
Q6FBD/Cgmn+VltRpzbawlXvgVtBsOy5VkskN5Y4qb6Mn+vtkVuk9cKu0KbvS
a9WUTRU/aMmeTOmj1jrPAkR5OCI3c6ghb7cihVcxeGsAqslKqq8qHNSa8GW9
nHugfTHEduQvp/UVx5Wa0iwllL6cSlKo9tKUou0VaErUpd98dTGmf62sAuVc
bUpC3a/vwq7StIz3ol2RJtNvFWRq6zc1Ur/WHnbXbMFGvQ3ftnqYQKZ+jQmZ
q63UkCs3qba0fC4KTAibFifE7jQxBWWhbccc7LzxTRmZ/c1KPuC6supIqyN+
YR11tax6YcZWRSlLlihxLlUsoyWNNT6tXFM95LNC1vTcqLhI1dcEr88J4QUZ
OtICD6tEdOvNmkUT/ZaRX1Eq5yQyWejLhRPV1cK6Y7iaLyatELT2dG9VMSm3
fFQFBjUqKkVlpGqwFI8lVDy2VJZ7gWWpoHXik3oIbcbKZeP/B77ay1agYAEA

-->

</rfc>

