<?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.5 (Ruby 3.1.2) -->


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

<!ENTITY SELF "RFC nnnn">
]>

<?rfc tocindent="yes"?>
<?rfc strict="yes"?>
<?rfc compact="yes"?>
<?rfc comments="yes"?>
<?rfc inline="yes"?>
<?rfc docmapping="yes"?>

<rfc ipr="trust200902" docName="draft-ietf-gnap-core-protocol-18" category="std" consensus="true" tocInclude="true" sortRefs="true" symRefs="true">
  <front>
    <title>Grant Negotiation and Authorization Protocol</title>

    <author initials="J." surname="Richer" fullname="Justin Richer" role="editor">
      <organization>Bespoke Engineering</organization>
      <address>
        <email>ietf@justin.richer.org</email>
        <uri>https://bspk.io/</uri>
      </address>
    </author>
    <author initials="F." surname="Imbault" fullname="Fabien Imbault">
      <organization>acert.io</organization>
      <address>
        <email>fabien.imbault@acert.io</email>
        <uri>https://acert.io/</uri>
      </address>
    </author>

    <date year="2024" month="February" day="10"/>

    <area>Security</area>
    <workgroup>GNAP</workgroup>
    <keyword>Internet-Draft</keyword>

    <abstract>


<?line 149?>

<t>GNAP defines a mechanism for delegating authorization to a
piece of software, and conveying the results and artifacts of that delegation to the software. This
delegation can include access to a set of APIs as well as subject information
passed directly to the software.</t>



    </abstract>



  </front>

  <middle>


<?line 156?>

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

<t>This protocol allows a piece of software, the client instance, to request delegated
authorization to resource servers and subject information. The delegated access to
the resource server can be used by the client instance to access resources and APIs
on behalf a resource owner, and delegated access to
subject information can in turn be used by the client instance to make authentication decisions.
This delegation is facilitated by an authorization server usually on
behalf of a resource owner. The end user operating the software can interact
with the authorization server to authenticate, provide consent, and
authorize the request as a resource owner.</t>

<t>The process by which the delegation happens is known as a grant, and
GNAP allows for the negotiation of the grant process
over time by multiple parties acting in distinct roles.</t>

<t>This specification focuses on the portions of the delegation process facing the client instance.
In particular, this specification defines interoperable methods for a client instance to request, negotiate,
and receive access to information facilitated by the authorization server.
This specification additionally defines methods for the client instance to access
protected resources at a resource server.
This specification also discusses discovery mechanisms for the client instance to
configure itself dynamically.
The means for an authorization server and resource server to interoperate are
discussed in the companion document, <xref target="I-D.ietf-gnap-resource-servers"/>.</t>

<t>The focus of this protocol is to provide interoperability between the different
parties acting in each role, and is not to specify implementation details of each.
Where appropriate, GNAP may make recommendations about internal implementation
details, but these recommendations are to ensure the security of the overall
deployment rather than to be prescriptive in the implementation.</t>

<t>This protocol solves many of the same use cases as OAuth 2.0 <xref target="RFC6749"/>,
OpenID Connect <xref target="OIDC"/>, and the family of protocols that have grown up
around that ecosystem. However, GNAP is not an extension of OAuth 2.0
and is not intended to be directly compatible with OAuth 2.0. GNAP seeks to
provide functionality and solve use cases that OAuth 2.0 cannot easily
or cleanly address. <xref target="vs-oauth2"/> further details the protocol rationale compared to OAuth 2.0.
GNAP and OAuth 2.0 will likely exist in parallel
for many deployments, and considerations have been taken to facilitate
the mapping and transition from existing OAuth 2.0 systems to GNAP. Some examples
of these can be found in <xref target="example-oauth2"/>.</t>

<section anchor="terminology"><name>Terminology</name>

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

<?line -18?>

<t>This document contains non-normative examples of partial and complete HTTP messages, JSON structures, URIs, query components, keys, and other elements. Whenever possible, the document uses URI as a generic term, since it aligns with <xref target="RFC3986"/> recommendations and matches better with the intent that the identifier may be reachable through various/generic means (compared to URLs). Some examples use a single trailing backslash <spanx style="verb">\</spanx> to indicate line wrapping for long values, as per <xref target="RFC8792"/>. The <spanx style="verb">\</spanx> character and leading spaces on wrapped lines are not part of the value.</t>

<t>This document uses the term "mutual TLS" as defined by <xref target="RFC8705"/>. The shortened form "MTLS" is used to mean the same thing.</t>

<t>For brevity, the term "signature" on its own is used in this document to refer to both digital signatures (which use asymmetric cryptography) and keyed MACs (which use symmetric cryptography). Similarly, the verb "sign" refers to the generation of either a digital signature or keyed MAC over a given signature base. The qualified term "digital signature" refers specifically to the output of an asymmetric cryptographic signing operation.</t>

</section>
<section anchor="roles"><name>Roles</name>

<t>The parties in GNAP perform actions under different roles.
Roles are defined by the actions taken and the expectations leveraged
on the role by the overall protocol.</t>

<figure title="Figure 1: Roles in GNAP"><artset><artwork  type="svg"><svg xmlns="http://www.w3.org/2000/svg" version="1.1" height="432" width="472" viewBox="0 0 472 432" class="diagram" text-anchor="middle" font-family="monospace" font-size="13px" stroke-linecap="round">
<path d="M 8,32 L 8,112" fill="none" stroke="black"/>
<path d="M 8,240 L 8,288" fill="none" stroke="black"/>
<path d="M 58,112 L 58,224" fill="none" stroke="black"/><path d="M 54,112 L 54,224" fill="none" stroke="black"/>
<path d="M 104,240 L 104,288" fill="none" stroke="black"/>
<path d="M 120,32 L 120,112" fill="none" stroke="black"/>
<path d="M 128,144 L 128,192" fill="none" stroke="black"/>
<path d="M 152,96 L 152,144" fill="none" stroke="black"/>
<path d="M 170,192 L 170,240" fill="none" stroke="black"/><path d="M 166,192 L 166,240" fill="none" stroke="black"/>
<path d="M 184,96 L 184,144" fill="none" stroke="black"/>
<path d="M 216,144 L 216,192" fill="none" stroke="black"/>
<path d="M 216,240 L 216,288" fill="none" stroke="black"/>
<path d="M 224,32 L 224,112" fill="none" stroke="black"/>
<path d="M 320,240 L 320,288" fill="none" stroke="black"/>
<path d="M 328,32 L 328,112" fill="none" stroke="black"/>
<path d="M 8,32 L 120,32" fill="none" stroke="black"/>
<path d="M 224,32 L 328,32" fill="none" stroke="black"/>
<path d="M 128,96 L 152,96" fill="none" stroke="black"/>
<path d="M 184,96 L 216,96" fill="none" stroke="black"/>
<path d="M 8,112 L 120,112" fill="none" stroke="black"/>
<path d="M 224,112 L 328,112" fill="none" stroke="black"/>
<path d="M 128,144 L 216,144" fill="none" stroke="black"/>
<path d="M 128,192 L 216,192" fill="none" stroke="black"/>
<path d="M 24,224 L 88,224" fill="none" stroke="black"/>
<path d="M 232,224 L 304,224" fill="none" stroke="black"/>
<path d="M 168,238 L 216,238" fill="none" stroke="black"/><path d="M 168,242 L 216,242" fill="none" stroke="black"/>
<path d="M 24,304 L 88,304" fill="none" stroke="black"/>
<path d="M 232,304 L 304,304" fill="none" stroke="black"/>
<path d="M 8,366 L 40,366" fill="none" stroke="black"/><path d="M 8,370 L 40,370" fill="none" stroke="black"/>
<path d="M 8,384 L 40,384" fill="none" stroke="black"/>
<path d="M 24,224 C 15.16936,224 8,231.16936 8,240" fill="none" stroke="black"/>
<path d="M 88,224 C 96.83064,224 104,231.16936 104,240" fill="none" stroke="black"/>
<path d="M 232,224 C 223.16936,224 216,231.16936 216,240" fill="none" stroke="black"/>
<path d="M 304,224 C 312.83064,224 320,231.16936 320,240" fill="none" stroke="black"/>
<path d="M 24,304 C 15.16936,304 8,296.83064 8,288" fill="none" stroke="black"/>
<path d="M 88,304 C 96.83064,304 104,296.83064 104,288" fill="none" stroke="black"/>
<path d="M 232,304 C 223.16936,304 216,296.83064 216,288" fill="none" stroke="black"/>
<path d="M 304,304 C 312.83064,304 320,296.83064 320,288" fill="none" stroke="black"/>
<polygon class="arrowhead" points="224,96 212,90.4 212,101.6" fill="black" transform="rotate(0,216,96)"/>
<polygon class="arrowhead" points="136,96 124,90.4 124,101.6" fill="black" transform="rotate(180,128,96)"/>
<g class="text">
<text x="64" y="68">Authorization</text>
<text x="276" y="68">Resource</text>
<text x="60" y="84">Server</text>
<text x="276" y="84">Server</text>
<text x="172" y="164">Client</text>
<text x="172" y="180">Instance</text>
<text x="60" y="260">Resource</text>
<text x="264" y="260">End</text>
<text x="56" y="276">Owner</text>
<text x="120" y="276">~</text>
<text x="136" y="276">~</text>
<text x="152" y="276">~</text>
<text x="168" y="276">~</text>
<text x="184" y="276">~</text>
<text x="200" y="276">~</text>
<text x="268" y="276">User</text>
<text x="28" y="340">Legend</text>
<text x="88" y="372">indicates</text>
<text x="176" y="372">interaction</text>
<text x="256" y="372">between</text>
<text x="296" y="372">a</text>
<text x="328" y="372">human</text>
<text x="368" y="372">and</text>
<text x="420" y="372">computer</text>
<text x="88" y="388">indicates</text>
<text x="176" y="388">interaction</text>
<text x="256" y="388">between</text>
<text x="304" y="388">two</text>
<text x="348" y="388">pieces</text>
<text x="388" y="388">of</text>
<text x="436" y="388">software</text>
<text x="8" y="404">~</text>
<text x="24" y="404">~</text>
<text x="40" y="404">~</text>
<text x="88" y="404">indicates</text>
<text x="136" y="404">a</text>
<text x="184" y="404">potential</text>
<text x="272" y="404">equivalence</text>
<text x="332" y="404">or</text>
<text x="392" y="404">out-of-band</text>
<text x="136" y="420">communication</text>
<text x="224" y="420">between</text>
<text x="280" y="420">roles</text>
</g>
</svg>
</artwork><artwork  type="ascii-art"><![CDATA[
+-------------+            +------------+
|             |            |            |
|Authorization|            |  Resource  |
|   Server    |            |   Server   |
|             |<--+   +--->|            |
+-----+-------+   |   |    +------------+
      ║           |   |
      ║        +--+---+---+
      ║        |  Client  |
      ║        | Instance |
      ║        +----+-----+
      ║             ║
 .----+----.        ║      .----------.
|           |       +=====+            |
|  Resource |             |    End     |
|   Owner   | ~ ~ ~ ~ ~ ~ |    User    |
|           |             |            |
 `---------`               `----------`

Legend

===== indicates interaction between a human and computer
----- indicates interaction between two pieces of software
~ ~ ~ indicates a potential equivalence or out-of-band
          communication between roles
]]></artwork></artset></figure>

<dl>
  <dt>Authorization Server (AS):</dt>
  <dd>
    <t>server that grants delegated privileges to a particular instance of client software in the form of access tokens or other information (such as subject information). The AS is uniquely defined by the <em>grant endpoint URI</em>, which the absolute URI where grant requests are started by clients.</t>
  </dd>
  <dt>Client:</dt>
  <dd>
    <t>application that consumes resources from one or several RSs, possibly requiring access privileges from one or several ASs. The client is operated by the end user or it runs autonomously on behalf of a resource owner.
</t>

    <t>Example: a client can be a mobile application, a web application, a back-end data processor, etc.</t>

    <t>Note: this specification differentiates between a specific instance (the client instance, identified by its unique key) and the software running the instance (the client software). For some kinds of client software, there could be many instances of that software, each instance with a different key.</t>
  </dd>
  <dt>Resource Server (RS):</dt>
  <dd>
    <t>server that provides an API on protected resources, where operations on the API require a valid access token issued by a trusted AS.</t>
  </dd>
  <dt>Resource Owner (RO):</dt>
  <dd>
    <t>subject entity that may grant or deny operations on resources it has authority upon.
</t>

    <t>Note: the act of granting or denying an operation may be manual (i.e. through an interaction with a physical person) or automatic (i.e. through predefined organizational rules).</t>
  </dd>
  <dt>End user:</dt>
  <dd>
    <t>natural person that operates a client instance.
</t>

    <t>Note: that natural person may or may not be the same entity as the RO.</t>
  </dd>
</dl>

<t>The design of GNAP does not assume any one deployment architecture,
but instead attempts to define roles that can be fulfilled in a number
of different ways for different use cases. As long as a given role fulfills
all of its obligations and behaviors as defined by the protocol, GNAP does
not make additional requirements on its structure or setup.</t>

<t>Multiple roles can be fulfilled by the same party, and a given party
can switch roles in different instances of the protocol. For example,
the RO and end user in many instances are the same person, where a user is
authorizing the client instance to act on their own behalf at the RS. In this case,
one party fulfills both of the RO and end-user roles, but the roles themselves
are still defined separately from each other to allow for other
use cases where they are fulfilled by different parties.</t>

<t>For another example,
in some complex scenarios, an RS receiving requests from one client instance can act as
a client instance for a downstream secondary RS in order to fulfill the
original request. In this case, one piece of software is both an
RS and a client instance from different perspectives, and it fulfills these
roles separately as far as the overall protocol is concerned.</t>

<t>A single role need not be deployed as a monolithic service. For example,
a client instance could have front-end components that are installed on the end user's device as
well as a back-end system that the front-end communicates with. If both of these
components participate in the delegation protocol, they are both considered
part of the client instance. If there are several copies of the client software
that run separately but all share the same key material, such as a
deployed cluster, then this cluster is considered a single client instance.
In these cases, the distinct components of what is considered a GNAP client instance
may use any number of different communication mechanisms between them, all of which
would be considered an implementation detail of the client instances and out of scope of GNAP.</t>

<t>For another example, an AS could likewise be built out of many constituent
components in a distributed architecture. The component that the client instance
calls directly could be different from the component that the
RO interacts with to drive consent, since API calls and user interaction
have different security considerations in many environments. Furthermore,
the AS could need to collect identity claims about the RO from one system
that deals with user attributes while generating access tokens at
another system that deals with security rights. From the perspective of
GNAP, all of these are pieces of the AS and together fulfill the
role of the AS as defined by the protocol. These pieces may have their own internal
communications mechanisms which are considered out of scope of GNAP.</t>

</section>
<section anchor="elements"><name>Elements</name>

<t>In addition to the roles above, the protocol also involves several
elements that are acted upon by the roles throughout the process.</t>

<dl>
  <dt>Access Token:</dt>
  <dd>
    <t>a data artifact representing a set of rights and/or attributes.
</t>

    <t>Note: an access token can be first issued to a client instance (requiring authorization by the RO) and subsequently rotated.</t>
  </dd>
  <dt>Grant:</dt>
  <dd>
    <t>(verb): to permit an instance of client software to receive some attributes at a specific time and valid for a specific duration and/or to exercise some set of delegated rights to access a protected resource;</t>
  </dd>
  <dt/>
  <dd>
    <t>(noun): the act of granting permission to a client instance.</t>
  </dd>
  <dt>Privilege:</dt>
  <dd>
    <t>right or attribute associated with a subject.
</t>

    <t>Note: the RO defines and maintains the rights and attributes associated to the protected resource, and might temporarily delegate some set of those privileges to an end user. This process is refered to as privilege delegation.</t>
  </dd>
  <dt>Protected Resource:</dt>
  <dd>
    <t>protected API (Application Programming Interface) served by an RS and that can be accessed by a client, if and only if a valid and sufficient access token is provided.
</t>

    <t>Note: to avoid complex sentences, the specification document may simply refer to "resource" instead of "protected resource".</t>
  </dd>
  <dt>Right:</dt>
  <dd>
    <t>ability given to a subject to perform a given operation on a resource under the control of an RS.</t>
  </dd>
  <dt>Subject:</dt>
  <dd>
    <t>person or organization. The subject decides whether and under which conditions its attributes can be disclosed to other parties.</t>
  </dd>
  <dt>Subject Information:</dt>
  <dd>
    <t>set of statements and attributes asserted by an AS about a subject. These statements can be used by the client instance as part of an authentication decision.</t>
  </dd>
</dl>

</section>
<section anchor="trust"><name>Trust relationships</name>

<t>GNAP defines its trust objective as: "the RO trusts the AS to ensure access validation and delegation of protected resources to end users, through third party clients."</t>

<t>This trust objective can be decomposed into trust relationships between software elements and roles, especially the pairs end user/RO, end user/client, client/AS, RS/RO, AS/RO, AS/RS. Trust of an agent by its pair can exist if the pair is informed that the agent has made a promise to follow the protocol in the past (e.g. pre-registration, uncompromised cryptographic components) or if the pair is able to infer by indirect means that the agent has made such a promise (e.g. a compliant client request). Each agent defines its own valuation function of promises given or received. Examples of such valuations can be the benefits from interacting with other agents (e.g. safety in client access, interoperability with identity standards), the cost of following the protocol (including its security and privacy requirements and recommendations), a ranking of promise importance (e.g. a policy decision made by the AS), the assessment of one's vulnerability or risk of not being able to defend against threats, etc. Those valuations may depend on the context of the request. For instance, the AS may decide to either take into account or discard hints provided by the client, the RS may refuse bearer tokens, etc. depending on the specific case in which GNAP is used. Some promises can be conditional of some previous interactions (e.g. repeated requests).</t>

<t>Looking back on each trust relationship:</t>

<t><list style="symbols">
  <t>end user/RO: this relationship exists only when the end user and the RO are different, in which case the end user needs some out of band mechanism of getting the RO consent (see <xref target="authorization"/>). GNAP generally assumes that humans can be authenticated thanks to identity protocols (for instance, through an id_token assertion in <xref target="request-subject"/>).</t>
  <t>end user/client: the client acts as a user agent. Depending on the technology used (browser, SPA, mobile application, IoT device, etc.), some interactions may or may not be possible (as described in <xref target="request-interact-start"/>). Client developers implement requirements and generally some recommendations or best practices, so that the end users may confidently use their software. However, end users might also be facing an attacker's client software or a poorly-implemented client, without even realizing it.</t>
  <t>end user/AS: when the client supports the interaction feature (see <xref target="response-interact"/>), the end user interacts with the AS through an AS-provided interface. In may cases, this happens through a front-channel interaction through the end user's browser. See <xref target="security-front-channel"/> for some considerations in trusting these interactions.</t>
  <t>client/AS: An honest AS may be facing an attacker's client (as discussed just above), or the reverse, and GNAP aims at making common attacks impractical. The core specification makes access tokens opaque to the client and defines the request/response scheme in detail, therefore avoiding extra trust hypotheses from this critical piece of software. Yet the AS may further define cryptographic attestations or optional rules to simplify the access of clients it already trusts, due to past behavior or organizational policies (see <xref target="request-client"/>).</t>
  <t>RS/RO: the RS promises it protects its resources on behalf of the RO from unauthorized access, and only accepts valid access tokens issued by a trusted AS. In case tokens are key bound, proper validation of the proof method is expected from the RS.</t>
  <t>AS/RO: the AS is expected to follow the decisions made by the RO, either through interactive consent requests, repeated interactions, or automated rules (as described in <xref target="sequence"/>). Privacy considerations aim to reduce the risk of an honest but too-curious AS, or the consequences of an unexpected user data exposure.</t>
  <t>AS/RS: the AS promises to issue valid access tokens to legitimate client requests (i.e. after carrying out appropriate due diligence, as defined in the GNAP protocol). Some optional configurations are covered by <xref target="I-D.ietf-gnap-resource-servers"/>.</t>
</list></t>

<t>A global assumption made by GNAP is that authorization requests are security and privacy sensitive, and appropriate measures are respectively detailed in <xref target="security"/> and <xref target="privacy"/>.</t>

<t>A formal trust model is out of scope of this specification, but one could be developed using techniques such as <xref target="promise-theory"/>.</t>

</section>
<section anchor="protocol"><name>Protocol Flow</name>

<t>GNAP is fundamentally designed to allow delegated access to APIs and other information, such as subject information, using a multi-stage, stateful process. This process allows different parties to provide information into the system to alter and augment the state of the delegated access and its artifacts.</t>

<t>The underlying requested grant moves through several states as different actions take place during the protocol:</t>

<figure title="Figure 2: State diagram of a grant request throughout GNAP"><artset><artwork  type="svg"><svg xmlns="http://www.w3.org/2000/svg" version="1.1" height="432" width="584" viewBox="0 0 584 432" class="diagram" text-anchor="middle" font-family="monospace" font-size="13px" stroke-linecap="round">
<path d="M 112,192 L 112,256" fill="none" stroke="black"/>
<path d="M 216,192 L 216,256" fill="none" stroke="black"/>
<path d="M 378,192 L 378,256" fill="none" stroke="black"/><path d="M 374,192 L 374,256" fill="none" stroke="black"/>
<path d="M 376,320 L 376,384" fill="none" stroke="black"/>
<path d="M 384,64 L 384,128" fill="none" stroke="black"/>
<path d="M 424,128 L 424,176" fill="none" stroke="black"/>
<path d="M 424,272 L 424,320" fill="none" stroke="black"/>
<path d="M 440,48 L 440,64" fill="none" stroke="black"/>
<path d="M 440,384 L 440,400" fill="none" stroke="black"/>
<path d="M 464,64 L 464,128" fill="none" stroke="black"/>
<path d="M 464,320 L 464,384" fill="none" stroke="black"/>
<path d="M 474,192 L 474,256" fill="none" stroke="black"/><path d="M 470,192 L 470,256" fill="none" stroke="black"/>
<path d="M 504,48 L 504,80" fill="none" stroke="black"/>
<path d="M 504,368 L 504,400" fill="none" stroke="black"/>
<path d="M 456,32 L 488,32" fill="none" stroke="black"/>
<path d="M 384,64 L 464,64" fill="none" stroke="black"/>
<path d="M 184,80 L 208,80" fill="none" stroke="black"/>
<path d="M 344,80 L 376,80" fill="none" stroke="black"/>
<path d="M 472,96 L 488,96" fill="none" stroke="black"/>
<path d="M 200,112 L 216,112" fill="none" stroke="black"/>
<path d="M 368,112 L 384,112" fill="none" stroke="black"/>
<path d="M 384,128 L 464,128" fill="none" stroke="black"/>
<path d="M 112,192 L 216,192" fill="none" stroke="black"/>
<path d="M 376,190 L 472,190" fill="none" stroke="black"/><path d="M 376,194 L 472,194" fill="none" stroke="black"/>
<path d="M 8,224 L 24,224" fill="none" stroke="black"/>
<path d="M 88,224 L 104,224" fill="none" stroke="black"/>
<path d="M 216,224 L 264,224" fill="none" stroke="black"/>
<path d="M 336,224 L 368,224" fill="none" stroke="black"/>
<path d="M 112,256 L 216,256" fill="none" stroke="black"/>
<path d="M 376,254 L 472,254" fill="none" stroke="black"/><path d="M 376,258 L 472,258" fill="none" stroke="black"/>
<path d="M 376,320 L 464,320" fill="none" stroke="black"/>
<path d="M 208,336 L 248,336" fill="none" stroke="black"/>
<path d="M 304,336 L 376,336" fill="none" stroke="black"/>
<path d="M 472,352 L 488,352" fill="none" stroke="black"/>
<path d="M 184,368 L 224,368" fill="none" stroke="black"/>
<path d="M 344,368 L 368,368" fill="none" stroke="black"/>
<path d="M 376,384 L 464,384" fill="none" stroke="black"/>
<path d="M 456,416 L 488,416" fill="none" stroke="black"/>
<path d="M 128,256 L 184,368" fill="none" stroke="black"/>
<path d="M 172,264 L 208,336" fill="none" stroke="black"/>
<path d="M 128,192 L 184,80" fill="none" stroke="black"/>
<path d="M 164,184 L 200,112" fill="none" stroke="black"/>
<path d="M 456,32 C 447.16936,32 440,39.16936 440,48" fill="none" stroke="black"/>
<path d="M 488,32 C 496.83064,32 504,39.16936 504,48" fill="none" stroke="black"/>
<path d="M 488,96 C 496.83064,96 504,88.83064 504,80" fill="none" stroke="black"/>
<path d="M 488,352 C 496.83064,352 504,359.16936 504,368" fill="none" stroke="black"/>
<path d="M 456,416 C 447.16936,416 440,408.83064 440,400" fill="none" stroke="black"/>
<path d="M 488,416 C 496.83064,416 504,408.83064 504,400" fill="none" stroke="black"/>
<polygon class="arrowhead" points="480,352 468,346.4 468,357.6" fill="black" transform="rotate(180,472,352)"/>
<polygon class="arrowhead" points="480,96 468,90.4 468,101.6" fill="black" transform="rotate(180,472,96)"/>
<polygon class="arrowhead" points="432,272 420,266.4 420,277.6" fill="black" transform="rotate(270,424,272)"/>
<polygon class="arrowhead" points="432,176 420,170.4 420,181.6" fill="black" transform="rotate(90,424,176)"/>
<polygon class="arrowhead" points="384,80 372,74.4 372,85.6" fill="black" transform="rotate(0,376,80)"/>
<polygon class="arrowhead" points="376,368 364,362.4 364,373.6" fill="black" transform="rotate(0,368,368)"/>
<polygon class="arrowhead" points="376,224 364,218.4 364,229.6" fill="black" transform="rotate(0,368,224)"/>
<polygon class="arrowhead" points="180,264 168,258.4 168,269.6" fill="black" transform="rotate(243.43494882292202,172,264)"/>
<polygon class="arrowhead" points="172,184 160,178.4 160,189.6" fill="black" transform="rotate(116.56505117707799,164,184)"/>
<polygon class="arrowhead" points="112,224 100,218.4 100,229.6" fill="black" transform="rotate(0,104,224)"/>
<g class="text">
<text x="548" y="68">Continue</text>
<text x="228" y="84">Need</text>
<text x="296" y="84">Interaction</text>
<text x="424" y="100">Pending</text>
<text x="244" y="116">Finish</text>
<text x="320" y="116">Interaction</text>
<text x="292" y="132">(approve/deny)</text>
<text x="460" y="164">Cancel</text>
<text x="56" y="228">Request</text>
<text x="164" y="228">Processing</text>
<text x="300" y="228">Finalize</text>
<text x="424" y="228">Finalized</text>
<text x="460" y="292">Revoke</text>
<text x="500" y="292">or</text>
<text x="468" y="308">Finalize</text>
<text x="276" y="340">Update</text>
<text x="420" y="356">Approved</text>
<text x="236" y="372">No</text>
<text x="296" y="372">Interaction</text>
<text x="548" y="388">Continue</text>
</g>
</svg>
</artwork><artwork  type="ascii-art"><![CDATA[
                                                       .-----.
                                                      |       |
                                               +------+--+    | Continue
                      .---Need Interaction---->|         |    |
                     /                         | Pending |<--`
                    /   .--Finish Interaction--+         |
                   /   /     (approve/deny)    +----+----+
                  /   /                             |
                 /   /                              | Cancel
                /   v                               v
             +-+----------+                   +===========+
             |            |                   ║           ║
---Request-->| Processing +------Finalize---->║ Finalized ║
             |            |                   ║           ║
             +-+----------+                   +===========+
                \    ^                              ^
                 \    \                             | Revoke or
                  \    \                            | Finalize
                   \    \                     +-----+----+
                    \    `-----Update---------+          |
                     \                        | Approved |<--.
                      `-----No Interaction--->|          |    |
                                              +-------+--+    | Continue
                                                      |       |
                                                       `-----`
]]></artwork></artset></figure>

<t>The state of the grant request is defined and managed by the AS, though the client instance also needs to manage its view of the grant request over time. The means by which these roles manage their state is outside the scope of this specification.</t>

<dl>
  <dt><em>Processing</em>:</dt>
  <dd>
    <t>When a <xref target="request">request for access</xref> is received by the AS, a new grant request is created and placed in the <em>processing</em> state by the AS. This state is also entered when an existing grant request is updated by the client instance and when interaction is completed. In this state, the AS processes the context of the grant request to determine whether interaction with the end user or RO is required for approval of the request. The grant request has to exit this state before a response can be returned to the client instance. If approval is required, the request moves to the <em>pending</em> state and the AS returns a <xref target="response-continue">continue response</xref> along with any appropriate <xref target="response-interact">interaction responses</xref>. If no such approval is required, such as when the client instance is acting on its own behalf or the AS can determine that access has been fulfilled, the request moves to the <em>approved</em> state where <xref target="response-token">access tokens for API access</xref> and <xref target="response-subject">subject information</xref> can be issued to the client instance. If the AS determines that no additional processing can occur (such as a timeout or an unrecoverable error), the grant request is moved to the <em>finalized</em> state and is terminated.</t>
  </dd>
  <dt><em>Pending</em>:</dt>
  <dd>
    <t>When a request needs to be approved by a RO, or interaction with the end user is required, the grant request enters a state of <em>pending</em>. In this state, no access tokens can be granted and no subject information can be released to the client instance. While a grant request is in this state, the AS seeks to gather the required <xref target="authorization">consent and authorization</xref> for the requested access. A grant request in this state is always associated with a <em>continuation access token</em> bound to the client instance's key (see <xref target="response-continue"/> for details of the continuation access token). If no <xref target="request-interact-finish">interaction finish method</xref> is associated with this request, the client instance can send a <xref target="continue-poll">polling continue request</xref> to the AS. This returns a <xref target="response-continue">continue response</xref> while the grant request remains in this state, allowing the client instance to continue to check the state of the pending grant request. If an <xref target="request-interact-finish">interaction finish method</xref> is specified in the grant request, the client instance can <xref target="continue-after-interaction">continue the request after interaction</xref> to the AS to move this request to the <em>processing</em> state to be re-evaluated by the AS. Note that this occurs whether the grant request has been approved or denied by the RO, since the AS needs to take into account the full context of the request before determining the next step for the grant request. When other information is made available in the context of the grant request, such as through the asynchronous actions of the RO, the AS moves this request to the <em>processing</em> state to be re-evaluated. If the AS determines that no additional interaction can occur, such as all the interaction methods have timed out or a <xref target="continue-delete">revocation request</xref> is received from the client instance, the grant request can be moved to the <em>finalized</em> state.</t>
  </dd>
  <dt><em>Approved</em>:</dt>
  <dd>
    <t>When a request has been approved by an RO and no further interaction with the end user is required, the grant request enters a state of <em>approved</em>. In this state, responses to the client instance can include <xref target="response-token">access tokens for API access</xref> and <xref target="response-subject">subject information</xref>. If continuation and updates are allowed for this grant request, the AS can include the <xref target="response-continue">continuation response</xref>. In this state, <xref target="continue-after-interaction">post-interaction continuation requests</xref> are not allowed and will result in an error, since all interaction is assumed to have been completed. If the client instance sends a <xref target="continue-poll">polling continue request</xref> while the request is in this state, <xref target="response-token">new access tokens</xref> can be issued in the response. Note that this always creates a new access token, but any existing access tokens could be rotated and revoked using the <xref target="token-management">token management API</xref>. The client instance can send an <xref target="continue-modify">update continuation request</xref> to modify the requested access, causing the AS to move the request back to the <em>processing</em> state for re-evaluation. If the AS determines that no additional tokens can be issued, and that no additional updates are to be accepted (such as the continuation access tokens have expired), the grant is moved to the <em>finalized</em> state.</t>
  </dd>
  <dt><em>Finalized</em>:</dt>
  <dd>
    <t>After the access tokens are issued, if the AS does not allow any additional updates on the grant request, the grant request enters the <em>finalized</em> state. This state is also entered when an existing grant request is <xref target="continue-delete">revoked by the client instance</xref> or otherwise revoked by the AS (such as through out-of-band action by the RO). This state can also be entered if the AS determines that no additional processing is possible, for example if the RO has denied the requested access or if interaction is required but no compatible interaction methods are available. Once in this state, no new access tokens can be issued, no subject information can be returned, and no interactions can take place. Once in this state, the grant request is dead and cannot be revived. If future access is desired by the client instance, a new grant request can be created, unrelated to this grant request.</t>
  </dd>
</dl>

<t>While it is possible to deploy an AS in a stateless environment, GNAP is a stateful protocol and such deployments will need a way to manage the current state of the grant request in a secure and deterministic fashion without relying on other components, such as the client software, to keep track of the current state.</t>

</section>
<section anchor="sequence"><name>Sequences</name>

<t>GNAP can be used in a variety of ways to allow the core
delegation process to take place. Many portions of this process are
conditionally present depending on the context of the deployments,
and not every step in this overview will happen in all circumstances.</t>

<t>Note that a connection between roles in this process does not necessarily
indicate that a specific protocol message is sent across the wire
between the components fulfilling the roles in question, or that a
particular step is required every time. For example, for a client instance interested
in only getting subject information directly, and not calling an RS,
all steps involving the RS below do not apply.</t>

<t>In some circumstances,
the information needed at a given stage is communicated out of band
or is preconfigured between the components or entities performing
the roles. For example, one entity can fulfill multiple roles, and so
explicit communication between the roles is not necessary within the
protocol flow. Additionally some components may not be involved
in all use cases. For example, a client instance could be calling the
AS just to get direct user information and have no need to get
an access token to call an RS.</t>

<section anchor="sequence-overall"><name>Overall Protocol Sequence</name>

<t>The following diagram provides a general overview of GNAP, including many
different optional phases and connections. The diagrams in the following sections
provide views of GNAP under more specific circumstances. These additional diagrams
use the same conventions as the overall diagram below.</t>

<figure title="Figure 3: Overall sequence of GNAP"><artset><artwork  type="svg"><svg xmlns="http://www.w3.org/2000/svg" version="1.1" height="624" width="456" viewBox="0 0 456 624" class="diagram" text-anchor="middle" font-family="monospace" font-size="13px" stroke-linecap="round">
<path d="M 8,48 L 8,64" fill="none" stroke="black"/>
<path d="M 8,176 L 8,512" fill="none" stroke="black"/>
<path d="M 58,80 L 58,112" fill="none" stroke="black"/><path d="M 54,80 L 54,112" fill="none" stroke="black"/>
<path d="M 58,144 L 58,176" fill="none" stroke="black"/><path d="M 54,144 L 54,176" fill="none" stroke="black"/>
<path d="M 80,176 L 80,512" fill="none" stroke="black"/>
<path d="M 112,48 L 112,64" fill="none" stroke="black"/>
<path d="M 152,224 L 152,328" fill="none" stroke="black"/>
<path d="M 152,376 L 152,440" fill="none" stroke="black"/>
<path d="M 152,456 L 152,512" fill="none" stroke="black"/>
<path d="M 192,48 L 192,64" fill="none" stroke="black"/>
<path d="M 250,80 L 250,112" fill="none" stroke="black"/><path d="M 246,80 L 246,112" fill="none" stroke="black"/>
<path d="M 250,144 L 250,224" fill="none" stroke="black"/><path d="M 246,144 L 246,224" fill="none" stroke="black"/>
<path d="M 280,224 L 280,328" fill="none" stroke="black"/>
<path d="M 280,376 L 280,440" fill="none" stroke="black"/>
<path d="M 280,456 L 280,512" fill="none" stroke="black"/>
<path d="M 296,48 L 296,64" fill="none" stroke="black"/>
<path d="M 344,176 L 344,512" fill="none" stroke="black"/>
<path d="M 448,176 L 448,512" fill="none" stroke="black"/>
<path d="M 24,32 L 96,32" fill="none" stroke="black"/>
<path d="M 208,32 L 280,32" fill="none" stroke="black"/>
<path d="M 24,80 L 96,80" fill="none" stroke="black"/>
<path d="M 208,80 L 280,80" fill="none" stroke="black"/>
<path d="M 8,176 L 80,176" fill="none" stroke="black"/>
<path d="M 344,176 L 448,176" fill="none" stroke="black"/>
<path d="M 152,224 L 280,224" fill="none" stroke="black"/>
<path d="M 80,240 L 104,240" fill="none" stroke="black"/>
<path d="M 120,240 L 144,240" fill="none" stroke="black"/>
<path d="M 88,256 L 104,256" fill="none" stroke="black"/>
<path d="M 120,256 L 152,256" fill="none" stroke="black"/>
<path d="M 80,288 L 104,288" fill="none" stroke="black"/>
<path d="M 120,288 L 144,288" fill="none" stroke="black"/>
<path d="M 88,304 L 104,304" fill="none" stroke="black"/>
<path d="M 120,304 L 152,304" fill="none" stroke="black"/>
<path d="M 80,336 L 208,336" fill="none" stroke="black"/>
<path d="M 224,336 L 336,336" fill="none" stroke="black"/>
<path d="M 88,368 L 208,368" fill="none" stroke="black"/>
<path d="M 224,368 L 336,368" fill="none" stroke="black"/>
<path d="M 80,400 L 104,400" fill="none" stroke="black"/>
<path d="M 120,400 L 144,400" fill="none" stroke="black"/>
<path d="M 88,416 L 104,416" fill="none" stroke="black"/>
<path d="M 128,416 L 152,416" fill="none" stroke="black"/>
<path d="M 80,448 L 208,448" fill="none" stroke="black"/>
<path d="M 232,448 L 336,448" fill="none" stroke="black"/>
<path d="M 80,480 L 104,480" fill="none" stroke="black"/>
<path d="M 128,480 L 144,480" fill="none" stroke="black"/>
<path d="M 8,512 L 80,512" fill="none" stroke="black"/>
<path d="M 152,512 L 280,512" fill="none" stroke="black"/>
<path d="M 344,512 L 448,512" fill="none" stroke="black"/>
<path d="M 8,558 L 40,558" fill="none" stroke="black"/><path d="M 8,562 L 40,562" fill="none" stroke="black"/>
<path d="M 8,576 L 40,576" fill="none" stroke="black"/>
<path d="M 24,32 C 15.16936,32 8,39.16936 8,48" fill="none" stroke="black"/>
<path d="M 96,32 C 104.83064,32 112,39.16936 112,48" fill="none" stroke="black"/>
<path d="M 208,32 C 199.16936,32 192,39.16936 192,48" fill="none" stroke="black"/>
<path d="M 280,32 C 288.83064,32 296,39.16936 296,48" fill="none" stroke="black"/>
<path d="M 24,80 C 15.16936,80 8,72.83064 8,64" fill="none" stroke="black"/>
<path d="M 96,80 C 104.83064,80 112,72.83064 112,64" fill="none" stroke="black"/>
<path d="M 208,80 C 199.16936,80 192,72.83064 192,64" fill="none" stroke="black"/>
<path d="M 280,80 C 288.83064,80 296,72.83064 296,64" fill="none" stroke="black"/>
<polygon class="arrowhead" points="344,448 332,442.4 332,453.6" fill="black" transform="rotate(0,336,448)"/>
<polygon class="arrowhead" points="344,368 332,362.4 332,373.6" fill="black" transform="rotate(0,336,368)"/>
<polygon class="arrowhead" points="344,336 332,330.4 332,341.6" fill="black" transform="rotate(0,336,336)"/>
<polygon class="arrowhead" points="152,480 140,474.4 140,485.6" fill="black" transform="rotate(0,144,480)"/>
<polygon class="arrowhead" points="152,400 140,394.4 140,405.6" fill="black" transform="rotate(0,144,400)"/>
<polygon class="arrowhead" points="152,288 140,282.4 140,293.6" fill="black" transform="rotate(0,144,288)"/>
<polygon class="arrowhead" points="152,240 140,234.4 140,245.6" fill="black" transform="rotate(0,144,240)"/>
<polygon class="arrowhead" points="96,416 84,410.4 84,421.6" fill="black" transform="rotate(180,88,416)"/>
<polygon class="arrowhead" points="96,368 84,362.4 84,373.6" fill="black" transform="rotate(180,88,368)"/>
<polygon class="arrowhead" points="96,304 84,298.4 84,309.6" fill="black" transform="rotate(180,88,304)"/>
<polygon class="arrowhead" points="96,256 84,250.4 84,261.6" fill="black" transform="rotate(180,88,256)"/>
<g class="text">
<text x="40" y="52">End</text>
<text x="76" y="52">user</text>
<text x="128" y="52">~</text>
<text x="144" y="52">~</text>
<text x="160" y="52">~</text>
<text x="176" y="52">~</text>
<text x="244" y="52">Resource</text>
<text x="224" y="68">Owner</text>
<text x="268" y="68">(RO)</text>
<text x="56" y="132">(A)</text>
<text x="248" y="132">(B)</text>
<text x="44" y="196">Client</text>
<text x="104" y="196">(1)</text>
<text x="396" y="196">Resource</text>
<text x="44" y="212">Instance</text>
<text x="396" y="212">Server</text>
<text x="396" y="228">(RS)</text>
<text x="112" y="244">2</text>
<text x="216" y="244">Authorization</text>
<text x="112" y="260">3</text>
<text x="220" y="260">Server</text>
<text x="220" y="276">(AS)</text>
<text x="112" y="292">4</text>
<text x="112" y="308">5</text>
<text x="216" y="340">6</text>
<text x="152" y="356">|</text>
<text x="280" y="356">|</text>
<text x="320" y="356">(7)</text>
<text x="216" y="372">8</text>
<text x="112" y="404">9</text>
<text x="116" y="420">10</text>
<text x="220" y="452">11</text>
<text x="316" y="468">(12)</text>
<text x="116" y="484">13</text>
<text x="28" y="548">Legend</text>
<text x="88" y="564">indicates</text>
<text x="136" y="564">a</text>
<text x="180" y="564">possible</text>
<text x="264" y="564">interaction</text>
<text x="332" y="564">with</text>
<text x="360" y="564">a</text>
<text x="392" y="564">human</text>
<text x="88" y="580">indicates</text>
<text x="140" y="580">an</text>
<text x="200" y="580">interaction</text>
<text x="280" y="580">between</text>
<text x="348" y="580">protocol</text>
<text x="408" y="580">roles</text>
<text x="8" y="596">~</text>
<text x="24" y="596">~</text>
<text x="40" y="596">~</text>
<text x="88" y="596">indicates</text>
<text x="136" y="596">a</text>
<text x="184" y="596">potential</text>
<text x="272" y="596">equivalence</text>
<text x="332" y="596">or</text>
<text x="392" y="596">out-of-band</text>
<text x="120" y="612">communication</text>
<text x="208" y="612">between</text>
<text x="264" y="612">roles</text>
</g>
</svg>
</artwork><artwork  type="ascii-art"><![CDATA[
 .----------.           .----------.
|  End user  | ~ ~ ~ ~ |  Resource  |
|            |         | Owner (RO) |
 `----+-----`           `-----+----`
      ║                       ║
      ║                       ║
     (A)                     (B)
      ║                       ║
      ║                       ║
+-----+--+                    ║           +------------+
| Client | (1)                ║           |  Resource  |
|Instance|                    ║           |   Server   |
|        |        +-----------+---+       |    (RS)    |
|        +--(2)-->| Authorization |       |            |
|        |<-(3)---+     Server    |       |            |
|        |        |      (AS)     |       |            |
|        +--(4)-->|               |       |            |
|        |<-(5)---+               |       |            |
|        |        |               |       |            |
|        +---------------(6)------------->|            |
|        |        |               |   (7) |            |
|        |<--------------(8)------------->|            |
|        |        |               |       |            |
|        +--(9)-->|               |       |            |
|        |<-(10)--+               |       |            |
|        |        |               |       |            |
|        +---------------(11)------------>|            |
|        |        |               |  (12) |            |
|        +--(13)->|               |       |            |
|        |        |               |       |            |
+--------+        +---------------+       +------------+

Legend
===== indicates a possible interaction with a human
----- indicates an interaction between protocol roles
~ ~ ~ indicates a potential equivalence or out-of-band
        communication between roles
]]></artwork></artset></figure>

<t><list style="symbols">
  <t>(A) The end user interacts with the client instance to indicate a need for resources on
  behalf of the RO. This could identify the RS the client instance needs to call,
  the resources needed, or the RO that is needed to approve the
  request. Note that the RO and end user are often
  the same entity in practice, but GNAP makes no general assumption that they are.</t>
  <t>(1) The client instance determines what access is needed and which AS to approach for access. Note that
  for most situations, the client instance is pre-configured with which AS to talk to and which
  kinds of access it needs, but some more dynamic processes are discussed in
  <xref target="rs-request-without-token"/>.</t>
  <t>(2) The client instance <xref target="request">requests access at the AS</xref>.</t>
  <t>(3) The AS processes the request and determines what is needed to fulfill
  the request (See <xref target="authorization"/>).
  The AS sends its <xref target="response">response to the client instance</xref>.</t>
  <t>(B) If interaction is required, the
  AS <xref target="authorization">interacts with the RO</xref> to gather authorization.
  The interactive component of the AS can function
  using a variety of possible mechanisms including web page
  redirects, applications, challenge/response protocols, or
  other methods. The RO approves the request for the client instance
  being operated by the end user. Note that the RO and end user are often
  the same entity in practice, and many of GNAP's interaction methods allow
  the client instance to facilitate the end user interacting with the AS
  in order to fulfill the role of the RO.</t>
  <t>(4) The client instance <xref target="continue-request">continues the grant at the AS</xref>. This action could
  occur in response to receiving a signal that <xref target="interaction-finish">interaction has finished</xref> or
  through a periodic polling mechanism, depending on the interaction capabilities of the client
  software and the options active in the grant request.</t>
  <t>(5) If the AS determines that access can be granted, it returns a
  <xref target="response">response to the client instance</xref> including an <xref target="response-token">access token</xref> for
  calling the RS and any <xref target="response-subject">directly returned information</xref> about the RO.</t>
  <t>(6) The client instance <xref target="use-access-token">uses the access token</xref> to call the RS.</t>
  <t>(7) The RS determines if the token is sufficient for the request by
  examining the token. The means of the RS determining this access are
  out of scope of this specification, but some options are discussed in
  <xref target="I-D.ietf-gnap-resource-servers"/>.</t>
  <t>(8) The client instance <xref target="use-access-token">calls the RS</xref> using the access token
  until the RS or client instance determine that the token is no longer valid.</t>
  <t>(9) When the token no longer works, the client instance
  <xref target="rotate-access-token">rotates the access token</xref>.</t>
  <t>(10) The AS issues a <xref target="response-token">new access token</xref> to the client instance
  with the same rights as the original access token returned in (5).</t>
  <t>(11) The client instance <xref target="use-access-token">uses the new access token</xref> to call the RS.</t>
  <t>(12) The RS determines if the new token is sufficient for the request, as in (7).</t>
  <t>(13) The client instance <xref target="revoke-access-token">disposes of the token</xref> once the client instance
  has completed its access of the RS and no longer needs the token.</t>
</list></t>

<t>The following sections and <xref target="examples"/> contain specific guidance on how to use
GNAP in different situations and deployments. For example, it is possible for the
client instance to never request an access token and never call an RS, just as it is
possible to have no end user involved in the delegation process.</t>

</section>
<section anchor="sequence-redirect"><name>Redirect-based Interaction</name>

<t>In this example flow, the client instance is a web application that wants access to resources on behalf
of the current user, who acts as both the end user and the resource
owner (RO). Since the client instance is capable of directing the user to an arbitrary URI and
receiving responses from the user's browser, interaction here is handled through
front-channel redirects using the user's browser. The redirection URI used for interaction is
a service hosted by the AS in this example. The client instance uses a persistent session
with the user to ensure the same user that is starting the interaction is the user
that returns from the interaction.</t>

<figure title="Figure 4: Diagram of a redirect-based interaction"><artset><artwork  type="svg"><svg xmlns="http://www.w3.org/2000/svg" version="1.1" height="496" width="576" viewBox="0 0 576 496" class="diagram" text-anchor="middle" font-family="monospace" font-size="13px" stroke-linecap="round">
<path d="M 8,32 L 8,480" fill="none" stroke="black"/>
<path d="M 80,32 L 80,480" fill="none" stroke="black"/>
<path d="M 360,32 L 360,64" fill="none" stroke="black"/>
<path d="M 360,96 L 360,160" fill="none" stroke="black"/>
<path d="M 360,192 L 360,288" fill="none" stroke="black"/>
<path d="M 360,320 L 360,408" fill="none" stroke="black"/>
<path d="M 360,456 L 360,480" fill="none" stroke="black"/>
<path d="M 432,32 L 432,64" fill="none" stroke="black"/>
<path d="M 432,96 L 432,160" fill="none" stroke="black"/>
<path d="M 432,192 L 432,288" fill="none" stroke="black"/>
<path d="M 432,320 L 432,408" fill="none" stroke="black"/>
<path d="M 432,456 L 432,480" fill="none" stroke="black"/>
<path d="M 480,400 L 480,464" fill="none" stroke="black"/>
<path d="M 512,48 L 512,304" fill="none" stroke="black"/>
<path d="M 552,400 L 552,464" fill="none" stroke="black"/>
<path d="M 568,48 L 568,304" fill="none" stroke="black"/>
<path d="M 8,32 L 80,32" fill="none" stroke="black"/>
<path d="M 360,32 L 432,32" fill="none" stroke="black"/>
<path d="M 528,32 L 552,32" fill="none" stroke="black"/>
<path d="M 88,78 L 104,78" fill="none" stroke="black"/><path d="M 88,82 L 104,82" fill="none" stroke="black"/>
<path d="M 120,78 L 136,78" fill="none" stroke="black"/><path d="M 120,82 L 136,82" fill="none" stroke="black"/>
<path d="M 264,78 L 512,78" fill="none" stroke="black"/><path d="M 264,82 L 512,82" fill="none" stroke="black"/>
<path d="M 80,112 L 104,112" fill="none" stroke="black"/>
<path d="M 120,112 L 144,112" fill="none" stroke="black"/>
<path d="M 280,112 L 352,112" fill="none" stroke="black"/>
<path d="M 88,144 L 104,144" fill="none" stroke="black"/>
<path d="M 120,144 L 136,144" fill="none" stroke="black"/>
<path d="M 304,144 L 360,144" fill="none" stroke="black"/>
<path d="M 80,174 L 104,174" fill="none" stroke="black"/><path d="M 80,178 L 104,178" fill="none" stroke="black"/>
<path d="M 120,174 L 136,174" fill="none" stroke="black"/><path d="M 120,178 L 136,178" fill="none" stroke="black"/>
<path d="M 352,174 L 504,174" fill="none" stroke="black"/><path d="M 352,178 L 504,178" fill="none" stroke="black"/>
<path d="M 512,192 L 568,192" fill="none" stroke="black"/>
<path d="M 440,206 L 464,206" fill="none" stroke="black"/><path d="M 440,210 L 464,210" fill="none" stroke="black"/>
<path d="M 480,206 L 504,206" fill="none" stroke="black"/><path d="M 480,210 L 504,210" fill="none" stroke="black"/>
<path d="M 440,254 L 464,254" fill="none" stroke="black"/><path d="M 440,258 L 464,258" fill="none" stroke="black"/>
<path d="M 480,254 L 504,254" fill="none" stroke="black"/><path d="M 480,258 L 504,258" fill="none" stroke="black"/>
<path d="M 512,272 L 568,272" fill="none" stroke="black"/>
<path d="M 88,302 L 104,302" fill="none" stroke="black"/><path d="M 88,306 L 104,306" fill="none" stroke="black"/>
<path d="M 120,302 L 136,302" fill="none" stroke="black"/><path d="M 120,306 L 136,306" fill="none" stroke="black"/>
<path d="M 360,302 L 512,302" fill="none" stroke="black"/><path d="M 360,306 L 512,306" fill="none" stroke="black"/>
<path d="M 528,320 L 552,320" fill="none" stroke="black"/>
<path d="M 80,336 L 104,336" fill="none" stroke="black"/>
<path d="M 120,336 L 144,336" fill="none" stroke="black"/>
<path d="M 296,336 L 352,336" fill="none" stroke="black"/>
<path d="M 88,368 L 104,368" fill="none" stroke="black"/>
<path d="M 120,368 L 160,368" fill="none" stroke="black"/>
<path d="M 280,368 L 360,368" fill="none" stroke="black"/>
<path d="M 480,400 L 552,400" fill="none" stroke="black"/>
<path d="M 80,416 L 104,416" fill="none" stroke="black"/>
<path d="M 128,416 L 144,416" fill="none" stroke="black"/>
<path d="M 248,416 L 472,416" fill="none" stroke="black"/>
<path d="M 88,448 L 104,448" fill="none" stroke="black"/>
<path d="M 128,448 L 144,448" fill="none" stroke="black"/>
<path d="M 264,448 L 472,448" fill="none" stroke="black"/>
<path d="M 480,464 L 552,464" fill="none" stroke="black"/>
<path d="M 8,480 L 80,480" fill="none" stroke="black"/>
<path d="M 360,480 L 432,480" fill="none" stroke="black"/>
<path d="M 528,32 C 519.16936,32 512,39.16936 512,48" fill="none" stroke="black"/>
<path d="M 552,32 C 560.83064,32 568,39.16936 568,48" fill="none" stroke="black"/>
<path d="M 528,320 C 519.16936,320 512,312.83064 512,304" fill="none" stroke="black"/>
<path d="M 552,320 C 560.83064,320 568,312.83064 568,304" fill="none" stroke="black"/>
<polygon class="arrowhead" points="512,256 500,250.4 500,261.6" fill="black" transform="rotate(0,504,256)"/>
<polygon class="arrowhead" points="512,208 500,202.4 500,213.6" fill="black" transform="rotate(0,504,208)"/>
<polygon class="arrowhead" points="512,176 500,170.4 500,181.6" fill="black" transform="rotate(0,504,176)"/>
<polygon class="arrowhead" points="480,416 468,410.4 468,421.6" fill="black" transform="rotate(0,472,416)"/>
<polygon class="arrowhead" points="448,256 436,250.4 436,261.6" fill="black" transform="rotate(180,440,256)"/>
<polygon class="arrowhead" points="448,208 436,202.4 436,213.6" fill="black" transform="rotate(180,440,208)"/>
<polygon class="arrowhead" points="360,336 348,330.4 348,341.6" fill="black" transform="rotate(0,352,336)"/>
<polygon class="arrowhead" points="360,112 348,106.4 348,117.6" fill="black" transform="rotate(0,352,112)"/>
<polygon class="arrowhead" points="96,448 84,442.4 84,453.6" fill="black" transform="rotate(180,88,448)"/>
<polygon class="arrowhead" points="96,368 84,362.4 84,373.6" fill="black" transform="rotate(180,88,368)"/>
<polygon class="arrowhead" points="96,304 84,298.4 84,309.6" fill="black" transform="rotate(180,88,304)"/>
<polygon class="arrowhead" points="96,144 84,138.4 84,149.6" fill="black" transform="rotate(180,88,144)"/>
<polygon class="arrowhead" points="96,80 84,74.4 84,85.6" fill="black" transform="rotate(180,88,80)"/>
<g class="text">
<text x="44" y="52">Client</text>
<text x="396" y="52">AS</text>
<text x="536" y="52">End</text>
<text x="44" y="68">Instance</text>
<text x="540" y="68">User</text>
<text x="112" y="84">1</text>
<text x="168" y="84">Start</text>
<text x="224" y="84">Session</text>
<text x="112" y="116">2</text>
<text x="184" y="116">Request</text>
<text x="244" y="116">Access</text>
<text x="112" y="148">3</text>
<text x="192" y="148">Interaction</text>
<text x="268" y="148">Needed</text>
<text x="112" y="180">4</text>
<text x="180" y="180">Redirect</text>
<text x="232" y="180">for</text>
<text x="296" y="180">Interaction</text>
<text x="472" y="212">5</text>
<text x="472" y="228">AuthN</text>
<text x="540" y="228">RO</text>
<text x="472" y="260">6</text>
<text x="472" y="276">AuthZ</text>
<text x="536" y="292">End</text>
<text x="112" y="308">7</text>
<text x="180" y="308">Redirect</text>
<text x="232" y="308">for</text>
<text x="300" y="308">Continuation</text>
<text x="540" y="308">User</text>
<text x="112" y="340">8</text>
<text x="188" y="340">Continue</text>
<text x="256" y="340">Request</text>
<text x="112" y="372">9</text>
<text x="192" y="372">Grant</text>
<text x="244" y="372">Access</text>
<text x="116" y="420">10</text>
<text x="180" y="420">Access</text>
<text x="224" y="420">API</text>
<text x="516" y="420">RS</text>
<text x="360" y="436">|</text>
<text x="432" y="436">|</text>
<text x="116" y="452">11</text>
<text x="168" y="452">API</text>
<text x="220" y="452">Response</text>
</g>
</svg>
</artwork><artwork  type="ascii-art"><![CDATA[
+--------+                                  +--------+          .----.
| Client |                                  |   AS   |         | End  |
|Instance|                                  |        |         | User |
|        |<=(1)== Start Session ===============================+      |
|        |                                  |        |         |      |
|        +--(2)--- Request Access --------->|        |         |      |
|        |                                  |        |         |      |
|        |<-(3)-- Interaction Needed -------+        |         |      |
|        |                                  |        |         |      |
|        +==(4)== Redirect for Interaction ===================>|      |
|        |                                  |        |         +------+
|        |                                  |        |<==(5)==>|      |
|        |                                  |        |  AuthN  |  RO  |
|        |                                  |        |         |      |
|        |                                  |        |<==(6)==>|      |
|        |                                  |        |  AuthZ  +------+
|        |                                  |        |         | End  |
|        |<=(7)== Redirect for Continuation ===================+ User |
|        |                                  |        |          `----`
|        +--(8)--- Continue Request ------->|        |
|        |                                  |        |
|        |<-(9)----- Grant Access ----------+        |
|        |                                  |        |
|        |                                  |        |     +--------+
|        +--(10)-- Access API ---------------------------->|   RS   |
|        |                                  |        |     |        |
|        |<-(11)-- API Response ---------------------------|        |
|        |                                  |        |     +--------+
+--------+                                  +--------+
]]></artwork></artset></figure>

<t><list style="numbers">
  <t>The client instance establishes a session with the user, in the role of the end user.</t>
  <t>The client instance <xref target="request">requests access to the resource</xref>. The client instance indicates that
 it can <xref target="request-interact-redirect">redirect to an arbitrary URI</xref> and
 <xref target="request-interact-callback-redirect">receive a redirect from the browser</xref>. The client instance
 stores verification information for its redirect in the session created
 in (1).</t>
  <t>The AS determines that interaction is needed and <xref target="response">responds</xref> with
 a <xref target="response-interact-redirect">URI to send the user to</xref> and
 <xref target="response-interact-finish">information needed to verify the redirect</xref> in (7).
 The AS also includes information the client instance will need to
 <xref target="response-continue">continue the request</xref> in (8). The AS associates this
 continuation information with an ongoing request that will be referenced in (4), (6), and (8).</t>
  <t>The client instance stores the verification and continuation information from (3) in the session from (1). The client instance
 then <xref target="interaction-redirect">redirects the user to the URI</xref> given by the AS in (3).
 The user's browser loads the interaction redirect URI. The AS loads the pending
 request based on the incoming URI generated in (3).</t>
  <t>The user authenticates at the AS, taking on the role of the RO.</t>
  <t>As the RO, the user authorizes the pending request from the client instance.</t>
  <t>When the AS is done interacting with the user, the AS
 <xref target="interaction-callback">redirects the user back</xref> to the
 client instance using the redirect URI provided in (2). The redirect URI is augmented with
 an interaction reference that the AS associates with the ongoing
 request created in (2) and referenced in (4). The redirect URI is also
 augmented with a hash of the security information provided
 in (2) and (3). The client instance loads the verification information from (2) and (3) from
 the session created in (1). The client instance <xref target="interaction-hash">calculates a hash</xref>
 based on this information and continues only if the hash validates.
 Note that the client instance needs to ensure that the parameters for the incoming
 request match those that it is expecting from the session created
 in (1). The client instance also needs to be prepared for the end user never being returned
 to the client instance and handle timeouts appropriately.</t>
  <t>The client instance loads the continuation information from (3) and sends the
 interaction reference from (7) in a request to
 <xref target="continue-after-interaction">continue the request</xref>. The AS
 validates the interaction reference ensuring that the reference
 is associated with the request being continued.</t>
  <t>If the request has been authorized, the AS grants access to the information
 in the form of <xref target="response-token">access tokens</xref> and
 <xref target="response-subject">direct subject information</xref> to the client instance.</t>
  <t>The client instance <xref target="use-access-token">uses the access token</xref> to call the RS.</t>
  <t>The RS validates the access token and returns an appropriate response for the
API.</t>
</list></t>

<t>An example set of protocol messages for this method can be found in <xref target="example-auth-code"/>.</t>

</section>
<section anchor="sequence-user-code"><name>User-code Interaction</name>

<t>In this example flow, the client instance is a device that is capable of presenting a short,
human-readable code to the user and directing the user to enter that code at
a known URI. The user enters the code at a URI that is an interactive service hosted by the
AS in this example. The client instance is not capable of presenting an arbitrary URI to the user,
nor is it capable of accepting incoming HTTP requests from the user's browser.
The client instance polls the AS while it is waiting for the RO to authorize the request.
The user's interaction is assumed to occur on a secondary device. In this example
it is assumed that the user is both the end user and RO. Note that since the user is not assumed
to be interacting with the client instance through the same web browser used for interaction at
the AS, the user is not shown as being connected to the client instance in this diagram.</t>

<figure title="Figure 5: Diagram of a user-code-based interaction"><artset><artwork  type="svg"><svg xmlns="http://www.w3.org/2000/svg" version="1.1" height="560" width="576" viewBox="0 0 576 560" class="diagram" text-anchor="middle" font-family="monospace" font-size="13px" stroke-linecap="round">
<path d="M 8,32 L 8,544" fill="none" stroke="black"/>
<path d="M 80,32 L 80,544" fill="none" stroke="black"/>
<path d="M 360,32 L 360,112" fill="none" stroke="black"/>
<path d="M 360,144 L 360,472" fill="none" stroke="black"/>
<path d="M 360,520 L 360,544" fill="none" stroke="black"/>
<path d="M 432,32 L 432,112" fill="none" stroke="black"/>
<path d="M 432,144 L 432,472" fill="none" stroke="black"/>
<path d="M 432,520 L 432,544" fill="none" stroke="black"/>
<path d="M 480,464 L 480,528" fill="none" stroke="black"/>
<path d="M 512,48 L 512,416" fill="none" stroke="black"/>
<path d="M 552,464 L 552,528" fill="none" stroke="black"/>
<path d="M 568,48 L 568,416" fill="none" stroke="black"/>
<path d="M 8,32 L 80,32" fill="none" stroke="black"/>
<path d="M 360,32 L 432,32" fill="none" stroke="black"/>
<path d="M 528,32 L 552,32" fill="none" stroke="black"/>
<path d="M 80,64 L 104,64" fill="none" stroke="black"/>
<path d="M 120,64 L 144,64" fill="none" stroke="black"/>
<path d="M 280,64 L 352,64" fill="none" stroke="black"/>
<path d="M 88,96 L 104,96" fill="none" stroke="black"/>
<path d="M 120,96 L 136,96" fill="none" stroke="black"/>
<path d="M 304,96 L 360,96" fill="none" stroke="black"/>
<path d="M 80,126 L 104,126" fill="none" stroke="black"/><path d="M 80,130 L 104,130" fill="none" stroke="black"/>
<path d="M 120,126 L 152,126" fill="none" stroke="black"/><path d="M 120,130 L 152,130" fill="none" stroke="black"/>
<path d="M 312,126 L 504,126" fill="none" stroke="black"/><path d="M 312,130 L 504,130" fill="none" stroke="black"/>
<path d="M 440,158 L 464,158" fill="none" stroke="black"/><path d="M 440,162 L 464,162" fill="none" stroke="black"/>
<path d="M 480,158 L 512,158" fill="none" stroke="black"/><path d="M 480,162 L 512,162" fill="none" stroke="black"/>
<path d="M 512,192 L 568,192" fill="none" stroke="black"/>
<path d="M 440,206 L 464,206" fill="none" stroke="black"/><path d="M 440,210 L 464,210" fill="none" stroke="black"/>
<path d="M 480,206 L 504,206" fill="none" stroke="black"/><path d="M 480,210 L 504,210" fill="none" stroke="black"/>
<path d="M 80,240 L 104,240" fill="none" stroke="black"/>
<path d="M 120,240 L 144,240" fill="none" stroke="black"/>
<path d="M 328,240 L 352,240" fill="none" stroke="black"/>
<path d="M 440,254 L 464,254" fill="none" stroke="black"/><path d="M 440,258 L 464,258" fill="none" stroke="black"/>
<path d="M 480,254 L 504,254" fill="none" stroke="black"/><path d="M 480,258 L 504,258" fill="none" stroke="black"/>
<path d="M 88,272 L 104,272" fill="none" stroke="black"/>
<path d="M 128,272 L 144,272" fill="none" stroke="black"/>
<path d="M 344,272 L 360,272" fill="none" stroke="black"/>
<path d="M 440,302 L 464,302" fill="none" stroke="black"/><path d="M 440,306 L 464,306" fill="none" stroke="black"/>
<path d="M 480,302 L 504,302" fill="none" stroke="black"/><path d="M 480,306 L 504,306" fill="none" stroke="black"/>
<path d="M 440,350 L 464,350" fill="none" stroke="black"/><path d="M 440,354 L 464,354" fill="none" stroke="black"/>
<path d="M 480,350 L 504,350" fill="none" stroke="black"/><path d="M 480,354 L 504,354" fill="none" stroke="black"/>
<path d="M 512,384 L 568,384" fill="none" stroke="black"/>
<path d="M 80,400 L 104,400" fill="none" stroke="black"/>
<path d="M 128,400 L 144,400" fill="none" stroke="black"/>
<path d="M 328,400 L 352,400" fill="none" stroke="black"/>
<path d="M 88,432 L 104,432" fill="none" stroke="black"/>
<path d="M 128,432 L 168,432" fill="none" stroke="black"/>
<path d="M 288,432 L 360,432" fill="none" stroke="black"/>
<path d="M 528,432 L 552,432" fill="none" stroke="black"/>
<path d="M 480,464 L 552,464" fill="none" stroke="black"/>
<path d="M 80,480 L 104,480" fill="none" stroke="black"/>
<path d="M 128,480 L 144,480" fill="none" stroke="black"/>
<path d="M 248,480 L 472,480" fill="none" stroke="black"/>
<path d="M 88,512 L 104,512" fill="none" stroke="black"/>
<path d="M 128,512 L 144,512" fill="none" stroke="black"/>
<path d="M 264,512 L 480,512" fill="none" stroke="black"/>
<path d="M 480,528 L 552,528" fill="none" stroke="black"/>
<path d="M 8,544 L 80,544" fill="none" stroke="black"/>
<path d="M 360,544 L 432,544" fill="none" stroke="black"/>
<path d="M 528,32 C 519.16936,32 512,39.16936 512,48" fill="none" stroke="black"/>
<path d="M 552,32 C 560.83064,32 568,39.16936 568,48" fill="none" stroke="black"/>
<path d="M 528,432 C 519.16936,432 512,424.83064 512,416" fill="none" stroke="black"/>
<path d="M 552,432 C 560.83064,432 568,424.83064 568,416" fill="none" stroke="black"/>
<polygon class="arrowhead" points="512,352 500,346.4 500,357.6" fill="black" transform="rotate(0,504,352)"/>
<polygon class="arrowhead" points="512,304 500,298.4 500,309.6" fill="black" transform="rotate(0,504,304)"/>
<polygon class="arrowhead" points="512,256 500,250.4 500,261.6" fill="black" transform="rotate(0,504,256)"/>
<polygon class="arrowhead" points="512,208 500,202.4 500,213.6" fill="black" transform="rotate(0,504,208)"/>
<polygon class="arrowhead" points="512,128 500,122.4 500,133.6" fill="black" transform="rotate(0,504,128)"/>
<polygon class="arrowhead" points="480,480 468,474.4 468,485.6" fill="black" transform="rotate(0,472,480)"/>
<polygon class="arrowhead" points="448,352 436,346.4 436,357.6" fill="black" transform="rotate(180,440,352)"/>
<polygon class="arrowhead" points="448,304 436,298.4 436,309.6" fill="black" transform="rotate(180,440,304)"/>
<polygon class="arrowhead" points="448,256 436,250.4 436,261.6" fill="black" transform="rotate(180,440,256)"/>
<polygon class="arrowhead" points="448,208 436,202.4 436,213.6" fill="black" transform="rotate(180,440,208)"/>
<polygon class="arrowhead" points="448,160 436,154.4 436,165.6" fill="black" transform="rotate(180,440,160)"/>
<polygon class="arrowhead" points="360,400 348,394.4 348,405.6" fill="black" transform="rotate(0,352,400)"/>
<polygon class="arrowhead" points="360,240 348,234.4 348,245.6" fill="black" transform="rotate(0,352,240)"/>
<polygon class="arrowhead" points="360,64 348,58.4 348,69.6" fill="black" transform="rotate(0,352,64)"/>
<polygon class="arrowhead" points="96,512 84,506.4 84,517.6" fill="black" transform="rotate(180,88,512)"/>
<polygon class="arrowhead" points="96,432 84,426.4 84,437.6" fill="black" transform="rotate(180,88,432)"/>
<polygon class="arrowhead" points="96,272 84,266.4 84,277.6" fill="black" transform="rotate(180,88,272)"/>
<polygon class="arrowhead" points="96,96 84,90.4 84,101.6" fill="black" transform="rotate(180,88,96)"/>
<g class="text">
<text x="44" y="52">Client</text>
<text x="396" y="52">AS</text>
<text x="536" y="52">End</text>
<text x="44" y="68">Instance</text>
<text x="112" y="68">1</text>
<text x="184" y="68">Request</text>
<text x="244" y="68">Access</text>
<text x="540" y="68">User</text>
<text x="112" y="100">2</text>
<text x="192" y="100">Interaction</text>
<text x="268" y="100">Needed</text>
<text x="112" y="132">3</text>
<text x="192" y="132">Display</text>
<text x="244" y="132">User</text>
<text x="284" y="132">Code</text>
<text x="472" y="164">4</text>
<text x="452" y="180">Open</text>
<text x="488" y="180">URI</text>
<text x="472" y="212">5</text>
<text x="540" y="212">RO</text>
<text x="472" y="228">AuthN</text>
<text x="112" y="244">9</text>
<text x="188" y="244">Continue</text>
<text x="256" y="244">Request</text>
<text x="304" y="244">(A)</text>
<text x="472" y="260">6</text>
<text x="116" y="276">10</text>
<text x="168" y="276">Not</text>
<text x="200" y="276">Yet</text>
<text x="248" y="276">Granted</text>
<text x="308" y="276">(Wait)</text>
<text x="468" y="276">Code</text>
<text x="472" y="308">7</text>
<text x="472" y="324">AuthZ</text>
<text x="472" y="356">8</text>
<text x="468" y="372">Complete</text>
<text x="116" y="404">11</text>
<text x="188" y="404">Continue</text>
<text x="256" y="404">Request</text>
<text x="304" y="404">(B)</text>
<text x="536" y="404">End</text>
<text x="540" y="420">User</text>
<text x="116" y="436">12</text>
<text x="200" y="436">Grant</text>
<text x="252" y="436">Access</text>
<text x="116" y="484">13</text>
<text x="180" y="484">Access</text>
<text x="224" y="484">API</text>
<text x="516" y="484">RS</text>
<text x="360" y="500">|</text>
<text x="432" y="500">|</text>
<text x="116" y="516">14</text>
<text x="168" y="516">API</text>
<text x="220" y="516">Response</text>
</g>
</svg>
</artwork><artwork  type="ascii-art"><![CDATA[
+--------+                                  +--------+          .----.
| Client |                                  |   AS   |         | End  |
|Instance+--(1)--- Request Access --------->|        |         | User |
|        |                                  |        |         |      |
|        |<-(2)-- Interaction Needed -------+        |         |      |
|        |                                  |        |         |      |
|        +==(3)==== Display User Code ========================>|      |
|        |                                  |        |         |      |
|        |                                  |        |<==(4)===+      |
|        |                                  |        |Open URI |      |
|        |                                  |        |         +------+
|        |                                  |        |<==(5)==>|  RO  |
|        |                                  |        |  AuthN  |      |
|        +--(9)--- Continue Request (A) --->|        |         |      |
|        |                                  |        |<==(6)==>|      |
|        |<-(10)-- Not Yet Granted (Wait) --+        |  Code   |      |
|        |                                  |        |         |      |
|        |                                  |        |<==(7)==>|      |
|        |                                  |        |  AuthZ  |      |
|        |                                  |        |         |      |
|        |                                  |        |<==(8)==>|      |
|        |                                  |        |Complete |      |
|        |                                  |        |         +------+
|        +--(11)-- Continue Request (B) --->|        |         | End  |
|        |                                  |        |         | User |
|        |<-(12)----- Grant Access ---------+        |          `----`
|        |                                  |        |
|        |                                  |        |     +--------+
|        +--(13)-- Access API ---------------------------->|   RS   |
|        |                                  |        |     |        |
|        |<-(14)-- API Response ---------------------------+        |
|        |                                  |        |     +--------+
+--------+                                  +--------+
]]></artwork></artset></figure>

<t><list style="numbers">
  <t>The client instance <xref target="request">requests access to the resource</xref>. The client instance indicates that
 it can <xref target="request-interact-usercode">display a user code</xref>.</t>
  <t>The AS determines that interaction is needed and <xref target="response">responds</xref> with
 a <xref target="response-interact-usercode">user code to communicate to the user</xref>.
 The AS also includes information the client instance will need to
 <xref target="response-continue">continue the request</xref> in (8) and (10). The AS associates this
 continuation information with an ongoing request that will be referenced in (4), (6), (8), and (10).</t>
  <t>The client instance stores the continuation information from (2) for use in (8) and (10). The client instance
 then <xref target="interaction-usercode">communicates the code to the user</xref> given by the AS in (2).</t>
  <t>The users directs their browser to the user code URI. This URI is stable and
 can be communicated via the client software's documentation, the AS documentation, or
 the client software itself. Since it is assumed that the RO will interact
 with the AS through a secondary device, the client instance does not provide a mechanism to
 launch the RO's browser at this URI.</t>
  <t>The end user authenticates at the AS, taking on the role of the RO.</t>
  <t>The RO enters the code communicated in (3) to the AS. The AS validates this code
against a current request in process.</t>
  <t>As the RO, the user authorizes the pending request from the client instance.</t>
  <t>When the AS is done interacting with the user, the AS
 indicates to the RO that the request has been completed.</t>
  <t>Meanwhile, the client instance loads the continuation information stored at (3) and
 <xref target="continue-request">continues the request</xref>. The AS determines which
 ongoing access request is referenced here and checks its state.</t>
  <t>If the access request has not yet been authorized by the RO in (6),
the AS responds to the client instance to <xref target="response-continue">continue the request</xref>
at a future time through additional polled continuation requests. This response can include
updated continuation information as well as information regarding how long the
client instance should wait before calling again. The client instance replaces its stored
continuation information from the previous response (2).
Note that the AS may need to determine that the RO has not approved
the request in a sufficient amount of time and return an appropriate
error to the client instance.</t>
  <t>The client instance continues to <xref target="continue-poll">poll the AS</xref> with the new
continuation information in (9).</t>
  <t>If the request has been authorized, the AS grants access to the information
in the form of <xref target="response-token">access tokens</xref> and
<xref target="response-subject">direct subject information</xref> to the client instance.</t>
  <t>The client instance <xref target="use-access-token">uses the access token</xref> to call the RS.</t>
  <t>The RS validates the access token and returns an appropriate response for the
API.</t>
</list></t>

<t>An example set of protocol messages for this method can be found in <xref target="example-device"/>.</t>

</section>
<section anchor="sequence-async"><name>Asynchronous Authorization</name>

<t>In this example flow, the end user and RO roles are fulfilled by different parties, and
the RO does not interact with the client instance. The AS reaches out asynchronously to the RO
during the request process to gather the RO's authorization for the client instance's request.
The client instance polls the AS while it is waiting for the RO to authorize the request.</t>

<figure title="Figure 6: Diagram of an asynchronous authorization process, with no end user interaction"><artset><artwork  type="svg"><svg xmlns="http://www.w3.org/2000/svg" version="1.1" height="416" width="576" viewBox="0 0 576 416" class="diagram" text-anchor="middle" font-family="monospace" font-size="13px" stroke-linecap="round">
<path d="M 8,32 L 8,400" fill="none" stroke="black"/>
<path d="M 80,32 L 80,400" fill="none" stroke="black"/>
<path d="M 360,32 L 360,328" fill="none" stroke="black"/>
<path d="M 360,376 L 360,400" fill="none" stroke="black"/>
<path d="M 432,32 L 432,328" fill="none" stroke="black"/>
<path d="M 432,376 L 432,400" fill="none" stroke="black"/>
<path d="M 480,320 L 480,384" fill="none" stroke="black"/>
<path d="M 512,48 L 512,240" fill="none" stroke="black"/>
<path d="M 552,320 L 552,384" fill="none" stroke="black"/>
<path d="M 568,48 L 568,240" fill="none" stroke="black"/>
<path d="M 8,32 L 80,32" fill="none" stroke="black"/>
<path d="M 360,32 L 432,32" fill="none" stroke="black"/>
<path d="M 528,32 L 552,32" fill="none" stroke="black"/>
<path d="M 80,64 L 104,64" fill="none" stroke="black"/>
<path d="M 120,64 L 144,64" fill="none" stroke="black"/>
<path d="M 280,64 L 352,64" fill="none" stroke="black"/>
<path d="M 88,96 L 104,96" fill="none" stroke="black"/>
<path d="M 120,96 L 136,96" fill="none" stroke="black"/>
<path d="M 336,96 L 360,96" fill="none" stroke="black"/>
<path d="M 440,110 L 464,110" fill="none" stroke="black"/><path d="M 440,114 L 464,114" fill="none" stroke="black"/>
<path d="M 480,110 L 504,110" fill="none" stroke="black"/><path d="M 480,114 L 504,114" fill="none" stroke="black"/>
<path d="M 80,144 L 104,144" fill="none" stroke="black"/>
<path d="M 120,144 L 144,144" fill="none" stroke="black"/>
<path d="M 328,144 L 352,144" fill="none" stroke="black"/>
<path d="M 440,158 L 464,158" fill="none" stroke="black"/><path d="M 440,162 L 464,162" fill="none" stroke="black"/>
<path d="M 480,158 L 504,158" fill="none" stroke="black"/><path d="M 480,162 L 504,162" fill="none" stroke="black"/>
<path d="M 88,176 L 104,176" fill="none" stroke="black"/>
<path d="M 120,176 L 136,176" fill="none" stroke="black"/>
<path d="M 336,176 L 360,176" fill="none" stroke="black"/>
<path d="M 440,206 L 464,206" fill="none" stroke="black"/><path d="M 440,210 L 464,210" fill="none" stroke="black"/>
<path d="M 480,206 L 504,206" fill="none" stroke="black"/><path d="M 480,210 L 504,210" fill="none" stroke="black"/>
<path d="M 80,256 L 104,256" fill="none" stroke="black"/>
<path d="M 120,256 L 144,256" fill="none" stroke="black"/>
<path d="M 328,256 L 352,256" fill="none" stroke="black"/>
<path d="M 528,256 L 552,256" fill="none" stroke="black"/>
<path d="M 88,288 L 104,288" fill="none" stroke="black"/>
<path d="M 120,288 L 168,288" fill="none" stroke="black"/>
<path d="M 288,288 L 360,288" fill="none" stroke="black"/>
<path d="M 480,320 L 552,320" fill="none" stroke="black"/>
<path d="M 80,336 L 104,336" fill="none" stroke="black"/>
<path d="M 128,336 L 144,336" fill="none" stroke="black"/>
<path d="M 248,336 L 472,336" fill="none" stroke="black"/>
<path d="M 88,368 L 104,368" fill="none" stroke="black"/>
<path d="M 128,368 L 144,368" fill="none" stroke="black"/>
<path d="M 264,368 L 480,368" fill="none" stroke="black"/>
<path d="M 480,384 L 552,384" fill="none" stroke="black"/>
<path d="M 8,400 L 80,400" fill="none" stroke="black"/>
<path d="M 360,400 L 432,400" fill="none" stroke="black"/>
<path d="M 528,32 C 519.16936,32 512,39.16936 512,48" fill="none" stroke="black"/>
<path d="M 552,32 C 560.83064,32 568,39.16936 568,48" fill="none" stroke="black"/>
<path d="M 528,256 C 519.16936,256 512,248.83064 512,240" fill="none" stroke="black"/>
<path d="M 552,256 C 560.83064,256 568,248.83064 568,240" fill="none" stroke="black"/>
<polygon class="arrowhead" points="512,208 500,202.4 500,213.6" fill="black" transform="rotate(0,504,208)"/>
<polygon class="arrowhead" points="512,160 500,154.4 500,165.6" fill="black" transform="rotate(0,504,160)"/>
<polygon class="arrowhead" points="512,112 500,106.4 500,117.6" fill="black" transform="rotate(0,504,112)"/>
<polygon class="arrowhead" points="480,336 468,330.4 468,341.6" fill="black" transform="rotate(0,472,336)"/>
<polygon class="arrowhead" points="448,208 436,202.4 436,213.6" fill="black" transform="rotate(180,440,208)"/>
<polygon class="arrowhead" points="448,160 436,154.4 436,165.6" fill="black" transform="rotate(180,440,160)"/>
<polygon class="arrowhead" points="448,112 436,106.4 436,117.6" fill="black" transform="rotate(180,440,112)"/>
<polygon class="arrowhead" points="360,256 348,250.4 348,261.6" fill="black" transform="rotate(0,352,256)"/>
<polygon class="arrowhead" points="360,144 348,138.4 348,149.6" fill="black" transform="rotate(0,352,144)"/>
<polygon class="arrowhead" points="360,64 348,58.4 348,69.6" fill="black" transform="rotate(0,352,64)"/>
<polygon class="arrowhead" points="96,368 84,362.4 84,373.6" fill="black" transform="rotate(180,88,368)"/>
<polygon class="arrowhead" points="96,288 84,282.4 84,293.6" fill="black" transform="rotate(180,88,288)"/>
<polygon class="arrowhead" points="96,176 84,170.4 84,181.6" fill="black" transform="rotate(180,88,176)"/>
<polygon class="arrowhead" points="96,96 84,90.4 84,101.6" fill="black" transform="rotate(180,88,96)"/>
<g class="text">
<text x="44" y="52">Client</text>
<text x="396" y="52">AS</text>
<text x="540" y="52">RO</text>
<text x="44" y="68">Instance</text>
<text x="112" y="68">1</text>
<text x="184" y="68">Request</text>
<text x="244" y="68">Access</text>
<text x="112" y="100">2</text>
<text x="160" y="100">Not</text>
<text x="192" y="100">Yet</text>
<text x="240" y="100">Granted</text>
<text x="300" y="100">(Wait)</text>
<text x="472" y="116">3</text>
<text x="472" y="132">AuthN</text>
<text x="112" y="148">6</text>
<text x="188" y="148">Continue</text>
<text x="256" y="148">Request</text>
<text x="304" y="148">(A)</text>
<text x="472" y="164">4</text>
<text x="112" y="180">7</text>
<text x="160" y="180">Not</text>
<text x="192" y="180">Yet</text>
<text x="240" y="180">Granted</text>
<text x="300" y="180">(Wait)</text>
<text x="472" y="180">AuthZ</text>
<text x="472" y="212">5</text>
<text x="472" y="228">Completed</text>
<text x="112" y="260">8</text>
<text x="188" y="260">Continue</text>
<text x="256" y="260">Request</text>
<text x="304" y="260">(B)</text>
<text x="112" y="292">9</text>
<text x="200" y="292">Grant</text>
<text x="252" y="292">Access</text>
<text x="116" y="340">10</text>
<text x="180" y="340">Access</text>
<text x="224" y="340">API</text>
<text x="516" y="340">RS</text>
<text x="360" y="356">|</text>
<text x="432" y="356">|</text>
<text x="116" y="372">11</text>
<text x="168" y="372">API</text>
<text x="220" y="372">Response</text>
</g>
</svg>
</artwork><artwork  type="ascii-art"><![CDATA[
+--------+                                  +--------+          .----.
| Client |                                  |   AS   |         |  RO  |
|Instance+--(1)--- Request Access --------->|        |         |      |
|        |                                  |        |         |      |
|        |<-(2)-- Not Yet Granted (Wait) ---+        |         |      |
|        |                                  |        |<==(3)==>|      |
|        |                                  |        |  AuthN  |      |
|        +--(6)--- Continue Request (A) --->|        |         |      |
|        |                                  |        |<==(4)==>|      |
|        |<-(7)-- Not Yet Granted (Wait) ---+        |  AuthZ  |      |
|        |                                  |        |         |      |
|        |                                  |        |<==(5)==>|      |
|        |                                  |        |Completed|      |
|        |                                  |        |         |      |
|        +--(8)--- Continue Request (B) --->|        |          `----`
|        |                                  |        |
|        |<-(9)------ Grant Access ---------+        |
|        |                                  |        |
|        |                                  |        |     +--------+
|        +--(10)-- Access API ---------------------------->|   RS   |
|        |                                  |        |     |        |
|        |<-(11)-- API Response ---------------------------+        |
|        |                                  |        |     +--------+
+--------+                                  +--------+
]]></artwork></artset></figure>

<t><list style="numbers">
  <t>The client instance <xref target="request">requests access to the resource</xref>. The client instance does not
 send any interaction modes to the server, indicating that
 it does not expect to interact with the RO. The client instance can also signal
 which RO it requires authorization from, if known, by using the
 <xref target="request-subject">subject request</xref> and
 <xref target="request-user">user request</xref> sections. It's also possible for the AS to determine which
 RO needs to be contacted by the nature of what access is being requested.</t>
  <t>The AS determines that interaction is needed, but the client instance cannot interact
 with the RO. The AS <xref target="response">responds</xref> with the information the client instance
 will need to <xref target="response-continue">continue the request</xref> in (6) and (8), including
 a signal that the client instance should wait before checking the status of the request again.
 The AS associates this continuation information with an ongoing request that will be
 referenced in (3), (4), (5), (6), and (8).</t>
  <t>The AS determines which RO to contact based on the request in (1), through a
 combination of the <xref target="request-user">user request</xref>, the
 <xref target="request-subject">subject request</xref>, the
 <xref target="request-token">access request</xref>, and other policy information. The AS
 contacts the RO and authenticates them.</t>
  <t>The RO authorizes the pending request from the client instance.</t>
  <t>When the AS is done interacting with the RO, the AS
 indicates to the RO that the request has been completed.</t>
  <t>Meanwhile, the client instance loads the continuation information stored at (2) and
 <xref target="continue-request">continues the request</xref>. The AS determines which
 ongoing access request is referenced here and checks its state.</t>
  <t>If the access request has not yet been authorized by the RO in (6),
 the AS responds to the client instance to <xref target="response-continue">continue the request</xref>
 at a future time through additional polling. Note that this response is not
 an error message, since no error has yet occurred. This response can include
 refreshed credentials as well as information regarding how long the
 client instance should wait before calling again. The client instance replaces its stored
 continuation information from the previous response (2).
 Note that the AS may need to determine that the RO has not approved
 the request in a sufficient amount of time and return an appropriate
 error to the client instance.</t>
  <t>The client instance continues to <xref target="continue-poll">poll the AS</xref> with the new
 continuation information from (7).</t>
  <t>If the request has been authorized, the AS grants access to the information
 in the form of <xref target="response-token">access tokens</xref> and
 <xref target="response-subject">direct subject information</xref> to the client instance.</t>
  <t>The client instance <xref target="use-access-token">uses the access token</xref> to call the RS.</t>
  <t>The RS validates the access token and returns an appropriate response for the
API.</t>
</list></t>

<t>An example set of protocol messages for this method can be found in <xref target="example-async"/>.</t>

<t>Additional considerations for asynchronous interactions like this are discussed in
<xref target="security-async"/>.</t>

</section>
<section anchor="sequence-no-user"><name>Software-only Authorization</name>

<t>In this example flow, the AS policy allows the client instance to make a call on its own behalf,
without the need for an RO to be involved at runtime to approve the decision.
Since there is no explicit RO, the client instance does not interact with an RO.</t>

<figure title="Figure 7: Diagram of a software-only authorization, with no end user or explicit resource owner"><artset><artwork  type="svg"><svg xmlns="http://www.w3.org/2000/svg" version="1.1" height="208" width="488" viewBox="0 0 488 208" class="diagram" text-anchor="middle" font-family="monospace" font-size="13px" stroke-linecap="round">
<path d="M 8,32 L 8,192" fill="none" stroke="black"/>
<path d="M 80,32 L 80,192" fill="none" stroke="black"/>
<path d="M 312,32 L 312,120" fill="none" stroke="black"/>
<path d="M 312,168 L 312,192" fill="none" stroke="black"/>
<path d="M 384,32 L 384,120" fill="none" stroke="black"/>
<path d="M 384,168 L 384,192" fill="none" stroke="black"/>
<path d="M 408,112 L 408,176" fill="none" stroke="black"/>
<path d="M 480,112 L 480,176" fill="none" stroke="black"/>
<path d="M 8,32 L 80,32" fill="none" stroke="black"/>
<path d="M 312,32 L 384,32" fill="none" stroke="black"/>
<path d="M 80,64 L 104,64" fill="none" stroke="black"/>
<path d="M 120,64 L 144,64" fill="none" stroke="black"/>
<path d="M 280,64 L 304,64" fill="none" stroke="black"/>
<path d="M 88,96 L 104,96" fill="none" stroke="black"/>
<path d="M 120,96 L 152,96" fill="none" stroke="black"/>
<path d="M 272,96 L 312,96" fill="none" stroke="black"/>
<path d="M 408,112 L 480,112" fill="none" stroke="black"/>
<path d="M 80,128 L 104,128" fill="none" stroke="black"/>
<path d="M 120,128 L 144,128" fill="none" stroke="black"/>
<path d="M 248,128 L 400,128" fill="none" stroke="black"/>
<path d="M 88,160 L 104,160" fill="none" stroke="black"/>
<path d="M 120,160 L 144,160" fill="none" stroke="black"/>
<path d="M 264,160 L 408,160" fill="none" stroke="black"/>
<path d="M 408,176 L 480,176" fill="none" stroke="black"/>
<path d="M 8,192 L 80,192" fill="none" stroke="black"/>
<path d="M 312,192 L 384,192" fill="none" stroke="black"/>
<polygon class="arrowhead" points="408,128 396,122.4 396,133.6" fill="black" transform="rotate(0,400,128)"/>
<polygon class="arrowhead" points="312,64 300,58.4 300,69.6" fill="black" transform="rotate(0,304,64)"/>
<polygon class="arrowhead" points="96,160 84,154.4 84,165.6" fill="black" transform="rotate(180,88,160)"/>
<polygon class="arrowhead" points="96,96 84,90.4 84,101.6" fill="black" transform="rotate(180,88,96)"/>
<g class="text">
<text x="44" y="52">Client</text>
<text x="348" y="52">AS</text>
<text x="44" y="68">Instance</text>
<text x="112" y="68">1</text>
<text x="184" y="68">Request</text>
<text x="244" y="68">Access</text>
<text x="112" y="100">2</text>
<text x="184" y="100">Grant</text>
<text x="236" y="100">Access</text>
<text x="112" y="132">3</text>
<text x="180" y="132">Access</text>
<text x="224" y="132">API</text>
<text x="444" y="132">RS</text>
<text x="312" y="148">|</text>
<text x="384" y="148">|</text>
<text x="112" y="164">4</text>
<text x="168" y="164">API</text>
<text x="220" y="164">Response</text>
</g>
</svg>
</artwork><artwork  type="ascii-art"><![CDATA[
+--------+                            +--------+
| Client |                            |   AS   |
|Instance+--(1)--- Request Access --->|        |
|        |                            |        |
|        |<-(2)---- Grant Access -----+        |
|        |                            |        |  +--------+
|        +--(3)--- Access API ------------------->|   RS   |
|        |                            |        |  |        |
|        |<-(4)--- API Response ------------------+        |
|        |                            |        |  +--------+
+--------+                            +--------+
]]></artwork></artset></figure>

<t><list style="numbers">
  <t>The client instance <xref target="request">requests access to the resource</xref>. The client instance does not
 send any interaction modes to the server.</t>
  <t>The AS determines that the request has been authorized based on the identity of
 the client instance making the request and the <xref target="request-token">access requested</xref>.
 The AS grants access to the resource
 in the form of <xref target="response-token">access tokens</xref> to the client instance.
 Note that <xref target="response-subject">direct subject information</xref> is not
 generally applicable in this use case, as there is no user involved.</t>
  <t>The client instance <xref target="use-access-token">uses the access token</xref> to call the RS.</t>
  <t>The RS validates the access token and returns an appropriate response for the
 API.</t>
</list></t>

<t>An example set of protocol messages for this method can be found in <xref target="example-no-user"/>.</t>

</section>
<section anchor="sequence-refresh"><name>Refreshing an Expired Access Token</name>

<t>In this example flow, the client instance receives an access token to access a resource server through
some valid GNAP process. The client instance uses that token at the RS for some time, but eventually
the access token expires. The client instance then gets a refreshed access token by rotating the
expired access token's value at the AS using the token management API.</t>

<figure title="Figure 8: Diagram of the process of refreshing an access token"><artset><artwork  type="svg"><svg xmlns="http://www.w3.org/2000/svg" version="1.1" height="400" width="504" viewBox="0 0 504 400" class="diagram" text-anchor="middle" font-family="monospace" font-size="13px" stroke-linecap="round">
<path d="M 8,32 L 8,384" fill="none" stroke="black"/>
<path d="M 80,32 L 80,384" fill="none" stroke="black"/>
<path d="M 320,128 L 320,288" fill="none" stroke="black"/>
<path d="M 392,128 L 392,288" fill="none" stroke="black"/>
<path d="M 424,32 L 424,384" fill="none" stroke="black"/>
<path d="M 496,32 L 496,384" fill="none" stroke="black"/>
<path d="M 8,32 L 80,32" fill="none" stroke="black"/>
<path d="M 424,32 L 496,32" fill="none" stroke="black"/>
<path d="M 80,64 L 104,64" fill="none" stroke="black"/>
<path d="M 120,64 L 144,64" fill="none" stroke="black"/>
<path d="M 280,64 L 416,64" fill="none" stroke="black"/>
<path d="M 88,96 L 104,96" fill="none" stroke="black"/>
<path d="M 120,96 L 144,96" fill="none" stroke="black"/>
<path d="M 264,96 L 424,96" fill="none" stroke="black"/>
<path d="M 320,128 L 392,128" fill="none" stroke="black"/>
<path d="M 80,144 L 104,144" fill="none" stroke="black"/>
<path d="M 120,144 L 144,144" fill="none" stroke="black"/>
<path d="M 288,144 L 312,144" fill="none" stroke="black"/>
<path d="M 88,176 L 104,176" fill="none" stroke="black"/>
<path d="M 120,176 L 144,176" fill="none" stroke="black"/>
<path d="M 296,176 L 320,176" fill="none" stroke="black"/>
<path d="M 80,240 L 104,240" fill="none" stroke="black"/>
<path d="M 120,240 L 144,240" fill="none" stroke="black"/>
<path d="M 288,240 L 312,240" fill="none" stroke="black"/>
<path d="M 88,272 L 104,272" fill="none" stroke="black"/>
<path d="M 120,272 L 144,272" fill="none" stroke="black"/>
<path d="M 280,272 L 320,272" fill="none" stroke="black"/>
<path d="M 320,288 L 392,288" fill="none" stroke="black"/>
<path d="M 80,320 L 104,320" fill="none" stroke="black"/>
<path d="M 120,320 L 144,320" fill="none" stroke="black"/>
<path d="M 264,320 L 416,320" fill="none" stroke="black"/>
<path d="M 88,352 L 104,352" fill="none" stroke="black"/>
<path d="M 120,352 L 144,352" fill="none" stroke="black"/>
<path d="M 272,352 L 424,352" fill="none" stroke="black"/>
<path d="M 8,384 L 80,384" fill="none" stroke="black"/>
<path d="M 424,384 L 496,384" fill="none" stroke="black"/>
<polygon class="arrowhead" points="424,320 412,314.4 412,325.6" fill="black" transform="rotate(0,416,320)"/>
<polygon class="arrowhead" points="424,64 412,58.4 412,69.6" fill="black" transform="rotate(0,416,64)"/>
<polygon class="arrowhead" points="320,240 308,234.4 308,245.6" fill="black" transform="rotate(0,312,240)"/>
<polygon class="arrowhead" points="320,144 308,138.4 308,149.6" fill="black" transform="rotate(0,312,144)"/>
<polygon class="arrowhead" points="96,352 84,346.4 84,357.6" fill="black" transform="rotate(180,88,352)"/>
<polygon class="arrowhead" points="96,272 84,266.4 84,277.6" fill="black" transform="rotate(180,88,272)"/>
<polygon class="arrowhead" points="96,176 84,170.4 84,181.6" fill="black" transform="rotate(180,88,176)"/>
<polygon class="arrowhead" points="96,96 84,90.4 84,101.6" fill="black" transform="rotate(180,88,96)"/>
<g class="text">
<text x="44" y="52">Client</text>
<text x="460" y="52">AS</text>
<text x="44" y="68">Instance</text>
<text x="112" y="68">1</text>
<text x="184" y="68">Request</text>
<text x="244" y="68">Access</text>
<text x="112" y="100">2</text>
<text x="176" y="100">Grant</text>
<text x="228" y="100">Access</text>
<text x="112" y="148">3</text>
<text x="180" y="148">Access</text>
<text x="244" y="148">Resource</text>
<text x="356" y="148">RS</text>
<text x="112" y="180">4</text>
<text x="184" y="180">Success</text>
<text x="252" y="180">Response</text>
<text x="144" y="212">(</text>
<text x="172" y="212">Time</text>
<text x="220" y="212">Passes</text>
<text x="256" y="212">)</text>
<text x="112" y="244">5</text>
<text x="180" y="244">Access</text>
<text x="244" y="244">Resource</text>
<text x="112" y="276">6</text>
<text x="176" y="276">Error</text>
<text x="236" y="276">Response</text>
<text x="112" y="324">7</text>
<text x="180" y="324">Rotate</text>
<text x="232" y="324">Token</text>
<text x="112" y="356">8</text>
<text x="184" y="356">Rotated</text>
<text x="240" y="356">Token</text>
</g>
</svg>
</artwork><artwork  type="ascii-art"><![CDATA[
+--------+                                          +--------+
| Client |                                          |   AS   |
|Instance+--(1)--- Request Access ----------------->|        |
|        |                                          |        |
|        |<-(2)--- Grant Access --------------------+        |
|        |                                          |        |
|        |                             +--------+   |        |
|        +--(3)--- Access Resource --->|   RS   |   |        |
|        |                             |        |   |        |
|        |<-(4)--- Success Response ---+        |   |        |
|        |                             |        |   |        |
|        |       ( Time Passes )       |        |   |        |
|        |                             |        |   |        |
|        +--(5)--- Access Resource --->|        |   |        |
|        |                             |        |   |        |
|        |<-(6)--- Error Response -----+        |   |        |
|        |                             +--------+   |        |
|        |                                          |        |
|        +--(7)--- Rotate Token ------------------->|        |
|        |                                          |        |
|        |<-(8)--- Rotated Token -------------------+        |
|        |                                          |        |
+--------+                                          +--------+
]]></artwork></artset></figure>

<t><list style="numbers">
  <t>The client instance <xref target="request">requests access to the resource</xref>.</t>
  <t>The AS <xref target="response">grants access to the resource</xref> with an
 <xref target="response-token">access token</xref> usable at the RS. The access token
 response includes a token management URI.</t>
  <t>The client instance <xref target="use-access-token">uses the access token</xref> to call the RS.</t>
  <t>The RS validates the access token and returns an appropriate response for the
 API.</t>
  <t>Time passes and the client instance uses the access token to call the RS again.</t>
  <t>The RS validates the access token and determines that the access token is expired.
 The RS responds to the client instance with an error.</t>
  <t>The client instance calls the token management URI returned in (2) to
 <xref target="rotate-access-token">rotate the access token</xref>. The client instance
 <xref target="use-access-token">uses the access token</xref> in this call as well as the appropriate key,
 see the token rotation section for details.</t>
  <t>The AS validates the rotation request including the signature
 and keys presented in (7) and refreshes the
 <xref target="response-token-single">access token</xref>. The response includes
 a new version of the access token and can also include updated token management
 information, which the client instance will store in place of the values
 returned in (2).</t>
</list></t>

</section>
<section anchor="sequence-user"><name>Requesting Subject Information Only</name>

<t>In this scenario, the client instance does not call an RS and does not
request an access token. Instead, the client instance only requests
and is returned <xref target="response-subject">direct subject information</xref>. Many different
interaction modes can be used in this scenario, so these are shown only in
the abstract as functions of the AS here.</t>

<figure title="Figure 9: Diagram of the process of requesting and releasing subject information apart from access tokens"><artset><artwork  type="svg"><svg xmlns="http://www.w3.org/2000/svg" version="1.1" height="384" width="576" viewBox="0 0 576 384" class="diagram" text-anchor="middle" font-family="monospace" font-size="13px" stroke-linecap="round">
<path d="M 8,32 L 8,368" fill="none" stroke="black"/>
<path d="M 80,32 L 80,368" fill="none" stroke="black"/>
<path d="M 360,32 L 360,128" fill="none" stroke="black"/>
<path d="M 360,160 L 360,256" fill="none" stroke="black"/>
<path d="M 360,288 L 360,368" fill="none" stroke="black"/>
<path d="M 432,32 L 432,128" fill="none" stroke="black"/>
<path d="M 432,160 L 432,256" fill="none" stroke="black"/>
<path d="M 432,288 L 432,368" fill="none" stroke="black"/>
<path d="M 512,48 L 512,272" fill="none" stroke="black"/>
<path d="M 568,48 L 568,272" fill="none" stroke="black"/>
<path d="M 8,32 L 80,32" fill="none" stroke="black"/>
<path d="M 360,32 L 432,32" fill="none" stroke="black"/>
<path d="M 528,32 L 552,32" fill="none" stroke="black"/>
<path d="M 80,80 L 104,80" fill="none" stroke="black"/>
<path d="M 120,80 L 144,80" fill="none" stroke="black"/>
<path d="M 280,80 L 352,80" fill="none" stroke="black"/>
<path d="M 88,112 L 104,112" fill="none" stroke="black"/>
<path d="M 120,112 L 136,112" fill="none" stroke="black"/>
<path d="M 304,112 L 360,112" fill="none" stroke="black"/>
<path d="M 80,142 L 104,142" fill="none" stroke="black"/><path d="M 80,146 L 104,146" fill="none" stroke="black"/>
<path d="M 120,142 L 136,142" fill="none" stroke="black"/><path d="M 120,146 L 136,146" fill="none" stroke="black"/>
<path d="M 336,142 L 504,142" fill="none" stroke="black"/><path d="M 336,146 L 504,146" fill="none" stroke="black"/>
<path d="M 512,160 L 568,160" fill="none" stroke="black"/>
<path d="M 440,174 L 464,174" fill="none" stroke="black"/><path d="M 440,178 L 464,178" fill="none" stroke="black"/>
<path d="M 480,174 L 504,174" fill="none" stroke="black"/><path d="M 480,178 L 504,178" fill="none" stroke="black"/>
<path d="M 440,222 L 464,222" fill="none" stroke="black"/><path d="M 440,226 L 464,226" fill="none" stroke="black"/>
<path d="M 480,222 L 504,222" fill="none" stroke="black"/><path d="M 480,226 L 504,226" fill="none" stroke="black"/>
<path d="M 512,240 L 568,240" fill="none" stroke="black"/>
<path d="M 88,270 L 104,270" fill="none" stroke="black"/><path d="M 88,274 L 104,274" fill="none" stroke="black"/>
<path d="M 120,270 L 136,270" fill="none" stroke="black"/><path d="M 120,274 L 136,274" fill="none" stroke="black"/>
<path d="M 312,270 L 512,270" fill="none" stroke="black"/><path d="M 312,274 L 512,274" fill="none" stroke="black"/>
<path d="M 528,288 L 552,288" fill="none" stroke="black"/>
<path d="M 80,304 L 104,304" fill="none" stroke="black"/>
<path d="M 120,304 L 144,304" fill="none" stroke="black"/>
<path d="M 296,304 L 352,304" fill="none" stroke="black"/>
<path d="M 88,336 L 104,336" fill="none" stroke="black"/>
<path d="M 120,336 L 160,336" fill="none" stroke="black"/>
<path d="M 280,336 L 360,336" fill="none" stroke="black"/>
<path d="M 8,368 L 80,368" fill="none" stroke="black"/>
<path d="M 360,368 L 432,368" fill="none" stroke="black"/>
<path d="M 528,32 C 519.16936,32 512,39.16936 512,48" fill="none" stroke="black"/>
<path d="M 552,32 C 560.83064,32 568,39.16936 568,48" fill="none" stroke="black"/>
<path d="M 528,288 C 519.16936,288 512,280.83064 512,272" fill="none" stroke="black"/>
<path d="M 552,288 C 560.83064,288 568,280.83064 568,272" fill="none" stroke="black"/>
<polygon class="arrowhead" points="512,224 500,218.4 500,229.6" fill="black" transform="rotate(0,504,224)"/>
<polygon class="arrowhead" points="512,176 500,170.4 500,181.6" fill="black" transform="rotate(0,504,176)"/>
<polygon class="arrowhead" points="512,144 500,138.4 500,149.6" fill="black" transform="rotate(0,504,144)"/>
<polygon class="arrowhead" points="448,224 436,218.4 436,229.6" fill="black" transform="rotate(180,440,224)"/>
<polygon class="arrowhead" points="448,176 436,170.4 436,181.6" fill="black" transform="rotate(180,440,176)"/>
<polygon class="arrowhead" points="360,304 348,298.4 348,309.6" fill="black" transform="rotate(0,352,304)"/>
<polygon class="arrowhead" points="360,80 348,74.4 348,85.6" fill="black" transform="rotate(0,352,80)"/>
<polygon class="arrowhead" points="96,336 84,330.4 84,341.6" fill="black" transform="rotate(180,88,336)"/>
<polygon class="arrowhead" points="96,272 84,266.4 84,277.6" fill="black" transform="rotate(180,88,272)"/>
<polygon class="arrowhead" points="96,112 84,106.4 84,117.6" fill="black" transform="rotate(180,88,112)"/>
<g class="text">
<text x="44" y="52">Client</text>
<text x="396" y="52">AS</text>
<text x="536" y="52">End</text>
<text x="44" y="68">Instance</text>
<text x="540" y="68">User</text>
<text x="112" y="84">1</text>
<text x="184" y="84">Request</text>
<text x="244" y="84">Access</text>
<text x="112" y="116">2</text>
<text x="192" y="116">Interaction</text>
<text x="268" y="116">Needed</text>
<text x="112" y="148">3</text>
<text x="188" y="148">Facilitate</text>
<text x="280" y="148">Interaction</text>
<text x="472" y="180">4</text>
<text x="540" y="180">RO</text>
<text x="472" y="196">AuthN</text>
<text x="472" y="228">5</text>
<text x="472" y="244">AuthZ</text>
<text x="536" y="260">End</text>
<text x="112" y="276">6</text>
<text x="172" y="276">Signal</text>
<text x="252" y="276">Continuation</text>
<text x="540" y="276">User</text>
<text x="112" y="308">7</text>
<text x="188" y="308">Continue</text>
<text x="256" y="308">Request</text>
<text x="112" y="340">8</text>
<text x="192" y="340">Grant</text>
<text x="244" y="340">Access</text>
</g>
</svg>
</artwork><artwork  type="ascii-art"><![CDATA[
+--------+                                  +--------+          .----.
| Client |                                  |   AS   |         | End  |
|Instance|                                  |        |         | User |
|        +--(1)--- Request Access --------->|        |         |      |
|        |                                  |        |         |      |
|        |<-(2)-- Interaction Needed -------+        |         |      |
|        |                                  |        |         |      |
|        +==(3)== Facilitate Interaction =====================>|      |
|        |                                  |        |         +------+
|        |                                  |        |<==(4)==>|  RO  |
|        |                                  |        |  AuthN  |      |
|        |                                  |        |         |      |
|        |                                  |        |<==(5)==>|      |
|        |                                  |        |  AuthZ  +------+
|        |                                  |        |         | End  |
|        |<=(6)== Signal Continuation =========================+ User |
|        |                                  |        |          `----`
|        +--(7)--- Continue Request ------->|        |
|        |                                  |        |
|        |<-(8)----- Grant Access ----------+        |
|        |                                  |        |
+--------+                                  +--------+
]]></artwork></artset></figure>

<t><list style="numbers">
  <t>The client instance <xref target="request">requests access to subject information</xref>.</t>
  <t>The AS determines that interaction is needed and <xref target="response">responds</xref> with
 appropriate information for <xref target="response-interact">facilitating user interaction</xref>.</t>
  <t>The client instance facilitates <xref target="authorization">the user interacting with the AS</xref> as directed in (2).</t>
  <t>The user authenticates at the AS, taking on the role of the RO.</t>
  <t>As the RO, the user authorizes the pending request from the client instance.</t>
  <t>When the AS is done interacting with the user, the AS
 returns the user to the client instance and signals continuation.</t>
  <t>The client instance loads the continuation information from (2) and
 calls the AS to <xref target="continue-request">continue the request</xref>.</t>
  <t>If the request has been authorized, the AS grants access to the requested
 <xref target="response-subject">direct subject information</xref> to the client instance.
 At this stage, the user is generally considered "logged in" to the client
 instance based on the identifiers and assertions provided by the AS.
 Note that the AS can restrict the subject information returned and it
 might not match what the client instance requested, see the section on
 subject information for details.</t>
</list></t>

</section>
<section anchor="sequence-cross-user"><name>Cross-User Authentication</name>

<t>In this scenario, the end user and resource owner are two different people.
Here, the client instance already knows who the end user
is, likely through a separate authentication process. The
end user, operating the client instance, needs to get subject information
about another person in the system, the RO. The RO is given an opportunity
to release this information using an asynchronous interaction method
with the AS. This scenario would apply, for instance, when the end user
is an agent in a call-center and the resource owner is a customer
authorizing the call center agent to access their account on their behalf.</t>

<figure title="Figure 10: Diagram of cross-user authorization, where the end user and RO are different"><artset><artwork  type="svg"><svg xmlns="http://www.w3.org/2000/svg" version="1.1" height="480" width="576" viewBox="0 0 576 480" class="diagram" text-anchor="middle" font-family="monospace" font-size="13px" stroke-linecap="round">
<path d="M 8,48 L 8,448" fill="none" stroke="black"/>
<path d="M 64,48 L 64,448" fill="none" stroke="black"/>
<path d="M 136,96 L 136,464" fill="none" stroke="black"/>
<path d="M 208,96 L 208,464" fill="none" stroke="black"/>
<path d="M 360,96 L 360,464" fill="none" stroke="black"/>
<path d="M 432,96 L 432,464" fill="none" stroke="black"/>
<path d="M 512,48 L 512,448" fill="none" stroke="black"/>
<path d="M 568,48 L 568,448" fill="none" stroke="black"/>
<path d="M 24,32 L 48,32" fill="none" stroke="black"/>
<path d="M 528,32 L 552,32" fill="none" stroke="black"/>
<path d="M 72,62 L 216,62" fill="none" stroke="black"/><path d="M 72,66 L 216,66" fill="none" stroke="black"/>
<path d="M 232,62 L 248,62" fill="none" stroke="black"/><path d="M 232,66 L 248,66" fill="none" stroke="black"/>
<path d="M 360,62 L 504,62" fill="none" stroke="black"/><path d="M 360,66 L 504,66" fill="none" stroke="black"/>
<path d="M 136,96 L 208,96" fill="none" stroke="black"/>
<path d="M 360,96 L 432,96" fill="none" stroke="black"/>
<path d="M 64,110 L 88,110" fill="none" stroke="black"/><path d="M 64,114 L 88,114" fill="none" stroke="black"/>
<path d="M 104,110 L 128,110" fill="none" stroke="black"/><path d="M 104,114 L 128,114" fill="none" stroke="black"/>
<path d="M 208,160 L 232,160" fill="none" stroke="black"/>
<path d="M 248,160 L 264,160" fill="none" stroke="black"/>
<path d="M 320,160 L 352,160" fill="none" stroke="black"/>
<path d="M 216,192 L 232,192" fill="none" stroke="black"/>
<path d="M 248,192 L 264,192" fill="none" stroke="black"/>
<path d="M 320,192 L 360,192" fill="none" stroke="black"/>
<path d="M 440,206 L 464,206" fill="none" stroke="black"/><path d="M 440,210 L 464,210" fill="none" stroke="black"/>
<path d="M 480,206 L 504,206" fill="none" stroke="black"/><path d="M 480,210 L 504,210" fill="none" stroke="black"/>
<path d="M 440,254 L 464,254" fill="none" stroke="black"/><path d="M 440,258 L 464,258" fill="none" stroke="black"/>
<path d="M 480,254 L 504,254" fill="none" stroke="black"/><path d="M 480,258 L 504,258" fill="none" stroke="black"/>
<path d="M 440,302 L 464,302" fill="none" stroke="black"/><path d="M 440,306 L 464,306" fill="none" stroke="black"/>
<path d="M 480,302 L 504,302" fill="none" stroke="black"/><path d="M 480,306 L 504,306" fill="none" stroke="black"/>
<path d="M 216,320 L 232,320" fill="none" stroke="black"/>
<path d="M 248,320 L 272,320" fill="none" stroke="black"/>
<path d="M 344,320 L 360,320" fill="none" stroke="black"/>
<path d="M 208,352 L 232,352" fill="none" stroke="black"/>
<path d="M 248,352 L 272,352" fill="none" stroke="black"/>
<path d="M 336,352 L 352,352" fill="none" stroke="black"/>
<path d="M 216,384 L 232,384" fill="none" stroke="black"/>
<path d="M 256,384 L 272,384" fill="none" stroke="black"/>
<path d="M 336,384 L 360,384" fill="none" stroke="black"/>
<path d="M 72,398 L 88,398" fill="none" stroke="black"/><path d="M 72,402 L 88,402" fill="none" stroke="black"/>
<path d="M 112,398 L 136,398" fill="none" stroke="black"/><path d="M 112,402 L 136,402" fill="none" stroke="black"/>
<path d="M 24,464 L 48,464" fill="none" stroke="black"/>
<path d="M 136,464 L 208,464" fill="none" stroke="black"/>
<path d="M 360,464 L 432,464" fill="none" stroke="black"/>
<path d="M 528,464 L 552,464" fill="none" stroke="black"/>
<path d="M 24,32 C 15.16936,32 8,39.16936 8,48" fill="none" stroke="black"/>
<path d="M 48,32 C 56.83064,32 64,39.16936 64,48" fill="none" stroke="black"/>
<path d="M 528,32 C 519.16936,32 512,39.16936 512,48" fill="none" stroke="black"/>
<path d="M 552,32 C 560.83064,32 568,39.16936 568,48" fill="none" stroke="black"/>
<path d="M 24,464 C 15.16936,464 8,456.83064 8,448" fill="none" stroke="black"/>
<path d="M 48,464 C 56.83064,464 64,456.83064 64,448" fill="none" stroke="black"/>
<path d="M 528,464 C 519.16936,464 512,456.83064 512,448" fill="none" stroke="black"/>
<path d="M 552,464 C 560.83064,464 568,456.83064 568,448" fill="none" stroke="black"/>
<polygon class="arrowhead" points="512,304 500,298.4 500,309.6" fill="black" transform="rotate(0,504,304)"/>
<polygon class="arrowhead" points="512,256 500,250.4 500,261.6" fill="black" transform="rotate(0,504,256)"/>
<polygon class="arrowhead" points="512,208 500,202.4 500,213.6" fill="black" transform="rotate(0,504,208)"/>
<polygon class="arrowhead" points="512,64 500,58.4 500,69.6" fill="black" transform="rotate(0,504,64)"/>
<polygon class="arrowhead" points="448,304 436,298.4 436,309.6" fill="black" transform="rotate(180,440,304)"/>
<polygon class="arrowhead" points="448,256 436,250.4 436,261.6" fill="black" transform="rotate(180,440,256)"/>
<polygon class="arrowhead" points="448,208 436,202.4 436,213.6" fill="black" transform="rotate(180,440,208)"/>
<polygon class="arrowhead" points="360,352 348,346.4 348,357.6" fill="black" transform="rotate(0,352,352)"/>
<polygon class="arrowhead" points="360,160 348,154.4 348,165.6" fill="black" transform="rotate(0,352,160)"/>
<polygon class="arrowhead" points="224,384 212,378.4 212,389.6" fill="black" transform="rotate(180,216,384)"/>
<polygon class="arrowhead" points="224,320 212,314.4 212,325.6" fill="black" transform="rotate(180,216,320)"/>
<polygon class="arrowhead" points="224,192 212,186.4 212,197.6" fill="black" transform="rotate(180,216,192)"/>
<polygon class="arrowhead" points="136,112 124,106.4 124,117.6" fill="black" transform="rotate(0,128,112)"/>
<polygon class="arrowhead" points="80,400 68,394.4 68,405.6" fill="black" transform="rotate(180,72,400)"/>
<polygon class="arrowhead" points="80,64 68,58.4 68,69.6" fill="black" transform="rotate(180,72,64)"/>
<g class="text">
<text x="32" y="52">End</text>
<text x="540" y="52">RO</text>
<text x="36" y="68">User</text>
<text x="224" y="68">1</text>
<text x="292" y="68">Identify</text>
<text x="340" y="68">RO</text>
<text x="96" y="116">2</text>
<text x="172" y="116">Client</text>
<text x="396" y="116">AS</text>
<text x="84" y="132">RO</text>
<text x="108" y="132">ID</text>
<text x="172" y="132">Instance</text>
<text x="240" y="164">3</text>
<text x="292" y="164">Req.</text>
<text x="240" y="196">4</text>
<text x="292" y="196">Res.</text>
<text x="472" y="212">5</text>
<text x="472" y="228">AuthN</text>
<text x="472" y="260">6</text>
<text x="472" y="276">AuthZ</text>
<text x="472" y="308">7</text>
<text x="240" y="324">8</text>
<text x="308" y="324">Finish</text>
<text x="472" y="324">Completed</text>
<text x="240" y="356">9</text>
<text x="304" y="356">Cont.</text>
<text x="244" y="388">10</text>
<text x="304" y="388">Subj.</text>
<text x="100" y="404">11</text>
<text x="300" y="404">Info</text>
<text x="100" y="420">Return</text>
<text x="84" y="436">RO</text>
<text x="92" y="452">Info</text>
</g>
</svg>
</artwork><artwork  type="ascii-art"><![CDATA[
 .----.                                                         .----.
| End  |                                                       |  RO  |
| User |<=================(1)== Identify RO ==================>|      |
|      |                                                       |      |
|      |        +--------+                  +--------+         |      |
|      +==(2)==>| Client |                  |   AS   |         |      |
|      | RO ID  |Instance|                  |        |         |      |
|      |        |        |                  |        |         |      |
|      |        |        +--(3)-- Req. ---->|        |         |      |
|      |        |        |                  |        |         |      |
|      |        |        |<-(4)-- Res. -----+        |         |      |
|      |        |        |                  |        |<==(5)==>|      |
|      |        |        |                  |        |  AuthN  |      |
|      |        |        |                  |        |         |      |
|      |        |        |                  |        |<==(6)==>|      |
|      |        |        |                  |        |  AuthZ  |      |
|      |        |        |                  |        |         |      |
|      |        |        |                  |        |<==(7)==>|      |
|      |        |        |<-(8)--- Finish --+        |Completed|      |
|      |        |        |                  |        |         |      |
|      |        |        +--(9)--- Cont. -->|        |         |      |
|      |        |        |                  |        |         |      |
|      |        |        |<-(10)-- Subj. ---+        |         |      |
|      |<=(11)==+        |         Info     |        |         |      |
|      | Return |        |                  |        |         |      |
|      | RO     |        |                  |        |         |      |
|      | Info   |        |                  |        |         |      |
 `----`         +--------+                  +--------+          `----`
]]></artwork></artset></figure>

<t>Precondition: The end user is authenticated to the client instance, and the client
instance has an identifier representing the end user that it can present to the AS.
This identifier should be unique to the particular session with the client instance
and the AS.
The client instance is also known to the AS and allowed to access this
advanced functionality where the information of someone other than
the end user is returned to the client instance.</t>

<t><list style="numbers">
  <t>The RO communicates a human-readable
identifier to the end user, such as an email address or account number. This communication
happens out of band from the protocol, such as over the phone between parties. Note that the
RO is not interacting with the client instance.</t>
  <t>The end user communicates the identifier to the client instance. The means by which the
 identifier is communicated to the client instance is out of scope for this specification.</t>
  <t>The client instance <xref target="request">requests access to subject information</xref>. The request includes
 the RO's identifier in the <xref target="request-subject">subject information request</xref> <spanx style="verb">sub_ids</spanx> field,
 and the end user's identifier in the <xref target="request-user">user information field</xref> of the request.
 The request includes no interaction start methods, since the end user is not expected to
 be the one interacting with the AS. The request does include the
 <xref target="request-interact-callback-push">push based interaction finish method</xref> to allow the AS
 to signal to the client instance when the interaction with the RO has concluded.</t>
  <t>The AS sees that the identifier for the end user and subject being requested are different.
 The AS determines that it can reach out to the RO asynchronously for approval. While it
 is doing so, the AS returns a <xref target="response-continue">continuation response</xref> with a <spanx style="verb">finish</spanx> nonce
 to allow the client instance to continue the grant request after interaction with the RO has concluded.</t>
  <t>The AS contacts the RO and has them authenticate to the system. The means for doing this are
 outside the scope of this specification, but the identity of the RO is known from the subject
 identifier sent in (3).</t>
  <t>The RO is prompted to authorize the end user's request via the client instance. Since the end
 user was identified in (3) via the user field, the AS can show this information to the
 RO during the authorization request.</t>
  <t>The RO completes the authorization with the AS. The AS marks the request as <em>approved</em>.</t>
  <t>The RO pushes the <xref target="interaction-pushback">interaction finish message</xref> to the client instance.
 Note that in the case the RO cannot be reached or the RO denies the request, the AS still sends the interaction
 finish message to the client instance, after which the client instance can negotiate next steps if possible.</t>
  <t>The client instance validates the interaction finish message and
 <xref target="continue-after-interaction">continues the grant request</xref>.</t>
  <t>The AS returns the RO's <xref target="response-subject">subject information</xref> to the client instance.</t>
  <t>The client instance can display or otherwise utilize the RO's user information in its session
with the end user. Note that since the client instance requested different sets of user
information in (3), the client instance does not conflate the end user with the RO.</t>
</list></t>

<t>Additional considerations for asynchronous interactions like this are discussed in
<xref target="security-async"/>.</t>

</section>
</section>
</section>
<section anchor="request"><name>Requesting Access</name>

<t>To start a request, the client instance sends an HTTP POST with a <xref target="RFC8259">JSON</xref> document
to the grant endpoint of the AS. The grant endpoint is a URI that uniquely identifies
the AS to client instances and serves as the identifier for the AS. The document is a JSON object
where each field represents a different aspect of the
client instance's request. Each field is described in detail in a section below.</t>

<dl>
  <dt><spanx style="verb">access_token</spanx> (object / array of objects):</dt>
  <dd>
    <t>Describes the rights and properties associated with the requested access token. <bcp14>REQUIRED</bcp14> if requesting an access token. See <xref target="request-token"/>.</t>
  </dd>
  <dt><spanx style="verb">subject</spanx> (object):</dt>
  <dd>
    <t>Describes the information about the RO that the client instance is requesting to be returned
  directly in the response from the AS. <bcp14>REQUIRED</bcp14> if requesting subject information. See <xref target="request-subject"/>.</t>
  </dd>
  <dt><spanx style="verb">client</spanx> (object / string):</dt>
  <dd>
    <t>Describes the client instance that is making this request, including
  the key that the client instance will use to protect this request and any continuation
  requests at the AS and any user-facing information about the client instance used in
  interactions. <bcp14>REQUIRED</bcp14>. See <xref target="request-client"/>.</t>
  </dd>
  <dt><spanx style="verb">user</spanx> (object / string):</dt>
  <dd>
    <t>Identifies the end user to the AS in a manner that the AS can verify, either directly or
  by interacting with the end user to determine their status as the RO. <bcp14>OPTIONAL</bcp14>. See <xref target="request-user"/>.</t>
  </dd>
  <dt><spanx style="verb">interact</spanx> (object):</dt>
  <dd>
    <t>Describes the modes that the client instance supports for allowing the RO to interact with the
  AS and modes for the client instance to receive updates when interaction is complete. <bcp14>REQUIRED</bcp14> if interaction is supported. See <xref target="request-interact"/>.</t>
  </dd>
</dl>

<t>Additional members of this request object can be defined by extensions using the <xref target="IANA-grant-request">GNAP Grant Request Parameters Registry</xref>.</t>

<t>A non-normative example of a grant request is below:</t>

<figure><sourcecode type="json"><![CDATA[
{
    "access_token": {
        "access": [
            {
                "type": "photo-api",
                "actions": [
                    "read",
                    "write",
                    "dolphin"
                ],
                "locations": [
                    "https://server.example.net/",
                    "https://resource.local/other"
                ],
                "datatypes": [
                    "metadata",
                    "images"
                ]
            },
            "dolphin-metadata"
        ]
    },
    "client": {
      "display": {
        "name": "My Client Display Name",
        "uri": "https://example.net/client"
      },
      "key": {
        "proof": "httpsig",
        "jwk": {
          "kty": "RSA",
          "e": "AQAB",
          "kid": "xyz-1",
          "alg": "RS256",
          "n": "kOB5rR4Jv0GMeL...."
        }
      }
    },
    "interact": {
        "start": ["redirect"],
        "finish": {
            "method": "redirect",
            "uri": "https://client.example.net/return/123455",
            "nonce": "LKLTI25DK82FX4T4QFZC"
        }
    },
    "subject": {
        "sub_id_formats": ["iss_sub", "opaque"],
        "assertion_formats": ["id_token"]
    }
}
]]></sourcecode></figure>

<t>Sending a request to the grant endpoint creates a grant request in the <em>processing</em> state. The AS processes this request to determine whether interaction or authorization are necessary (moving to the <em>pending</em> state), or if access can be granted immediately (moving to the <em>approved</em> state).</t>

<t>The request <bcp14>MUST</bcp14> be sent as a JSON object in the content of the HTTP
POST request with Content-Type <spanx style="verb">application/json</spanx>. A key proofing mechanism <bcp14>MAY</bcp14>
define an alternative content type, as long as the content is formed from
the JSON object. For example, the attached JWS key proofing mechanism (see <xref target="attached-jws"/>) places the JSON object
into the payload of a JWS wrapper, which is in turn sent as the message content.</t>

<section anchor="request-token"><name>Requesting Access to Resources</name>

<t>If the client instance is requesting one or more access tokens for the
purpose of accessing an API, the client instance <bcp14>MUST</bcp14> include an <spanx style="verb">access_token</spanx>
field. This field <bcp14>MUST</bcp14> be an object (for a <xref target="request-token-single">single access token</xref>) or
an array of these objects (for <xref target="request-token-multiple">multiple access tokens</xref>),
as described in the following sections.</t>

<section anchor="request-token-single"><name>Requesting a Single Access Token</name>

<t>To request a single access token, the client instance sends an <spanx style="verb">access_token</spanx> object
composed of the following fields.</t>

<dl>
  <dt><spanx style="verb">access</spanx> (array of objects/strings):</dt>
  <dd>
    <t>Describes the rights that the client instance is requesting for the access token to be
  used at the RS. <bcp14>REQUIRED</bcp14>. See <xref target="resource-access-rights"/>.</t>
  </dd>
  <dt><spanx style="verb">label</spanx> (string):</dt>
  <dd>
    <t>A unique name chosen by the client instance to refer to the resulting access token. The value of this
  field is opaque to the AS.  If this field
  is included in the request, the AS <bcp14>MUST</bcp14> include the same label in the <xref target="response-token">token response</xref>.
  <bcp14>REQUIRED</bcp14> if used as part of a <xref target="request-token-multiple">multiple access token request</xref>,
  <bcp14>OPTIONAL</bcp14> otherwise.</t>
  </dd>
  <dt><spanx style="verb">flags</spanx> (array of strings):</dt>
  <dd>
    <t>A set of flags that indicate desired attributes or behavior to be attached to the access token by the
  AS. <bcp14>OPTIONAL</bcp14>.</t>
  </dd>
</dl>

<t>The values of the <spanx style="verb">flags</spanx> field defined by this specification are as follows:</t>

<dl>
  <dt><spanx style="verb">"bearer"</spanx>:</dt>
  <dd>
    <t>If this flag is included, the access token being requested is a bearer token.
  If this flag is omitted, the access token is bound to the key used
  by the client instance in this request (or that key's most recent rotation)
  and the access token <bcp14>MUST</bcp14> be presented using the same key and proofing method.
  Methods for presenting bound and bearer access tokens are described
  in <xref target="use-access-token"/>. See <xref target="security-bearer-tokens"/> for additional
  considerations on the use of bearer tokens.</t>
  </dd>
</dl>

<t>Flag values <bcp14>MUST NOT</bcp14> be included more than once.</t>

<t>Additional flags can be defined by extensions using the <xref target="IANA-token-flags">GNAP Access Token Flags Registry</xref>.</t>

<t>In the following example, the client instance is requesting access to a complex resource
described by a pair of access request object.</t>

<figure><sourcecode type="json"><![CDATA[
"access_token": {
    "access": [
        {
            "type": "photo-api",
            "actions": [
                "read",
                "write",
                "delete"
            ],
            "locations": [
                "https://server.example.net/",
                "https://resource.local/other"
            ],
            "datatypes": [
                "metadata",
                "images"
            ]
        },
        {
            "type": "walrus-access",
            "actions": [
                "foo",
                "bar"
            ],
            "locations": [
                "https://resource.other/"
            ],
            "datatypes": [
                "data",
                "pictures",
                "walrus whiskers"
            ]
        }
    ],
    "label": "token1-23"
}
]]></sourcecode></figure>

<t>If access is approved, the resulting access token is valid for the described resource.
Since the "bearer" flag is not provided in this example, the token is bound to the client instance's key (or its most recent rotation). The token
is labeled "token1-23". The token response structure is described in <xref target="response-token-single"/>.</t>

</section>
<section anchor="request-token-multiple"><name>Requesting Multiple Access Tokens</name>

<t>To request multiple access tokens to be returned in a single response, the
client instance sends an array of objects as the value of the <spanx style="verb">access_token</spanx>
parameter. Each object <bcp14>MUST</bcp14> conform to the request format for a single
access token request, as specified in
<xref target="request-token-single">requesting a single access token</xref>.
Additionally, each object in the array <bcp14>MUST</bcp14> include the <spanx style="verb">label</spanx> field, and
all values of these fields <bcp14>MUST</bcp14> be unique within the request. If the
client instance does not include a <spanx style="verb">label</spanx> value for any entry in the
array, or the values of the <spanx style="verb">label</spanx> field are not unique within the array,
the AS <bcp14>MUST</bcp14> return an "invalid_request" error (<xref target="response-error"/>).</t>

<t>The following non-normative example shows a request for two
separate access tokens, <spanx style="verb">token1</spanx> and <spanx style="verb">token2</spanx>.</t>

<figure><sourcecode type="json"><![CDATA[
"access_token": [
    {
        "label": "token1",
        "access": [
            {
                "type": "photo-api",
                "actions": [
                    "read",
                    "write",
                    "dolphin"
                ],
                "locations": [
                    "https://server.example.net/",
                    "https://resource.local/other"
                ],
                "datatypes": [
                    "metadata",
                    "images"
                ]
            },
            "dolphin-metadata"
        ]
    },
    {
        "label": "token2",
        "access": [
            {
                "type": "walrus-access",
                "actions": [
                    "foo",
                    "bar"
                ],
                "locations": [
                    "https://resource.other/"
                ],
                "datatypes": [
                    "data",
                    "pictures",
                    "walrus whiskers"
                ]
            }
        ],
        "flags": [ "bearer" ]
    }
]

]]></sourcecode></figure>

<t>All approved access requests are returned in the
<xref target="response-token-multiple">multiple access token response</xref> structure using
the values of the <spanx style="verb">label</spanx> fields in the request.</t>

</section>
</section>
<section anchor="request-subject"><name>Requesting Subject Information</name>

<t>If the client instance is requesting information about the RO from
the AS, it sends a <spanx style="verb">subject</spanx> field as a JSON object. This object <bcp14>MAY</bcp14>
contain the following fields.</t>

<dl>
  <dt><spanx style="verb">sub_id_formats</spanx> (array of strings):</dt>
  <dd>
    <t>An array of subject identifier subject formats
  requested for the RO, as defined by <xref target="I-D.ietf-secevent-subject-identifiers"/>.
  <bcp14>REQUIRED</bcp14> if subject identifiers are requested.</t>
  </dd>
  <dt><spanx style="verb">assertion_formats</spanx> (array of strings):</dt>
  <dd>
    <t>An array of requested assertion formats. Possible values include
  <spanx style="verb">id_token</spanx> for an OpenID Connect ID Token (<xref target="OIDC"/>) and <spanx style="verb">saml2</spanx> for a SAML 2 assertion (<xref target="SAML2"/>). Additional
  assertion formats are defined by the <xref target="IANA-assertion-formats">GNAP Assertion Formats Registry</xref>.
  <bcp14>REQUIRED</bcp14> if assertions are requested.</t>
  </dd>
  <dt><spanx style="verb">sub_ids</spanx> (array of objects):</dt>
  <dd>
    <t>An array of subject identifiers representing the subject for which information
  is being requested. Each object is a subject identifier as defined by
  <xref target="I-D.ietf-secevent-subject-identifiers"/>. All identifiers in the <spanx style="verb">sub_ids</spanx> array <bcp14>MUST</bcp14> identify
  the same subject. If omitted, the AS <bcp14>SHOULD</bcp14> assume
  that subject information requests are about the current user and <bcp14>SHOULD</bcp14>
  require direct interaction or proof of presence before releasing information. <bcp14>OPTIONAL</bcp14>.</t>
  </dd>
</dl>

<t>Additional fields are defined in the <xref target="IANA-subject-request">GNAP Subject Information Request Fields Registry</xref>.</t>

<figure><sourcecode type="json"><![CDATA[
"subject": {
  "sub_id_formats": [ "iss_sub", "opaque" ],
  "assertion_formats": [ "id_token", "saml2" ]
}
]]></sourcecode></figure>

<t>The AS can determine the RO's identity and permission for releasing
this information through <xref target="authorization">interaction with the RO</xref>,
AS policies, or <xref target="request-user">assertions presented by the client instance</xref>. If
this is determined positively, the AS <bcp14>MAY</bcp14> <xref target="response-subject">return the RO's information in its response</xref>
as requested.</t>

<t>Subject identifier types requested by the client instance serve only to identify
the RO in the context of the AS and can't be used as communication
channels by the client instance, as discussed in <xref target="response-subject"/>.</t>

</section>
<section anchor="request-client"><name>Identifying the Client Instance</name>

<t>When sending new grant request to the AS, the client instance <bcp14>MUST</bcp14> identify
itself by including its client information in the <spanx style="verb">client</spanx> field of the request and by signing the
request with its unique key as described in <xref target="binding-keys"/>. Note that once a
grant has been created and is in the <em>pending</em> or <em>accepted</em> states, the AS can
determine which client is associated with the grant by dereferencing the
continuation access token sent in the <xref target="continue-request">continuation request</xref>.
As a consequence, the <spanx style="verb">client</spanx> field is not sent or accepted for continuation requests.</t>

<t>Client information <bcp14>MUST</bcp14> either be sent by value as an object or by reference as a string (see <xref target="request-instance"/>).</t>

<t>When client instance information is sent
by value, the <spanx style="verb">client</spanx> field of the request consists of a JSON
object with the following fields.</t>

<dl>
  <dt><spanx style="verb">key</spanx> (object / string):</dt>
  <dd>
    <t>The public key of the client instance to be used in this request as
  described in <xref target="key-format"/> or a reference to a key as
  described in <xref target="key-reference"/>. <bcp14>REQUIRED</bcp14>.</t>
  </dd>
  <dt><spanx style="verb">class_id</spanx> (string):</dt>
  <dd>
    <t>An identifier string that the AS can use to identify the
  client software comprising this client instance. The contents
  and format of this field are up to the AS. <bcp14>OPTIONAL</bcp14>.</t>
  </dd>
  <dt><spanx style="verb">display</spanx> (object):</dt>
  <dd>
    <t>An object containing additional information that the AS
  <bcp14>MAY</bcp14> display to the RO during interaction, authorization,
  and management. <bcp14>OPTIONAL</bcp14>. (<xref target="request-display"/>)</t>
  </dd>
</dl>

<figure><sourcecode type="json"><![CDATA[
"client": {
    "key": {
        "proof": "httpsig",
        "jwk": {
            "kty": "RSA",
            "e": "AQAB",
            "kid": "xyz-1",
            "alg": "RS256",
            "n": "kOB5rR4Jv0GMeLaY6_It_r3ORwdf8ci_JtffXyaSx8..."
        }
    },
    "class_id": "web-server-1234",
    "display": {
        "name": "My Client Display Name",
        "uri": "https://example.net/client"
    }
}
]]></sourcecode></figure>

<t>Additional fields are defined in the <xref target="IANA-client-instance">GNAP Client Instance Fields Registry</xref>.</t>

<t>Absent additional attestations, profiles, or trust mechanisms, both the <spanx style="verb">display</spanx> and <spanx style="verb">class_id</spanx> fields are self-declarative, presented by the client instance and the AS <bcp14>MUST</bcp14> exercise caution in their interpretation, taking them as a hint but not as absolute truth. The <spanx style="verb">class_id</spanx> field can be used in a variety of ways to help the AS make sense of the particular context in which the client instance is operating. In corporate environments, for example, different levels of trust might apply depending on security policies. This field aims to help the AS adjust its own access decisions for different classes of client software. It is possible to configure a set of values and rules during a pre-registration, and then have the client instances provide them later in runtime as a hint to the AS. In other cases, the client runs with a specific AS in mind, so a single hardcoded value would acceptable (for instance, a set top box with a <spanx style="verb">class_id</spanx> claiming to be "FooBarTV version 4"). While the client instance may not have contacted the AS yet, the value of this <spanx style="verb">class_id</spanx> field can be evaluated by the AS according to a broader context of dynamic use, alongside other related information available elsewhere (for instance, corresponding fields in a certificate). If the AS is not able to interpret or validate the class_id field, it <bcp14>SHOULD</bcp14> return an <spanx style="verb">invalid_client</spanx> error (<xref target="response-error"/>) or interpret the request as if the class_id were not present and not allow the set of privileges associated with the class_id. See additional discussion of client instance impersonation in <xref target="security-impersonation"/>.</t>

<t>The client instance <bcp14>MUST</bcp14> prove possession of any presented key by the <spanx style="verb">proof</spanx> mechanism
associated with the key in the request. Key proofing methods
are defined in the <xref target="IANA-key-proof-methods">GNAP Key Proofing Methods Registry</xref> and an initial set of methods
is described in <xref target="binding-keys"/>.</t>

<t>If the same public key is sent by value on different access requests, the AS <bcp14>MUST</bcp14>
treat these requests as coming from the same client instance for purposes
of identification, authentication, and policy application.
If the AS does not know the client instance's public key ahead of time, the AS
<bcp14>MAY</bcp14> accept or reject the request based on attestations
within the <spanx style="verb">client</spanx> request and other AS policy mechanisms.</t>

<t>The client instance <bcp14>MUST NOT</bcp14> send a symmetric key by value in the request, as doing so would expose
the key directly instead of simply proving possession of it. See considerations on symmetric keys
in <xref target="security-symmetric"/>.</t>

<t>The client instance's key <bcp14>MAY</bcp14> be pre-registered with the AS ahead of time and associated
with a set of policies and allowable actions pertaining to that client. If this pre-registration
includes other fields that can occur in the <spanx style="verb">client</spanx> request object described in this section,
such as <spanx style="verb">class_id</spanx> or <spanx style="verb">display</spanx>, the pre-registered values <bcp14>MUST</bcp14> take precedence over any values
given at runtime. Additional fields sent during a request but not present in a pre-registered
client instance record at the AS <bcp14>SHOULD NOT</bcp14> be added to the client's pre-registered record.
See additional considerations regarding client instance impersonation in <xref target="security-impersonation"/>.</t>

<t>A client instance that is capable of talking to multiple AS's <bcp14>SHOULD</bcp14> use a different key for each
AS to prevent a class of mix-up attacks as described in <xref target="security-cuckoo"/> unless other mechanisms
can be used to assure the identity of the AS for a given request.</t>

<section anchor="request-instance"><name>Identifying the Client Instance by Reference</name>

<t>If the client instance has an instance identifier that the AS can use to determine
appropriate key information, the client instance can send this instance
identifier as a direct reference value in lieu of the <spanx style="verb">client</spanx> object.
The instance identifier <bcp14>MAY</bcp14> be assigned to a client instance at runtime
through a grant response (<xref target="response-dynamic-handles"/>) or <bcp14>MAY</bcp14> be obtained in another fashion,
such as a static registration process at the AS.</t>

<figure><sourcecode type="json"><![CDATA[
"client": "client-541-ab"
]]></sourcecode></figure>

<t>When the AS receives a request with an instance identifier, the AS <bcp14>MUST</bcp14>
ensure that the key used to <xref target="binding-keys">sign the request</xref> is
associated with the instance identifier.</t>

<t>If the AS does not recognize the instance identifier, the request <bcp14>MUST</bcp14> be rejected
with an <spanx style="verb">invalid_client</spanx> error (<xref target="response-error"/>).</t>

<t>If the client instance is identified in this manner, the registered key for the client instance
<bcp14>MAY</bcp14> be a symmetric key known to the AS. See considerations on symmetric keys
in <xref target="security-symmetric"/>.</t>

</section>
<section anchor="request-display"><name>Providing Displayable Client Instance Information</name>

<t>If the client instance has additional information to display to the RO
during any interactions at the AS, it <bcp14>MAY</bcp14> send that information in the
"display" field. This field is a JSON object that declares information
to present to the RO during any interactive sequences.</t>

<dl>
  <dt><spanx style="verb">name</spanx> (string):</dt>
  <dd>
    <t>Display name of the client software. <bcp14>RECOMMENDED</bcp14>.</t>
  </dd>
  <dt><spanx style="verb">uri</spanx> (string):</dt>
  <dd>
    <t>User-facing information about the client software, such as a web page. This URI <bcp14>MUST</bcp14> be an absolute URI. <bcp14>OPTIONAL</bcp14>.</t>
  </dd>
  <dt><spanx style="verb">logo_uri</spanx> (string)</dt>
  <dd>
    <t>Display image to represent the client software. This URI <bcp14>MUST</bcp14> be an absolute URI. The logo <bcp14>MAY</bcp14> be passed by value by using a data: URI <xref target="RFC2397"/> referencing an image mediatype. <bcp14>OPTIONAL</bcp14>.</t>
  </dd>
</dl>

<figure><sourcecode type="json"><![CDATA[
"display": {
    "name": "My Client Display Name",
    "uri": "https://example.net/client",
    "logo_uri": "data:image/png;base64,Eeww...="
}
]]></sourcecode></figure>

<t>Additional display fields are defined by the <xref target="IANA-client-instance-display">GNAP Client Instance Display Fields Registry</xref>.</t>

<t>The AS <bcp14>SHOULD</bcp14> use these values during interaction with the RO.
The values are for informational purposes only and <bcp14>MUST NOT</bcp14>
be taken as authentic proof of the client instance's identity or source.
The AS <bcp14>MAY</bcp14> restrict display values to specific client instances, as identified
by their keys in <xref target="request-client"/>. See additional considerations for displayed
client information in <xref target="security-impersonation"/> and for the <spanx style="verb">logo_uri</spanx> in
particular in <xref target="security-client-hosted-logo"/>.</t>

</section>
<section anchor="request-key-authenticate"><name>Authenticating the Client Instance</name>

<t>If the presented key is known to the AS and is associated with a single instance
of the client software, the process of presenting a key and proving possession of that key
is sufficient to authenticate the client instance to the AS. The AS <bcp14>MAY</bcp14> associate policies
with the client instance identified by this key, such as limiting which resources
can be requested and which interaction methods can be used. For example, only
specific client instances with certain known keys might be trusted with access tokens without the
AS interacting directly with the RO as in <xref target="example-no-user"/>.</t>

<t>The presentation of a key allows the AS to strongly associate multiple
successive requests from the same client instance with each other. This
is true when the AS knows the key ahead of time and can use the key to
authenticate the client instance, but also if the key is
ephemeral and created just for this series of requests. As such the
AS <bcp14>MAY</bcp14> allow for client instances to make requests with unknown keys. This pattern allows
for ephemeral client instances, such as single-page applications, and client software with many individual long-lived instances,
such as mobile applications, to generate key pairs per instance and use the keys within
the protocol without having to go through a separate registration step.
The AS <bcp14>MAY</bcp14> limit which capabilities are made available to client instances
with unknown keys. For example, the AS could have a policy saying that only
previously-registered client instances can request particular resources, or that all
client instances with unknown keys have to be interactively approved by an RO.</t>

</section>
</section>
<section anchor="request-user"><name>Identifying the User</name>

<t>If the client instance knows the identity of the end user through one or more
identifiers or assertions, the client instance <bcp14>MAY</bcp14> send that information to the
AS in the "user" field. The client instance <bcp14>MAY</bcp14> pass this information by value
or by reference (See <xref target="request-user-reference"/>).</t>

<dl>
  <dt><spanx style="verb">sub_ids</spanx> (array of objects):</dt>
  <dd>
    <t>An array of subject identifiers for the
  end user, as defined by <xref target="I-D.ietf-secevent-subject-identifiers"/>.
  <bcp14>OPTIONAL</bcp14>.</t>
  </dd>
  <dt><spanx style="verb">assertions</spanx> (array of objects)</dt>
  <dd>
    <t>An array containing assertions as objects each containing the assertion
  format and the assertion value as the JSON string serialization of the assertion,
  as defined in <xref target="response-subject"/>.
  <bcp14>OPTIONAL</bcp14>.</t>
  </dd>
</dl>

<figure><sourcecode type="json"><![CDATA[
"user": {
  "sub_ids": [ {
    "format": "opaque",
    "id": "J2G8G8O4AZ"
  } ],
  "assertions": [ {
    "format": "id_token",
    "value": "eyj..."
  } ]
}

]]></sourcecode></figure>

<t>Subject identifiers are hints to the AS in determining the
RO and <bcp14>MUST NOT</bcp14> be taken as authoritative statements that a particular
RO is present at the client instance and acting as the end user.</t>

<t>Assertions presented by the client instance <bcp14>SHOULD</bcp14> be validated by the AS. While the details of
such validation are outside the scope of this specification, common validation steps include
verifying the signature of the assertion against a trusted signing key, verifying the audience
and issuer of the assertion map to expected values, and verifying the time window for the
assertion itself. However, note that in many use cases, some of these common steps are relaxed.
For example, an AS acting as an identity provider (IdP) could expect that assertions being presented using this
mechanism were issued by the AS to the client software. The AS would verify that the AS is the
issuer of the assertion, not the audience, and that the client instance is instead the audience of
the assertion. Similarly, an AS might accept a recently-expired assertion in order to help
bootstrap a new session with a specific end user.</t>

<t>If the identified end user does not match the RO present at the AS
during an interaction step, and the AS is not explicitly allowing a cross-user
authorization, the AS <bcp14>SHOULD</bcp14> reject the request with an <spanx style="verb">unknown_user</spanx> error  (<xref target="response-error"/>).</t>

<t>If the AS trusts the client instance to present verifiable assertions or known subject identifiers,
such as an opaque identifier issued by the AS for this specific client instance, the AS <bcp14>MAY</bcp14>
decide, based on its policy, to skip interaction with the RO, even
if the client instance provides one or more interaction modes in its request.</t>

<t>See <xref target="security-assertions"/> for considerations that the AS has to make when accepting and
processing assertions from the client instance.</t>

<section anchor="request-user-reference"><name>Identifying the User by Reference</name>

<t>The AS can identify the current end user to the client instance with a reference
which can be used by the client instance to refer to the end user across
multiple requests.
If the client instance has a reference for the end user at this AS, the
client instance <bcp14>MAY</bcp14> pass that reference as a string. The format of this string
is opaque to the client instance.</t>

<figure><sourcecode type="json"><![CDATA[
"user": "XUT2MFM1XBIKJKSDU8QM"
]]></sourcecode></figure>

<t>One means of dynamically obtaining such a user reference is from the AS returning
an <spanx style="verb">opaque</spanx> subject identifier as described in <xref target="response-subject"/>.
Other means of configuring a client instance with a user identifier are out
of scope of this specification.
The lifetime and validity of these user references is determined by the AS and
this lifetime is not exposed to the client instance in GNAP. As such, a client instance
using such a user reference is likely to keep using that reference until such a time as
it stops working.</t>

<t>User reference identifiers are not intended to be human-readable
user identifiers or structured assertions. For the client instance to send
either of these, the client can use the full <xref target="request-user">user request object</xref> instead.</t>

<t>If the AS does not recognize the user reference, it <bcp14>MUST</bcp14>
return an <spanx style="verb">unknown_user</spanx> error (<xref target="response-error"/>).</t>

</section>
</section>
<section anchor="request-interact"><name>Interacting with the User</name>

<t>Often, the AS will require <xref target="authorization">interaction with the RO</xref> in order to
approve a requested delegation to the client instance for both access to resources and direct
subject information. Many times the end user using the client instance is the same person as
the RO, and the client instance can directly drive interaction with the end user by facilitating
the process through means such as redirection to a URI or launching an application. Other times, the
client instance can provide information to start the RO's interaction on a secondary
device, or the client instance will wait for the RO to approve the request asynchronously.
The client instance could also be signaled that interaction has concluded through a
callback mechanism.</t>

<t>The client instance declares the parameters for interaction methods that it can support
using the <spanx style="verb">interact</spanx> field.</t>

<t>The <spanx style="verb">interact</spanx> field is a JSON object with three keys whose values declare how the client can initiate
and complete the request, as well as provide hints to the AS about user preferences such as locale.
A client instance <bcp14>MUST NOT</bcp14> declare an interaction mode it does not support.
The client instance <bcp14>MAY</bcp14> send multiple modes in the same request.
There is no preference order specified in this request. An AS <bcp14>MAY</bcp14>
<xref target="response-interact">respond to any, all, or none of the presented interaction modes</xref> in a request, depending on
its capabilities and what is allowed to fulfill the request.</t>

<dl>
  <dt><spanx style="verb">start</spanx> (array of objects/strings):</dt>
  <dd>
    <t>Indicates how the client instance can start an interaction. <bcp14>REQUIRED</bcp14>. (<xref target="request-interact-start"/>)</t>
  </dd>
  <dt><spanx style="verb">finish</spanx> (object):</dt>
  <dd>
    <t>Indicates how the client instance can receive an indication that interaction has finished at the AS. <bcp14>OPTIONAL</bcp14>. (<xref target="request-interact-finish"/>)</t>
  </dd>
  <dt><spanx style="verb">hints</spanx> (object):</dt>
  <dd>
    <t>Provides additional information to inform the interaction process at the AS. <bcp14>OPTIONAL</bcp14>. (<xref target="request-interact-hint"/>)</t>
  </dd>
</dl>

<t>In this non-normative example, the client instance is indicating that it can <xref target="request-interact-redirect">redirect</xref>
the end user to an arbitrary URI and can receive a <xref target="request-interact-callback-redirect">redirect</xref> through
a browser request. Note that the client instance does not accept a push-style callback.
The pattern of using a redirect for both interaction start and finish is common for web-based client software.</t>

<figure><sourcecode type="json"><![CDATA[
"interact": {
    "start": ["redirect"],
    "finish": {
        "method": "redirect",
        "uri": "https://client.example.net/return/123455",
        "nonce": "LKLTI25DK82FX4T4QFZC"
    }
}
]]></sourcecode></figure>

<t>In this non-normative example, the client instance is indicating that it can
display a <xref target="request-interact-usercode">user code</xref> and direct the end user
to an <xref target="request-interact-redirect">arbitrary URI</xref>, but it cannot accept a redirect or push callback.
This pattern is common for devices with robust display capabilities but that expect
the use of a secondary device to facilitate end-user interaction with the AS, such
as a set-top box capable of displaying an interaction URL as a QR code.</t>

<figure><sourcecode type="json"><![CDATA[
"interact": {
    "start": ["redirect", "user_code"]
}
]]></sourcecode></figure>

<t>In this non-normative example, the client instance is indicating that it can
not start any interaction with the end-user, but that the AS can
<xref target="request-interact-callback-push">push an interaction finish message</xref> when
authorization from the RO is received asynchronously. This pattern is
common for scenarios where a service needs to be authorized, but the RO is
able to be contacted separately from the GNAP transaction itself, such as through a push
notification or existing interactive session on a secondary device.</t>

<figure><sourcecode type="json"><![CDATA[
"interact": {
    "start": [],
    "finish": {
        "method": "push",
        "uri": "https://client.example.net/return/123455",
        "nonce": "LKLTI25DK82FX4T4QFZC"
    }
}
]]></sourcecode></figure>

<t>If the client instance does not provide a suitable interaction mechanism, the
AS cannot contact the RO asynchronously, and the AS determines
that interaction is required, then the AS <bcp14>MUST</bcp14> return an <spanx style="verb">invalid_interaction</spanx>
error (<xref target="response-error"/>) since the client instance will be unable to complete the
request without authorization.</t>

<section anchor="request-interact-start"><name>Start Mode Definitions</name>

<t>If the client instance is capable of starting interaction with the end user, the client instance
indicates this by sending an array of start modes under the <spanx style="verb">start</spanx> key.
Each interaction start modes has a unique identifying name.
Interaction start modes are specified in the array either by a string, which consists of the start
mode name on its own, or by a JSON object with the required field <spanx style="verb">mode</spanx>:</t>

<dl>
  <dt><spanx style="verb">mode</spanx>:</dt>
  <dd>
    <t>The interaction start mode. <bcp14>REQUIRED</bcp14>.</t>
  </dd>
</dl>

<t>Interaction start modes defined as objects <bcp14>MAY</bcp14> define additional parameters to be required in the object.</t>

<t>The <spanx style="verb">start</spanx> array can contain both string-type and object-type modes.</t>

<t>This specification defines the following interaction start modes:</t>

<dl>
  <dt><spanx style="verb">"redirect"</spanx> (string):</dt>
  <dd>
    <t>Indicates that the client instance can direct the end user to an arbitrary URI
  for interaction. <xref target="request-interact-redirect"/></t>
  </dd>
  <dt><spanx style="verb">"app"</spanx> (string):</dt>
  <dd>
    <t>Indicates that the client instance can launch an application on the end user's
  device for interaction. <xref target="request-interact-app"/></t>
  </dd>
  <dt><spanx style="verb">"user_code"</spanx> (string):</dt>
  <dd>
    <t>Indicates that the client instance can communicate a human-readable short
  code to the end user for use with a stable URI. <xref target="request-interact-usercode"/></t>
  </dd>
  <dt><spanx style="verb">"user_code_uri"</spanx> (string):</dt>
  <dd>
    <t>Indicates that the client instance can communicate a human-readable short
  code to the end user for use with a short, dynamic URI. <xref target="request-interact-usercodeuri"/></t>
  </dd>
</dl>

<t>Additional start modes are defined in the <xref target="IANA-interaction-start-modes">GNAP Interaction Start Modes Registry</xref>.</t>

<section anchor="request-interact-redirect"><name>Redirect to an Arbitrary URI</name>

<t>If the client instance is capable of directing the end user to a URI defined
by the AS at runtime, the client instance indicates this by including
<spanx style="verb">redirect</spanx> in the array under the <spanx style="verb">start</spanx> key. The means by which
the client instance will activate this URI is out of scope of this
specification, but common methods include an HTTP redirect,
launching a browser on the end user's device, providing a scannable
image encoding, and printing out a URI to an interactive
console. While this URI is generally hosted at the AS, the client
instance can make no assumptions about its contents, composition,
or relationship to the grant endpoint URI.</t>

<figure><sourcecode type="json"><![CDATA[
"interact": {
  "start": ["redirect"]
}
]]></sourcecode></figure>

<t>If this interaction mode is supported for this client instance and
request, the AS returns a redirect interaction response <xref target="response-interact-redirect"/>.
The client instance manages this interaction method as described in <xref target="interaction-redirect"/>.</t>

<t>See <xref target="security-front-channel"/> for more considerations regarding the use of front-channel
communication techniques.</t>

</section>
<section anchor="request-interact-app"><name>Open an Application-specific URI</name>

<t>If the client instance can open a URI associated with an application on
the end user's device, the client instance indicates this by including <spanx style="verb">app</spanx>
in the array under the <spanx style="verb">start</spanx> key. The means by which the client instance
determines the application to open with this URI are out of scope of
this specification.</t>

<figure><sourcecode type="json"><![CDATA[
"interact": {
  "start": ["app"]
}
]]></sourcecode></figure>

<t>If this interaction mode is supported for this client instance and
request, the AS returns an app interaction response with an app URI
payload (<xref target="response-interact-app"/>). The client instance manages
this interaction method as described in <xref target="interaction-app"/>.</t>

</section>
<section anchor="request-interact-usercode"><name>Display a Short User Code</name>

<t>If the client instance is capable of displaying or otherwise communicating
a short, human-entered code to the RO, the client instance indicates this
by including <spanx style="verb">user_code</spanx> in the array under the <spanx style="verb">start</spanx> key. This
code is to be entered at a static URI that does not change at
runtime. The client instance has no reasonable means to communicate a dynamic
URI to the RO, and so this URI is usually communicated out of band to the
RO through documentation or other messaging outside of GNAP.
While this URI is generally hosted at the AS, the client
instance can make no assumptions about its contents, composition,
or relationship to the grant endpoint URI.</t>

<figure><sourcecode type="json"><![CDATA[
"interact": {
    "start": ["user_code"]
}
]]></sourcecode></figure>

<t>If this interaction mode is supported for this client instance and
request, the AS returns a user code as specified
in <xref target="response-interact-usercode"/>. The client instance manages this interaction
method as described in <xref target="interaction-usercode"/>.</t>

</section>
<section anchor="request-interact-usercodeuri"><name>Display a Short User Code and URI</name>

<t>If the client instance is capable of displaying or otherwise communicating
a short, human-entered code along with a short, human-entered URI to the RO,
the client instance indicates this
by including <spanx style="verb">user_code_uri</spanx> in the array under the <spanx style="verb">start</spanx> key. This
code is to be entered at the dynamic URL given in the response.
While this URL is generally hosted at the AS, the client
instance can make no assumptions about its contents, composition,
or relationship to the grant endpoint URI.</t>

<figure><sourcecode type="json"><![CDATA[
"interact": {
    "start": ["user_code_uri"]
}
]]></sourcecode></figure>

<t>If this interaction mode is supported for this client instance and
request, the AS returns a user code and interaction URL as specified
in <xref target="response-interact-usercodeuri"/>. The client instance manages this interaction
method as described in <xref target="interaction-usercodeuri"/>.</t>

</section>
</section>
<section anchor="request-interact-finish"><name>Interaction Finish Methods</name>

<t>If the client instance is capable of receiving a message from the AS indicating
that the RO has completed their interaction, the client instance
indicates this by sending the following members of an object under the <spanx style="verb">finish</spanx> key.</t>

<dl>
  <dt><spanx style="verb">method</spanx> (string):</dt>
  <dd>
    <t>The callback method that the AS will use to contact the client instance.
  <bcp14>REQUIRED</bcp14>.</t>
  </dd>
  <dt><spanx style="verb">uri</spanx> (string):</dt>
  <dd>
    <t>Indicates the URI that the AS will either send the RO to
  after interaction or send an HTTP POST request. This URI <bcp14>MAY</bcp14> be unique per request and <bcp14>MUST</bcp14>
  be hosted by or accessible by the client instance. This URI <bcp14>MUST</bcp14> be an absolute
  URI, and <bcp14>MUST NOT</bcp14> contain
  any fragment component. If the client instance needs any
  state information to tie to the front channel interaction
  response, it <bcp14>MUST</bcp14> use a unique callback URI to link to
  that ongoing state. The allowable URIs and URI patterns <bcp14>MAY</bcp14> be restricted by the AS
  based on the client instance's presented key information. The callback URI
  <bcp14>SHOULD</bcp14> be presented to the RO during the interaction phase
  before redirect. <bcp14>REQUIRED</bcp14> for <spanx style="verb">redirect</spanx> and <spanx style="verb">push</spanx> methods.</t>
  </dd>
  <dt><spanx style="verb">nonce</spanx> (string):</dt>
  <dd>
    <t>Unique ASCII string value to be used in the
  calculation of the "hash" query parameter sent to the callback URI,
  must be sufficiently random to be unguessable by an attacker.
  <bcp14>MUST</bcp14> be generated by the client instance as a unique value for this
  request. <bcp14>REQUIRED</bcp14>.</t>
  </dd>
  <dt><spanx style="verb">hash_method</spanx> (string):</dt>
  <dd>
    <t>An identifier of a hash calculation mechanism to be used for the callback hash in <xref target="interaction-hash"/>,
  as defined in the <xref target="HASH-ALG">IANA Named Information Hash Algorithm Registry</xref>.
  If absent, the default value is <spanx style="verb">sha-256</spanx>. <bcp14>OPTIONAL</bcp14>.</t>
  </dd>
</dl>

<t>This specification defines the following values for the <spanx style="verb">method</spanx> parameter,
with other values defined by the <xref target="IANA-interaction-finish-methods">GNAP Interaction Finish Methods Registry</xref>:</t>

<dl>
  <dt><spanx style="verb">"redirect"</spanx>:</dt>
  <dd>
    <t>Indicates that the client instance can receive a redirect from the end user's device
  after interaction with the RO has concluded. <xref target="request-interact-callback-redirect"/></t>
  </dd>
  <dt><spanx style="verb">"push"</spanx>:</dt>
  <dd>
    <t>Indicates that the client instance can receive an HTTP POST request from the AS
  after interaction with the RO has concluded. <xref target="request-interact-callback-push"/></t>
  </dd>
</dl>

<t>If interaction finishing is supported for this client instance and
request, the AS will <xref target="response-interact-finish">return a nonce</xref> used by the client
instance to validate the callback.
All interaction finish methods <bcp14>MUST</bcp14> use this nonce to allow the client to verify the connection
between the pending interaction request and the callback. GNAP does this through the use of the
interaction hash, defined in <xref target="interaction-hash"/>.
All requests to the callback URI <bcp14>MUST</bcp14> be processed as described in
<xref target="interaction-finish"/>.</t>

<t>All interaction finish methods <bcp14>MUST</bcp14> require presentation of an interaction reference for continuing
this grant request. This means that the interaction
reference <bcp14>MUST</bcp14> be returned by the AS and <bcp14>MUST</bcp14> be presented by the client as described in
<xref target="continue-after-interaction"/>. The means by which the interaction reference is returned to the
client instance is specific to the interaction finish method.</t>

<section anchor="request-interact-callback-redirect"><name>Receive an HTTP Callback Through the Browser</name>

<t>A finish <spanx style="verb">method</spanx> value of <spanx style="verb">redirect</spanx> indicates that the client instance
will expect a request from the RO's browser using the HTTP method
GET as described in <xref target="interaction-callback"/>.</t>

<t>The client instance's URI <bcp14>MUST</bcp14> be protected by HTTPS, be
hosted on a server local to the RO's browser ("localhost"), or
use an application-specific URI scheme that is loaded on the
end user's device.</t>

<figure><sourcecode type="json"><![CDATA[
"interact": {
    "finish": {
        "method": "redirect",
        "uri": "https://client.example.net/return/123455",
        "nonce": "LKLTI25DK82FX4T4QFZC"
    }
}
]]></sourcecode></figure>

<t>Requests to the callback URI <bcp14>MUST</bcp14> be processed by the client instance as described in
<xref target="interaction-callback"/>.</t>

<t>Since the incoming request to the callback URI is from the RO's
browser, this method is usually used when the RO and end user are the
same entity. See <xref target="security-sessions"/> for considerations on ensuring the incoming HTTP message
matches the expected context of the request.
See <xref target="security-front-channel"/> for more considerations regarding the use of front-channel
communication techniques.</t>

</section>
<section anchor="request-interact-callback-push"><name>Receive an HTTP Direct Callback</name>

<t>A finish <spanx style="verb">method</spanx> value of <spanx style="verb">push</spanx> indicates that the client instance will
expect a request from the AS directly using the HTTP method POST
as described in <xref target="interaction-pushback"/>.</t>

<t>The client instance's URI <bcp14>MUST</bcp14> be protected by HTTPS, be
hosted on a server local to the RO's browser ("localhost"), or
use an application-specific URI scheme that is loaded on the end user's device.</t>

<figure><sourcecode type="json"><![CDATA[
"interact": {
    "finish": {
        "method": "push",
        "uri": "https://client.example.net/return/123455",
        "nonce": "LKLTI25DK82FX4T4QFZC"
    }
}
]]></sourcecode></figure>

<t>Requests to the callback URI <bcp14>MUST</bcp14> be processed by the client instance as described in
<xref target="interaction-pushback"/>.</t>

<t>Since the incoming request to the callback URI is from the AS and
not from the RO's browser, this request is not expected to have any shared
session information from the start method. See <xref target="security-sessions"/> and <xref target="security-polling"/> for
more considerations regarding the use of back-channel and polling mechanisms like this.</t>

</section>
</section>
<section anchor="request-interact-hint"><name>Hints</name>

<t>The <spanx style="verb">hints</spanx> key is an object describing one or more suggestions from the client
instance that the AS can use to help drive user interaction.</t>

<t>This specification defines the following properties under the <spanx style="verb">hints</spanx> key:</t>

<dl>
  <dt><spanx style="verb">ui_locales</spanx> (array of strings):</dt>
  <dd>
    <t>Indicates the end user's preferred locales that the AS can use
  during interaction, particularly before the RO has
  authenticated. <bcp14>OPTIONAL</bcp14>. <xref target="request-interact-locale"/></t>
  </dd>
</dl>

<t>The following sections detail requests for interaction
hints. Additional interaction hints are defined in
the <xref target="IANA-interaction-hints">GNAP Interaction Hints Registry</xref>.</t>

<section anchor="request-interact-locale"><name>Indicate Desired Interaction Locales</name>

<t>If the client instance knows the end user's locale and language preferences, the
client instance can send this information to the AS using the <spanx style="verb">ui_locales</spanx> field
with an array of locale strings as defined by <xref target="RFC5646"/>.</t>

<figure><sourcecode type="json"><![CDATA[
"interact": {
    "hints": {
        "ui_locales": ["en-US", "fr-CA"]
    }
}
]]></sourcecode></figure>

<t>If possible, the AS <bcp14>SHOULD</bcp14> use one of the locales in the array, with
preference to the first item in the array supported by the AS. If none
of the given locales are supported, the AS <bcp14>MAY</bcp14> use a default locale.</t>

</section>
</section>
</section>
</section>
<section anchor="response"><name>Grant Response</name>

<t>In response to a client instance's request, the AS responds with a JSON object
as the HTTP content. Each possible field is detailed in the sections below.</t>

<dl>
  <dt><spanx style="verb">continue</spanx> (object):</dt>
  <dd>
    <t>Indicates that the client instance can continue the request by making one or
  more continuation requests. <bcp14>REQUIRED</bcp14> if continuation calls are allowed for this client instance on this grant request. See <xref target="response-continue"/>.</t>
  </dd>
  <dt><spanx style="verb">access_token</spanx> (object / array of objects):</dt>
  <dd>
    <t>A single access token or set of access tokens that the client instance can use to call the RS on
  behalf of the RO. <bcp14>REQUIRED</bcp14> if an access token is included. See <xref target="response-token"/>.</t>
  </dd>
  <dt><spanx style="verb">interact</spanx> (object):</dt>
  <dd>
    <t>Indicates that interaction through some set of defined mechanisms
  needs to take place. <bcp14>REQUIRED</bcp14> if interaction is expected. See <xref target="response-interact"/>.</t>
  </dd>
  <dt><spanx style="verb">subject</spanx> (object):</dt>
  <dd>
    <t>Claims about the RO as known and declared by the AS. <bcp14>REQUIRED</bcp14> if subject information is included. See <xref target="response-subject"/>.</t>
  </dd>
  <dt><spanx style="verb">instance_id</spanx> (string):</dt>
  <dd>
    <t>An identifier this client instance can use to identify itself when making
  future requests. <bcp14>OPTIONAL</bcp14>. See <xref target="response-dynamic-handles"/>.</t>
  </dd>
  <dt><spanx style="verb">error</spanx> (object or string):</dt>
  <dd>
    <t>An error code indicating that something has gone wrong. <bcp14>REQUIRED</bcp14> for an error condition. See <xref target="response-error"/>.</t>
  </dd>
</dl>

<t>Additional fields can be defined by extensions to GNAP in the <xref target="IANA-grant-response">GNAP Grant Response Parameters Registry</xref>.</t>

<t>In this example, the AS is returning an <xref target="response-interact-redirect">interaction URI</xref>,
a <xref target="response-interact-finish">callback nonce</xref>, and a <xref target="response-continue">continuation response</xref>.</t>

<figure><sourcecode type="json"><![CDATA[
NOTE: '\' line wrapping per RFC 8792

{
    "interact": {
        "redirect": "https://server.example.com/interact/4CF492ML\
          VMSW9MKMXKHQ",
        "finish": "MBDOFXG4Y5CVJCX821LH"
    },
    "continue": {
        "access_token": {
            "value": "80UPRY5NM33OMUKMKSKU",
        },
        "uri": "https://server.example.com/tx"
    }
}
]]></sourcecode></figure>

<t>In this example, the AS is returning a bearer <xref target="response-token-single">access token</xref> with a management URI and a <xref target="response-subject">subject identifier</xref> in the form of
an opaque identifier.</t>

<figure><sourcecode type="json"><![CDATA[
{
    "access_token": {
        "value": "OS9M2PMHKUR64TB8N6BW7OZB8CDFONP219RP1LT0",
        "flags": ["bearer"],
        "manage": {
            "uri": "https://server.example.com/token/PRY5NM33O",
            "access_token": {
                "value": "B8CDFONP21-4TB8N6.BW7ONM"
            }
        }
    },
    "subject": {
        "sub_ids": [ {
          "format": "opaque",
          "id": "J2G8G8O4AZ"
        } ]
    }
}
]]></sourcecode></figure>

<t>In this example, the AS is returning set of <xref target="response-subject">subject identifiers</xref>,
simultaneously as an opaque identifier, an email address, and a decentralized identifier (DID).</t>

<figure><sourcecode type="json"><![CDATA[
{
    "subject": {
        "sub_ids": [ {
          "format": "opaque",
          "id": "J2G8G8O4AZ"
        }, {
          "format": "email",
          "email": "user@example.com"
        }, {
          "format": "did",
          "url": "did:example:123456"
        } ]
    }
}
]]></sourcecode></figure>

<t>The response <bcp14>MUST</bcp14> be sent as a JSON object in the content of the HTTP response with Content-Type <spanx style="verb">application/json</spanx>, unless otherwise specified by the specific response (e.g., an empty response with no Content-Type).</t>

<t>The authorization server <bcp14>MUST</bcp14> include the HTTP Cache-Control response header field <xref target="RFC9111"/> with a value set to "no-store".</t>

<section anchor="response-continue"><name>Request Continuation</name>

<t>If the AS determines that the grant request can be continued by the
client instance, the AS responds with the <spanx style="verb">continue</spanx> field. This field
contains a JSON object with the following properties.</t>

<dl>
  <dt><spanx style="verb">uri</spanx> (string):</dt>
  <dd>
    <t>The URI at which the client instance can make
  continuation requests. This URI <bcp14>MAY</bcp14> vary per
  request, or <bcp14>MAY</bcp14> be stable at the AS. This URI <bcp14>MUST</bcp14> be an absolute URI.
  The client instance <bcp14>MUST</bcp14> use this
  value exactly as given when making a <xref target="continue-request">continuation request</xref>.
  <bcp14>REQUIRED</bcp14>.</t>
  </dd>
  <dt><spanx style="verb">wait</spanx> (integer):</dt>
  <dd>
    <t>The amount of time in integer
  seconds the client instance <bcp14>MUST</bcp14> wait after receiving this request continuation
  response and calling the continuation URI. The value <bcp14>SHOULD NOT</bcp14> be less than five seconds,
  and omission of the value <bcp14>MUST</bcp14> be interpreted as five seconds.
  <bcp14>RECOMMENDED</bcp14>.</t>
  </dd>
  <dt><spanx style="verb">access_token</spanx> (object):</dt>
  <dd>
    <t>A unique access token for continuing the request, called the "continuation access token".
  The value of this property <bcp14>MUST</bcp14> be an object in the format specified
  in <xref target="response-token-single"/>. This access token <bcp14>MUST</bcp14> be bound to the
  client instance's key used in the request and <bcp14>MUST NOT</bcp14> be a bearer token. As a consequence,
  the <spanx style="verb">flags</spanx> array of this access token <bcp14>MUST NOT</bcp14> contain the string <spanx style="verb">bearer</spanx> and the
  <spanx style="verb">key</spanx> field <bcp14>MUST</bcp14> be omitted.
  This access token <bcp14>MUST NOT</bcp14> have a <spanx style="verb">manage</spanx> field.
  The client instance <bcp14>MUST</bcp14> present the continuation access token in all requests to the continuation URI as described in <xref target="use-access-token"/>.
  <bcp14>REQUIRED</bcp14>.</t>
  </dd>
</dl>

<figure><sourcecode type="json"><![CDATA[
{
    "continue": {
        "access_token": {
            "value": "80UPRY5NM33OMUKMKSKU"
        },
        "uri": "https://server.example.com/continue",
        "wait": 60
    }
}
]]></sourcecode></figure>

<t>This field is <bcp14>REQUIRED</bcp14> if the grant request is in the <em>pending</em> state, as
the field contains the information needed by the client request to continue the
request as described in <xref target="continue-request"/>. Note that the
continuation access token is bound to the client instance's key, and therefore the
client instance <bcp14>MUST</bcp14> sign all continuation requests with its key as described
in <xref target="binding-keys"/> and
<bcp14>MUST</bcp14> present the continuation access token in its continuation request.</t>

</section>
<section anchor="response-token"><name>Access Tokens</name>

<t>If the AS has successfully granted one or more access tokens to the client instance,
the AS responds with the <spanx style="verb">access_token</spanx> field. This field contains either a single
access token as described in <xref target="response-token-single"/> or an array of access tokens
as described in <xref target="response-token-multiple"/>.</t>

<t>The client instance uses any access tokens in this response to call the RS as
described in <xref target="use-access-token"/>.</t>

<t>The grant request <bcp14>MUST</bcp14> be in the <em>approved</em> state to include this field in the response.</t>

<section anchor="response-token-single"><name>Single Access Token</name>

<t>If the client instance has requested a single access token and the AS has
granted that access token, the AS responds with the "access_token"
field. The value of this field is an object with the following
properties.</t>

<dl>
  <dt><spanx style="verb">value</spanx> (string):</dt>
  <dd>
    <t>The value of the access token as a
  string. The value is opaque to the client instance. The value <bcp14>MUST</bcp14> be
  limited to the <spanx style="verb">token68</spanx> character set defined in <xref section="11.2" sectionFormat="of" target="HTTP"/> to facilitate transmission over HTTP
  headers and within other protocols without requiring additional encoding.
  <bcp14>REQUIRED</bcp14>.</t>
  </dd>
  <dt><spanx style="verb">label</spanx> (string):</dt>
  <dd>
    <t>The value of the <spanx style="verb">label</spanx> the client instance provided in the associated
  <xref target="request-token">token request</xref>, if present.
  <bcp14>REQUIRED</bcp14> for multiple access tokens or if a <spanx style="verb">label</spanx> was included in the single access token request, <bcp14>OPTIONAL</bcp14> for a single access token where no <spanx style="verb">label</spanx> was included in the request.</t>
  </dd>
  <dt><spanx style="verb">manage</spanx> (object):</dt>
  <dd>
    <t>Access information for the token management API for this access token.
  The management URI for this
  access token.
  If provided, the client instance <bcp14>MAY</bcp14> manage its access
  token as described in <xref target="token-management"/>.
  This management API is a function of the AS and is separate from the RS
  the client instance is requesting access to.
  <bcp14>OPTIONAL</bcp14>.</t>
  </dd>
  <dt><spanx style="verb">access</spanx> (array of objects/strings):</dt>
  <dd>
    <t>A description of the rights
  associated with this access token, as defined in
  <xref target="resource-access-rights"/>. If included, this <bcp14>MUST</bcp14> reflect the rights
  associated with the issued access token. These rights <bcp14>MAY</bcp14> vary
  from what was requested by the client instance.
  <bcp14>REQUIRED</bcp14>.</t>
  </dd>
  <dt><spanx style="verb">expires_in</spanx> (integer):</dt>
  <dd>
    <t>The number of seconds in
  which the access will expire. The client instance <bcp14>MUST NOT</bcp14> use the access
  token past this time. Note that the access token <bcp14>MAY</bcp14> be revoked by the
  AS or RS at any point prior to its expiration.
  <bcp14>OPTIONAL</bcp14>.</t>
  </dd>
  <dt><spanx style="verb">key</spanx> (object / string):</dt>
  <dd>
    <t>The key that the token is bound to, if different from the
  client instance's presented key. The key <bcp14>MUST</bcp14> be an object or string in a format
  described in <xref target="key-format"/>. The client instance <bcp14>MUST</bcp14> be able to
  dereference or process the key information in order to be able
  to <xref target="use-access-token">sign subsequent requests using the access token</xref>.
  When the key is provided by value from the AS, the token shares some security properties
  with bearer tokens as discussed in <xref target="security-as-keys"/>.
  It is <bcp14>RECOMMENDED</bcp14> that keys returned for use with access tokens be key references
  as described in <xref target="key-reference"/> that the client instance can correlate to
  its known keys.
  <bcp14>OPTIONAL</bcp14>.</t>
  </dd>
  <dt><spanx style="verb">flags</spanx> (array of strings):</dt>
  <dd>
    <t>A set of flags that represent attributes or behaviors of the access token
  issued by the AS.
  <bcp14>OPTIONAL</bcp14>.</t>
  </dd>
</dl>

<t>The value of the <spanx style="verb">manage</spanx> field is an object with the following properties:</t>

<t><spanx style="verb">uri</spanx> (string):
    The URI of the token management API for this access token.
    This URI <bcp14>MUST</bcp14> be an absolute URI.
    This URI <bcp14>MUST NOT</bcp14> include the
    access token value and <bcp14>SHOULD</bcp14> be different for each access
    token issued in a request and <bcp14>MUST NOT</bcp14> include the value of the
    access token being managed.
    <bcp14>REQUIRED</bcp14>.</t>

<dl>
  <dt><spanx style="verb">access_token</spanx> (object):</dt>
  <dd>
    <t>A unique access token for continuing the request, called the "token management access token".
  The value of this property <bcp14>MUST</bcp14> be an object in the format specified
  in <xref target="response-token-single"/>. This access token <bcp14>MUST</bcp14> be bound to the
  client instance's key used in the request (or its most recent rotation) and <bcp14>MUST NOT</bcp14> be a bearer token. As a consequence,
  the <spanx style="verb">flags</spanx> array of this access token <bcp14>MUST NOT</bcp14> contain the string <spanx style="verb">bearer</spanx> and the
  <spanx style="verb">key</spanx> field <bcp14>MUST</bcp14> be omitted.
  This access token <bcp14>MUST NOT</bcp14> have a <spanx style="verb">manage</spanx> field.
  This access token <bcp14>MUST NOT</bcp14> have the same value as the token it is managing.
  The client instance <bcp14>MUST</bcp14> present the continuation access token in all requests to the continuation URI as described in <xref target="use-access-token"/>.
  <bcp14>REQUIRED</bcp14>.</t>
  </dd>
</dl>

<t>The values of the <spanx style="verb">flags</spanx> field defined by this specification are as follows:</t>

<dl>
  <dt><spanx style="verb">"bearer"</spanx>:</dt>
  <dd>
    <t>This flag indicates whether the token is a bearer token, not bound to a key and proofing mechanism.
  If the <spanx style="verb">bearer</spanx> flag is present, the access token is a bearer token, and the <spanx style="verb">key</spanx>
  field in this response <bcp14>MUST</bcp14> be omitted.
  See <xref target="security-bearer-tokens"/> for additional considerations on the use of bearer tokens.</t>
  </dd>
  <dt><spanx style="verb">"durable"</spanx>:</dt>
  <dd>
    <t>Flag indicating a hint of AS behavior on token rotation.
  If this flag is present, then the client instance can expect
  a previously-issued access token to continue to work after it has been <xref target="rotate-access-token">rotated</xref>
  or the underlying grant request has been <xref target="continue-modify">modified</xref>, resulting
  in the issuance of new access tokens. If this flag is omitted, the client
  instance can anticipate a given access token
  could stop working after token rotation or grant request modification.
  Note that a token flagged as <spanx style="verb">durable</spanx> can still expire or be revoked through
  any normal means.</t>
  </dd>
</dl>

<t>Flag values <bcp14>MUST NOT</bcp14> be included more than once.</t>

<t>Additional flags can be defined by extensions using the <xref target="IANA-token-flags">GNAP Access Token Fields Registry</xref>.</t>

<t>If the <spanx style="verb">bearer</spanx> flag and the <spanx style="verb">key</spanx> field
in this response are omitted, the token is bound the <xref target="request-client">key used by the client instance</xref>
in its request for access. If the <spanx style="verb">bearer</spanx> flag is omitted, and the <spanx style="verb">key</spanx> field is present,
the token is bound to the key and proofing mechanism indicated in the <spanx style="verb">key</spanx> field.
The means by which the AS determines how to bind an access token to a key
other than that presented by the client instance is out of scope for this
specification, but common practices include pre-registering specific keys in a static fashion.</t>

<t>The client software <bcp14>MUST</bcp14> reject any access token where the <spanx style="verb">flags</spanx> field contains the <spanx style="verb">bearer</spanx> flag
and the <spanx style="verb">key</spanx> field is present with any value.</t>

<t>The following non-normative example shows a single access token bound to the client instance's key
used in the initial request, with a management URI, and that has access to three described resources
(one using an object and two described by reference strings).</t>

<figure><sourcecode type="json"><![CDATA[
NOTE: '\' line wrapping per RFC 8792

"access_token": {
    "value": "OS9M2PMHKUR64TB8N6BW7OZB8CDFONP219RP1LT0",
    "manage": {
        "uri": "https://server.example.com/token/PRY5NM33O",
        "access_token": {
            "value": "B8CDFONP21-4TB8N6.BW7ONM"
        }
    },
    "access": [
        {
            "type": "photo-api",
            "actions": [
                "read",
                "write",
                "dolphin"
            ],
            "locations": [
                "https://server.example.net/",
                "https://resource.local/other"
            ],
            "datatypes": [
                "metadata",
                "images"
            ]
        },
        "read", "dolphin-metadata"
    ]
}
]]></sourcecode></figure>

<t>The following non-normative example shows a single bearer access token
with access to two described resources.</t>

<figure><sourcecode type="json"><![CDATA[
"access_token": {
    "value": "OS9M2PMHKUR64TB8N6BW7OZB8CDFONP219RP1LT0",
    "flags": ["bearer"],
    "access": [
        "finance", "medical"
    ]
}
]]></sourcecode></figure>

<t>If the client instance <xref target="request-token-single">requested a single access token</xref>, the AS <bcp14>MUST NOT</bcp14> respond with the multiple
access token structure.</t>

</section>
<section anchor="response-token-multiple"><name>Multiple Access Tokens</name>

<t>If the client instance has requested multiple access tokens and the AS has
granted at least one of them, the AS responds with the
"access_token" field. The value of this field is a JSON
array, the members of which are distinct access
tokens as described in <xref target="response-token-single"/>.
Each object <bcp14>MUST</bcp14> have a unique <spanx style="verb">label</spanx> field, corresponding to the token labels
chosen by the client instance in the <xref target="request-token-multiple">multiple access token request</xref>.</t>

<t>In this non-normative example, two tokens are issued under the
names <spanx style="verb">token1</spanx> and <spanx style="verb">token2</spanx>, and only the first token has a management
URI associated with it.</t>

<figure><sourcecode type="json"><![CDATA[
NOTE: '\' line wrapping per RFC 8792

"access_token": [
    {
        "label": "token1",
        "value": "OS9M2PMHKUR64TB8N6BW7OZB8CDFONP219RP1LT0",
        "manage": {
            "uri": "https://server.example.com/token/PRY5NM33O",
            "access_token": {
                "value": "B8CDFONP21-4TB8N6.BW7ONM"
            }
        },
        "access": [ "finance" ]
    },
    {
        "label": "token2",
        "value": "UFGLO2FDAFG7VGZZPJ3IZEMN21EVU71FHCARP4J1",
        "access": [ "medical" ]
    }
}
]]></sourcecode></figure>

<t>Each access token corresponds to one of the objects in the <spanx style="verb">access_token</spanx> array of
the client instance's <xref target="request-token-multiple">request</xref>.</t>

<t>The AS <bcp14>MAY</bcp14> refuse to issue one or more of the
requested access tokens, for any reason. In such cases the refused token is omitted
from the response and all of the other issued access
tokens are included in the response under their respective requested labels.
If the client instance <xref target="request-token-multiple">requested multiple access tokens</xref>, the AS <bcp14>MUST NOT</bcp14> respond with a
single access token structure, even if only a single access token is granted. In such cases, the AS <bcp14>MUST</bcp14> respond
with a multiple access token structure containing one access token.</t>

<figure><sourcecode type="json"><![CDATA[
"access_token": [
    {
        "label": "token2",
        "value": "8N6BW7OZB8CDFONP219-OS9M2PMHKUR64TBRP1LT0",
        "manage": {
            "uri": "https://server.example.com/token/PRY5NM33O",
            "access_token": {
                "value": "B8CDFONP21-4TB8N6.BW7ONM"
            }
        },
        "access": [ "fruits" ]
    }
]
]]></sourcecode></figure>

<t>The parameters of each access token are separate. For example, each access token is expected to
have a unique value and (if present) label, and likely has different access rights associated with
it. Each access token could also be bound to different keys with different proofing mechanisms.</t>

</section>
</section>
<section anchor="response-interact"><name>Interaction Modes</name>

<t>If the client instance has indicated a <xref target="request-interact">capability to interact with the RO in its request</xref>,
and the AS has determined that interaction is both
supported and necessary, the AS responds to the client instance with any of the
following values in the <spanx style="verb">interact</spanx> field of the response. There is
no preference order for interaction modes in the response,
and it is up to the client instance to determine which ones to use. All supported
interaction methods are included in the same <spanx style="verb">interact</spanx> object.</t>

<dl>
  <dt><spanx style="verb">redirect</spanx> (string):</dt>
  <dd>
    <t>Redirect to an arbitrary URI. <bcp14>REQUIRED</bcp14> if the <spanx style="verb">redirect</spanx> interaction start mode is possible for this request. See <xref target="response-interact-redirect"/>.</t>
  </dd>
  <dt><spanx style="verb">app</spanx> (string):</dt>
  <dd>
    <t>Launch of an application URI. <bcp14>REQUIRED</bcp14> if the <spanx style="verb">app</spanx> interaction start mode is possible for this request. See <xref target="response-interact-app"/>.</t>
  </dd>
  <dt><spanx style="verb">user_code</spanx> (string):</dt>
  <dd>
    <t>Display a short user code. <bcp14>REQUIRED</bcp14> if the <spanx style="verb">user_code</spanx> interaction start mode is possible for this request. See <xref target="response-interact-usercode"/>.</t>
  </dd>
  <dt><spanx style="verb">user_code_uri</spanx> (object):</dt>
  <dd>
    <t>Display a short user code and URI. <bcp14>REQUIRED</bcp14> if the <spanx style="verb">user_code_uri</spanx> interaction start mode is possible for this request. <xref target="response-interact-usercodeuri"/></t>
  </dd>
  <dt><spanx style="verb">finish</spanx> (string):</dt>
  <dd>
    <t>A unique ASCII string value provided by the AS as a nonce. This is used by the client instance to verify the callback after interaction is completed. <bcp14>REQUIRED</bcp14> if the interaction finish method requested by the client instance is possible for this request. See <xref target="response-interact-finish"/>.</t>
  </dd>
  <dt><spanx style="verb">expires_in</spanx> (integer):</dt>
  <dd>
    <t>The number of integer seconds after which this set of interaction responses will expire and no longer be usable by the client instance. If the interaction methods expire, the client <bcp14>MAY</bcp14> re-start the interaction process for this grant request by sending an <xref target="continue-modify">update</xref> with a new <xref target="request-interact">interaction request</xref> section. <bcp14>OPTIONAL</bcp14>. If omitted, the interaction response modes returned do not expire but <bcp14>MAY</bcp14> be invalidated by the AS at any time.</t>
  </dd>
</dl>

<t>Additional interaction mode responses can be defined in the <xref target="IANA-interaction-response">GNAP Interaction Mode Responses Registry</xref>.</t>

<t>The AS <bcp14>MUST NOT</bcp14> respond with any interaction mode that the
client instance did not indicate in its request. The AS <bcp14>MUST NOT</bcp14> respond with
any interaction mode that the AS does not support. Since interaction
responses include secret or unique information, the AS <bcp14>SHOULD</bcp14>
respond to each interaction mode only once in an ongoing request,
particularly if the client instance <xref target="continue-modify">modifies its request</xref>.</t>

<t>The grant request <bcp14>MUST</bcp14> be in the <em>pending</em> state to include this field in the response.</t>

<section anchor="response-interact-redirect"><name>Redirection to an arbitrary URI</name>

<t>If the client instance indicates that it can <xref target="request-interact-redirect">redirect to an arbitrary URI</xref> and the AS supports this mode for the client instance's
request, the AS responds with the "redirect" field, which is
a string containing the URI for the end user to visit. This URI <bcp14>MUST</bcp14> be
unique for the request and <bcp14>MUST NOT</bcp14> contain any security-sensitive
information such as user identifiers or access tokens.</t>

<figure><artwork><![CDATA[
"interact": {
    "redirect": "https://interact.example.com/4CF492MLVMSW9MKMXKHQ"
}
]]></artwork></figure>

<t>The URI returned is a function of the AS, but the URI itself <bcp14>MAY</bcp14> be completely
distinct from the grant endpoint URI that the client instance uses to <xref target="request">request access</xref>, allowing an
AS to separate its user-interactive functionality from its back-end security
functionality. The AS will need to dereference the specific grant
request and its information from the URI alone. If the AS does not directly host the functionality accessed through
the redirect URI, then the means for the interaction functionality to communicate
with the rest of the AS are out of scope for this specification.</t>

<t>The client instance sends the end user to the URI to interact with the AS. The
client instance <bcp14>MUST NOT</bcp14> alter the URI in any way. The means for the client instance
to send the end user to this URI is out of scope of this specification,
but common methods include an HTTP redirect, launching the system
browser, displaying a scannable code, or printing out the URI in an
interactive console. See details of the interaction in <xref target="interaction-redirect"/>.</t>

</section>
<section anchor="response-interact-app"><name>Launch of an application URI</name>

<t>If the client instance indicates that it can <xref target="request-interact-app">launch an application URI</xref> and
the AS supports this mode for the client instance's request, the AS
responds with the "app" field, which is a string containing the URI
for the client instance to launch. This URI <bcp14>MUST</bcp14> be unique for the request and
<bcp14>MUST NOT</bcp14> contain any security-sensitive information such as user identifiers or access tokens.</t>

<figure><sourcecode type="json"><![CDATA[
"interact": {
    "app": "https://app.example.com/launch?tx=4CF492MLV"
}
]]></sourcecode></figure>

<t>The means for the launched application to communicate with the AS are out of
scope for this specification.</t>

<t>The client instance launches the URI as appropriate on its platform, and
the means for the client instance to launch this URI is out of scope of this
specification. The client instance <bcp14>MUST NOT</bcp14> alter the URI in any way. The
client instance <bcp14>MAY</bcp14> attempt to detect if an installed application will
service the URI being sent before attempting to launch the
application URI. See details of the interaction in <xref target="interaction-app"/>.</t>

</section>
<section anchor="response-interact-usercode"><name>Display of a Short User Code</name>

<t>If the client instance indicates that it can
<xref target="request-interact-usercode">display a short user-typeable code</xref>
and the AS supports this mode for the client instance's
request, the AS responds with a "user_code" field. This field is string
containing a unique short code that the user
can type into a web page. To facilitate usability, this string <bcp14>MUST</bcp14> consist only of characters
that can be easily typed by the end user
(such as ASCII letters or numbers) and
<bcp14>MUST</bcp14> be processed by the AS in a case-insensitive manner (see <xref target="interaction-usercode"/>).
The string <bcp14>MUST</bcp14> be randomly generated
so as to be unguessable by an attacker within the time it is accepted. The time in which this
code will be accepted <bcp14>SHOULD</bcp14> be short lived, such as several
minutes. It is <bcp14>RECOMMENDED</bcp14> that this code be no more than eight
characters in length.</t>

<figure><sourcecode type="json"><![CDATA[
"interact": {
    "user_code": "A1BC3DFF"
}
]]></sourcecode></figure>

<t>The client instance <bcp14>MUST</bcp14> communicate the "user_code" value to the end user in some
fashion, such as displaying it on a screen or reading it out
audibly. This code is used by the interaction component of the AS as a means
of identifying the pending grant request and does not function as an
authentication factor for the RO.</t>

<t>The URI that the end user is intended to enter the code into <bcp14>MUST</bcp14> be stable,
since the client instance is expected to have no means of communicating a
dynamic URI to the end user at runtime.</t>

<t>As this interaction mode is designed to facilitate interaction
via a secondary device, it is not expected that the client instance redirect
the end user to the URI where the code is entered.
If the client instance is capable of communicating an
short arbitrary URI to the end user for use with the user code, the client
instance <bcp14>SHOULD</bcp14> instead use the <xref target="request-interact-usercodeuri">"user_code_uri"</xref> mode.
If the client instance is capable of communicating a long arbitrary URI to the end user,
such as through a scannable code, the
client instance <bcp14>SHOULD</bcp14> use the <xref target="request-interact-redirect">"redirect"</xref> mode
for this purpose instead of or in addition to the user code mode.</t>

<t>See details of the interaction in <xref target="interaction-usercode"/>.</t>

</section>
<section anchor="response-interact-usercodeuri"><name>Display of a Short User Code and URI</name>

<t>If the client instance indicates that it can
<xref target="request-interact-usercode">display a short user-typeable code</xref>
and the AS supports this mode for the client instance's
request, the AS responds with a "user_code_uri"
object that contains the following members.</t>

<dl>
  <dt><spanx style="verb">code</spanx> (string):</dt>
  <dd>
    <t>A unique short code that the end user
  can type into a provided URI. To facilitate usability, this string <bcp14>MUST</bcp14> consist only of characters
  that can be easily typed by the end user
  (such as ASCII letters or numbers) and
  <bcp14>MUST</bcp14> be processed by the AS in a case-insensitive manner (see <xref target="interaction-usercodeuri"/>).
  The string <bcp14>MUST</bcp14> be randomly generated
  so as to be unguessable by an attacker within the time it is accepted. The time in which this
  code will be accepted <bcp14>SHOULD</bcp14> be short lived, such as several
  minutes. It is <bcp14>RECOMMENDED</bcp14> that this code be no more than eight
  characters in length.
  <bcp14>REQUIRED</bcp14>.</t>
  </dd>
  <dt><spanx style="verb">uri</spanx> (string):</dt>
  <dd>
    <t>The interaction URI that the client instance
  will direct the RO to. This URI <bcp14>MUST</bcp14> be short enough to be
  communicated to the end user by the client instance. It is <bcp14>RECOMMENDED</bcp14> that this URI
  be short enough for an end user to type in manually. The URI
  <bcp14>MUST NOT</bcp14> contain the <spanx style="verb">code</spanx> value. This URI <bcp14>MUST</bcp14> be an absolute URI.
  <bcp14>REQUIRED</bcp14>.</t>
  </dd>
</dl>

<figure><sourcecode type="json"><![CDATA[
"interact": {
    "user_code_uri": {
        "code": "A1BC3DFF",
        "uri": "https://s.example/device"
    }
}
]]></sourcecode></figure>

<t>The client instance <bcp14>MUST</bcp14> communicate the "code" to the end user in some
fashion, such as displaying it on a screen or reading it out
audibly. This code is used by the interaction component of the AS as a means
of identifying the pending grant request and does not function as an
authentication factor for the RO.</t>

<t>The client instance <bcp14>MUST</bcp14> also communicate the URI to the end user. Since it is expected
that the end user will continue interaction on a secondary device,
the URI needs to be short enough to allow the end user to type or copy it to a secondary
device without mistakes.</t>

<t>The URI returned is a function of the AS, but the URI itself <bcp14>MAY</bcp14> be completely
distinct from the grant endpoint URI that the client instance uses to <xref target="request">request access</xref>, allowing an
AS to separate its user-interactive functionality from its back-end security
functionality. If the AS does not directly host the functionality accessed through
the given URI, then the means for the interaction functionality to communicate
with the rest of the AS are out of scope for this specification.</t>

<t>See details of the interaction in <xref target="interaction-usercode"/>.</t>

</section>
<section anchor="response-interact-finish"><name>Interaction Finish</name>

<t>If the client instance indicates that it can <xref target="request-interact-finish">receive a post-interaction redirect or push at a URI</xref>
and the AS supports this mode for the
client instance's request, the AS responds with a <spanx style="verb">finish</spanx> field containing a nonce
that the client instance will use in validating the callback as defined in
<xref target="interaction-finish"/>.</t>

<figure><sourcecode type="json"><![CDATA[
"interact": {
    "finish": "MBDOFXG4Y5CVJCX821LH"
}
]]></sourcecode></figure>

<t>When the interaction is completed, the interaction component of the AS <bcp14>MUST</bcp14> contact the client instance using the means defined by the finish method
as described in <xref target="interaction-finish"/>.</t>

<t>If the AS returns the finish field, the client instance <bcp14>MUST NOT</bcp14>
continue a grant request before it receives the associated
interaction reference on the callback URI. See details in <xref target="interaction-finish"/>.</t>

</section>
</section>
<section anchor="response-subject"><name>Returning Subject Information</name>

<t>If information about the RO is requested and the AS
grants the client instance access to that data, the AS returns the approved
information in the "subject" response field. The AS <bcp14>MUST</bcp14> return the <spanx style="verb">subject</spanx> field only in cases where the AS is sure that
the RO and the end user are the same party. This can be accomplished through some forms of
<xref target="authorization">interaction with the RO</xref>.</t>

<t>This field is an object with the following properties.</t>

<dl>
  <dt><spanx style="verb">sub_ids</spanx> (array of objects):</dt>
  <dd>
    <t>An array of subject identifiers for the
  RO, as defined by
  <xref target="I-D.ietf-secevent-subject-identifiers"/>.
  <bcp14>REQUIRED</bcp14> if returning subject identifiers.</t>
  </dd>
  <dt><spanx style="verb">assertions</spanx> (array of objects):</dt>
  <dd>
    <t>An array containing assertions as objects each containing the assertion
  object described below.
  <bcp14>REQUIRED</bcp14> if returning assertions.</t>
  </dd>
  <dt><spanx style="verb">updated_at</spanx> (string):</dt>
  <dd>
    <t>Timestamp as an <xref target="RFC3339"/> date string, indicating
  when the identified account was last updated. The client instance <bcp14>MAY</bcp14> use
  this value to determine if it needs to request updated profile
  information through an identity API. The definition of such an
  identity API is out of scope for this specification.
  <bcp14>RECOMMENDED</bcp14>.</t>
  </dd>
</dl>

<t>Assertion objects contain the following fields:</t>

<dl>
  <dt><spanx style="verb">format</spanx> (string):</dt>
  <dd>
    <t>The assertion format.
  Possible formats include <spanx style="verb">id_token</spanx> for an OpenID Connect ID Token (<xref target="OIDC"/>) and <spanx style="verb">saml2</spanx> for a SAML 2 assertion (<xref target="SAML2"/>).
  Additional assertion formats are defined by the <xref target="IANA-assertion-formats">GNAP Assertion Formats Registry</xref>.
  <bcp14>REQUIRED</bcp14>.</t>
  </dd>
  <dt><spanx style="verb">value</spanx> (string):</dt>
  <dd>
    <t>The assertion value as the JSON string serialization of the assertion.
  <bcp14>REQUIRED</bcp14>.</t>
  </dd>
</dl>

<t>The following non-normative example contains an opaque identifier and an OpenID Connect ID Token:</t>

<figure><sourcecode type="json"><![CDATA[
"subject": {
  "sub_ids": [ {
    "format": "opaque",
    "id": "XUT2MFM1XBIKJKSDU8QM"
  } ],
  "assertions": [ {
    "format": "id_token",
    "value": "eyj..."
  } ]
}
]]></sourcecode></figure>

<t>Subject identifiers returned by the AS <bcp14>SHOULD</bcp14> uniquely identify the RO at the
AS. Some forms of subject identifier are opaque to the client instance (such as the subject of an
issuer and subject pair), while others forms (such as email address and phone number) are
intended to allow the client instance to correlate the identifier with other account information
at the client instance. The client instance <bcp14>MUST NOT</bcp14> request or use any returned subject identifiers for communication
purposes (see <xref target="request-subject"/>). That is, a subject identifier returned in the format of an email address or
a phone number only identifies the RO to the AS and does not indicate that the
AS has validated that the represented email address or phone number in the identifier
is suitable for communication with the current user. To get such information,
the client instance <bcp14>MUST</bcp14> use an identity protocol to request and receive additional identity
claims. The details of an identity protocol and associated schema
are outside the scope of this specification.</t>

<t>The AS <bcp14>MUST</bcp14> ensure that the returned subject information represents the RO. In most cases,
the AS will also ensure that the returned subject information represents the end user authenticated
interactively at the AS.
The AS <bcp14>SHOULD NOT</bcp14> re-use subject identifiers for multiple different ROs.</t>

<t>The "sub_ids" and "assertions" response fields are independent of each other. That is, a
returned assertion <bcp14>MAY</bcp14> use a different subject identifier than other assertions and
subject identifiers in the response. However, all subject identifiers and assertions returned
<bcp14>MUST</bcp14> refer to the same party.</t>

<t>The client instance <bcp14>MUST</bcp14> interpret all subject information in the context of the AS from which the
subject information is received, as is discussed in Section 6 of <xref target="SP80063C"/>. For example, one AS could
return an email identifier of  "user@example.com" for one RO, and a different AS could return that
same email identifier of "user@example.com" for a completely different RO. A client instance talking to
both AS's needs to differentiate between these two accounts by accounting for the AS source
of each identifier and not assuming that either has a canonical claim on the identifier without
additional configuration and trust agreements. Otherwise, a rogue AS could exploit this to
take over a targeted account asserted by a different AS.</t>

<t>Extensions to this specification <bcp14>MAY</bcp14> define additional response
properties in the <xref target="IANA-subject-response">GNAP Subject Information Response Fields Registry</xref>.</t>

<t>The grant request <bcp14>MUST</bcp14> be in the <em>approved</em> state to return this field in the response.</t>

<t>See <xref target="security-assertions"/> for considerations that the client instance has to make when accepting
and processing assertions from the AS.</t>

</section>
<section anchor="response-dynamic-handles"><name>Returning a Dynamically-bound Client Instance Identifier</name>

<t>Many parts of the client instance's request can be passed as either a value
or a reference. The use of a reference in place of a value allows
for a client instance to optimize requests to the AS.</t>

<t>Some references, such as for the <xref target="request-instance">client instance's identity</xref>
or the <xref target="resource-access-reference">requested resources</xref>, can be managed statically through an
admin console or developer portal provided by the AS or RS. The developer
of the client software can include these values in their code for a more
efficient and compact request.</t>

<t>If desired, the AS <bcp14>MAY</bcp14> also generate and return an instance identifier
dynamically to the client instance in the response to facilitate multiple
interactions with the same client instance over time. The client instance <bcp14>SHOULD</bcp14> use this
instance identifier in future requests in lieu of sending the associated data
values in the <spanx style="verb">client</spanx> field.</t>

<t>Dynamically generated client instance identifiers are string values that <bcp14>MUST</bcp14> be
protected by the client instance as secrets. Instance identifier values <bcp14>MUST</bcp14> be unguessable
and <bcp14>MUST NOT</bcp14> contain any information that would compromise any party if revealed. Instance identifier values are
opaque to the client instance, and their content is determined by the AS. The instance
identifier <bcp14>MUST</bcp14> be unique per client instance at the AS.</t>

<dl>
  <dt><spanx style="verb">instance_id</spanx> (string):</dt>
  <dd>
    <t>A string value used to represent the information
  in the <spanx style="verb">client</spanx> object that the client instance can use in a future request, as
  described in <xref target="request-instance"/>.
  <bcp14>OPTIONAL</bcp14>.</t>
  </dd>
</dl>

<t>This non-normative example shows an instance identifier along side an issued access token.</t>

<figure><sourcecode type="json"><![CDATA[
{
    "instance_id": "7C7C4AZ9KHRS6X63AJAO",
    "access_token": {
        "value": "OS9M2PMHKUR64TB8N6BW7OZB8CDFONP219RP1LT0"
    }
}

]]></sourcecode></figure>

</section>
<section anchor="response-error"><name>Error Response</name>

<t>If the AS determines that the request cannot be completed for any reason, it responds to the client instance with an <spanx style="verb">error</spanx> field in the response message. This field is either an object or a string.</t>

<t>When returned as an object, the object contains the following fields:</t>

<dl>
  <dt><spanx style="verb">code</spanx> (string):</dt>
  <dd>
    <t>A single ASCII error code defining the error.
<bcp14>REQUIRED</bcp14>.</t>
  </dd>
  <dt><spanx style="verb">description</spanx> (string):</dt>
  <dd>
    <t>A human-readable string description of the error intended for the
developer of the client.
<bcp14>OPTIONAL</bcp14>.</t>
  </dd>
</dl>

<t>This specification defines the following <spanx style="verb">code</spanx> values:</t>

<dl>
  <dt><spanx style="verb">"invalid_request"</spanx>:</dt>
  <dd>
    <t>The request is missing a required parameter, includes an
  invalid parameter value or is otherwise malformed.</t>
  </dd>
  <dt><spanx style="verb">"invalid_client"</spanx>:</dt>
  <dd>
    <t>The request was made from a client that was not recognized
  or allowed by the AS, or the client's signature validation failed.</t>
  </dd>
  <dt><spanx style="verb">"invalid_interaction"</spanx></dt>
  <dd>
    <t>The client instance has provided an interaction reference that is incorrect
  for this request or the interaction modes in use have expired.</t>
  </dd>
  <dt><spanx style="verb">"invalid_flag"</spanx></dt>
  <dd>
    <t>The flag configuration is not valid.</t>
  </dd>
  <dt><spanx style="verb">"invalid_rotation"</spanx></dt>
  <dd>
    <t>The token rotation request is not valid.</t>
  </dd>
  <dt><spanx style="verb">"key_rotation_not_supported"</spanx></dt>
  <dd>
    <t>The AS does not allow rotation of this access token's key.</t>
  </dd>
  <dt><spanx style="verb">"invalid_continuation"</spanx>:</dt>
  <dd>
    <t>The continuation of the referenced grant could not be processed.</t>
  </dd>
  <dt><spanx style="verb">"user_denied"</spanx>:</dt>
  <dd>
    <t>The RO denied the request.</t>
  </dd>
  <dt><spanx style="verb">"request_denied"</spanx>:</dt>
  <dd>
    <t>The request was denied for an unspecified reason.</t>
  </dd>
  <dt><spanx style="verb">"unknown_user"</spanx>:</dt>
  <dd>
    <t>The user presented in the request is not known to the AS or does not match the user present during interaction.</t>
  </dd>
  <dt><spanx style="verb">"unknown_interaction"</spanx>:</dt>
  <dd>
    <t>The interaction integrity could not be established.</t>
  </dd>
  <dt><spanx style="verb">"too_fast"</spanx>:</dt>
  <dd>
    <t>The client instance did not respect the timeout in the wait response before the next call.</t>
  </dd>
  <dt><spanx style="verb">"too_many_attempts"</spanx>:</dt>
  <dd>
    <t>A limit has been reached in the total number of reasonable attempts. This number is either defined statically or adjusted based on runtime conditions by the AS.</t>
  </dd>
</dl>

<t>Additional error codes can be defined in the <xref target="IANA-error-code">GNAP Error Codes Registry</xref>.</t>

<t>For example, if the RO denied the request while interacting with the AS,
the AS would return the following error when the client instance tries to
continue the grant request:</t>

<figure><sourcecode type="json"><![CDATA[
{
    "error": {
        "code": "user_denied",
        "description": "The RO denied the request"
    }
}
]]></sourcecode></figure>

<t>Alternatively, the AS <bcp14>MAY</bcp14> choose to only return the error as codes and provide the error as a string. Since the <spanx style="verb">description</spanx> field is not intended to be machine-readable, the following response is considered functionally equivalent to the previous example for the purposes of the client software's understanding:</t>

<figure><sourcecode type="json"><![CDATA[
{
    "error": "user_denied"
}
]]></sourcecode></figure>

<t>If an error state is reached but the grant is in the <em>pending</em> state (and therefore the client instance can continue), the AS <bcp14>MAY</bcp14> include the <spanx style="verb">continue</spanx> field in the response along with the <spanx style="verb">error</spanx>, as defined <xref target="response-continue"/>. This allows the client instance to modify its request for access, potentially leading to prompting the RO again. Other fields <bcp14>MUST NOT</bcp14> be included in the response.</t>

</section>
</section>
<section anchor="authorization"><name>Determining Authorization and Consent</name>

<t>When the client instance makes its <xref target="request">initial request</xref> to the AS for delegated access, it
is capable of asking for several different kinds of information in response:</t>

<t><list style="symbols">
  <t>the access being requested, in the <spanx style="verb">access_token</spanx> request parameter</t>
  <t>the subject information being requested, in the <spanx style="verb">subject</spanx> request parameter</t>
  <t>any additional requested information defined by extensions of this protocol</t>
</list></t>

<t>When the grant request is in the <em>processing</em> state, the AS determines what authorizations and
consents are required to fulfill this requested delegation. The details of how the
AS makes this determination are out of scope for this document. However, there are several common
patterns defined and supported by GNAP for fulfilling these requirements, including information
sent by the client instance, information gathered through the interaction process, and information
supplied by external parties. An individual AS can define its own policies and processes for
deciding when and how to gather the necessary authorizations and consent, and how those are applied
to the grant request.</t>

<t>To facilitate the AS fulfilling this request, the client instance sends information about the
actions the client software can take, including:</t>

<t><list style="symbols">
  <t>starting interaction with the end user, in the <spanx style="verb">interact</spanx> request parameter</t>
  <t>receiving notification that interaction with the RO has concluded, in the <spanx style="verb">interact</spanx> request parameter</t>
  <t>any additional capabilities defined by extensions of this protocol</t>
</list></t>

<t>The client instance can also supply information directly to the AS in its request. The client instance can send several kinds of things, including:</t>

<t><list style="symbols">
  <t>the identity of the client instance, known from the keys or identifiers in the <spanx style="verb">client</spanx> request parameter</t>
  <t>the identity of the end user, in the <spanx style="verb">user</spanx> request parameter</t>
  <t>any additional information presented by the client instance in the request defined by extensions of this protocol</t>
</list></t>

<t>The AS will process this presented information in the context of the client instance's request and
can only trust the information as much as it trusts the presentation and context of that request.
If the AS determines that the information presented in the initial request is sufficient for granting the requested
access, the AS <bcp14>MAY</bcp14> move the grant request to the <em>approved</em> state and return results <xref target="response">immediately in its response</xref> with
access tokens and subject information.</t>

<t>If the AS determines that additional runtime authorization is required, the AS can either deny the
request outright (if there is no possible recovery) or move the grant request to the <em>pending</em>
state and use a number of means at its disposal to gather that authorization from the appropriate ROs, including for example:</t>

<t><list style="symbols">
  <t>starting interaction with the end user facilitated by the client software, such as a redirection or user code</t>
  <t>challenging the client instance through a challenge-response mechanism</t>
  <t>requesting that the client instance present specific additional information, such as a user's credential or an assertion</t>
  <t>contacting an RO through an out-of-band mechanism, such as a push notification</t>
  <t>executing an auxiliary software process through an out-of-band mechanism, such as querying a digital wallet</t>
</list></t>

<t>The authorization and consent gathering process in GNAP is left deliberately flexible to allow for a
wide variety of different deployments, interactions, and methodologies.
In this process, the AS can gather consent from the RO or apply the RO's policy as necessitated by the access that has
been requested. The AS can sometimes determine which RO needs to prompt for consent based on what has been requested
by the client instance, such as a specific RS record, an identified subject, or a request requiring specific
access such as approval by an administrator. In other cases, the request is applied to whichever RO is present at the time of consent gathering. This pattern is especially prevalent when the
end user is sent to the AS for an interactive session, during which the end user takes on the role of the RO. In these cases, the end user is delegating their own access as RO to the client instance.</t>

<t>The client instance can indicate that it is capable of facilitating interaction with the end user,
another party, or another piece of software through its <xref target="request-interact-start">interaction start</xref> request. Here, the
AS usually needs to interact directly with
the end user to determine their identity, determine their status as an RO, and collect their consent. If the AS has determined
that authorization is required and the AS can support one or more of the requested interaction start
methods, the AS returns the associated <xref target="response-interact">interaction start responses</xref>. The client
instance <bcp14>SHOULD</bcp14> <xref target="interaction-start">initiate one or more of these interaction methods</xref> in order to
facilitate the granting of the request. If more than one interaction start method is available,
the means by which the client chooses which methods to follow is out of scope of this specification.</t>

<t>After starting interaction, the client instance can then make a <xref target="continue-request">continuation request</xref>
either in response to a signal indicating the <xref target="interaction-finish">finish of the interaction</xref>, after a time-based
polling, or through some other method defined by an extension of this specification through the <xref target="IANA-interaction-response">GNAP Interaction Mode Responses registry</xref>.</t>

<t>If the grant request is not in the <em>approved</em> state, the
client instance can repeat the interaction process by sending a <xref target="continue-modify">grant update request</xref> with new <xref target="request-interact">interaction</xref> methods.</t>

<t>The client instance <bcp14>MUST</bcp14> use each interaction method at most once, if a response can be detected.
The AS <bcp14>MUST</bcp14> handle any interact request as a one-time-use mechanism and <bcp14>SHOULD</bcp14> apply suitable
timeouts to any interaction start methods provided, including user codes and redirection URIs.
The client instance <bcp14>SHOULD</bcp14> apply suitable timeouts to any interaction finish method.</t>

<t>In order to support client software deployed in disadvantaged network conditions, the AS <bcp14>MAY</bcp14>
allow for processing of the same interaction method multiple times if the AS can determine
that the request is from the same party and the results are idempotent.
For example, if a client instance launches a redirect to the AS but does not receive a response
within a reasonable time, the client software can launch the redirect again, assuming that it never
reached the AS in the first place. However, if the AS in question
receives both requests, it could mistakenly process them separately, creating an undefined state for the
client instance. If the AS can determine that both requests come from the same origin or under the same session,
and the requests both came before any additional state change to the grant occurs, the AS can reasonably
conclude that the initial response was not received and the same response can be returned to the client instance.</t>

<t>If the AS instead has a means of contacting the RO directly, it could
do so without involving the client instance in its consent gathering process. For example, the AS could
push a notification to a known RO and have the RO approve the pending request asynchronously. These interactions
can be through an interface of the AS itself (such as a hosted web page), through another application (such as
something installed on the RO's device), through a messaging fabric, or any other means.</t>

<t>When interacting with an RO, the AS can do anything it needs to determine the authorization of the requested grant,
including:</t>

<t><list style="symbols">
  <t>authenticate the RO, through a local account or some other means such as federated login</t>
  <t>validate the RO through presentation of claims, attributes, or other information</t>
  <t>prompt the RO for consent for the requested delegation</t>
  <t>describe to the RO what information is being released, to whom, and for what purpose</t>
  <t>provide warnings to the RO about potential attacks or negative effects of allowing the information</t>
  <t>allow the RO to modify the client instance's requested access, including limiting or expanding that access</t>
  <t>provide the RO with artifacts such as receipts to facilitate an audit trail of authorizations</t>
  <t>allow the RO to deny the requested delegation</t>
</list></t>

<t>The AS is also allowed to request authorization from more than one RO, if the AS deems fit. For example, a medical
record might need to be released by both an attending nurse and a physician, or both owners of a bank account
need to sign off on a transfer request. Alternatively, the AS could require N of M possible RO's
to approve a given request. In some circumstances, the AS could even determine that the end user
present during the interaction is not the appropriate RO
for a given request and reach out to the appropriate RO asynchronously.</t>

<t>The RO is also allowed to define an automated policy at the AS to determine which kind of end user can get access to the resource, and under which condition. For instance, such a condition might require the end user login and the acceptance of the RO's legal provisions. Alternatively, client software could be acting without an end user, and the RO's policy allows issuance of access tokens to specific instances of that client software without human interaction.</t>

<t>While all of these cases
are supported by GNAP, the details of their implementation, and for determining which RO's or
related policies are required for a given request, are out of scope for this specification.</t>

<section anchor="interaction-start"><name>Starting Interaction With the End User</name>

<t>When a grant request is in the <em>pending</em> state, the interaction start methods sent by
the client instance can be used to facilitate interaction with the end user.
To initiate an interaction start method indicated by the
<xref target="response-interact">interaction start responses</xref> from the AS, the client instance
follows the steps defined by that interaction start mode. The actions of the client instance
required for the interaction start modes defined in this specification are described
in the following sections. Interaction start modes defined in extensions to this specification
<bcp14>MUST</bcp14> define the expected actions of the client software when that interaction start mode is used.</t>

<t>If the client instance does not start an interaction start mode within an AS-determined amount of
time, the AS <bcp14>MUST</bcp14> reject attempts to use the interaction start modes. If the client instance has
already begun one interaction start mode and the interaction has been successfully completed, the AS <bcp14>MUST</bcp14> reject attempts to use other interaction
start modes. For example, if a user code has been successfully entered for a grant request, the AS
will need to reject requests to an arbitrary redirect URI on the same grant request in order to prevent an
attacker from capturing and altering an active authorization process.</t>

<section anchor="interaction-redirect"><name>Interaction at a Redirected URI</name>

<t>When the end user is directed to an arbitrary URI through the <xref target="response-interact-redirect">"redirect"</xref>
mode, the client instance facilitates opening the URI through the end user's web browser.
The client instance could launch the URI through the system browser, provide a clickable
link, redirect the user through HTTP response codes, or display the URI in a form
the end user can use to launch such as a multidimensional barcode. In all cases, the URI
is accessed with an HTTP GET request, and the resulting page is assumed to allow direct interaction
with the end user through an HTTP user agent.
With this method, it is common (though not required) for the RO to be the same party as the end user, since
the client instance has to communicate the redirection URI to the end user.</t>

<t>In many cases, the URI indicates a web page hosted at the AS, allowing the
AS to authenticate the end user as the RO and interactively provide consent.
The URI value is used to identify the grant request being authorized.
If the URI cannot be associated with a currently active
request, the AS <bcp14>MUST</bcp14> display an error to the RO and <bcp14>MUST NOT</bcp14> attempt
to redirect the RO back to any client instance even if a <xref target="request-interact-callback-redirect">redirect finish method is supplied</xref>.
If the URI is not hosted by the AS directly, the means of communication between
the AS and the service provided by this URI are out of scope for this specification.</t>

<t>The client instance <bcp14>MUST NOT</bcp14> modify the URI when launching it,
in particular the client instance <bcp14>MUST NOT</bcp14> add any parameters to the URI.
The URI <bcp14>MUST</bcp14> be reachable from the end user's browser, though
the URI <bcp14>MAY</bcp14> be opened on a separate device from the client instance
itself. The URI <bcp14>MUST</bcp14> be accessible from an HTTP GET
request and <bcp14>MUST</bcp14> be protected by HTTPS, be
hosted on a server local to the RO's browser ("localhost"), or
use an application-specific URI scheme that is loaded on the end user's device.</t>

</section>
<section anchor="interaction-usercode"><name>Interaction at the Static User Code URI</name>

<t>When the end user is directed to enter a short code through the <xref target="response-interact-usercode">"user_code"</xref>
mode, the client instance communicates the user code to the end user and
directs the end user to enter that code at an associated URI.
The client instance <bcp14>MAY</bcp14>
format the user code in such a way as to facilitate memorability and transfer of the
code, so long as this formatting does not alter the value as accepted at the user code
URI. For example, a client instance receiving the user code "A1BC3DFF" could choose to
display this to the user as "A1BC 3DFF", breaking up the long string into two shorter
strings.</t>

<t>When processing input codes, the AS <bcp14>MUST</bcp14> transform the input string to remove invalid characters.
In the above example, the space in between the two parts would be removed upon its
entry into the interactive form at the user code URI. Additionally, the AS <bcp14>MUST</bcp14> treat
user input as case insensitive. For example, if the user inputs the string "a1bc 3DFF", the
AS will treat the input the same as "A1BC3DFF". To facilitate this, it is <bcp14>RECOMMENDED</bcp14>
that the AS use only ASCII letters and numbers as valid characters for the user code.</t>

<t>It is <bcp14>RECOMMENDED</bcp14> that the AS choose from character values that are easily copied and typed without ambiguity.
For example, some glyphs have multiple Unicode code points for the same visual character, and the end-user
could potentially type a different character than what the AS has returned.</t>

<t>This mode is designed to be used when the client instance is not able to communicate or facilitate launching
an arbitrary URI. The associated URI could be statically configured with the client instance or
in the client software's documentation. As a consequence, these URIs <bcp14>SHOULD</bcp14> be short.
The user code URI <bcp14>MUST</bcp14> be reachable from the end user's browser, though
the URI is usually opened on a separate device from the client instance
itself. The URI <bcp14>MUST</bcp14> be accessible from an HTTP GET
request and <bcp14>MUST</bcp14> be protected by HTTPS, be
hosted on a server local to the RO's browser ("localhost"), or
use an application-specific URI scheme that is loaded on the end user's device.</t>

<t>In many cases, the URI indicates a web page hosted at the AS, allowing the
AS to authenticate the end user as the RO and interactively provide consent.
The value of the user code is used to identify the grant request being authorized.
If the user code cannot be associated with a currently active
request, the AS <bcp14>MUST</bcp14> display an error to the RO and <bcp14>MUST NOT</bcp14> attempt
to redirect the RO back to any client instance even if a <xref target="request-interact-callback-redirect">redirect finish method is supplied</xref>.
If the interaction component at the user code URI is not hosted by the AS directly, the means of communication between
the AS and this URI, including communication of the user code itself, are out of scope for this specification.</t>

<t>When the RO enters this code at the user code URI,
the AS <bcp14>MUST</bcp14> uniquely identify the pending request that the code was associated
with. If the AS does not recognize the entered code, the interaction component <bcp14>MUST</bcp14>
display an error to the user. If the AS detects too many unrecognized code
enter attempts, the interaction component <bcp14>SHOULD</bcp14> display an error to the user indicating too many attempts and
<bcp14>MAY</bcp14> take additional actions such as slowing down the input interactions.
The user should be warned as such an error state is approached, if possible.</t>

</section>
<section anchor="interaction-usercodeuri"><name>Interaction at a Dynamic User Code URI</name>

<t>When the end user is directed to enter a short code through the <xref target="response-interact-usercodeuri">"user_code_uri"</xref>
mode, the client instance communicates the user code and associated URI to the end user and
directs the end user to enter that code at the URI.
The client instance <bcp14>MAY</bcp14>
format the user code in such a way as to facilitate memorability and transfer of the
code, so long as this formatting does not alter the value as accepted at the user code
URI. For example, a client instance receiving the user code "A1BC3DFF" could choose to
display this to the user as "A1BC 3DFF", breaking up the long string into two shorter
strings.</t>

<t>When processing input codes, the AS <bcp14>MUST</bcp14> transform the input string to remove invalid characters.
In the above example, the space in between the two parts would be removed upon its
entry into the interactive form at the user code URI. Additionally, the AS <bcp14>MUST</bcp14> treat
user input as case insensitive. For example, if the user inputs the string "a1bc 3DFF", the
AS will treat the input the same as "A1BC3DFF". To facilitate this, it is <bcp14>RECOMMENDED</bcp14>
that the AS use only ASCII letters and numbers as valid characters for the user code.</t>

<t>This mode is used when the client instance is not able to facilitate launching
a complex arbitrary URI but can communicate arbitrary values like URIs. As a consequence, these URIs
<bcp14>SHOULD</bcp14> be short enough to allow the URI to be typed by the end user,
such as a total length of 20 characters or fewer.
The client instance <bcp14>MUST NOT</bcp14> modify the URI when communicating it to the end user;
in particular the client instance <bcp14>MUST NOT</bcp14> add any parameters to the URI.
The user code URI <bcp14>MUST</bcp14> be reachable from the end user's browser, though
the URI is usually be opened on a separate device from the client instance
itself. The URI <bcp14>MUST</bcp14> be accessible from an HTTP GET
request and <bcp14>MUST</bcp14> be protected by HTTPS, be
hosted on a server local to the RO's browser ("localhost"), or
use an application-specific URI scheme that is loaded on the end user's device.</t>

<t>In many cases, the URI indicates a web page hosted at the AS, allowing the
AS to authenticate the end user as the RO and interactively provide consent.
The value of the user code is used to identify the grant request being authorized.
If the user code cannot be associated with a currently active
request, the AS <bcp14>MUST</bcp14> display an error to the RO and <bcp14>MUST NOT</bcp14> attempt
to redirect the RO back to any client instance even if a <xref target="request-interact-callback-redirect">redirect finish method is supplied</xref>.
If the interaction component at the user code URI is not hosted by the AS directly, the means of communication between
the AS and this URI, including communication of the user code itself, are out of scope for this specification.</t>

<t>When the RO enters this code at the given URI,
the AS <bcp14>MUST</bcp14> uniquely identify the pending request that the code was associated
with. If the AS does not recognize the entered code, the interaction component <bcp14>MUST</bcp14>
display an error to the user. If the AS detects too many unrecognized code
enter attempts, the interaction component <bcp14>SHOULD</bcp14> display an error to the user indicating too many attempts and
<bcp14>MAY</bcp14> take additional actions such as slowing down the input interactions.
The user should be warned as such an error state is approached, if possible.</t>

</section>
<section anchor="interaction-app"><name>Interaction through an Application URI</name>

<t>When the client instance is directed to launch an application through the
<xref target="response-interact-app">"app"</xref> mode, the client launches the
URI as appropriate to the system, such as through a deep link or custom URI
scheme registered to a mobile application. The means by which the AS and the
launched application communicate with each other and perform any
of the required actions are out of scope for this specification.</t>

</section>
</section>
<section anchor="interaction-finish"><name>Post-Interaction Completion</name>

<t>If an interaction <xref target="response-interact-finish">"finish"</xref> method is
associated with the current request, the AS <bcp14>MUST</bcp14> follow the appropriate
method upon completion of interaction in order to signal the client
instance to continue, except for some limited error cases discussed below.
If a finish method is not available, the AS <bcp14>SHOULD</bcp14> instruct the RO to
return to the client instance upon completion. In such cases, it is expected
that the client instance will poll the continuation endpoint as described in <xref target="continue-poll"/>.</t>

<t>The AS <bcp14>MUST</bcp14> create an interaction reference and associate that
reference with the current interaction and the underlying pending
request. The interaction reference value is an ASCII string consisting of only
unreserved characters per <xref section="2.3" sectionFormat="of" target="RFC3986"/>.
The interaction reference value <bcp14>MUST</bcp14> be sufficiently random so as not to be
guessable by an attacker. The interaction reference <bcp14>MUST</bcp14> be
one-time-use to prevent interception and replay attacks.</t>

<t>The AS <bcp14>MUST</bcp14> calculate a hash value based on the client instance and AS nonces and the
interaction reference, as described in
<xref target="interaction-hash"/>. The client instance will use this value to
validate the "finish" call.</t>

<t>All interaction finish methods <bcp14>MUST</bcp14> define a way
to convey the hash and interaction reference back to the client instance. When an
interaction finish method is used, the client instance <bcp14>MUST</bcp14> present the interaction
reference back to the AS as part of its <xref target="continue-after-interaction">continuation request</xref>.</t>

<t>Note that in many error cases, such as when the RO has denied
access, the "finish" method is still enacted by the AS.
This pattern allows the client instance to potentially recover from the error
state by modifying its request or providing additional information directly to the AS in a
continuation request. The AS <bcp14>MUST NOT</bcp14> follow the "finish" method in the
following circumstances:</t>

<t><list style="symbols">
  <t>The AS has determined that any URIs involved with the finish method are dangerous or blocked.</t>
  <t>The AS cannot determine which ongoing grant request is being referenced.</t>
  <t>The ongoing grant request has been cancelled or otherwise blocked.</t>
</list></t>

<section anchor="interaction-callback"><name>Completing Interaction with a Browser Redirect to the Callback URI</name>

<t>When using the <spanx style="verb">redirect</spanx> interaction finish method defined in <xref target="request-interact-callback-redirect"/> and <xref target="response-interact-finish"/>,
the AS signals to the client instance that interaction is
complete and the request can be continued by directing the RO (in
their browser) back to the client instance's redirect URI.</t>

<t>The AS secures this redirect by adding the hash and interaction
reference as query parameters to the client instance's redirect URI.</t>

<dl>
  <dt><spanx style="verb">hash</spanx>:</dt>
  <dd>
    <t>The interaction hash value as
  described in <xref target="interaction-hash"/>.
  <bcp14>REQUIRED</bcp14>.</t>
  </dd>
  <dt><spanx style="verb">interact_ref</spanx>:</dt>
  <dd>
    <t>The interaction reference
  generated for this interaction.
  <bcp14>REQUIRED</bcp14>.</t>
  </dd>
</dl>

<t>The means of directing the RO to this URI are outside the scope
of this specification, but common options include redirecting the
RO from a web page and launching the system browser with the
target URI. See <xref target="security-redirect-status-codes"/> for considerations on
which HTTP status code to use when redirecting a request that
potentially contains credentials.</t>

<figure><artwork><![CDATA[
NOTE: '\' line wrapping per RFC 8792

https://client.example.net/return/123455\
  ?hash=x-gguKWTj8rQf7d7i3w3UhzvuJ5bpOlKyAlVpLxBffY\
  &interact_ref=4IFWWIKYBC2PQ6U56NL1
]]></artwork></figure>

<t>The client instance <bcp14>MUST</bcp14> be able to process a request on the URI. If the URI is
HTTP, the request <bcp14>MUST</bcp14> be an HTTP GET.</t>

<t>When receiving the request, the client instance <bcp14>MUST</bcp14> parse the query
parameters to extract the hash and interaction reference values.
The client instance <bcp14>MUST</bcp14> calculate and validate the hash value as described in
<xref target="interaction-hash"/>. If the hash validates, the client instance
sends a continuation request to the AS as described in
<xref target="continue-after-interaction"/> using the interaction
reference value received here. If the hash does not validate, the client instance
<bcp14>MUST NOT</bcp14> send the interaction reference to the AS.</t>

</section>
<section anchor="interaction-pushback"><name>Completing Interaction with a Direct HTTP Request Callback</name>

<t>When using the <spanx style="verb">push</spanx> interaction finish method defined in <xref target="request-interact-callback-redirect"/> and <xref target="response-interact-finish"/>,
the AS signals to the client instance that interaction is
complete and the request can be continued by sending an HTTP POST
request to the client instance's callback URI.</t>

<t>The HTTP message content is a JSON object consisting of the
following two fields:</t>

<dl>
  <dt><spanx style="verb">hash</spanx> (string):</dt>
  <dd>
    <t>The interaction hash value as
  described in <xref target="interaction-hash"/>.
  <bcp14>REQUIRED</bcp14>.</t>
  </dd>
  <dt><spanx style="verb">interact_ref</spanx> (string)</dt>
  <dd>
    <t>The interaction reference
  generated for this interaction.
  <bcp14>REQUIRED</bcp14>.</t>
  </dd>
</dl>

<figure><sourcecode type="json"><![CDATA[
POST /push/554321 HTTP/1.1
Host: client.example.net
Content-Type: application/json

{
  "hash": "pjdHcrti02HLCwGU3qhUZ3wZXt8IjrV_BtE3oUyOuKNk",
  "interact_ref": "4IFWWIKYBC2PQ6U56NL1"
}
]]></sourcecode></figure>

<t>Since the AS is making an outbound connection to a URI supplied by an outside party (the client
instance), the AS <bcp14>MUST</bcp14> protect itself against SSRF attacks when making this call as discussed in
<xref target="security-ssrf"/>.</t>

<t>When receiving the request, the client instance <bcp14>MUST</bcp14> parse the JSON object
and validate the hash value as described in
<xref target="interaction-hash"/>. If either fails, the client instance <bcp14>MUST</bcp14> return an <spanx style="verb">unknown_interaction</spanx> error (<xref target="response-error"/>). If the hash validates, the client instance sends
a continuation request to the AS as described in <xref target="continue-after-interaction"/> using the interaction
reference value received here.</t>

</section>
<section anchor="interaction-hash"><name>Calculating the interaction hash</name>

<t>The "hash" parameter in the request to the client instance's callback URI ties
the front channel response to an ongoing request by using values
known only to the parties involved. This security mechanism allows the client instance to protect itself against
several kinds of session fixation and injection attacks as discussed in <xref target="security-interact-hash"/> and related sections. The AS <bcp14>MUST</bcp14>
always provide this hash, and the client instance <bcp14>MUST</bcp14> validate the hash when received.</t>

<t>To calculate the "hash" value, the party doing the calculation
creates a hash base string by concatenating the following values in the following order
using a single newline (0x0A) character to separate them:</t>

<t><list style="symbols">
  <t>the "nonce" value sent by the client instance in the <xref target="request-interact-finish">interaction "finish" section of the initial request</xref></t>
  <t>the AS's nonce value from <xref target="response-interact-finish">the interaction finish response</xref></t>
  <t>the "interact_ref" returned from the AS as part of the <xref target="interaction-finish">interaction finish method</xref></t>
  <t>the grant endpoint URI the client instance used to make its <xref target="request">initial request</xref></t>
</list></t>

<t>There is no padding or whitespace before or after any of the lines,
and no trailing newline character. The following example shows a constructed
hash base string consisting of these four elements.</t>

<figure><artwork><![CDATA[
VJLO6A4CATR0KRO
MBDOFXG4Y5CVJCX821LH
4IFWWIKYB2PQ6U56NL1
https://server.example.com/tx
]]></artwork></figure>

<t>The party then hashes the bytes of the ASCII encoding of this string with the appropriate algorithm
based on the "hash_method" parameter under the "finish" key of the <xref target="request-interact-finish">interaction finish request</xref>. The resulting
byte array from the hash function is then encoded using URL-Safe Base64
with no padding <xref target="RFC4648"/>. The resulting string is the hash value.</t>

<t>If provided, the "hash_method" value <bcp14>MUST</bcp14> be one of the hash name strings defined in the
<xref target="HASH-ALG">IANA Named Information Hash Algorithm Registry</xref>.
If the "hash_method" value is not present in the client instance's
request, the algorithm defaults to "sha-256".</t>

<t>For example, the "sha-256" hash method consists of hashing the input string
with the 256-bit SHA2 algorithm. The following is the encoded "sha-256" hash of the above example
hash base string.</t>

<figure><artwork><![CDATA[
x-gguKWTj8rQf7d7i3w3UhzvuJ5bpOlKyAlVpLxBffY
]]></artwork></figure>

<t>For another example, the "sha3-512" hash method consists of hashing the input string
with the 512-bit SHA3 algorithm. The following is the encoded "sha3-512" hash of the above example
hash base string.</t>

<figure><artwork><![CDATA[
NOTE: '\' line wrapping per RFC 8792

pyUkVJSmpqSJMaDYsk5G8WCvgY91l-agUPe1wgn-cc5rUtN69gPI2-S_s-Eswed8iB4\
  PJ_a5Hg6DNi7qGgKwSQ
]]></artwork></figure>

</section>
</section>
</section>
<section anchor="continue-request"><name>Continuing a Grant Request</name>

<t>While it is possible for the AS to return an approved <xref target="response">grant response</xref> with all the
client instance's requested information (including <xref target="response-token">access tokens</xref> and
<xref target="response-subject">subject information</xref>) immediately, it's more common that the AS will
place the grant request into the <em>pending</em> state and require communication with
the client instance several times over the lifetime of a grant request.
This is often part of facilitating <xref target="authorization">interaction</xref>, but it could
also be used to allow the AS and client instance to continue negotiating the parameters of
the <xref target="request">original grant request</xref> through modification of the request.</t>

<t>The ability to continue an already-started request allows the client instance to perform several
important functions, including presenting additional information from interaction,
modifying the initial request, and revoking a grant request in progress.</t>

<t>To enable this ongoing negotiation, the AS provides a continuation API to the client software.
The AS returns a <spanx style="verb">continue</spanx> field
<xref target="response-continue">in the response</xref> that contains information the client instance needs to
access this API, including a URI to access
as well as a special access token to use during the requests, called the <em>continuation access token</em>.</t>

<t>All requests to the continuation API are protected by a bound continuation access token.
The continuation access token is bound to the same key and method the client instance used to make
the initial request (or its most recent rotation). As a consequence,
when the client instance makes any calls to the continuation URI, the client instance <bcp14>MUST</bcp14> present
the continuation access token as described in <xref target="use-access-token"/> and present
proof of the client instance's key (or its most recent rotation)
by signing the request as described in <xref target="binding-keys"/>.
The AS <bcp14>MUST</bcp14> validate the signature and ensure that it is bound to the appropriate key for
the continuation access token.</t>

<t>Access tokens other than the continuation access tokens <bcp14>MUST NOT</bcp14> be usable for continuation
requests. Conversely, continuation access tokens <bcp14>MUST NOT</bcp14> be usable to make authorized requests to
RS's, even if co-located within the AS.</t>

<t>For example, here the client instance makes a POST request to a unique URI and signs
the request with HTTP Message Signatures:</t>

<figure><sourcecode type="http-message"><![CDATA[
POST /continue/KSKUOMUKM HTTP/1.1
Authorization: GNAP 80UPRY5NM33OMUKMKSKU
Host: server.example.com
Content-Length: 0
Signature-Input: sig1=...
Signature: sig1=...
]]></sourcecode></figure>

<t>The AS <bcp14>MUST</bcp14> be able to tell from the client instance's request which specific ongoing request
is being accessed, using a combination of the continuation URI and
the continuation access token.
If the AS cannot determine a single active grant request to map the
continuation request to, the AS <bcp14>MUST</bcp14> return an <spanx style="verb">invalid_continuation</spanx> error (<xref target="response-error"/>).</t>

<t>For example, here the client instance makes a POST request to a stable continuation endpoint
URI with the <xref target="continue-after-interaction">interaction reference</xref>,
includes the access token, and signs with HTTP Message Signatures:</t>

<figure><sourcecode type="http-message"><![CDATA[
POST /continue HTTP/1.1
Host: server.example.com
Content-Type: application/json
Authorization: GNAP 80UPRY5NM33OMUKMKSKU
Signature-Input: sig1=...
Signature: sig1=...
Content-Digest: sha-256=...

{
  "interact_ref": "4IFWWIKYBC2PQ6U56NL1"
}
]]></sourcecode></figure>

<t>In this alternative example, the client instance had been provided a continuation URI unique to this ongoing grant request:</t>

<figure><sourcecode type="http-message"><![CDATA[
POST /tx/rxgIIEVMBV-BQUO7kxbsp HTTP/1.1
Host: server.example.com
Content-Type: application/json
Authorization: GNAP eyJhbGciOiJub25lIiwidHlwIjoiYmFkIn0
Signature-Input: sig1=...
Signature: sig1=...
Content-Digest: sha-256=...

{
  "interact_ref": "4IFWWIKYBC2PQ6U56NL1"
}
]]></sourcecode></figure>

<t>In both cases, the AS determines which grant is being asked for based on the URI and continuation access token provided.</t>

<t>If a <spanx style="verb">wait</spanx> parameter was included in the <xref target="response-continue">continuation response</xref>, the
client instance <bcp14>MUST NOT</bcp14> call the continuation URI prior to waiting the number of
seconds indicated. If no <spanx style="verb">wait</spanx> period is indicated, the client instance
<bcp14>MUST NOT</bcp14> poll immediately and <bcp14>SHOULD</bcp14>
wait at least 5 seconds. If the client instance does not respect the
given wait period, the AS <bcp14>MUST</bcp14> return the <spanx style="verb">too_fast</spanx> error (<xref target="response-error"/>).</t>

<t>The response from the AS is a JSON object of a grant response and <bcp14>MAY</bcp14> contain any of the
fields described in <xref target="response"/>, as described in more detail in the
sections below.</t>

<t>If the AS determines that the client instance can
make further requests to the continuation API, the AS <bcp14>MUST</bcp14> include a new
<xref target="response-continue">"continue" response</xref>.
The new <spanx style="verb">continue</spanx> response <bcp14>MUST</bcp14> include a continuation access token as well, and
this token <bcp14>SHOULD</bcp14> be a new access token, invalidating the previous access token.
If the AS does not return a new <spanx style="verb">continue</spanx> response, the client instance
<bcp14>MUST NOT</bcp14> make an additional continuation request. If a client instance does so,
the AS <bcp14>MUST</bcp14> return an <spanx style="verb">invalid_continuation</spanx> error (<xref target="response-error"/>).</t>

<t>For continuation functions that require the client instance to send a message content, the content <bcp14>MUST</bcp14> be
a JSON object.</t>

<t>For all requests to the grant continuation API, the AS <bcp14>MAY</bcp14> make use of long polling mechanisms such as discussed in <xref target="RFC6202"/>. That is to say, instead of
returning the current status immediately, the long polling technique
allows the AS additional time to process and fulfill the request before returning the HTTP response
to the client instance. For example, when the AS receives a continuation request but the
grant request is in the <em>processing</em> state, the AS could wait until the grant request has moved
to the <em>pending</em> or <em>approved</em> state before returning the response message.</t>

<section anchor="continue-after-interaction"><name>Continuing After a Completed Interaction</name>

<t>When the AS responds to the client instance's <spanx style="verb">finish</spanx> method as in <xref target="interaction-callback"/>, this
response includes an interaction reference. The client instance <bcp14>MUST</bcp14> include that value as the field
<spanx style="verb">interact_ref</spanx> in a POST request to the continuation URI.</t>

<figure><sourcecode type="http-message"><![CDATA[
POST /continue HTTP/1.1
Host: server.example.com
Content-Type: application/json
Authorization: GNAP 80UPRY5NM33OMUKMKSKU
Signature-Input: sig1=...
Signature: sig1=...
Content-Digest: sha-256=...

{
  "interact_ref": "4IFWWIKYBC2PQ6U56NL1"
}
]]></sourcecode></figure>

<t>Since the interaction reference is a one-time-use value as described in <xref target="interaction-callback"/>,
if the client instance needs to make additional continuation calls after this request, the client instance
<bcp14>MUST NOT</bcp14> include the interaction reference in subsequent calls. If the AS detects a client instance
submitting an interaction reference when the request is not in the <em>pending</em> state, the AS <bcp14>MUST</bcp14>
return a <spanx style="verb">too_many_attempts</spanx> error (<xref target="response-error"/>) and <bcp14>SHOULD</bcp14> invalidate
the ongoing request by moving it to the <em>finalized</em> state.</t>

<t>If the grant request is in the <em>approved</em> state, the <xref target="response">grant response</xref> <bcp14>MAY</bcp14> contain any
newly-created <xref target="response-token">access tokens</xref> or
newly-released <xref target="response-subject">subject information</xref>. The response <bcp14>MAY</bcp14> contain
a new <xref target="response-continue">"continue" response</xref> as described above. The response
<bcp14>SHOULD NOT</bcp14> contain any <xref target="response-interact">interaction responses</xref>.</t>

<t>If the grant request is in the <em>pending</em> state, the <xref target="response">grant response</xref> <bcp14>MUST NOT</bcp14> contain access tokens or subject information, and <bcp14>MAY</bcp14> contain a new <xref target="response-interact">interaction responses</xref> to any interaction methods that have not been exhausted at the AS.</t>

<t>For example, if the request is successful in causing the AS to issue access tokens and
release opaque subject claims, the response could look like this:</t>

<figure><sourcecode type="json"><![CDATA[
NOTE: '\' line wrapping per RFC 8792

{
    "access_token": {
        "value": "OS9M2PMHKUR64TB8N6BW7OZB8CDFONP219RP1LT0",
        "manage": {
            "uri": "https://server.example.com/token/PRY5NM33O",
            "access_token": {
                "value": "B8CDFONP21-4TB8N6.BW7ONM"
            }
        }
    },
    "subject": {
        "sub_ids": [ {
          "format": "opaque",
          "id": "J2G8G8O4AZ"
        } ]
    }
}
]]></sourcecode></figure>

<t>With this example, the client instance can not make an additional continuation request because
a <spanx style="verb">continue</spanx> field is not included.</t>

<t>For another example, if the RO has denied the client instance's request, the AS responds with the following response:</t>

<figure><artwork><![CDATA[
{
    "error": "user_denied",
    "continue": {
        "access_token": {
            "value": "33OMUKMKSKU80UPRY5NM"
        },
        "uri": "https://server.example.com/continue",
        "wait": 30
    }
}
]]></artwork></figure>

<t>In this example, the AS includes the <spanx style="verb">continue</spanx> field in the response. Therefore, the client instance can continue the grant negotiation process, perhaps modifying the request as discussed in <xref target="continue-modify"/>.</t>

</section>
<section anchor="continue-poll"><name>Continuing During Pending Interaction (Polling)</name>

<t>When the client instance does not include a <spanx style="verb">finish</spanx> parameter, the client instance will often need to
poll the AS until the RO has authorized the request. To do so, the client instance makes a POST
request to the continuation URI as in <xref target="continue-after-interaction"/>, but does not
include message content.</t>

<figure><sourcecode type="http-message"><![CDATA[
POST /continue HTTP/1.1
Host: server.example.com
Authorization: GNAP 80UPRY5NM33OMUKMKSKU
Signature-Input: sig1=...
Signature: sig1=...
]]></sourcecode></figure>

<t>If the grant request is in the <em>approved</em> state, the <xref target="response">grant response</xref> <bcp14>MAY</bcp14> contain any
newly-created <xref target="response-token">access tokens</xref> or
newly-released <xref target="response-subject">subject claims</xref>. The response <bcp14>MAY</bcp14> contain
a new <xref target="response-continue">"continue" response</xref> as described above. If a <spanx style="verb">continue</spanx>
field is included, it <bcp14>SHOULD</bcp14> include a <spanx style="verb">wait</spanx> field to facilitate a reasonable polling rate by
the client instance. The response <bcp14>SHOULD NOT</bcp14> contain <xref target="response-interact">interaction responses</xref>.</t>

<t>If the grant request is in the <em>pending</em> state, the <xref target="response">grant response</xref> <bcp14>MUST NOT</bcp14> contain access tokens or subject information, and <bcp14>MAY</bcp14> contain a new <xref target="response-interact">interaction responses</xref> to any interaction methods that have not been exhausted at the AS.</t>

<t>For example, if the request has not yet been authorized by the RO, the AS could respond
by telling the client instance to make another continuation request in the future. In this example,
a new, unique access token has been issued for the call, which the client instance will use in its
next continuation request.</t>

<figure><sourcecode type="json"><![CDATA[
{
    "continue": {
        "access_token": {
            "value": "33OMUKMKSKU80UPRY5NM"
        },
        "uri": "https://server.example.com/continue",
        "wait": 30
    }
}
]]></sourcecode></figure>

<t>If the request is successful in causing the AS to issue access tokens and
release subject information, the response could look like this example:</t>

<figure><sourcecode type="json"><![CDATA[
NOTE: '\' line wrapping per RFC 8792

{
    "access_token": {
        "value": "OS9M2PMHKUR64TB8N6BW7OZB8CDFONP219RP1LT0",
        "manage": {
            "uri": "https://server.example.com/token/PRY5NM33O",
            "access_token": {
                "value": "B8CDFONP21-4TB8N6.BW7ONM"
            }
        }
    },
    "subject": {
        "sub_ids": [ {
          "format": "opaque",
          "id": "J2G8G8O4AZ"
        } ]
    }
}
]]></sourcecode></figure>

<t>See <xref target="security-polling"/> for considerations on polling for continuation without an interaction
<spanx style="verb">finish</spanx> method.</t>

<t>In error conditions, the AS responds to the client instance with the error code as discussed in <xref target="response-error"/>.
For example, if the client instance has polled too many times before the RO has approved the request, the AS would respond with a message like this:</t>

<figure><artwork><![CDATA[
{
    "error": "too_many_attempts"
}
]]></artwork></figure>

<t>Since this response does not include a <spanx style="verb">continue</spanx> section, the client instance cannot continue to
poll the AS for additional updates and the grant request is <em>finalized</em>. If the client instance
still needs access to the resource, it will need to start with a new grant request.</t>

</section>
<section anchor="continue-modify"><name>Modifying an Existing Request</name>

<t>The client instance might need to modify an ongoing request, whether or not tokens have already been
issued or subject information has already been released. In such cases, the client instance makes an HTTP PATCH
request to the continuation URI and includes any fields it needs to modify. Fields
that aren't included in the request are considered unchanged from the original request.</t>

<t>A grant request associated with a modification request <bcp14>MUST</bcp14> be in the <em>approved</em> or <em>pending</em> state.
When the AS receives a valid modification request, the AS <bcp14>MUST</bcp14> place the grant request into the
<em>processing</em> state and re-evaluate the authorization in the new context created by the update
request, since the extent and context of the request could have changed.</t>

<t>The client instance <bcp14>MAY</bcp14> include the <spanx style="verb">access_token</spanx> and <spanx style="verb">subject</spanx> fields as described in <xref target="request-token"/>
and <xref target="request-subject"/>. Inclusion of these fields override any values in the initial request,
which <bcp14>MAY</bcp14> trigger additional requirements and policies by the AS. For example, if the client instance is asking for
more access, the AS could require additional interaction with the RO to gather additional consent.
If the client instance is asking for more limited access, the AS could determine that sufficient authorization
has been granted to the client instance and return the more limited access rights immediately.
If the grant request was previously in the <em>approved</em> state, the AS could decide to remember the larger scale of access rights associated
with the grant request, allowing the client instance to make subsequent requests of different
subsets of granted access. The details of this processing are out of scope for this specification,
but a one possible approach is as follows:</t>

<t><list style="numbers">
  <t>A client instance requests access to <spanx style="verb">Foo</spanx>, and is granted by the RO. This results in an access token, <spanx style="verb">AT1</spanx>.</t>
  <t>The client instance later modifies the grant request to include <spanx style="verb">Foo</spanx> and <spanx style="verb">Bar</spanx> together. Since the client instance was previously granted <spanx style="verb">Foo</spanx> under this grant request, the RO is prompted to allow the client instance access to <spanx style="verb">Foo</spanx> and <spanx style="verb">Bar</spanx> together. This results in a new access token, <spanx style="verb">AT2</spanx> This access token has access to both <spanx style="verb">Foo</spanx> and <spanx style="verb">Bar</spanx>. The rights of the original access token <spanx style="verb">AT1</spanx> are not modified.</t>
  <t>The client instance makes another grant modification to ask only for <spanx style="verb">Bar</spanx>. Since the client instance was previously granted <spanx style="verb">Foo</spanx> and <spanx style="verb">Bar</spanx> together under this grant request, the RO is not prompted and the access to <spanx style="verb">Bar</spanx> is granted in a new access token, <spanx style="verb">AT3</spanx>. This new access token does not allow access to <spanx style="verb">Foo</spanx>.</t>
  <t>The original access token <spanx style="verb">AT1</spanx> expires and the client seeks a new access token to replace it. The client instance makes another grant modification to ask only for <spanx style="verb">Foo</spanx>. Since the client instance was previously granted <spanx style="verb">Foo</spanx> and <spanx style="verb">Bar</spanx> together under this grant request, the RO is not prompted and the access to <spanx style="verb">Foo</spanx> is granted in a new access token, <spanx style="verb">AT4</spanx>. This new access token does not allow access to <spanx style="verb">Bar</spanx>.</t>
</list></t>

<t>All four access tokens are independent of each other and associated with the same underlying grant request. Each of these access tokens could possibly also be rotated using token management, if available. For example, instead of asking for a new token to replace <spanx style="verb">AT1</spanx>, the client instance could ask for a refresh of <spanx style="verb">AT1</spanx> using the rotation method of the token management API. This would result in a refreshed <spanx style="verb">AT1</spanx> with a different token value and expiration from the original <spanx style="verb">AT1</spanx> but with the same access rights of allowing only access to <spanx style="verb">Foo</spanx>.</t>

<t>The client instance <bcp14>MAY</bcp14> include the <spanx style="verb">interact</spanx> field as described in <xref target="request-interact"/>.
Inclusion of this field indicates that the client instance is capable of driving interaction with
the end user, and this field replaces any values from a previous request. The AS <bcp14>MAY</bcp14> respond to any
of the interaction responses as described in <xref target="response-interact"/>, just like it would to a new
request.</t>

<t>The client instance <bcp14>MAY</bcp14> include the <spanx style="verb">user</spanx> field as described in <xref target="request-user"/> to present new assertions
or information about the end user. The AS <bcp14>SHOULD</bcp14> check that this presented user information is
consistent with any user information previously presented by the client instance or otherwise
associated with this grant request.</t>

<t>The client instance <bcp14>MUST NOT</bcp14> include the <spanx style="verb">client</spanx> section of the request, since the client
instance is assumed not to have changed. Modification of client instance information, including
rotation of keys associated with the client instance, is outside the
scope of this specification.</t>

<t>The client instance <bcp14>MUST NOT</bcp14> include post-interaction responses such as described in <xref target="continue-after-interaction"/>.</t>

<t>Modification requests <bcp14>MUST NOT</bcp14> alter previously-issued access tokens. Instead, any access
tokens issued from a continuation are considered new, separate access tokens. The AS
<bcp14>MAY</bcp14> revoke previously-issued access tokens after a modification has occurred.</t>

<t>If the modified request can be granted immediately by the AS (the grant request is in the <em>approved</em> state),
the <xref target="response">grant response</xref> <bcp14>MAY</bcp14> contain any newly-created <xref target="response-token">access tokens</xref> or
newly-released <xref target="response-subject">subject claims</xref>. The response <bcp14>MAY</bcp14> contain
a new <xref target="response-continue">"continue" response</xref> as described above. If interaction
can occur, the response <bcp14>SHOULD</bcp14> contain <xref target="response-interact">interaction responses</xref> as well.</t>

<t>For example, a client instance initially requests a set of resources using references:</t>

<figure><sourcecode type="http-message"><![CDATA[
POST /tx HTTP/1.1
Host: server.example.com
Content-Type: application/json
Signature-Input: sig1=...
Signature: sig1=...
Content-Digest: sha-256=...

{
    "access_token": {
        "access": [
            "read", "write"
        ]
    },
    "interact": {
        "start": ["redirect"],
        "finish": {
            "method": "redirect",
            "uri": "https://client.example.net/return/123455",
            "nonce": "LKLTI25DK82FX4T4QFZC"
        }
    },
    "client": "987YHGRT56789IOLK"
}
]]></sourcecode></figure>

<t>Access is granted by the RO, and a token is issued by the AS.
In its final response, the AS includes a <spanx style="verb">continue</spanx> field, which includes
a separate access token for accessing the continuation API:</t>

<figure><sourcecode type="json"><![CDATA[
{
    "continue": {
        "access_token": {
            "value": "80UPRY5NM33OMUKMKSKU"
        },
        "uri": "https://server.example.com/continue",
        "wait": 30
    },
    "access_token": {
        "value": "RP1LT0-OS9M2P_R64TB",
        "access": [
            "read", "write"
        ]
    }
}
]]></sourcecode></figure>

<t>This <spanx style="verb">continue</spanx> field allows the client instance to make an eventual continuation call.
Some time later, the client instance realizes that it no longer needs
"write" access and therefore modifies its ongoing request, here asking for just "read" access
instead of both "read" and "write" as before.</t>

<figure><sourcecode type="json"><![CDATA[
PATCH /continue HTTP/1.1
Host: server.example.com
Content-Type: application/json
Authorization: GNAP 80UPRY5NM33OMUKMKSKU
Signature-Input: sig1=...
Signature: sig1=...
Content-Digest: sha-256=...

{
    "access_token": {
        "access": [
            "read"
        ]
    }
    ...
}
]]></sourcecode></figure>

<t>The AS replaces the previous <spanx style="verb">access</spanx> from the first request, allowing the AS to
determine if any previously-granted consent already applies. In this case, the AS would
determine that reducing the breadth of the requested access means that new access
tokens can be issued to the client instance without additional interaction or consent. The AS would likely revoke previously-issued access tokens
that had the greater access rights associated with them, unless they had been issued
with the <spanx style="verb">durable</spanx> flag.</t>

<figure><sourcecode type="json"><![CDATA[
{
    "continue": {
        "access_token": {
            "value": "M33OMUK80UPRY5NMKSKU"
        },
        "uri": "https://server.example.com/continue",
        "wait": 30
    },
    "access_token": {
        "value": "0EVKC7-2ZKwZM_6N760",
        "access": [
            "read"
        ]
    }
}
]]></sourcecode></figure>

<t>For another example, the client instance initially requests read-only access but later
needs to step up its access. The initial request could look like this example.</t>

<figure><sourcecode type="http-message"><![CDATA[
POST /tx HTTP/1.1
Host: server.example.com
Content-Type: application/json
Signature-Input: sig1=...
Signature: sig1=...
Content-Digest: sha-256=...

{
    "access_token": {
        "access": [
            "read"
        ]
    },
    "interact": {
        "start": ["redirect"],
        "finish": {
            "method": "redirect",
            "uri": "https://client.example.net/return/123455",
            "nonce": "LKLTI25DK82FX4T4QFZC"
        }
    },
    "client": "987YHGRT56789IOLK"
}
]]></sourcecode></figure>

<t>Access is granted by the RO, and a token is issued by the AS.
In its final response, the AS includes a <spanx style="verb">continue</spanx> field:</t>

<figure><sourcecode type="http-message"><![CDATA[
{
    "continue": {
        "access_token": {
            "value": "80UPRY5NM33OMUKMKSKU"
        },
        "uri": "https://server.example.com/continue",
        "wait": 30
    },
    "access_token": {
        "value": "RP1LT0-OS9M2P_R64TB",
        "access": [
            "read"
        ]
    }
}
]]></sourcecode></figure>

<t>This allows the client instance to make an eventual continuation call. The client instance later realizes that it now
needs "write" access in addition to the "read" access. Since this is an expansion of what
it asked for previously, the client instance also includes a new interaction section in case the AS needs
to interact with the RO again to gather additional authorization. Note that the client instance's
nonce and callback are different from the initial request. Since the original callback was
already used in the initial exchange, and the callback is intended for one-time-use, a new one
needs to be included in order to use the callback again.</t>

<figure><sourcecode type="http-message"><![CDATA[
PATCH /continue HTTP/1.1
Host: server.example.com
Content-Type: application/json
Authorization: GNAP 80UPRY5NM33OMUKMKSKU
Signature-Input: sig1=...
Signature: sig1=...
Content-Digest: sha-256=...

{
    "access_token": {
        "access": [
            "read", "write"
        ]
    },
    "interact": {
        "start": ["redirect"],
        "finish": {
            "method": "redirect",
            "uri": "https://client.example.net/return/654321",
            "nonce": "K82FX4T4LKLTI25DQFZC"
        }
    }
}
]]></sourcecode></figure>

<t>From here, the AS can determine that the client instance is asking for more than it was previously granted,
but since the client instance has also provided a mechanism to interact with the RO, the AS can use that
to gather the additional consent. The protocol continues as it would with a new request.
Since the old access tokens are good for a subset of the rights requested here, the
AS might decide to not revoke them. However, any access tokens granted after this update
process are new access tokens and do not modify the rights of existing access tokens.</t>

</section>
<section anchor="continue-delete"><name>Revoking a Grant Request</name>

<t>If the client instance wishes to cancel an ongoing grant request and place it into the <em>finalized</em>
state, the client instance makes an
HTTP DELETE request to the continuation URI.</t>

<figure><sourcecode type="http-message"><![CDATA[
DELETE /continue HTTP/1.1
Host: server.example.com
Content-Type: application/json
Authorization: GNAP 80UPRY5NM33OMUKMKSKU
Signature-Input: sig1=...
Signature: sig1=...
]]></sourcecode></figure>

<t>If the request is successfully revoked, the AS responds with status code HTTP 204 (No Content).
The AS <bcp14>SHOULD</bcp14> revoke all associated access tokens, if possible. The AS <bcp14>SHOULD</bcp14> disable all
token rotation and other token management functions on such access tokens, if possible.
Once the grant request is in the <em>finalized</em> state, it <bcp14>MUST NOT</bcp14> be moved to any other state.</t>

</section>
</section>
<section anchor="token-management"><name>Token Management</name>

<t>If an access token response includes the <spanx style="verb">manage</spanx> field as
described in <xref target="response-token-single"/>, the client instance <bcp14>MAY</bcp14> call
this URI to manage the access token with the rotate and revoke actions defined in
the following sections. Other actions are undefined by this
specification.</t>

<figure><sourcecode type="json"><![CDATA[
{
    "access_token": {
        "value": "OS9M2PMHKUR64TB8N6BW7OZB8CDFONP219RP1LT0",
        "flags": ["bearer"],
        "manage": {
            "uri": "https://server.example.com/token/PRY5NM33O",
            "access_token": {
                "value": "B8CDFONP21-4TB8N6.BW7ONM"
            }
        }
    }
}
]]></sourcecode></figure>

<t>The token management access token issued under the <spanx style="verb">manage</spanx> field is used to protect
all calls to the token management API.
The client instance <bcp14>MUST</bcp14> present proof of the key associated with the token
along with the token management access token value.</t>

<t>The AS <bcp14>MUST</bcp14> validate the proof and ensure that it is associated with the
token management access token.</t>

<t>The AS <bcp14>MUST</bcp14> uniquely identify the token being managed from the token management URI,
the token management access token, or a combination of both.</t>

<section anchor="rotate-access-token"><name>Rotating the Access Token Value</name>

<t>If the client instance has an access token and that access token expires, the
client instance might want to rotate the access token to a new value without expiration.
Rotating an access token consists of issuing a new access token in place of an
existing access token, with the same rights and properties as the original token,
apart from an updated token value and expiration time.</t>

<t>To rotate an access token, the client instance makes an HTTP POST to the token management URI
with no message content,
sending the access token in the authorization header as described in <xref target="use-access-token"/> and signing the request
with the appropriate key.</t>

<figure><sourcecode type="http-message"><![CDATA[
POST /token/PRY5NM33O HTTP/1.1
Host: server.example.com
Authorization: GNAP B8CDFONP21-4TB8N6.BW7ONM
Signature-Input: sig1=...
Signature: sig1=...
Content-Digest: sha-256=...
]]></sourcecode></figure>

<t>The client instance can not request to alter the access rights
associated with the access token during a rotation request. To get an access token with different
access rights for this grant request, the client instance has to call the <xref target="continue-modify">continuation API's update</xref>
functionality to get a new access token. The client instance can also create a new grant request
with the required access rights.</t>

<t>The AS validates that the token management access token presented is associated with the management
URI, that the AS issued the token to the given client instance, and that
the presented key is the correct key for the token management access token. The AS determines
which access token is being rotated from the token management URI, the token management access token, or both.</t>

<t>If the token is validated and the key is appropriate for the
request, the AS <bcp14>MUST</bcp14> invalidate the current access token value associated
with this URI, if possible. Note that stateless access tokens can make proactive
revocation difficult within a system, see <xref target="security-stateless-tokens"/>.</t>

<t>For successful rotations, the AS responds with an HTTP 200 with a JSON-formatted message content consisting of the rotated access token
in the <spanx style="verb">access_token</spanx> field described in <xref target="response-token-single"/>. The value of the
access token <bcp14>MUST NOT</bcp14> be the same as the current value of the access
token used to access the management API. The response <bcp14>MUST</bcp14> include an
access token management URI, and the value of this URI <bcp14>MAY</bcp14> be different
from the URI used by the client instance to make the rotation call. The client instance
<bcp14>MUST</bcp14> use this new URI to manage the rotated access token.</t>

<t>The access rights in the <spanx style="verb">access</spanx> array for the rotated access token <bcp14>MUST</bcp14>
be included in the response and <bcp14>MUST</bcp14> be the same
as the token before rotation.</t>

<figure><sourcecode type="json"><![CDATA[
NOTE: '\' line wrapping per RFC 8792

{
    "access_token": {
        "value": "FP6A8H6HY37MH13CK76LBZ6Y1UADG6VEUPEER5H2",
        "manage": {
            "uri": "https://server.example.com/token/PRY5NM33O",
            "access_token": {
                "value": "B8CDFONP21-4TB8N6.BW7ONM"
            }
        },
        "expires_in": 3600,
        "access": [
            {
                "type": "photo-api",
                "actions": [
                    "read",
                    "write",
                    "dolphin"
                ],
                "locations": [
                    "https://server.example.net/",
                    "https://resource.local/other"
                ],
                "datatypes": [
                    "metadata",
                    "images"
                ]
            },
            "read", "dolphin-metadata"
        ]
    }
}
]]></sourcecode></figure>

<t>If the AS is unable or unwilling to rotate the value of the access token, the AS responds with an <spanx style="verb">invalid_rotation</spanx> error (<xref target="response-error"/>). Upon receiving such an error, the client instance <bcp14>MUST</bcp14> consider the access token to not have changed its state.</t>

<section anchor="rotate-access-token-key"><name>Binding a New Key to the Rotated Access Token</name>

<t>If the client instance wishes to bind a new presentation key to an access token, the client
instance <bcp14>MUST</bcp14> present both the new key and the proof of previous key material in the access token rotation request.
The client instance makes an HTTP POST as a JSON object with the following field:</t>

<dl>
  <dt><spanx style="verb">key</spanx>:</dt>
  <dd>
    <t>The new key value or reference in the format described in <xref target="key-format"/>. Note that keys
  passed by value are always public keys. <bcp14>REQUIRED</bcp14> when doing key rotation.</t>
  </dd>
</dl>

<t>The <spanx style="verb">proof</spanx> method and parameters for the new key <bcp14>MUST</bcp14> be the same as those established for the
previous key.</t>

<t>The client instance <bcp14>MUST</bcp14> prove possession of both the currently-bound key and the newly-requested
key simultaneously in the rotation request. Specifically, the signature from the previous key <bcp14>MUST</bcp14>
cover the value or reference of the new key, and the signature of the new key <bcp14>MUST</bcp14> cover the
signature value of the old key. The
means of doing so varies depending on the proofing method in use. For example, the HTTP Message
Signatures proofing method uses multiple signatures in the request as described in
<xref target="httpsig-rotate"/>, as shown in this example.</t>

<figure><sourcecode type="http-message"><![CDATA[
POST /token/PRY5NM33O HTTP/1.1
Host: server.example.com
Authorization: GNAP B8CDFONP21-4TB8N6.BW7ONM
Signature-Input: sig1=..., sig2=("signature";key=sig1)...
Signature: sig1=..., sig2=...
Content-Digest: sha-256=...

{
    "key": {
        "proof": "httpsig",
        "jwk": {
            "kty": "RSA",
            "e": "AQAB",
            "kid": "xyz-2",
            "alg": "RS256",
            "n": "kOB5rR4Jv0GMeLaY6_It_r3ORwdf8ci_JtffXyaSx8xY..."
        }
    }
}
]]></sourcecode></figure>

<t>Failure to present the appropriate proof of either the new key or the previous key for the access token, as defined by the proof method, <bcp14>MUST</bcp14> result in an <spanx style="verb">invalid_rotation</spanx> error code from the AS (<xref target="response-error"/>).</t>

<t>An attempt to change the <spanx style="verb">proof</spanx> method or parameters, including an attempt to rotate the key of a bearer token (which has no key), <bcp14>MUST</bcp14> result in an <spanx style="verb">invalid_rotation</spanx> error code returned from the AS (<xref target="response-error"/>).</t>

<t>If the AS does not allow rotation of the access token's key for any reason, including but not limited to lack of permission for this client instance or lack of capability by the AS, the AS <bcp14>MUST</bcp14> return a <spanx style="verb">key_rotation_not_supported</spanx> error code (<xref target="response-error"/>).</t>

</section>
</section>
<section anchor="revoke-access-token"><name>Revoking the Access Token</name>

<t>If the client instance wishes to revoke the access token proactively, such as when
a user indicates to the client instance that they no longer wish for it to have
access or the client instance application detects that it is being uninstalled,
the client instance can use the token management URI to indicate to the AS that
the AS <bcp14>SHOULD</bcp14> invalidate the access token for all purposes.</t>

<t>The client instance makes an HTTP DELETE request to the token management
URI, presenting the access token and signing the request with
the appropriate key.</t>

<figure><sourcecode type="http-message"><![CDATA[
DELETE /token/PRY5NM33O HTTP/1.1
Host: server.example.com
Authorization: GNAP B8CDFONP21-4TB8N6.BW7ONM
Signature-Input: sig1=...
Signature: sig1=...
]]></sourcecode></figure>

<t>If the key presented is associated with the token (or the client instance, in
the case of a bearer token), the AS <bcp14>MUST</bcp14> invalidate the access token, if
possible, and return an HTTP 204 response code.</t>

<figure><sourcecode type="http-message"><![CDATA[
204 No Content
]]></sourcecode></figure>

<t>Though the AS <bcp14>MAY</bcp14> revoke an access token at any time for
any reason, the token management function is specifically for the client instance's use.
If the access token has already expired or has been revoked through other
means, the AS <bcp14>SHOULD</bcp14> honor the revocation request to
the token management URI as valid, since the end result is still the token
not being usable.</t>

</section>
</section>
<section anchor="secure-requests"><name>Securing Requests from the Client Instance</name>

<t>In GNAP, the client instance secures its requests to an AS and RS by presenting an access
token, presenting proof of a key that it possesses (aka, a "key proof"), or both an access token and
key proof together.</t>

<t><list style="symbols">
  <t>When an access token is used with a key proof, this is a bound token request. This type of
  request is used for calls to the RS as well as the AS during grant negotiation.</t>
  <t>When a key proof is used with no access token, this is a non-authorized signed request. This
  type of request is used for calls to the AS to initiate a grant negotiation.</t>
  <t>When an access token is used with no key proof, this is a bearer token request. This type of
  request is used only for calls to the RS, and only with access tokens that are
  not bound to any key as described in <xref target="response-token-single"/>.</t>
  <t>When neither an access token nor key proof are used, this is an unsecured request. This type
  of request is used optionally for calls to the RS as part of an RS-first discovery
  process as described in <xref target="rs-request-without-token"/>.</t>
</list></t>

<section anchor="key-format"><name>Key Formats</name>

<t>Several different places in GNAP require the presentation of key material
by value or by reference. Key material sent by value is sent using a JSON object with several fields described in this section.</t>

<t>All keys are associated with a specific key proofing method.
The proofing method associated with the key
is indicated using the <spanx style="verb">proof</spanx> field of the key object.</t>

<dl>
  <dt><spanx style="verb">proof</spanx> (string or object):</dt>
  <dd>
    <t>The form of proof that the client instance will use when
  presenting the key. The valid values of this field and
  the processing requirements for each are detailed in
  <xref target="binding-keys"/>. <bcp14>REQUIRED</bcp14>.</t>
  </dd>
</dl>

<t>A key presented by value <bcp14>MUST</bcp14> be a public key and <bcp14>MUST</bcp14> be presented in one and only one
supported format, as discussed in <xref target="security-multiple-key-formats"/>. Note that
while most formats present the full value of the public key, some
formats present a value cryptographically derived from the public key. See
additional discussion of the presentation of public keys in <xref target="security-symmetric"/>.</t>

<dl>
  <dt><spanx style="verb">jwk</spanx> (object):</dt>
  <dd>
    <t>The public key and its properties represented as a JSON Web Key <xref target="RFC7517"/>.
  A JWK <bcp14>MUST</bcp14> contain the <spanx style="verb">alg</spanx> (Algorithm) and <spanx style="verb">kid</spanx> (Key ID) parameters. The <spanx style="verb">alg</spanx>
  parameter <bcp14>MUST NOT</bcp14> be "none". The <spanx style="verb">x5c</spanx> (X.509 Certificate Chain) parameter <bcp14>MAY</bcp14>
  be used to provide the X.509 representation of the provided public key.
  <bcp14>OPTIONAL</bcp14>.</t>
  </dd>
  <dt><spanx style="verb">cert</spanx> (string):</dt>
  <dd>
    <t>PEM serialized value of the certificate used to
  sign the request, with optional internal whitespace per <xref target="RFC7468"/>. The
  PEM header and footer are optionally removed.
  <bcp14>OPTIONAL</bcp14>.</t>
  </dd>
  <dt><spanx style="verb">cert#S256</spanx> (string):</dt>
  <dd>
    <t>The certificate thumbprint calculated as
  per <xref target="RFC8705">OAuth-MTLS</xref> in base64 URL
  encoding. Note that this format does not include
  the full public key.
  <bcp14>OPTIONAL</bcp14>.</t>
  </dd>
</dl>

<t>Additional key formats are defined in the <xref target="IANA-key-formats">GNAP Key Formats Registry</xref>.</t>

<t>This non-normative example shows a single key presented in two different formats. This example key is intended to be used with the <xref target="httpsig-binding">HTTP Message Signatures</xref>
proofing mechanism, as indicated by the <spanx style="verb">httpsig</spanx> value of the <spanx style="verb">proof</spanx> field.</t>

<t>As a JSON Web Key:</t>

<figure><sourcecode type="json"><![CDATA[
"key": {
    "proof": "httpsig",
    "jwk": {
        "kty": "RSA",
        "e": "AQAB",
        "kid": "xyz-1",
        "alg": "RS256",
        "n": "kOB5rR4Jv0GMeLaY6_It_r3ORwdf8ci_JtffXyaSx8xY..."
    }
}
]]></sourcecode></figure>

<t>As a certificate in PEM format:</t>

<figure><sourcecode type="json"><![CDATA[
"key": {
    "proof": "httpsig",
    "cert": "MIIEHDCCAwSgAwIBAgIBATANBgkqhkiG9w0BAQsFA..."
}
]]></sourcecode></figure>

<t>When the key is presented in GNAP, proof of this key material <bcp14>MUST</bcp14> be used to bind the request, the nature of which varies with
the location in the protocol the key is used. For a key used as part of a client instance's initial request
in <xref target="request-client"/>, the key value represents the client instance's public key, and
proof of that key <bcp14>MUST</bcp14> be presented in that request. For a key used as part of an
access token response in <xref target="response-token-single"/>, the proof of that key <bcp14>MUST</bcp14>
be used when the client instance later presents the access token to the RS.</t>

<section anchor="key-reference"><name>Key References</name>

<t>Keys in GNAP can also be passed by reference such that the party receiving
the reference will be able to determine the appropriate keying material for
use in that part of the protocol. Key references are a single opaque string.</t>

<figure><sourcecode type="json"><![CDATA[
    "key": "S-P4XJQ_RYJCRTSU1.63N3E"
]]></sourcecode></figure>

<t>Keys referenced in this manner <bcp14>MAY</bcp14> be shared symmetric keys. See the additional considerations for symmetric keys in <xref target="security-symmetric"/>.
The key reference <bcp14>MUST NOT</bcp14> contain any unencrypted private or shared symmetric key information.</t>

<t>Keys referenced in this manner <bcp14>MUST</bcp14> be bound to a single proofing mechanism.</t>

<t>The means of dereferencing this reference to a key value and proofing mechanism are out of scope for this specification.
Commonly, key references are created by the AS and are not necessarily needed
to be understood by the client. These types of key references are an
internal reference to the AS, such as an identifier of a record in a database.
In other applications, it can be useful to use key references that are resolvable
by both clients and AS, which could be accomplished by a client publishing
a public key at a URI, for example. For interoperability, this method could later be described
as an extension, but doing so is out of scope for this specification.</t>

</section>
<section anchor="key-protection"><name>Key Protection</name>

<t>The security of GNAP relies on the cryptographic security of the keys themselves.
When symmetric keys are used in GNAP, a key management system or secure key derivation mechanism <bcp14>MUST</bcp14> be used to supply the keys. Symmetric keys <bcp14>MUST NOT</bcp14> be a human memorable password or a value derived from one. Symmetric keys <bcp14>MUST NOT</bcp14> be passed by value from the client instance to the AS.</t>

<t>Additional security considerations apply when <xref target="security-key-rotation">rotating keys</xref>.</t>

</section>
</section>
<section anchor="use-access-token"><name>Presenting Access Tokens</name>

<t>Access tokens are issued to client instances in GNAP to allow the client instance to make
an authorized call to an API.
The method the client instance uses to send an access token depends on whether
the token is bound to a key, and if so which proofing method is associated
with the key. This information is conveyed by the
<spanx style="verb">key</spanx> parameter and the <spanx style="verb">bearer</spanx> flag in <xref target="response-token-single">the access token response structure</xref>.</t>

<t>If the <spanx style="verb">flags</spanx> field does not contain the <spanx style="verb">bearer</spanx> flag and the <spanx style="verb">key</spanx> is absent, the access token
<bcp14>MUST</bcp14> be sent using the same key and proofing mechanism that the client instance used
in its initial request (or its most recent rotation).</t>

<t>If the <spanx style="verb">flags</spanx> field does not contain the <spanx style="verb">bearer</spanx> flag and the <spanx style="verb">key</spanx> value is an object as
described in <xref target="key-format"/>, the access token <bcp14>MUST</bcp14> be sent using the key and proofing
mechanism defined by the value of the <spanx style="verb">proof</spanx> field within the key object.</t>

<t>The access token <bcp14>MUST</bcp14> be sent using the HTTP "Authorization" request header field and
the "GNAP" authorization scheme along with a key proof as described in <xref target="binding-keys"/>
for the key bound to the access token. For example, an access token bound using HTTP Message Signatures would be sent as follows:</t>

<figure><sourcecode type="http-message"><![CDATA[
NOTE: '\' line wrapping per RFC 8792

GET /stuff HTTP/1.1
Host: resource.example.com
Authorization: GNAP 80UPRY5NM33OMUKMKSKU
Signature-Input: sig1=("@method" "@target-uri" "authorization")\
  ;created=1618884473;keyid="gnap-rsa";nonce="NAOEJF12ER2";tag="gnap"
Signature: sig1=:FQ+EjWqc38uLFByKa5y+c4WyYYwCTGUhidWKfr5L1Cha8FiPEw\
  DxG7nWttpBLS/B6VLfkZJogPbclySs9MDIsAIJwHnzlcJjwXWR2lfvm2z3X7EkJHm\
  Zp4SmyKOS34luAiKR1xwf32NYFolHmZf/SbHZJuWvQuS4U33C+BbsXz8MflFH1Dht\
  H/C1E5i244gSbdLCPxzABc/Q0NHVSLo1qaouYIvnxXB8OT3K7mwWjsLh1GC5vFThb\
  3XQ363r6f0OPRa4qWHhubR/d/J/lNOjbBdjq9AJ69oqNJ+A2XT+ZCrVasEJE0OBvD\
  auQoiywhb8BMB7+PEINsPk5/8UvaNxbw==:
]]></sourcecode></figure>

<t>If the <spanx style="verb">flags</spanx> field contains the <spanx style="verb">bearer</spanx> flag, the access token is a bearer token
that <bcp14>MUST</bcp14> be sent using the <spanx style="verb">Authorization Request Header Field</spanx> method defined in <xref target="RFC6750"/>.</t>

<figure><sourcecode type="http-message"><![CDATA[
Authorization: Bearer OS9M2PMHKUR64TB8N6BW7OZB8CDFONP219RP1LT0
]]></sourcecode></figure>

<t>The <spanx style="verb">Form-Encoded Body Parameter</spanx> and <spanx style="verb">URI Query Parameter</spanx> methods of <xref target="RFC6750"/> <bcp14>MUST NOT</bcp14>
be used for GNAP access tokens.</t>

</section>
<section anchor="binding-keys"><name>Proving Possession of a Key with a Request</name>

<t>Any keys presented by the client instance to the AS or RS <bcp14>MUST</bcp14> be validated as
part of the request in which they are presented. The type of binding
used is indicated by the <spanx style="verb">proof</spanx> parameter of the key object in <xref target="key-format"/>.
Key proof methods are specified either by a string, which consists of the key proof
method name on its own, or by a JSON object with the required field <spanx style="verb">method</spanx>:</t>

<dl>
  <dt><spanx style="verb">method</spanx>:</dt>
  <dd>
    <t>The name of the key proofing method to be used.
  <bcp14>REQUIRED</bcp14>.</t>
  </dd>
</dl>

<t>Individual methods defined as objects <bcp14>MAY</bcp14> define additional parameters as members in this object.</t>

<t>Values for the <spanx style="verb">method</spanx> defined by this specification are as follows:</t>

<dl>
  <dt><spanx style="verb">"httpsig"</spanx> (string or object):</dt>
  <dd>
    <t>HTTP Signing signature headers. See <xref target="httpsig-binding"/>.</t>
  </dd>
  <dt><spanx style="verb">"mtls"</spanx> (string):</dt>
  <dd>
    <t>Mutual TLS certificate verification. See <xref target="mtls"/>.</t>
  </dd>
  <dt><spanx style="verb">"jwsd"</spanx> (string):</dt>
  <dd>
    <t>A detached JWS signature header. See <xref target="detached-jws"/>.</t>
  </dd>
  <dt><spanx style="verb">"jws"</spanx> (string):</dt>
  <dd>
    <t>Attached JWS payload. See <xref target="attached-jws"/>.</t>
  </dd>
</dl>

<t>Additional proofing methods are defined by the <xref target="IANA-key-proof-methods">GNAP Key Proofing Methods Registry</xref>.</t>

<t>Proof methods <bcp14>MAY</bcp14> be defined as both an object and a string. For example, the <spanx style="verb">httpsig</spanx> method can be specified as an
object with its parameters explicitly declared, such as:</t>

<figure><sourcecode type="json"><![CDATA[
{
    "proof": {
        "method": "httpsig",
        "alg": "ecdsa-p384-sha384",
        "content-digest-alg": "sha-256"
    }
}
]]></sourcecode></figure>

<t>The <spanx style="verb">httpsig</spanx> method also defines default behavior when it is passed as a string form,
using the signature algorithm specified by the associated key
material and the content digest is calculated using sha-256. This configuration can be selected
using the following shortened form:</t>

<figure><sourcecode type="json"><![CDATA[
{
    "proof": "httpsig"
}
]]></sourcecode></figure>

<t>All key binding methods used by this specification <bcp14>MUST</bcp14> cover all relevant portions
of the request, including anything that would change the nature of the request, to allow
for secure validation of the request. Relevant aspects include
the URI being called, the HTTP method being used, any relevant HTTP headers and
values, and the HTTP message content itself. The verifier of the signed message
<bcp14>MUST</bcp14> validate all components of the signed message to ensure that nothing
has been tampered with or substituted in a way that would change the nature of
the request. Key binding method definitions <bcp14>MUST</bcp14> enumerate how these
requirements are fulfilled.</t>

<t>When a key proofing mechanism is bound to an access token, the key being presented <bcp14>MUST</bcp14>
be the key associated with the access token and the access token <bcp14>MUST</bcp14> be covered
by the signature method of the proofing mechanism.</t>

<t>The key binding methods in this section <bcp14>MAY</bcp14> be used by other components making calls
as part of GNAP, such as the extensions allowing the RS to make calls to the
AS defined in <xref target="I-D.ietf-gnap-resource-servers"/>. To facilitate this extended use, the
sections below are defined in generic terms of the "signer" and "verifier" of the HTTP message.
In the core functions of GNAP specified in this document, the "signer" is the client instance and the "verifier"
is the AS (for grant requests) or RS (for resource requests), as appropriate.</t>

<t>When used for delegation in GNAP, these key binding mechanisms allow
the AS to ensure that the keys presented by the client instance in the initial request are in
control of the party calling any follow-up or continuation requests. To facilitate
this requirement, the <xref target="response-continue">continuation response</xref> includes
an access token bound to the <xref target="request-client">client instance's key</xref>, and that key (or its most recent rotation)
<bcp14>MUST</bcp14> be proved in all continuation requests
(<xref target="continue-request"/>). Token management requests (<xref target="token-management"/>) are similarly bound
to either the access token's own key or, in the case of bearer tokens, the client instance's key.</t>

<t>In the following sections, unless otherwise noted, the <spanx style="verb">RS256</spanx> JOSE Signature Algorithm (defined in <xref section="3.3" sectionFormat="of" target="RFC7518"/>) is applied
using the following RSA key (presented here in JWK format):</t>

<figure><sourcecode type="json"><![CDATA[
NOTE: '\' line wrapping per RFC 8792

{
    "kid": "gnap-rsa",
    "p": "xS4-YbQ0SgrsmcA7xDzZKuVNxJe3pCYwdAe6efSy4hdDgF9-vhC5gjaRk\
        i1wWuERSMW4Tv44l5HNrL-Bbj_nCJxr_HAOaesDiPn2PnywwEfg3Nv95Nn-\
        eilhqXRaW-tJKEMjDHu_fmJBeemHNZI412gBnXdGzDVo22dvYoxd6GM",
    "kty": "RSA",
    "q": "rVdcT_uy-CD0GKVLGpEGRR7k4JO6Tktc8MEHkC6NIFXihk_6vAIOCzCD6\
        LMovMinOYttpRndKoGTNdJfWlDFDScAs8C5n2y1STCQPRximBY-bw39-aZq\
        JXMxOLyPjzuVgiTOCBIvLD6-8-mvFjXZk_eefD0at6mQ5qV3U1jZt88",
    "d": "FHlhdTF0ozTliDxMBffT6aJVKZKmbbFJOVNten9c3lXKB3ux3NAb_D2dB\
        7inp9EV23oWrDspFtvCvD9dZrXgRKMHofkEpo_SSvBZfgtH-OTkbY_TqtPF\
        FLPKAw0JX5cFPnn4Q2xE4n-dQ7tpRCKl59vZLHBrHShr90zqzFp0AKXU5fj\
        b1gC9LPwsFA2Fd7KXmI1drQQEVq9R-o18Pnn4BGQNQNjO_VkcJTiBmEIVT_\
        KJRPdpVJAmbgnYWafL_hAfeb_dK8p85yurEVF8nCK5oO3EPrqB7IL4UqaEn\
        5Sl3u0j8x5or-xrrAoNz-gdOv7ONfZY6NFoa-3f8q9wBAHUuQ",
    "e": "AQAB",
    "qi": "ogpNEkDKg22Rj9cDV_-PJBZaXMk66Fp557RT1tafIuqJRHEufSOYnsto\
        bWPJ0gHxv1gVJw3gm-zYvV-wTMNgr2wVsBSezSJjPSjxWZtmT2z68W1DuvK\
        kZy15vz7Jd85hmDlriGcXNCoFEUsGLWkpHH9RwPIzguUHWmTt8y0oXyI",
    "dp": "dvCKGI2G7RLh3WyjoJ_Dr6hZ3LhXweB3YcY3qdD9BnxZ71mrLiMQg4c_\
        EBnwqCETN_5sStn2cRc2JXnvLP3G8t7IFKHTT_i_TSTacJ7uT04MSa053Y3\
        RfwbvLjRNPR0UKAE3ZxROUoIaVNuU_6-QMf8-2ilUv2GIOrCN87gP_Vk",
    "alg": "RS256",
    "dq": "iMZmELaKgT9_W_MRT-UfDWtTLeFjIGRW8aFeVmZk9R7Pnyt8rNzyN-IQ\
        M40ql8u8J6vc2GmQGfokLlPQ6XLSCY68_xkTXrhoU1f-eDntkhP7L6XawSK\
        Onv5F2H7wyBQ75HUmHTg8AK2B_vRlMyFKjXbVlzKf4kvqChSGEz4IjQ",
    "n": "hYOJ-XOKISdMMShn_G4W9m20mT0VWtQBsmBBkI2cmRt4Ai8BfYdHsFzAt\
        YKOjpBR1RpKpJmVKxIGNy0g6Z3ad2XYsh8KowlyVy8IkZ8NMwSrcUIBZGYX\
        jHpwjzvfGvXH_5KJlnR3_uRUp4Z4Ujk2bCaKegDn11V2vxE41hqaPUnhRZx\
        e0jRETddzsE3mu1SK8dTCROjwUl14mUNo8iTrTm4n0qDadz8BkPo-uv4BC0\
        bunS0K3bA_3UgVp7zBlQFoFnLTO2uWp_muLEWGl67gBq9MO3brKXfGhi3kO\
        zywzwPTuq-cVQDyEN7aL0SxCb3Hc4IdqDaMg8qHUyObpPitDQ"
}
]]></sourcecode></figure>

<t>Key proofing methods <bcp14>SHOULD</bcp14> define a mechanism to allow the rotation of keys discussed
in <xref target="rotate-access-token-key"/>. Key rotation mechanisms <bcp14>MUST</bcp14> define a way for presenting
proof of two keys simultaneously with the following attributes:</t>

<t><list style="symbols">
  <t>The value of or reference to the new key material <bcp14>MUST</bcp14> be signed by the existing key.
  Generally speaking, this amounts to using the existing key to sign the content of the
  message which contains the new key.</t>
  <t>The signature of the old key <bcp14>MUST</bcp14> be signed by the new key.
  Generally speaking, this means including the signature value of the old key under the
  coverage of the new key.</t>
</list></t>

<section anchor="httpsig-binding"><name>HTTP Message Signatures</name>

<t>This method is indicated by the method value <spanx style="verb">httpsig</spanx> and can be declared in either object
form or string form.</t>

<t>When the proof method is specified in object form, the following parameters are defined:</t>

<dl>
  <dt><spanx style="verb">alg</spanx>:</dt>
  <dd>
    <t>The HTTP signature algorithm, from the HTTP Signature Algorithm registry. <bcp14>REQUIRED</bcp14>.</t>
  </dd>
  <dt><spanx style="verb">content-digest-alg</spanx>:</dt>
  <dd>
    <t>The algorithm used for the Content-Digest field, used to protect the content when present in the message. <bcp14>REQUIRED</bcp14>.</t>
  </dd>
</dl>

<t>This example uses the ECDSA signing algorithm over the P384 curve and the SHA-512 hashing
algorithm for the content digest.</t>

<figure><sourcecode type="json"><![CDATA[
{
    "proof": {
        "method": "httpsig",
        "alg": "ecdsa-p384-sha384",
        "content-digest-alg": "sha-512"
    }
}
]]></sourcecode></figure>

<t>When the proof method is specified in string form, the signing algorithm <bcp14>MUST</bcp14> be derived from the
key material (such as using the JWS algorithm in a JWK formatted key), and the content digest
algorithm <bcp14>MUST</bcp14> be <spanx style="verb">sha-256</spanx>.</t>

<figure><sourcecode type="json"><![CDATA[
{
    "proof": "httpsig"
}
]]></sourcecode></figure>

<t>When using this method, the signer creates an HTTP Message Signature as described in
<xref target="I-D.ietf-httpbis-message-signatures"/>. The covered components of the signature <bcp14>MUST</bcp14> include the
following:</t>

<dl>
  <dt><spanx style="verb">"@method"</spanx>:</dt>
  <dd>
    <t>The method used in the HTTP request.</t>
  </dd>
  <dt><spanx style="verb">"@target-uri"</spanx>:</dt>
  <dd>
    <t>The full request URI of the HTTP request.</t>
  </dd>
</dl>

<t>When the message contains request content, the covered components <bcp14>MUST</bcp14> also include the following:</t>

<dl>
  <dt><spanx style="verb">"content-digest"</spanx>:</dt>
  <dd>
    <t>The Content-Digest header as defined in <xref target="I-D.ietf-httpbis-digest-headers"/>. When the
  request message has content, the signer <bcp14>MUST</bcp14> calculate this field value and include
  the field in the request. The verifier
  <bcp14>MUST</bcp14> validate this field value. <bcp14>REQUIRED</bcp14> when the message request contains message content.</t>
  </dd>
</dl>

<t>When the request is bound to an access token, the covered components
<bcp14>MUST</bcp14> also include the following:</t>

<dl>
  <dt><spanx style="verb">"authorization"</spanx>:</dt>
  <dd>
    <t>The Authorization header used to present the access token as discussed in
<xref target="use-access-token"/>.</t>
  </dd>
</dl>

<t>Other message components <bcp14>MAY</bcp14> also be included.</t>

<t>The signer <bcp14>MUST</bcp14> include the <spanx style="verb">tag</spanx> signature  parameter with the value <spanx style="verb">gnap</spanx>, and the verifier <bcp14>MUST</bcp14> verify that the parameter exists with this value. The signer <bcp14>MUST</bcp14> include the <spanx style="verb">created</spanx> signature parameter with a timestamp of when the signature was created, and the verifier <bcp14>MUST</bcp14> ensure that the creation timestamp is sufficiently close to the current time given expected network delay and clock skew. The signer <bcp14>SHOULD</bcp14> include the <spanx style="verb">nonce</spanx> parameter with a unique and unguessable value. When included, the verifier <bcp14>MUST</bcp14> determine that the nonce value is unique within a reasonably short time period such as several minutes.</t>

<t>If the signer's key presented is a JWK, the <spanx style="verb">keyid</spanx> parameter of the signature <bcp14>MUST</bcp14> be set
to the <spanx style="verb">kid</spanx> value of the JWK, the signing algorithm used <bcp14>MUST</bcp14> be the JWS
algorithm denoted by the key's <spanx style="verb">alg</spanx> field of the JWK.</t>

<t>The explicit <spanx style="verb">alg</spanx> signature parameter <bcp14>MUST NOT</bcp14> be included in the signature, since the algorithm
will be derived either from the key material or from the <spanx style="verb">proof</spanx> value.</t>

<t>In this example, the message content is the following JSON object:</t>

<figure><sourcecode type="json"><![CDATA[
NOTE: '\' line wrapping per RFC 8792

{
    "access_token": {
        "access": [
            "dolphin-metadata"
        ]
    },
    "interact": {
        "start": ["redirect"],
        "finish": {
            "method": "redirect",
            "uri": "https://client.foo/callback",
            "nonce": "VJLO6A4CAYLBXHTR0KRO"
        }
    },
    "client": {
      "key": {
        "proof": "httpsig",
        "jwk": {
            "kid": "gnap-rsa",
            "kty": "RSA",
            "e": "AQAB",
            "alg": "PS512",
            "n": "hYOJ-XOKISdMMShn_G4W9m20mT0VWtQBsmBBkI2cmRt4Ai8Bf\
  YdHsFzAtYKOjpBR1RpKpJmVKxIGNy0g6Z3ad2XYsh8KowlyVy8IkZ8NMwSrcUIBZG\
  YXjHpwjzvfGvXH_5KJlnR3_uRUp4Z4Ujk2bCaKegDn11V2vxE41hqaPUnhRZxe0jR\
  ETddzsE3mu1SK8dTCROjwUl14mUNo8iTrTm4n0qDadz8BkPo-uv4BC0bunS0K3bA_\
  3UgVp7zBlQFoFnLTO2uWp_muLEWGl67gBq9MO3brKXfGhi3kOzywzwPTuq-cVQDyE\
  N7aL0SxCb3Hc4IdqDaMg8qHUyObpPitDQ"
        }
      }
      "display": {
        "name": "My Client Display Name",
        "uri": "https://client.foo/"
      },
    }
}
]]></sourcecode></figure>

<t>This content is hashed for the Content-Digest header using <spanx style="verb">sha-256</spanx> into the following encoded value:</t>

<figure><artwork><![CDATA[
sha-256=:q2XBmzRDCREcS2nWo/6LYwYyjrlN1bRfv+HKLbeGAGg=:
]]></artwork></figure>

<t>The HTTP message signature input string is calculated to be the following:</t>

<figure><artwork><![CDATA[
NOTE: '\' line wrapping per RFC 8792

"@method": POST
"@target-uri": https://server.example.com/gnap
"content-digest": \
  sha-256=:q2XBmzRDCREcS2nWo/6LYwYyjrlN1bRfv+HKLbeGAGg=:
"content-length": 988
"content-type": application/json
"@signature-params": ("@method" "@target-uri" "content-digest" \
  "content-length" "content-type");created=1618884473\
  ;keyid="gnap-rsa";nonce="NAOEJF12ER2";tag="gnap"
]]></artwork></figure>

<t>This leads to the following full HTTP message request:</t>

<figure><sourcecode type="http-message"><![CDATA[
NOTE: '\' line wrapping per RFC 8792

POST /gnap HTTP/1.1
Host: server.example.com
Content-Type: application/json
Content-Length: 988
Content-Digest: sha-256=:q2XBmzRDCREcS2nWo/6LYwYyjrlN1bRfv+HKLbeGAG\
  g=:
Signature-Input: sig1=("@method" "@target-uri" "content-digest" \
  "content-length" "content-type");created=1618884473\
  ;keyid="gnap-rsa";nonce="NAOEJF12ER2";tag="gnap"
Signature: sig1=:c2uwTa6ok3iHZsaRKl1ediKlgd5cCAYztbym68XgX8gSOgK0Bt\
  +zLJ19oGjSAHDjJxX2gXP2iR6lh9bLMTfPzbFVn4Eh+5UlceP+0Z5mES7v0R1+eHe\
  OqBl0YlYKaSQ11YT7n+cwPnCSdv/6+62m5zwXEEftnBeA1ECorfTuPtau/yrTYEvD\
  9A/JqR2h9VzAE17kSlSSsDHYA6ohsFqcRJavX29duPZDfYgkZa76u7hJ23yVxoUpu\
  2J+7VUdedN/72N3u3/z2dC8vQXbzCPTOiLru12lb6vnBZoDbUGsRR/zHPauxhj9T+\
  218o5+tgwYXw17othJSxIIOZ9PkIgz4g==:

{
    "access_token": {
        "access": [
            "dolphin-metadata"
        ]
    },
    "interact": {
        "start": ["redirect"],
        "finish": {
            "method": "redirect",
            "uri": "https://client.foo/callback",
            "nonce": "VJLO6A4CAYLBXHTR0KRO"
        }
    },
    "client": {
      "key": {
        "proof": "httpsig",
        "jwk": {
            "kid": "gnap-rsa",
            "kty": "RSA",
            "e": "AQAB",
            "alg": "PS512",
            "n": "hYOJ-XOKISdMMShn_G4W9m20mT0VWtQBsmBBkI2cmRt4Ai8Bf\
  YdHsFzAtYKOjpBR1RpKpJmVKxIGNy0g6Z3ad2XYsh8KowlyVy8IkZ8NMwSrcUIBZG\
  YXjHpwjzvfGvXH_5KJlnR3_uRUp4Z4Ujk2bCaKegDn11V2vxE41hqaPUnhRZxe0jR\
  ETddzsE3mu1SK8dTCROjwUl14mUNo8iTrTm4n0qDadz8BkPo-uv4BC0bunS0K3bA_\
  3UgVp7zBlQFoFnLTO2uWp_muLEWGl67gBq9MO3brKXfGhi3kOzywzwPTuq-cVQDyE\
  N7aL0SxCb3Hc4IdqDaMg8qHUyObpPitDQ"
        }
      }
      "display": {
        "name": "My Client Display Name",
        "uri": "https://client.foo/"
      },
    }
}
]]></sourcecode></figure>

<t>The verifier <bcp14>MUST</bcp14> ensure that the signature covers all required message components.
If the HTTP Message includes content, the verifier <bcp14>MUST</bcp14>
calculate and verify the value of the <spanx style="verb">Content-Digest</spanx> header. The verifier <bcp14>MUST</bcp14> validate
the signature against the expected key of the signer.</t>

<t>A received message <bcp14>MAY</bcp14> include multiple signatures, each with its own label. The verifier <bcp14>MUST</bcp14> examine all included signatures until it finds (at least) one that's acceptable according to its policy and meets the requirements in this section.</t>

<section anchor="httpsig-rotate"><name>Key Rotation using HTTP Message Signatures</name>

<t>When rotating a key using HTTP Message Signatures, the message, which includes the new public key
value or reference, is first signed with the old key following all of the requirements in <xref target="httpsig-binding"/>.
The message is then signed again with the new key by following all of the requirements in <xref target="httpsig-binding"/> again
with the following additional requirements:</t>

<t><list style="symbols">
  <t>The covered components <bcp14>MUST</bcp14> include the Signature and Signature-Input values from the signature generated with the old key</t>
  <t>The tag value <bcp14>MUST</bcp14> be <spanx style="verb">gnap-rotate</spanx></t>
</list></t>

<t>For example, the following request to the token management endpoint for rotating a token value
contains the new key in the request. The message is first signed using the old key
and the resulting signature is placed in "old-key":</t>

<figure><sourcecode type="http-message"><![CDATA[
NOTE: '\' line wrapping per RFC 8792

POST /token/PRY5NM33 HTTP/1.1
Host: server.example.com
Authorization: GNAP 4398.34-12-asvDa.a
Content-Digest: sha-512=:Fb/A5vnawhuuJ5xk2RjGrbbxr6cvinZqd4+JPY85u/\
  JNyTlmRmCOtyVhZ1Oz/cSS4tsYen6fzpCwizy6UQxNBQ==:
Signature-Input: old-key=("@method" "@target-uri" "content-digest" \
  "authorization");created=1618884475;keyid="test-key-ecc-p256"\
  ;tag="gnap"
Signature: old-key=:vN4IKYsJl2RLFe+tYEm4dHM4R4BToqx5D2FfH4ge5WOkgxo\
  dI2QRrjB8rysvoSEGvAfiVJOWsGcPD1lU639Amw==:

{
    "key": {
        "proof": "httpsig",
        "jwk": {
            "kty": "RSA",
            "e": "AQAB",
            "kid": "xyz-2",
            "alg": "RS256",
            "n": "kOB5rR4Jv0GMeLaY6_It_r3ORwdf8ci_JtffXyaSx8xY..."
        }
    }
}
]]></sourcecode></figure>

<t>The signer then creates a new signature using the new key, adding the signature
input and value to the signature base.</t>

<figure><artwork><![CDATA[
NOTE: '\' line wrapping per RFC 8792

"@method": POST
"@target-uri": https://server.example.com/token/PRY5NM33
"content-digest": sha-512=:Fb/A5vnawhuuJ5xk2RjGrbbxr6cvinZqd4+JPY85\
  u/JNyTlmRmCOtyVhZ1Oz/cSS4tsYen6fzpCwizy6UQxNBQ==:
"authorization": GNAP 4398.34-12-asvDa.a
"signature";key="old-key": :YdDJjDn2Sq8FR82e5IcOLWmmf6wILoswlnRcz+n\
  M+e8xjFDpWS2YmiMYDqUdri2UiJsZx63T1z7As9Kl6HTGkQ==:
"signature-input";key="old-key": ("@method" "@target-uri" \
  "content-digest" "authorization");created=1618884475\
  ;keyid="test-key-ecc-p256";tag="gnap"
"@signature-params": ("@method" "@target-uri" "content-digest" \
  "authorization" "signature";key="old-key" "signature-input"\
  ;key="old-key");created=1618884480;keyid="xyz-2"
  ;tag="gnap-rotate"
]]></artwork></figure>

<t>This signature is then added to the message:</t>

<figure><sourcecode type="http-message"><![CDATA[
NOTE: '\' line wrapping per RFC 8792

POST /token/PRY5NM33 HTTP/1.1
Host: server.example.com
Authorization: GNAP 4398.34-12-asvDa.a
Content-Digest: sha-512=:Fb/A5vnawhuuJ5xk2RjGrbbxr6cvinZqd4+JPY85u/\
  JNyTlmRmCOtyVhZ1Oz/cSS4tsYen6fzpCwizy6UQxNBQ==:
Signature-Input: old-key=("@method" "@target-uri" "content-digest" \
    "authorization");created=1618884475;keyid="test-key-ecc-p256"\
    ;tag="gnap", \
  new-key=("@method" "@target-uri" "content-digest" \
    "authorization" "signature";key="old-key" "signature-input"\
    ;key="old-key");created=1618884480;keyid="xyz-2"
    ;tag="gnap-rotate"
Signature: old-key=:vN4IKYsJl2RLFe+tYEm4dHM4R4BToqx5D2FfH4ge5WOkgxo\
    dI2QRrjB8rysvoSEGvAfiVJOWsGcPD1lU639Amw==:, \
  new-key=:VWUExXQ0geWeTUKhCfDT7WJyT++OHSVbfPA1ukW0o7mmstdbvIz9iOuH\
    DRFzRBm0MQPFVMpLDFXQdE3vi2SL3ZjzcX2qLwzAtyRB9+RsV2caAA80A5ZGMoo\
    gUsKPk4FFDN7KRUZ0vT9Mo9ycx9Dq/996TOWtAmq5z0YUYEwwn+T6+NcW8rFtms\
    s1ZfXG0EoAfV6ve25p+x40Y1rvDHsfkakTRB4J8jWVDybSe39tjIKQBo3uicDVw\
    twewBMNidIa+66iF3pWj8w9RSb0cncEgvbkHgASqaZeXmxxG4gM8p1HH9v/OqQT\
    Oggm5gTWmCQs4oxEmWsfTOxefunfh3X+Qw==:

{
    "key": {
        "proof": "httpsig",
        "jwk": {
            "kty": "RSA",
            "e": "AQAB",
            "kid": "xyz-2",
            "alg": "RS256",
            "n": "kOB5rR4Jv0GMeLaY6_It_r3ORwdf8ci_JtffXyaSx8xY..."
        }
    }
}
]]></sourcecode></figure>

<t>The verifier <bcp14>MUST</bcp14> validate both signatures before processing the request for key rotation.</t>

</section>
</section>
<section anchor="mtls"><name>Mutual TLS</name>

<t>This method is indicated by the method value <spanx style="verb">mtls</spanx> in string form.</t>

<figure><sourcecode type="json"><![CDATA[
{
    "proof": "mtls"
}
]]></sourcecode></figure>

<t>The signer presents its TLS client certificate during TLS negotiation with the verifier.</t>

<t>In this example, the certificate is communicated to the application
through the Client-Cert header field from a TLS reverse proxy as per <xref target="RFC9440"/>, leading
to the following full HTTP request message:</t>

<figure><sourcecode type="http-message"><![CDATA[
POST /gnap HTTP/1.1
Host: server.example.com
Content-Type: application/jose
Content-Length: 1567
Client-Cert: \
  :MIIC6jCCAdKgAwIBAgIGAXjw74xPMA0GCSqGSIb3DQEBCwUAMDYxNDAyBgNVBAMM\
  K05JWU15QmpzRGp5QkM5UDUzN0Q2SVR6a3BEOE50UmppOXlhcEV6QzY2bVEwHhcN\
  MjEwNDIwMjAxODU0WhcNMjIwMjE0MjAxODU0WjA2MTQwMgYDVQQDDCtOSVlNeUJq\
  c0RqeUJDOVA1MzdENklUemtwRDhOdFJqaTl5YXBFekM2Nm1RMIIBIjANBgkqhkiG\
  9w0BAQEFAAOCAQ8AMIIBCgKCAQEAhYOJ+XOKISdMMShn/G4W9m20mT0VWtQBsmBB\
  kI2cmRt4Ai8BfYdHsFzAtYKOjpBR1RpKpJmVKxIGNy0g6Z3ad2XYsh8KowlyVy8I\
  kZ8NMwSrcUIBZGYXjHpwjzvfGvXH/5KJlnR3/uRUp4Z4Ujk2bCaKegDn11V2vxE4\
  1hqaPUnhRZxe0jRETddzsE3mu1SK8dTCROjwUl14mUNo8iTrTm4n0qDadz8BkPo+\
  uv4BC0bunS0K3bA/3UgVp7zBlQFoFnLTO2uWp/muLEWGl67gBq9MO3brKXfGhi3k\
  OzywzwPTuq+cVQDyEN7aL0SxCb3Hc4IdqDaMg8qHUyObpPitDQIDAQABMA0GCSqG\
  SIb3DQEBCwUAA4IBAQBnYFK0eYHy+hVf2D58usj39lhL5znb/q9G35GBd/XsWfCE\
  wHuLOSZSUmG71bZtrOcx0ptle9bp2kKl4HlSTTfbtpuG5onSa3swRNhtKtUy5NH9\
  W/FLViKWfoPS3kwoEpC1XqKY6l7evoTCtS+kTQRSrCe4vbNprCAZRxz6z1nEeCgu\
  NMk38yTRvx8ihZpVOuU+Ih+dOtVe/ex5IAPYxlQsvtfhsUZqc7IyCcy72WHnRHlU\
  fn3pJm0S5270+Yls3Iv6h3oBAP19i906UjiUTNH3g0xMW+V4uLxgyckt4wD4Mlyv\
  jnaQ7Z3sR6EsXMocAbXHIAJhwKdtU/fLgdwL5vtx:


{
    "access_token": {
        "access": [
            "dolphin-metadata"
        ]
    },
    "interact": {
        "start": ["redirect"],
        "finish": {
            "method": "redirect",
            "uri": "https://client.foo/callback",
            "nonce": "VJLO6A4CAYLBXHTR0KRO"
        }
    },
    "client": {
      "key": {
        "proof": "mtls",
        "cert": "MIIC6jCCAdKgAwIBAgIGAXjw74xPMA0GCSqGSIb3DQEBCwUAMD\
  YxNDAyBgNVBAMMK05JWU15QmpzRGp5QkM5UDUzN0Q2SVR6a3BEOE50UmppOXlhcEV\
  6QzY2bVEwHhcNMjEwNDIwMjAxODU0WhcNMjIwMjE0MjAxODU0WjA2MTQwMgYDVQQD\
  DCtOSVlNeUJqc0RqeUJDOVA1MzdENklUemtwRDhOdFJqaTl5YXBFekM2Nm1RMIIBI\
  jANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAhYOJ+XOKISdMMShn/G4W9m20mT\
  0VWtQBsmBBkI2cmRt4Ai8BfYdHsFzAtYKOjpBR1RpKpJmVKxIGNy0g6Z3ad2XYsh8\
  KowlyVy8IkZ8NMwSrcUIBZGYXjHpwjzvfGvXH/5KJlnR3/uRUp4Z4Ujk2bCaKegDn\
  11V2vxE41hqaPUnhRZxe0jRETddzsE3mu1SK8dTCROjwUl14mUNo8iTrTm4n0qDad\
  z8BkPo+uv4BC0bunS0K3bA/3UgVp7zBlQFoFnLTO2uWp/muLEWGl67gBq9MO3brKX\
  fGhi3kOzywzwPTuq+cVQDyEN7aL0SxCb3Hc4IdqDaMg8qHUyObpPitDQIDAQABMA0\
  GCSqGSIb3DQEBCwUAA4IBAQBnYFK0eYHy+hVf2D58usj39lhL5znb/q9G35GBd/Xs\
  WfCEwHuLOSZSUmG71bZtrOcx0ptle9bp2kKl4HlSTTfbtpuG5onSa3swRNhtKtUy5\
  NH9W/FLViKWfoPS3kwoEpC1XqKY6l7evoTCtS+kTQRSrCe4vbNprCAZRxz6z1nEeC\
  guNMk38yTRvx8ihZpVOuU+Ih+dOtVe/ex5IAPYxlQsvtfhsUZqc7IyCcy72WHnRHl\
  Ufn3pJm0S5270+Yls3Iv6h3oBAP19i906UjiUTNH3g0xMW+V4uLxgyckt4wD4Mlyv\
  jnaQ7Z3sR6EsXMocAbXHIAJhwKdtU/fLgdwL5vtx"
      }
      "display": {
        "name": "My Client Display Name",
        "uri": "https://client.foo/"
      },
    },
    "subject": {
        "formats": ["iss_sub", "opaque"]
    }
}
]]></sourcecode></figure>

<t>The verifier compares the TLS client certificate presented during
mutual TLS negotiation to the expected key of the signer. Since the
TLS connection covers the entire message, there are no additional
requirements to check.</t>

<t>Note that in many instances, the verifier will not do a full certificate
chain validation of the presented TLS client certificate, as the
means of trust for this certificate could be in something other than
a PKI system, such as a static registration or trust-on-first-use.
See <xref target="security-mtls"/> and <xref target="security-mtls-patterns"/> for some additional
considerations for this key proofing method.</t>

<section anchor="key-rotation-using-mtls"><name>Key Rotation using MTLS</name>

<t>Since it is not possible to present two client authenticated certificates to a mutual TLS
connection simultaneously, dynamic key rotation for this proofing method is not defined.
Instead, key rotation for MTLS-based client instances is expected to be managed through
deployment practices, as discussed in <xref target="security-mtls-patterns"/>.</t>

</section>
</section>
<section anchor="detached-jws"><name>Detached JWS</name>

<t>This method is indicated by the method value <spanx style="verb">jwsd</spanx> in string form.</t>

<figure><sourcecode type="json"><![CDATA[
{
    "proof": "jwsd"
}
]]></sourcecode></figure>

<t>The signer creates a JSON Web Signature (JWS) <xref target="RFC7515"/> object as follows:</t>

<t>To protect the request, the JOSE header of the signature contains the following
claims:</t>

<dl>
  <dt><spanx style="verb">kid</spanx> (string):</dt>
  <dd>
    <t>The key identifier. <bcp14>REQUIRED</bcp14> if the key is presented in JWK format, this
<bcp14>MUST</bcp14> be the value of the <spanx style="verb">kid</spanx> field of the key.</t>
  </dd>
  <dt><spanx style="verb">alg</spanx> (string):</dt>
  <dd>
    <t>The algorithm used to sign the request. <bcp14>MUST</bcp14> be appropriate to the key presented.
If the key is presented as a JWK, this <bcp14>MUST</bcp14> be equal to the <spanx style="verb">alg</spanx> parameter of the key. <bcp14>MUST NOT</bcp14> be <spanx style="verb">none</spanx>.
<bcp14>REQUIRED</bcp14>.</t>
  </dd>
  <dt><spanx style="verb">typ</spanx> (string):</dt>
  <dd>
    <t>The type header, value "gnap-binding+jwsd". <bcp14>REQUIRED</bcp14>.</t>
  </dd>
  <dt><spanx style="verb">htm</spanx> (string):</dt>
  <dd>
    <t>The HTTP Method used to make this request, as a case-sensitive ASCII string. Note that most public HTTP methods are in uppercase ASCII by convention. <bcp14>REQUIRED</bcp14>.</t>
  </dd>
  <dt><spanx style="verb">uri</spanx> (string):</dt>
  <dd>
    <t>The HTTP URI used for this request. This value <bcp14>MUST</bcp14> be an absolute URI, including all path and query components and no fragment component. <bcp14>REQUIRED</bcp14>.</t>
  </dd>
  <dt><spanx style="verb">created</spanx> (integer):</dt>
  <dd>
    <t>A timestamp of when the signature was created, in integer seconds since UNIX Epoch. <bcp14>REQUIRED</bcp14>.</t>
  </dd>
</dl>

<t>When the request is bound to an access token, the JOSE header <bcp14>MUST</bcp14> also include the following:</t>

<dl>
  <dt><spanx style="verb">ath</spanx> (string):</dt>
  <dd>
    <t>The hash of the access token. The value <bcp14>MUST</bcp14> be the
result of Base64url encoding (with no padding) the SHA-256 digest
of the ASCII encoding of the associated access token's value. <bcp14>REQUIRED</bcp14>.</t>
  </dd>
</dl>

<t>If the HTTP request has content, such as an HTTP POST or PUT method,
the payload of the JWS object is the Base64url encoding (without padding)
of the SHA256 digest of the bytes of the content.
If the request being made does not have content, such as
an HTTP GET, OPTIONS, or DELETE method, the JWS signature is
calculated over an empty payload.</t>

<t>The signer presents the signed object in compact form
<xref target="RFC7515"/> in the Detached-JWS HTTP Header field.</t>

<t>In this example, the JOSE Header contains the following parameters:</t>

<figure><sourcecode type="json"><![CDATA[
{
    "alg": "RS256",
    "kid": "gnap-rsa",
    "uri": "https://server.example.com/gnap",
    "htm": "POST",
    "typ": "gnap-binding+jwsd",
    "created": 1618884475
}
]]></sourcecode></figure>

<t>The request content is the following JSON object:</t>

<figure><sourcecode type="json"><![CDATA[
NOTE: '\' line wrapping per RFC 8792

{
    "access_token": {
        "access": [
            "dolphin-metadata"
        ]
    },
    "interact": {
        "start": ["redirect"],
        "finish": {
            "method": "redirect",
            "uri": "https://client.foo/callback",
            "nonce": "VJLO6A4CAYLBXHTR0KRO"
        }
    },
    "client": {
      "key": {
        "proof": "jwsd",
        "jwk": {
            "kid": "gnap-rsa",
            "kty": "RSA",
            "e": "AQAB",
            "alg": "RS256",
            "n": "hYOJ-XOKISdMMShn_G4W9m20mT0VWtQBsmBBkI2cmRt4Ai8Bf\
  YdHsFzAtYKOjpBR1RpKpJmVKxIGNy0g6Z3ad2XYsh8KowlyVy8IkZ8NMwSrcUIBZG\
  YXjHpwjzvfGvXH_5KJlnR3_uRUp4Z4Ujk2bCaKegDn11V2vxE41hqaPUnhRZxe0jR\
  ETddzsE3mu1SK8dTCROjwUl14mUNo8iTrTm4n0qDadz8BkPo-uv4BC0bunS0K3bA_\
  3UgVp7zBlQFoFnLTO2uWp_muLEWGl67gBq9MO3brKXfGhi3kOzywzwPTuq-cVQDyE\
  N7aL0SxCb3Hc4IdqDaMg8qHUyObpPitDQ"
        }
      }
      "display": {
        "name": "My Client Display Name",
        "uri": "https://client.foo/"
      },
    }
}
]]></sourcecode></figure>

<t>This is hashed to the following Base64 encoded value:</t>

<figure><artwork><![CDATA[
PGiVuOZUcN1tRtUS6tx2b4cBgw9mPgXG3IPB3wY7ctc
]]></artwork></figure>

<t>This leads to the following full HTTP request message:</t>

<figure><sourcecode type="http-message"><![CDATA[
NOTE: '\' line wrapping per RFC 8792

POST /gnap HTTP/1.1
Host: server.example.com
Content-Type: application/json
Content-Length: 983
Detached-JWS: eyJhbGciOiJSUzI1NiIsImNyZWF0ZWQiOjE2MTg4ODQ0NzUsImh0b\
  SI6IlBPU1QiLCJraWQiOiJnbmFwLXJzYSIsInR5cCI6ImduYXAtYmluZGluZytqd3\
  NkIiwidXJpIjoiaHR0cHM6Ly9zZXJ2ZXIuZXhhbXBsZS5jb20vZ25hcCJ9.PGiVuO\
  ZUcN1tRtUS6tx2b4cBgw9mPgXG3IPB3wY7ctc.fUq-SV-A1iFN2MwCRW_yolVtT2_\
  TZA2h5YeXUoi5F2Q2iToC0Tc4drYFOSHIX68knd68RUA7yHqCVP-ZQEd6aL32H69e\
  9zuMiw6O_s4TBKB3vDOvwrhYtDH6fX2hP70cQoO-47OwbqP-ifkrvI3hVgMX9TfjV\
  eKNwnhoNnw3vbu7SNKeqJEbbwZfpESaGepS52xNBlDNMYBQQXxM9OqKJaXffzLFEl\
  -Xe0UnfolVtBraz3aPrPy1C6a4uT7wLda3PaTOVtgysxzii3oJWpuz0WP5kRujzDF\
  wX_EOzW0jsjCSkL-PXaKSpZgEjNjKDMg9irSxUISt1C1T6q3SzRgfuQ


{
    "access_token": {
        "access": [
            "dolphin-metadata"
        ]
    },
    "interact": {
        "start": ["redirect"],
        "finish": {
            "method": "redirect",
            "uri": "https://client.foo/callback",
            "nonce": "VJLO6A4CAYLBXHTR0KRO"
        }
    },
    "client": {
      "key": {
        "proof": "jwsd",
        "jwk": {
            "kid": "gnap-rsa",
            "kty": "RSA",
            "e": "AQAB",
            "alg": "RS256",
            "n": "hYOJ-XOKISdMMShn_G4W9m20mT0VWtQBsmBBkI2cmRt4Ai8Bf\
  YdHsFzAtYKOjpBR1RpKpJmVKxIGNy0g6Z3ad2XYsh8KowlyVy8IkZ8NMwSrcUIBZG\
  YXjHpwjzvfGvXH_5KJlnR3_uRUp4Z4Ujk2bCaKegDn11V2vxE41hqaPUnhRZxe0jR\
  ETddzsE3mu1SK8dTCROjwUl14mUNo8iTrTm4n0qDadz8BkPo-uv4BC0bunS0K3bA_\
  3UgVp7zBlQFoFnLTO2uWp_muLEWGl67gBq9MO3brKXfGhi3kOzywzwPTuq-cVQDyE\
  N7aL0SxCb3Hc4IdqDaMg8qHUyObpPitDQ"
        }
      }
      "display": {
        "name": "My Client Display Name",
        "uri": "https://client.foo/"
      },
    }
}
]]></sourcecode></figure>

<t>When the verifier receives the Detached-JWS header, it <bcp14>MUST</bcp14> parse and
validate the JWS object. The signature <bcp14>MUST</bcp14> be validated against the
expected key of the signer. If the HTTP message request contains
content, the verifier <bcp14>MUST</bcp14> calculate the hash of the content just as
the signer does, with no normalization or transformation of the request.
All required fields <bcp14>MUST</bcp14> be present
and their values <bcp14>MUST</bcp14> be valid. All fields <bcp14>MUST</bcp14> match the corresponding portions of the HTTP
message. For example, the <spanx style="verb">htm</spanx> field of the JWS header has to be the same as the HTTP verb
used in the request.</t>

<t>Note that this proof method depends on a specific cryptographic algorithm, SHA-256, in two ways:
the <spanx style="verb">ath</spanx> hash algorithm is hardcoded, and computing the payload of the detached/attached signature
also uses a hardcoded hash. A future version of this document may address crypto-agility for both
these uses by replacing ath with a new header that upgrades the algorithm, and possibly defining a
new JWS header that indicates the HTTP content's hash method.</t>

<section anchor="key-rotation-using-detached-jws"><name>Key Rotation using Detached JWS</name>

<t>When rotating a key using Detached JWS, the message, which includes the new public key value or
reference, is first signed with the old key as described above using a JWS object with <spanx style="verb">typ</spanx> header value
"gnap-binding-rotation+jwsd". The value of the JWS object is then taken as the payload of a new JWS
object, to be signed by the new key using the parameters above.</t>

<t>The value of the new JWS object is sent in the Detached-JWS header.</t>

</section>
</section>
<section anchor="attached-jws"><name>Attached JWS</name>

<t>This method is indicated by the method value <spanx style="verb">jws</spanx> in string form.</t>

<figure><sourcecode type="json"><![CDATA[
{
    "proof": "jws"
}
]]></sourcecode></figure>

<t>The signer creates a JWS <xref target="RFC7515"/> object as follows:</t>

<t>To protect the request, the JWS header contains the following claims.</t>

<dl>
  <dt><spanx style="verb">kid</spanx> (string):</dt>
  <dd>
    <t>The key identifier. <bcp14>REQUIRED</bcp14> if the key is presented in JWK format, this
<bcp14>MUST</bcp14> be the value of the <spanx style="verb">kid</spanx> field of the key.</t>
  </dd>
  <dt><spanx style="verb">alg</spanx> (string):</dt>
  <dd>
    <t>The algorithm used to sign the request. <bcp14>MUST</bcp14> be appropriate to the key presented.
If the key is presented as a JWK, this <bcp14>MUST</bcp14> be equal to the <spanx style="verb">alg</spanx> parameter of the key. <bcp14>MUST NOT</bcp14> be <spanx style="verb">none</spanx>.
<bcp14>REQUIRED</bcp14>.</t>
  </dd>
  <dt><spanx style="verb">typ</spanx> (string):</dt>
  <dd>
    <t>The type header, value "gnap-binding+jwsd". <bcp14>REQUIRED</bcp14>.</t>
  </dd>
  <dt><spanx style="verb">htm</spanx> (string):</dt>
  <dd>
    <t>The HTTP Method used to make this request, as a case-sensitive ASCII string. (Note that most public HTTP methods are in uppercase.) <bcp14>REQUIRED</bcp14>.</t>
  </dd>
  <dt><spanx style="verb">uri</spanx> (string):</dt>
  <dd>
    <t>The HTTP URI used for this request, including all path and query components and no fragment component. <bcp14>REQUIRED</bcp14>.</t>
  </dd>
  <dt><spanx style="verb">created</spanx> (integer):</dt>
  <dd>
    <t>A timestamp of when the signature was created, in integer seconds since UNIX Epoch. <bcp14>REQUIRED</bcp14>.</t>
  </dd>
</dl>

<t>When the request is bound to an access token, the JOSE header <bcp14>MUST</bcp14> also include the following:</t>

<dl>
  <dt><spanx style="verb">ath</spanx> (string):</dt>
  <dd>
    <t>The hash of the access token. The value <bcp14>MUST</bcp14> be the
result of Base64url encoding (with no padding) the SHA-256 digest
of the ASCII encoding of the associated access token's value. <bcp14>REQUIRED</bcp14>.</t>
  </dd>
</dl>

<t>If the HTTP request has content, such as an HTTP POST or PUT method,
the payload of the JWS object is the JSON serialized content of the request, and
the object is signed according to JWS and serialized into compact form <xref target="RFC7515"/>.
The signer presents the JWS as the content of the request along with a
content type of <spanx style="verb">application/jose</spanx>. The verifier
<bcp14>MUST</bcp14> extract the payload of the JWS and treat it as the request content
for further processing.</t>

<t>If the request being made does not have content, such as
an HTTP GET, OPTIONS, or DELETE method, the JWS signature is
calculated over an empty payload and passed in the <spanx style="verb">Detached-JWS</spanx>
header as described in <xref target="detached-jws"/>.</t>

<t>In this example, the JOSE header contains the following parameters:</t>

<figure><sourcecode type="json"><![CDATA[
{
    "alg": "RS256",
    "kid": "gnap-rsa",
    "uri": "https://server.example.com/gnap",
    "htm": "POST",
    "typ": "gnap-binding+jwsd",
    "created": 1618884475
}
]]></sourcecode></figure>

<t>The request content, used as the JWS Payload, is the following JSON object:</t>

<figure><sourcecode type="json"><![CDATA[
NOTE: '\' line wrapping per RFC 8792

{
    "access_token": {
        "access": [
            "dolphin-metadata"
        ]
    },
    "interact": {
        "start": ["redirect"],
        "finish": {
            "method": "redirect",
            "uri": "https://client.foo/callback",
            "nonce": "VJLO6A4CAYLBXHTR0KRO"
        }
    },
    "client": {
      "key": {
        "proof": "jws",
        "jwk": {
            "kid": "gnap-rsa",
            "kty": "RSA",
            "e": "AQAB",
            "alg": "RS256",
            "n": "hYOJ-XOKISdMMShn_G4W9m20mT0VWtQBsmBBkI2cmRt4Ai8Bf\
  YdHsFzAtYKOjpBR1RpKpJmVKxIGNy0g6Z3ad2XYsh8KowlyVy8IkZ8NMwSrcUIBZG\
  YXjHpwjzvfGvXH_5KJlnR3_uRUp4Z4Ujk2bCaKegDn11V2vxE41hqaPUnhRZxe0jR\
  ETddzsE3mu1SK8dTCROjwUl14mUNo8iTrTm4n0qDadz8BkPo-uv4BC0bunS0K3bA_\
  3UgVp7zBlQFoFnLTO2uWp_muLEWGl67gBq9MO3brKXfGhi3kOzywzwPTuq-cVQDyE\
  N7aL0SxCb3Hc4IdqDaMg8qHUyObpPitDQ"
        }
      }
      "display": {
        "name": "My Client Display Name",
        "uri": "https://client.foo/"
      },
    },
    "subject": {
        "formats": ["iss_sub", "opaque"]
    }
}

]]></sourcecode></figure>

<t>This leads to the following full HTTP request message:</t>

<figure><sourcecode type="http-message"><![CDATA[
NOTE: '\' line wrapping per RFC 8792

POST /gnap HTTP/1.1
Host: server.example.com
Content-Type: application/jose
Content-Length: 1047

eyJhbGciOiJSUzI1NiIsImNyZWF0ZWQiOjE2MTg4ODQ0NzUsImh0bSI6IlBPU1QiLCJ\
raWQiOiJnbmFwLXJzYSIsInR5cCI6ImduYXAtYmluZGluZytqd3NkIiwidXJpIjoiaH\
R0cHM6Ly9zZXJ2ZXIuZXhhbXBsZS5jb20vZ25hcCJ9.CnsKICAgICJhY2Nlc3NfdG9r\
ZW4iOiB7CiAgICAgICAgImFjY2VzcyI6IFsKICAgICAgICAgICAgImRvbHBoaW4tbWV\
0YWRhdGEiCiAgICAgICAgXQogICAgfSwKICAgICJpbnRlcmFjdCI6IHsKICAgICAgIC\
Aic3RhcnQiOiBbInJlZGlyZWN0Il0sCiAgICAgICAgImZpbmlzaCI6IHsKICAgICAgI\
CAgICAgIm1ldGhvZCI6ICJyZWRpcmVjdCIsCiAgICAgICAgICAgICJ1cmkiOiAiaHR0\
cHM6Ly9jbGllbnQuZm9vL2NhbGxiYWNrIiwKICAgICAgICAgICAgIm5vbmNlIjogIlZ\
KTE82QTRDQVlMQlhIVFIwS1JPIgogICAgICAgIH0KICAgIH0sCiAgICAiY2xpZW50Ij\
ogewogICAgICAicHJvb2YiOiAiandzIiwKICAgICAgImtleSI6IHsKICAgICAgICAia\
ndrIjogewogICAgICAgICAgICAia2lkIjogImduYXAtcnNhIiwKICAgICAgICAgICAg\
Imt0eSI6ICJSU0EiLAogICAgICAgICAgICAiZSI6ICJBUUFCIiwKICAgICAgICAgICA\
gImFsZyI6ICJSUzI1NiIsCiAgICAgICAgICAgICJuIjogImhZT0otWE9LSVNkTU1TaG\
5fRzRXOW0yMG1UMFZXdFFCc21CQmtJMmNtUnQ0QWk4QmZZZEhzRnpBdFlLT2pwQlIxU\
nBLcEptVkt4SUdOeTBnNlozYWQyWFlzaDhLb3dseVZ5OElrWjhOTXdTcmNVSUJaR1lY\
akhwd2p6dmZHdlhIXzVLSmxuUjNfdVJVcDRaNFVqazJiQ2FLZWdEbjExVjJ2eEU0MWh\
xYVBVbmhSWnhlMGpSRVRkZHpzRTNtdTFTSzhkVENST2p3VWwxNG1VTm84aVRyVG00bj\
BxRGFkejhCa1BvLXV2NEJDMGJ1blMwSzNiQV8zVWdWcDd6QmxRRm9GbkxUTzJ1V3Bfb\
XVMRVdHbDY3Z0JxOU1PM2JyS1hmR2hpM2tPenl3endQVHVxLWNWUUR5RU43YUwwU3hD\
YjNIYzRJZHFEYU1nOHFIVXlPYnBQaXREUSIKICAgICAgICB9CiAgICAgIH0KICAgICA\
gImRpc3BsYXkiOiB7CiAgICAgICAgIm5hbWUiOiAiTXkgQ2xpZW50IERpc3BsYXkgTm\
FtZSIsCiAgICAgICAgInVyaSI6ICJodHRwczovL2NsaWVudC5mb28vIgogICAgICB9L\
AogICAgfSwKICAgICJzdWJqZWN0IjogewogICAgICAgICJmb3JtYXRzIjogWyJpc3Nf\
c3ViIiwgIm9wYXF1ZSJdCiAgICB9Cn0K.MwNoVMQp5hVxI0mCs9LlOUdFtkDXaA1_eT\
vOXq7DOGrtDKH7q4vP2xUq3fH2jRAZqnobo0WdPP3eM3NH5QUjW8pa6_QpwdIWkK7r-\
u_52puE0lPBp7J4U2w4l9gIbg8iknsmWmXeY5F6wiGT8ptfuEYGgmloAJd9LIeNvD3U\
LW2h2dz1Pn2eDnbyvgB0Ugae0BoZB4f69fKWj8Z9wvTIjk1LZJN1PcL7_zT8Lrlic9a\
PyzT7Q9ovkd1s-4whE7TrnGUzFc5mgWUn_gsOpsP5mIIljoEEv-FqOW2RyNYulOZl0Q\
8EnnDHV_vPzrHlUarbGg4YffgtwkQhdK72-JOxYQ
]]></sourcecode></figure>

<t>When the verifier receives an attached JWS request, it <bcp14>MUST</bcp14> parse and
validate the JWS object. The signature <bcp14>MUST</bcp14> be validated against the
expected key of the signer. All required fields <bcp14>MUST</bcp14> be present
and their values <bcp14>MUST</bcp14> be valid. All fields <bcp14>MUST</bcp14> match the corresponding portions of the HTTP
message. For example, the <spanx style="verb">htm</spanx> field of the JWS header has to be the same as the HTTP verb
used in the request.</t>

<t>Note that this proof method depends on a specific cryptographic algorithm, SHA-256, in two ways:
the <spanx style="verb">ath</spanx> hash algorithm is hardcoded, and computing the payload of the detached/attached signature
also uses a hardcoded hash. A future version of this document may address crypto-agility for both
these uses by replacing ath with a new header that upgrades the algorithm, and possibly defining a
new header that indicates the HTTP content's hash method.</t>

<section anchor="key-rotation-using-attached-jws"><name>Key Rotation using Attached JWS</name>

<t>When rotating a key using Attached JWS, the message, which includes the new public key value or reference, is first signed with the old key using a JWS object with <spanx style="verb">typ</spanx> header value "gnap-binding-rotation+jwsd". The value of the JWS object is then taken as the payload of a new JWS object, to be signed by the new key.</t>

</section>
</section>
</section>
</section>
<section anchor="resource-access-rights"><name>Resource Access Rights</name>

<t>GNAP provides a rich structure for describing the protected resources
hosted by RSs and accessed by client software. This structure is used when
the client instance <xref target="request-token">requests an access token</xref> and when
an <xref target="response-token">access token is returned</xref>. GNAP's structure is
designed to be analogous to the OAuth 2.0 Rich Authorization Request
data structure defined in <xref target="RFC9396"/>.</t>

<t>The root of this structure is a JSON array. The elements of the JSON
array represent rights of access that are associated with the
access token. Individual rights of access can be defined by the RS as
either an object or a string. The resulting access is the union of all elements
within the array.</t>

<t>The access associated with the access token is described
using objects that each contain multiple
dimensions of access. Each object contains a <bcp14>REQUIRED</bcp14> <spanx style="verb">type</spanx>
property that determines the type of API that the token is used for and
the structure of the rest of the object. There is no expected
interoperability between different <spanx style="verb">type</spanx> definitions.</t>

<dl>
  <dt><spanx style="verb">type</spanx> (string):</dt>
  <dd>
    <t>The type of resource request as a string. This field <bcp14>MAY</bcp14>
    define which other fields are allowed in the request object.
    <bcp14>REQUIRED</bcp14>.</t>
  </dd>
</dl>

<t>The value of the <spanx style="verb">type</spanx> field is under the control of the AS.
This field <bcp14>MUST</bcp14> be compared using an exact byte match of the string
value against known types by the AS.  The AS <bcp14>MUST</bcp14> ensure that there
is no collision between different authorization data types that it
supports. The AS <bcp14>MUST NOT</bcp14> do any collation or normalization of data
types during comparison. It is <bcp14>RECOMMENDED</bcp14> that designers of general-purpose
APIs use a URI for this field to avoid collisions between multiple
API types protected by a single AS.</t>

<t>While it is expected that many APIs will have their own properties,
this specification defines a set of common data fields that are designed to be
usable across different types of APIs. This specification does not require the
use of these common fields by an API definition but, instead, provides them as
reusable generic components for API designers to make use of. The allowable
values of all fields are determined by the API being protected, as defined
by a particular <spanx style="verb">type</spanx> value.</t>

<dl>
  <dt><spanx style="verb">actions</spanx> (array of strings):</dt>
  <dd>
    <t>The types of actions the client instance will take at the RS as an array of strings.
  For example, a client instance asking for a combination of "read" and "write" access.</t>
  </dd>
  <dt><spanx style="verb">locations</spanx> (array of strings):</dt>
  <dd>
    <t>The location of the RS as an array of
  strings. These strings are typically URIs identifying the
  location of the RS.</t>
  </dd>
  <dt><spanx style="verb">datatypes</spanx> (array of strings):</dt>
  <dd>
    <t>The kinds of data available to the client instance at the RS's API as an
  array of strings. For example, a client instance asking for access to
  raw "image" data and "metadata" at a photograph API.</t>
  </dd>
  <dt><spanx style="verb">identifier</spanx> (string):</dt>
  <dd>
    <t>A string identifier indicating a specific resource at the RS.
  For example, a patient identifier for a medical API or
  a bank account number for a financial API.</t>
  </dd>
  <dt><spanx style="verb">privileges</spanx> (array of strings):</dt>
  <dd>
    <t>The types or levels of privilege being requested at the resource. For example, a client
  instance asking for administrative level access, or access when the resource owner
  is no longer online.</t>
  </dd>
</dl>

<t>The following non-normative example is describing three kinds of access (read, write, delete) to each of
two different locations and two different data types (metadata, images) for a single access token
using the fictitious <spanx style="verb">photo-api</spanx> type definition.</t>

<figure><sourcecode type="json"><![CDATA[
"access": [
    {
        "type": "photo-api",
        "actions": [
            "read",
            "write",
            "delete"
        ],
        "locations": [
            "https://server.example.net/",
            "https://resource.local/other"
        ],
        "datatypes": [
            "metadata",
            "images"
        ]
    }
]
]]></sourcecode></figure>

<t>While the exact semantics of interpreting the fields of an access
request object is subject to the definition of the <spanx style="verb">type</spanx>,
it is expected that the access requested for each object in the array
is the cross-product of all fields of the object. That is to
say, the object represents a request for all <spanx style="verb">actions</spanx> listed
to be used at all <spanx style="verb">locations</spanx> listed for all possible <spanx style="verb">datatypes</spanx>
listed within the object. Assuming the request above was granted,
the client instance could assume that it
would be able to do a <spanx style="verb">read</spanx> action against the <spanx style="verb">images</spanx> on the first server
as well as a <spanx style="verb">delete</spanx> action on the <spanx style="verb">metadata</spanx> of the second server, or any other
combination of these fields, using the same access token.</t>

<t>To request a different combination of access,
such as requesting one of the possible <spanx style="verb">actions</spanx> against one of the possible <spanx style="verb">locations</spanx>
and a different choice of possible <spanx style="verb">actions</spanx> against a different one of the possible <spanx style="verb">locations</spanx>, the
client instance can include multiple separate objects in the <spanx style="verb">resources</spanx> array.
The total access rights for the resulting access
token is the union of all objects. The following non-normative example uses the same fictitious <spanx style="verb">photo-api</spanx>
type definition to request a single access token with more specifically
targeted access rights by using two discrete objects within the request.</t>

<figure><sourcecode type="json"><![CDATA[
"access": [
    {
        "type": "photo-api",
        "actions": [
            "read"
        ],
        "locations": [
            "https://server.example.net/"
        ],
        "datatypes": [
            "images"
        ]
    },
    {
        "type": "photo-api",
        "actions": [
            "write",
            "delete"
        ],
        "locations": [
            "https://resource.local/other"
        ],
        "datatypes": [
            "metadata"
        ]
    }
]
]]></sourcecode></figure>

<t>The access requested here is for <spanx style="verb">read</spanx> access to <spanx style="verb">images</spanx> on one server
while simultaneously requesting <spanx style="verb">write</spanx> and <spanx style="verb">delete</spanx> access for <spanx style="verb">metadata</spanx> on a different
server, but importantly without requesting <spanx style="verb">write</spanx> or <spanx style="verb">delete</spanx> access to <spanx style="verb">images</spanx> on the
first server.</t>

<t>It is anticipated that API designers will use a combination
of common fields defined in this specification as well as
fields specific to the API itself. The following non-normative
example shows the use of both common and API-specific fields as
part of two different fictitious API <spanx style="verb">type</spanx> values. The first
access request includes the <spanx style="verb">actions</spanx>, <spanx style="verb">locations</spanx>, and <spanx style="verb">datatypes</spanx>
fields specified here as well as the API-specific <spanx style="verb">geolocation</spanx>
field. The second access request includes the <spanx style="verb">actions</spanx> and
<spanx style="verb">identifier</spanx> fields specified here as well as the API-specific
<spanx style="verb">currency</spanx> field.</t>

<figure><sourcecode type="json"><![CDATA[
"access": [
    {
        "type": "photo-api",
        "actions": [
            "read",
            "write"
        ],
        "locations": [
            "https://server.example.net/",
            "https://resource.local/other"
        ],
        "datatypes": [
            "metadata",
            "images"
        ],
        "geolocation": [
            { lat: -32.364, lng: 153.207 },
            { lat: -35.364, lng: 158.207 }
        ]
    },
    {
        "type": "financial-transaction",
        "actions": [
            "withdraw"
        ],
        "identifier": "account-14-32-32-3",
        "currency": "USD"
    }
]
]]></sourcecode></figure>

<t>If this request is approved,
the resulting access token's access rights will be
the union of the requested types of access for each of the two APIs, just as above.</t>

<section anchor="resource-access-reference"><name>Requesting Resources By Reference</name>

<t>Instead of sending an <xref target="resource-access-rights">object describing the requested resource</xref>,
access rights <bcp14>MAY</bcp14> be communicated as a string known to
the AS representing the access being requested. Just like access rights communicated
as an object, access rights communicated as reference strings indicate a specific
access at a protected resource. In the following non-normative example,
three distinct resource access rights are being requested.</t>

<figure><sourcecode type="json"><![CDATA[
"access": [
    "read", "dolphin-metadata", "some other thing"
]
]]></sourcecode></figure>

<t>This value is opaque to the client instance and <bcp14>MAY</bcp14> be any
valid JSON string, and therefore could include spaces, unicode
characters, and properly escaped string sequences. However, in some
situations the value is intended to be
seen and understood by the client software's developer. In such cases, the
API designer choosing any such human-readable strings <bcp14>SHOULD</bcp14> take steps
to ensure the string values are not easily confused by a developer,
such as by limiting the strings to easily disambiguated characters.</t>

<t>This functionality is similar in practice to OAuth 2.0's <spanx style="verb">scope</spanx> parameter <xref target="RFC6749"/>, where a single string
represents the set of access rights requested by the client instance. As such, the reference
string could contain any valid OAuth 2.0 scope value as in <xref target="example-oauth2"/>. Note that the reference
string here is not bound to the same character restrictions as in OAuth 2.0's <spanx style="verb">scope</spanx> definition.</t>

<t>A single <spanx style="verb">access</spanx> array <bcp14>MAY</bcp14> include both object-type and
string-type resource items. In this non-normative example,
the client instance is requesting access to a <spanx style="verb">photo-api</spanx> and <spanx style="verb">financial-transaction</spanx> API type
as well as the reference values of <spanx style="verb">read</spanx>, <spanx style="verb">dolphin-metadata</spanx>, and <spanx style="verb">some other thing</spanx>.</t>

<figure><sourcecode type="json"><![CDATA[
"access": [
    {
        "type": "photo-api",
        "actions": [
            "read",
            "write",
            "delete"
        ],
        "locations": [
            "https://server.example.net/",
            "https://resource.local/other"
        ],
        "datatypes": [
            "metadata",
            "images"
        ]
    },
    "read",
    "dolphin-metadata",
    {
        "type": "financial-transaction",
        "actions": [
            "withdraw"
        ],
        "identifier": "account-14-32-32-3",
        "currency": "USD"
    },
    "some other thing"
]
]]></sourcecode></figure>

<t>The requested access is the union of all elements of the array, including both objects and
reference strings.</t>

<t>In order to facilitate the use of both object and reference strings to access the same
kind of APIs, the API designer can define a clear mapping between these forms.
One possible approach for choosing reference string values is to use the same value as the
<spanx style="verb">type</spanx> parameter from the fully-specified object, with the API defining a set of default
behaviors in this case. For example, an API definition could declare the following string:</t>

<figure><sourcecode type="json"><![CDATA[
"access": [
    "photo-api"
]
]]></sourcecode></figure>

<t>As being equivalent to the following fully-defined object:</t>

<figure><sourcecode type="json"><![CDATA[
"access": [
    {
        "type": "photo-api",
        "actions": [ "read", "write", "delete" ],
        "datatypes": [ "metadata", "image" ]
    }
]
]]></sourcecode></figure>

<t>The exact mechanisms for relating reference strings is up to the API designer. These are enforced
by the AS, and the details are out of scope for this specification.</t>

</section>
</section>
<section anchor="discovery"><name>Discovery</name>

<t>By design, GNAP minimizes the need for any pre-flight
discovery. To begin a request, the client instance only needs to know the grant endpoint of
the AS (a single URI) and which keys it will use to sign the request. Everything else
can be negotiated dynamically in the course of the protocol.</t>

<t>However, the AS can have limits on its allowed functionality. If the
client instance wants to optimize its calls to the AS before making a request, it <bcp14>MAY</bcp14>
send an HTTP OPTIONS request to the grant request endpoint to retrieve the
server's discovery information. The AS <bcp14>MUST</bcp14> respond with a JSON document with Content-Type
<spanx style="verb">application/json</spanx> containing a single object with the following fields:</t>

<dl>
  <dt><spanx style="verb">grant_request_endpoint</spanx> (string):</dt>
  <dd>
    <t>The location of the
  AS's grant request endpoint. The location <bcp14>MUST</bcp14> be an absolute URL <xref target="RFC3986"/>
  with a scheme component (which <bcp14>MUST</bcp14> be "https"), a host component, and optionally,
  port, path and query components and no fragment components. This URL <bcp14>MUST</bcp14>
  match the URL the client instance used to make the discovery request.
  <bcp14>REQUIRED</bcp14>.</t>
  </dd>
  <dt><spanx style="verb">interaction_start_modes_supported</spanx> (array of strings):</dt>
  <dd>
    <t>A list of the AS's interaction start methods. The values of this list correspond to the
  possible values for the <xref target="request-interact-start">interaction start section</xref> of the request and
  <bcp14>MUST</bcp14> be values from the <xref target="IANA-interaction-start-modes">GNAP Interaction Start Modes Registry</xref>.
  <bcp14>OPTIONAL</bcp14>.</t>
  </dd>
  <dt><spanx style="verb">interaction_finish_methods_supported</spanx> (array of strings):</dt>
  <dd>
    <t>A list of the AS's interaction finish methods. The values of this list correspond to the
  possible values for the method element of the <xref target="request-interact-finish">interaction finish section</xref> of the request and <bcp14>MUST</bcp14> be values from
  the <xref target="IANA-interaction-finish-methods">GNAP Interaction Finish Methods Registry</xref>.
  <bcp14>OPTIONAL</bcp14>.</t>
  </dd>
  <dt><spanx style="verb">key_proofs_supported</spanx> (array of strings):</dt>
  <dd>
    <t>A list of the AS's supported key
  proofing mechanisms. The values of this list correspond to possible
  values of the <spanx style="verb">proof</spanx> field of the
  <xref target="key-format">key section</xref> of the request and <bcp14>MUST</bcp14> be values from the
  <xref target="IANA-key-proof-methods">GNAP Key Proofing Methods Registry</xref>.
  <bcp14>OPTIONAL</bcp14>.</t>
  </dd>
  <dt><spanx style="verb">sub_id_formats_supported</spanx> (array of strings):</dt>
  <dd>
    <t>A list of the AS's supported
  subject identifier formats. The values of this list correspond to possible values
  of the <xref target="request-subject">subject identifier section</xref> of the request and <bcp14>MUST</bcp14>
  be values from the Subject Identifier Formats Registry established by
  <xref target="I-D.ietf-secevent-subject-identifiers"/>.
  <bcp14>OPTIONAL</bcp14>.</t>
  </dd>
  <dt><spanx style="verb">assertion_formats_supported</spanx> (array of strings):</dt>
  <dd>
    <t>A list of the AS's supported
  assertion formats. The values of this list correspond to possible
  values of the <xref target="request-subject">subject assertion section</xref> of the request and <bcp14>MUST</bcp14>
  be values from the <xref target="IANA-assertion-formats">GNAP Assertion Formats Registry</xref>.
  <bcp14>OPTIONAL</bcp14>.</t>
  </dd>
  <dt><spanx style="verb">key_rotation_supported</spanx> (boolean):</dt>
  <dd>
    <t>The boolean "true" indicates that <xref target="rotate-access-token-key">rotation of access token bound keys by the client</xref> is supported by the AS.
  The absence of this field or a boolean "false" value indicates that this feature is not supported.</t>
  </dd>
</dl>

<t>The information returned from this method is for optimization
purposes only. The AS <bcp14>MAY</bcp14> deny any request, or any portion of a request,
even if it lists a capability as supported. For example, a given client instance
can be registered with the <spanx style="verb">mtls</spanx> key proofing
mechanism, but the AS also returns other proofing methods from the discovery document, then the AS
will still deny a request from that client instance using a different proofing
mechanism. Similarly, an AS with <spanx style="verb">key_rotation_supported</spanx> set to "true" can still deny
any request for rotating any access token's key for a variety of reasons.</t>

<t>Additional fields can be defined the <xref target="IANA-as-discovery">GNAP Authorization Server Discovery Fields Registry</xref>.</t>

<section anchor="rs-request-without-token"><name>RS-first Method of AS Discovery</name>

<t>If the client instance calls an RS without an access token, or with an invalid access token, the RS <bcp14>SHOULD</bcp14> be explicit about the fact that GNAP needs to be used to access the resource by responding with the WWW-Authenticate header field and a GNAP challenge.</t>

<t>In some situations, the client instance might want to know with which specific AS it needs to negotiate for access to that RS.
The RS <bcp14>MAY</bcp14> additionally return the following <bcp14>OPTIONAL</bcp14> parameters:</t>

<dl>
  <dt><spanx style="verb">as_uri</spanx>:</dt>
  <dd>
    <t>The URI of the grant endpoint of the GNAP AS. Used by the client instance to call the AS to request an access token.</t>
  </dd>
  <dt><spanx style="verb">referrer</spanx>:</dt>
  <dd>
    <t>The URI of the GNAP RS. Sent by the client instance in the Referer header as part of the grant request.</t>
  </dd>
  <dt><spanx style="verb">access</spanx>:</dt>
  <dd>
    <t>An opaque access reference as defined in <xref target="resource-access-reference"/>.
  <bcp14>MUST</bcp14> be sufficient for at least the action the client instance was attempting to take at the RS and <bcp14>MAY</bcp14> allow additional access rights as well.
  Sent by the client as an access right in the grant request.</t>
  </dd>
</dl>

<t>The client instance <bcp14>SHOULD</bcp14> then use both the <spanx style="verb">referrer</spanx> and <spanx style="verb">access</spanx> parameters in its access token request. The client instance <bcp14>MUST</bcp14> check that the <spanx style="verb">referrer</spanx> parameter is equal to the URI of the RS using the simple string comparison method in <xref section="6.2.1" sectionFormat="of" target="RFC3986"/>.</t>

<t>The means for the RS to determine the value for the <spanx style="verb">access</spanx> reference are out of scope of this specification, but some dynamic methods are discussed in
<xref target="I-D.ietf-gnap-resource-servers"/>.</t>

<t>When receiving the following response from the RS:</t>

<figure><sourcecode type="http-message"><![CDATA[
NOTE: '\' line wrapping per RFC 8792

WWW-Authenticate: \
  GNAP as_uri=https://as.example/tx\
  ;access=FWWIKYBQ6U56NL1\
  ;referrer=https://rs.example
]]></sourcecode></figure>

<t>The client instance then makes a request to the <spanx style="verb">as_uri</spanx> as described in <xref target="request"/>, with the value of <spanx style="verb">referrer</spanx> passed as an HTTP Referer header field and the <spanx style="verb">access</spanx> reference passed unchanged into the <spanx style="verb">access</spanx> array in the <spanx style="verb">access_token</spanx> portion of the request. The client instance <bcp14>MAY</bcp14> request additional resources and other information.</t>

<t>In this non-normative example, the client instance is requesting a single access token using the opaque access reference <spanx style="verb">FWWIKYBQ6U56NL1</spanx> received from the RS in addition to the <spanx style="verb">dolphin-metadata</spanx> that the client instance has been configured with out of band.</t>

<figure><sourcecode type="http-message"><![CDATA[
POST /tx HTTP/1.1
Host: as.example
Referer: https://rs.example/resource
Content-Type: application/json
Signature-Input: sig1=...
Signature: sig1=...
Content-Digest: sha-256=...

{
    "access_token": {
        "access": [
            "FWWIKYBQ6U56NL1",
            "dolphin-metadata"
        ]
    },
    "client": "KHRS6X63AJ7C7C4AZ9AO"
}
]]></sourcecode></figure>

<t>The client instance includes the Referer header field as a way for the AS to know that the process is initiated through a discovery process at the RS.</t>

<t>If issued, the resulting access token would contain sufficient access to be used at both referenced resources.</t>

<t>Security considerations, especially related to the potential of a <xref target="security-compromised-rs">compromised RS</xref> redirecting the requests of an otherwise properly authenticated client, need to be carefully considered when allowing such a discovery process. This risk can be mitigated by an alternative pre-registration process so that the client knows which AS protects which RS. There are also privacy considerations related to revealing which AS is protecting a given resource, discussed in <xref target="privacy-correlation-client"/>.</t>

</section>
<section anchor="grant-discovery"><name>Dynamic grant endpoint discovery</name>

<t>Additional methods of discovering the appropriate grant endpoint for a given application
are outside the scope of this specification. This limitation is intentional, as many applications
rely on static configuration between the client instance and AS, as is common in OAuth 2.0.
However, the dynamic nature of GNAP makes it a prime candidate for other extensions defining methods
for discovery of the appropriate AS grant endpoint at runtime. Advanced use cases could define
contextual methods for contextually  providing this endpoint to the client instance securely.
Furthermore, GNAP's design intentionally requires the client instance to only know the grant
endpoint and not additional parameters, since other functions and values can be disclosed
and negotiated during the grant process.</t>

</section>
</section>
<section anchor="Acknowledgements"><name>Acknowledgements</name>

<t>The editors would like to thank the feedback of the following individuals for their reviews,
implementations, and contributions:
<contact fullname="Åke Axeland" asciiFullname="Ake Axeland"/>,
Aaron Parecki,
Adam Omar Oueidat,
Andrii Deinega,
Annabelle Backman,
Dick Hardt,
Dmitri Zagidulin,
Dmitry Barinov,
Fabien Imbault,
Florian Helmschmidt,
Francis Pouatcha,
George Fletcher,
Haardik Haardik,
Hamid Massaoud,
Jacky Yuan,
Joseph Heenan,
Justin Richer,
Kathleen Moriarty,
Leif Johansson,
Mike Jones,
Mike Varley,
Nat Sakimura,
Takahiko Kawasaki,
Takahiro Tsuchiya,
Yaron Sheffer.</t>

<t>The editors would also like to thank the GNAP working group design team of
Kathleen Moriarty, Fabien Imbault, Dick Hardt, Mike Jones, and Justin Richer, who incorporated
elements from the XAuth and XYZ proposals to create the first version of this document.</t>

<t>In addition, the editors would like to thank Aaron Parecki and Mike Jones for insights into how
to integrate identity and authentication systems into the core protocol, and Justin Richer and Dick Hardt for
the use cases, diagrams, and insights provided in the XYZ and XAuth proposals that have been
incorporated here. The editors would like to especially thank Mike Varley and the team at SecureKey
for feedback and development of early versions of the XYZ protocol that fed into this standards work.</t>

<t>Finally, the editors want to acknowledge the immense contributions of Aaron Parecki to the content
of this document. We thank him for his insight, input, and hard work, without which GNAP would
not have grown to what it is.</t>

</section>
<section anchor="IANA"><name>IANA Considerations</name>

<t>IANA is requested to add values to existing registries and to create 16 registries for the Grant Negotiation and Authorization Protocol and to populate those registries with initial values as described in this section.</t>

<t>All use of value typing is based on <xref target="RFC8259"/> data types and <bcp14>MUST</bcp14> be one of the following: number, object, string, boolean, or array. When the type is array, the contents of the array <bcp14>MUST</bcp14> be specified, as in "array of objects" when one subtype is allowed or "array of strings/objects" when multiple simultaneous subtypes are allowed. When the type is object, the structure of the object <bcp14>MUST</bcp14> be specified in the definition. If a parameter is available in different types, each type <bcp14>SHOULD</bcp14> be registered separately.</t>

<t>General guidance for extension parameters is found in <xref target="extensions"/>.</t>

<section anchor="http-authentication-scheme-registration"><name>HTTP Authentication Scheme Registration</name>

<t>This specification requests registration of the following scheme in the
"Hypertext Transfer Protocol (HTTP) Authentication Scheme Registry" defined be <xref section="18.5" sectionFormat="of" target="HTTP"/>:</t>

<t><list style="symbols">
  <t>Authentication Scheme Name: <spanx style="verb">GNAP</spanx></t>
  <t>Reference: <xref target="use-access-token"/> of &SELF;</t>
</list></t>

</section>
<section anchor="IANA-grant-request"><name>GNAP Grant Request Parameters</name>

<t>This document defines a GNAP grant request, for which IANA is asked to create and maintain a new registry titled "GNAP Grant Request Parameters". Initial values for this registry are given in <xref target="IANA-grant-request-contents"/>. Future assignments and modifications to existing assignment are to be made through the Specification Required registration policy <xref target="RFC8126"/>.</t>

<t>The Designated Expert (DE) is expected to ensure that all registrations follow the template presented in <xref target="IANA-grant-request-template"/>.
The DE is expected to ensure that the request parameter's definition is sufficiently orthogonal to existing functionality provided by existing parameters.
The DE is expected to ensure that registrations for the same name with different types are sufficiently close in functionality so as not to cause confusion for developers.
The DE is expected to ensure that the request parameter's definition specifies the expected behavior of the AS in response to the request parameter for each potential state of the grant request.</t>

<section anchor="IANA-grant-request-template"><name>Registration Template</name>

<dl newline="true">
  <dt>Name:</dt>
  <dd>
    <t>An identifier for the parameter.</t>
  </dd>
  <dt>Type:</dt>
  <dd>
    <t>The JSON type allowed for the value.</t>
  </dd>
  <dt>Specification document(s):</dt>
  <dd>
    <t>Reference to the document(s) that specify the
  value, preferably including a URI that can be used
  to retrieve a copy of the document(s). An indication of the
  relevant sections may also be included but is not required.</t>
  </dd>
</dl>

</section>
<section anchor="IANA-grant-request-contents"><name>Initial Contents</name>

<texttable>
      <ttcol align='left'>Name</ttcol>
      <ttcol align='left'>Type</ttcol>
      <ttcol align='left'>Specification document(s)</ttcol>
      <c>access_token</c>
      <c>object</c>
      <c><xref target="request-token-single"/> of &SELF;</c>
      <c>access_token</c>
      <c>array of objects</c>
      <c><xref target="request-token-multiple"/> of &SELF;</c>
      <c>subject</c>
      <c>object</c>
      <c><xref target="request-subject"/> of &SELF;</c>
      <c>client</c>
      <c>object</c>
      <c><xref target="request-client"/> of &SELF;</c>
      <c>client</c>
      <c>string</c>
      <c><xref target="request-instance"/> of &SELF;</c>
      <c>user</c>
      <c>object</c>
      <c><xref target="request-user"/> of &SELF;</c>
      <c>user</c>
      <c>string</c>
      <c><xref target="request-user-reference"/> of &SELF;</c>
      <c>interact</c>
      <c>object</c>
      <c><xref target="request-interact"/> of &SELF;</c>
      <c>interact_ref</c>
      <c>string</c>
      <c><xref target="continue-after-interaction"/> of &SELF;</c>
</texttable>

</section>
</section>
<section anchor="IANA-token-flags"><name>GNAP Access Token Flags</name>

<t>This document defines a GNAP access token flags, for which IANA is asked to create and maintain a new registry titled "GNAP Access Token Flags". Initial values for this registry are given in <xref target="IANA-token-flags-contents"/>. Future assignments and modifications to existing assignment are to be made through the Specification Required registration policy <xref target="RFC8126"/>.</t>

<t>The DE is expected to ensure that all registrations follow the template presented in <xref target="IANA-token-flags-template"/>.
The DE is expected to ensure that the flag specifies whether it applies to requests for tokens to the AS, responses with tokens from the AS, or both.</t>

<section anchor="IANA-token-flags-template"><name>Registration Template</name>

<dl newline="true">
  <dt>Name:</dt>
  <dd>
    <t>An identifier for the parameter.</t>
  </dd>
  <dt>Allowed Use:</dt>
  <dd>
    <t>Where the flag is allowed to occur. Possible values are
  "Request", "Response", and "Request, Response".</t>
  </dd>
  <dt>Specification document(s):</dt>
  <dd>
    <t>Reference to the document(s) that specify the
  value, preferably including a URI that can be used
  to retrieve a copy of the document(s). An indication of the
  relevant sections may also be included but is not required.</t>
  </dd>
</dl>

</section>
<section anchor="IANA-token-flags-contents"><name>Initial Contents</name>

<texttable>
      <ttcol align='left'>Name</ttcol>
      <ttcol align='left'>Allowed Use</ttcol>
      <ttcol align='left'>Specification document(s)</ttcol>
      <c>bearer</c>
      <c>Request, Response</c>
      <c><xref target="request-token-single"/> and <xref target="response-token-single"/> of &SELF;</c>
      <c>durable</c>
      <c>Response</c>
      <c><xref target="response-token-single"/> of &SELF;</c>
</texttable>

</section>
</section>
<section anchor="IANA-subject-request"><name>GNAP Subject Information Request Fields</name>

<t>This document defines a means to request subject information from the AS to the client instance, for which IANA is asked to create and maintain a new registry titled "GNAP Subject Information Request Fields". Initial values for this registry are given in <xref target="IANA-subject-request-contents"/>. Future assignments and modifications to existing assignment are to be made through the Specification Required registration policy <xref target="RFC8126"/>.</t>

<t>The DE is expected to ensure that all registrations follow the template presented in <xref target="IANA-subject-request-template"/>.
The DE is expected to ensure that registrations for the same name with different types are sufficiently close in functionality so as not to cause confusion for developers.</t>

<section anchor="IANA-subject-request-template"><name>Registration Template</name>

<dl newline="true">
  <dt>Name:</dt>
  <dd>
    <t>An identifier for the parameter.</t>
  </dd>
  <dt>Type:</dt>
  <dd>
    <t>The JSON type allowed for the value.</t>
  </dd>
  <dt>Specification document(s):</dt>
  <dd>
    <t>Reference to the document(s) that specify the
  value, preferably including a URI that can be used
  to retrieve a copy of the document(s). An indication of the
  relevant sections may also be included but is not required.</t>
  </dd>
</dl>

</section>
<section anchor="IANA-subject-request-contents"><name>Initial Contents</name>

<texttable>
      <ttcol align='left'>Name</ttcol>
      <ttcol align='left'>Type</ttcol>
      <ttcol align='left'>Specification document(s)</ttcol>
      <c>sub_id_formats</c>
      <c>array of strings</c>
      <c><xref target="request-subject"/> of &SELF;</c>
      <c>assertion_formats</c>
      <c>array of strings</c>
      <c><xref target="request-subject"/> of &SELF;</c>
      <c>sub_ids</c>
      <c>array of objects</c>
      <c><xref target="request-subject"/> of &SELF;</c>
</texttable>

</section>
</section>
<section anchor="IANA-assertion-formats"><name>GNAP Assertion Formats</name>

<t>This document defines a means to pass identity assertions between the AS and client instance, for which IANA is asked to create and maintain a new registry titled "GNAP Assertion Formats". Initial values for this registry are given in <xref target="IANA-assertion-formats-contents"/>. Future assignments and modifications to existing assignment are to be made through the Specification Required registration policy <xref target="RFC8126"/>.</t>

<t>The DE is expected to ensure that all registrations follow the template presented in <xref target="IANA-assertion-formats-template"/>.
The DE is expected to ensure that the definition specifies the serialization format of the assertion value as used within GNAP.</t>

<section anchor="IANA-assertion-formats-template"><name>Registration Template</name>

<dl newline="true">
  <dt>Name:</dt>
  <dd>
    <t>An identifier for the assertion format.</t>
  </dd>
  <dt>Specification document(s):</dt>
  <dd>
    <t>Reference to the document(s) that specify the
  value, preferably including a URI that can be used
  to retrieve a copy of the document(s). An indication of the
  relevant sections may also be included but is not required.</t>
  </dd>
</dl>

</section>
<section anchor="IANA-assertion-formats-contents"><name>Initial Contents</name>

<texttable>
      <ttcol align='left'>Name</ttcol>
      <ttcol align='left'>Specification document(s)</ttcol>
      <c>id_token</c>
      <c><xref target="request-subject"/> and <xref target="response-subject"/> of &SELF;</c>
      <c>saml2</c>
      <c><xref target="request-subject"/> and <xref target="response-subject"/> of &SELF;</c>
</texttable>

</section>
</section>
<section anchor="IANA-client-instance"><name>GNAP Client Instance Fields</name>

<t>This document defines a means to send information about the client instance, for which IANA is asked to create and maintain a new registry titled "GNAP Client Instance Fields". Initial values for this registry are given in <xref target="IANA-client-instance-contents"/>. Future assignments and modifications to existing assignment are to be made through the Specification Required registration policy <xref target="RFC8126"/>.</t>

<t>The DE is expected to ensure that all registrations follow the template presented in <xref target="IANA-client-instance-template"/>.
The DE is expected to ensure that registrations for the same name with different types are sufficiently close in functionality so as not to cause confusion for developers.</t>

<section anchor="IANA-client-instance-template"><name>Registration Template</name>

<dl newline="true">
  <dt>Name:</dt>
  <dd>
    <t>An identifier for the parameter.</t>
  </dd>
  <dt>Type:</dt>
  <dd>
    <t>The JSON type allowed for the value.</t>
  </dd>
  <dt>Specification document(s):</dt>
  <dd>
    <t>Reference to the document(s) that specify the
  value, preferably including a URI that can be used
  to retrieve a copy of the document(s). An indication of the
  relevant sections may also be included but is not required.</t>
  </dd>
</dl>

</section>
<section anchor="IANA-client-instance-contents"><name>Initial Contents</name>

<texttable>
      <ttcol align='left'>Name</ttcol>
      <ttcol align='left'>Type</ttcol>
      <ttcol align='left'>Specification document(s)</ttcol>
      <c>key</c>
      <c>object</c>
      <c><xref target="key-format"/> of &SELF;</c>
      <c>key</c>
      <c>string</c>
      <c><xref target="key-reference"/> of &SELF;</c>
      <c>class_id</c>
      <c>string</c>
      <c><xref target="request-client"/> of &SELF;</c>
      <c>display</c>
      <c>object</c>
      <c><xref target="request-display"/> of &SELF;</c>
</texttable>

</section>
</section>
<section anchor="IANA-client-instance-display"><name>GNAP Client Instance Display Fields</name>

<t>This document defines a means to send end-user facing displayable information about the client instance, for which IANA is asked to create and maintain a new registry titled "GNAP Client Instance Display Fields". Initial values for this registry are given in <xref target="IANA-client-instance-display-contents"/>. Future assignments and modifications to existing assignment are to be made through the Specification Required registration policy <xref target="RFC8126"/>.</t>

<t>The DE is expected to ensure that all registrations follow the template presented in <xref target="IANA-client-instance-display-template"/>.
The DE is expected to ensure that registrations for the same name with different types are sufficiently close in functionality so as not to cause confusion for developers.</t>

<section anchor="IANA-client-instance-display-template"><name>Registration Template</name>

<dl newline="true">
  <dt>Name:</dt>
  <dd>
    <t>An identifier for the parameter.</t>
  </dd>
  <dt>Type:</dt>
  <dd>
    <t>The JSON type allowed for the value.</t>
  </dd>
  <dt>Specification document(s):</dt>
  <dd>
    <t>Reference to the document(s) that specify the
  value, preferably including a URI that can be used
  to retrieve a copy of the document(s). An indication of the
  relevant sections may also be included but is not required.</t>
  </dd>
</dl>

</section>
<section anchor="IANA-client-instance-display-contents"><name>Initial Contents</name>

<texttable>
      <ttcol align='left'>Name</ttcol>
      <ttcol align='left'>Type</ttcol>
      <ttcol align='left'>Specification document(s)</ttcol>
      <c>name</c>
      <c>string</c>
      <c><xref target="request-display"/> of &SELF;</c>
      <c>uri</c>
      <c>string</c>
      <c><xref target="request-display"/> of &SELF;</c>
      <c>logo_uri</c>
      <c>string</c>
      <c><xref target="request-display"/> of &SELF;</c>
</texttable>

</section>
</section>
<section anchor="IANA-interaction-start-modes"><name>GNAP Interaction Start Modes</name>

<t>This document defines a means for the client instance to begin interaction between the end-user and the AS, for which IANA is asked to create and maintain a new registry titled "GNAP Interaction Start Modes". Initial values for this registry are given in <xref target="IANA-interaction-start-modes-contents"/>. Future assignments and modifications to existing assignment are to be made through the Specification Required registration policy <xref target="RFC8126"/>.</t>

<t>The DE is expected to ensure that all registrations follow the template presented in <xref target="IANA-interaction-start-modes-template"/>.
The DE is expected to ensure that registrations for the same name with different types are sufficiently close in functionality so as not to cause confusion for developers.
The DE is expected to ensure that any registration using an "object" type declares all additional parameters, their optionality, and purpose.
The DE is expected to ensure that the start mode clearly defines what actions the client is expected to take to begin interaction, what the expected user experience is, and any security considerations for this communication from either party.
The DE is expected to ensure that the start mode documents incompatibilities with other start modes or finish methods, if applicable.
The DE is expected to ensure that the start mode provides enough information to uniquely identify the grant request during the interaction. For example, tn the <spanx style="verb">redirect</spanx> and <spanx style="verb">app</spanx> modes, this is done using a unique URI (including its parameters). In the <spanx style="verb">user_code</spanx> and <spanx style="verb">user_code_uri</spanx> mode, this is done using the value of the user code.</t>

<section anchor="IANA-interaction-start-modes-template"><name>Registration Template</name>

<dl newline="true">
  <dt>Mode:</dt>
  <dd>
    <t>An identifier for the interaction start mode.</t>
  </dd>
  <dt>Type:</dt>
  <dd>
    <t>The JSON type for the value, either "string" or "object", as described in <xref target="request-interact-start"/>.</t>
  </dd>
  <dt>Specification document(s):</dt>
  <dd>
    <t>Reference to the document(s) that specify the
  value, preferably including a URI that can be used
  to retrieve a copy of the document(s). An indication of the
  relevant sections may also be included but is not required.</t>
  </dd>
</dl>

</section>
<section anchor="IANA-interaction-start-modes-contents"><name>Initial Contents</name>

<texttable>
      <ttcol align='left'>Mode</ttcol>
      <ttcol align='left'>Type</ttcol>
      <ttcol align='left'>Specification document(s)</ttcol>
      <c>redirect</c>
      <c>string</c>
      <c><xref target="request-interact-redirect"/> of &SELF;</c>
      <c>app</c>
      <c>string</c>
      <c><xref target="request-interact-app"/> of &SELF;</c>
      <c>user_code</c>
      <c>string</c>
      <c><xref target="request-interact-usercode"/> of &SELF;</c>
      <c>user_code_uri</c>
      <c>string</c>
      <c><xref target="request-interact-usercodeuri"/> of &SELF;</c>
</texttable>

</section>
</section>
<section anchor="IANA-interaction-finish-methods"><name>GNAP Interaction Finish Methods</name>

<t>This document defines a means for the client instance to be notified of the end of interaction between the end-user and the AS, for which IANA is asked to create and maintain a new registry titled "GNAP Interaction Finish Methods". Initial values for this registry are given in <xref target="IANA-interaction-finish-methods-contents"/>. Future assignments and modifications to existing assignment are to be made through the Specification Required registration policy <xref target="RFC8126"/>.</t>

<t>The DE is expected to ensure that all registrations follow the template presented in <xref target="IANA-interaction-finish-methods-template"/>.
The DE is expected to ensure that all finish methods clearly define what actions the AS is expected to take, what listening methods the client instance needs to enable, and any security considerations for this communication from either party.
The DE is expected to ensure that all finish methods document incompatibilities with any start modes, if applicable.</t>

<section anchor="IANA-interaction-finish-methods-template"><name>Registration Template</name>

<dl newline="true">
  <dt>Method:</dt>
  <dd>
    <t>An identifier for the interaction finish method.</t>
  </dd>
  <dt>Specification document(s):</dt>
  <dd>
    <t>Reference to the document(s) that specify the
  value, preferably including a URI that can be used
  to retrieve a copy of the document(s). An indication of the
  relevant sections may also be included but is not required.</t>
  </dd>
</dl>

</section>
<section anchor="IANA-interaction-finish-methods-contents"><name>Initial Contents</name>

<texttable>
      <ttcol align='left'>Mode</ttcol>
      <ttcol align='left'>Specification document(s)</ttcol>
      <c>redirect</c>
      <c><xref target="request-interact-callback-redirect"/> of &SELF;</c>
      <c>push</c>
      <c><xref target="request-interact-callback-push"/> of &SELF;</c>
</texttable>

</section>
</section>
<section anchor="IANA-interaction-hints"><name>GNAP Interaction Hints</name>

<t>This document defines a set of hints that a client instance can provide to the AS to facilitate interaction with the end user, for which IANA is asked to create and maintain a new registry titled "GNAP Interaction Hints". Initial values for this registry are given in <xref target="IANA-interaction-hints-contents"/>. Future assignments and modifications to existing assignment are to be made through the Specification Required registration policy <xref target="RFC8126"/>.</t>

<t>The DE is expected to ensure that all registrations follow the template presented in <xref target="IANA-interaction-hints-template"/>.
The DE is expected to ensure that all interaction hints clearly document the expected behaviors of the AS in response to the hint, and that an AS not processing the hint does not impede the operation of the AS or client instance.</t>

<section anchor="IANA-interaction-hints-template"><name>Registration Template</name>

<dl newline="true">
  <dt>Name:</dt>
  <dd>
    <t>An identifier for the parameter.</t>
  </dd>
  <dt>Specification document(s):</dt>
  <dd>
    <t>Reference to the document(s) that specify the
  value, preferably including a URI that can be used
  to retrieve a copy of the document(s). An indication of the
  relevant sections may also be included but is not required.</t>
  </dd>
</dl>

</section>
<section anchor="IANA-interaction-hints-contents"><name>Initial Contents</name>

<texttable>
      <ttcol align='left'>Mode</ttcol>
      <ttcol align='left'>Specification document(s)</ttcol>
      <c>ui_locales</c>
      <c><xref target="request-interact-hint"/> of &SELF;</c>
</texttable>

</section>
</section>
<section anchor="IANA-grant-response"><name>GNAP Grant Response Parameters</name>

<t>This document defines a GNAP grant response, for which IANA is asked to create and maintain a new registry titled "GNAP Grant Response Parameters". Initial values for this registry are given in <xref target="IANA-grant-response-contents"/>. Future assignments and modifications to existing assignment are to be made through the Specification Required registration policy <xref target="RFC8126"/>.</t>

<t>The DE is expected to ensure that all registrations follow the template presented in <xref target="IANA-grant-response-template"/>.
The DE is expected to ensure that the response parameter's definition is sufficiently orthogonal to existing functionality provided by existing parameters.
The DE is expected to ensure that registrations for the same name with different types are sufficiently close in functionality so as not to cause confusion for developers.
The DE is expected to ensure that the response parameter's definition specifies grant states for which the client instance can expect this parameter to appear in a response message.</t>

<section anchor="IANA-grant-response-template"><name>Registration Template</name>

<dl newline="true">
  <dt>Name:</dt>
  <dd>
    <t>An identifier for the parameter.</t>
  </dd>
  <dt>Type:</dt>
  <dd>
    <t>The JSON type allowed for the value.</t>
  </dd>
  <dt>Specification document(s):</dt>
  <dd>
    <t>Reference to the document(s) that specify the
  value, preferably including a URI that can be used
  to retrieve a copy of the document(s). An indication of the
  relevant sections may also be included but is not required.</t>
  </dd>
</dl>

</section>
<section anchor="IANA-grant-response-contents"><name>Initial Contents</name>

<texttable>
      <ttcol align='left'>Name</ttcol>
      <ttcol align='left'>Type</ttcol>
      <ttcol align='left'>Specification document(s)</ttcol>
      <c>continue</c>
      <c>object</c>
      <c><xref target="response-continue"/> of &SELF;</c>
      <c>acces_token</c>
      <c>object</c>
      <c><xref target="response-token-single"/> of &SELF;</c>
      <c>acces_token</c>
      <c>array of objects</c>
      <c><xref target="response-token-multiple"/> of &SELF;</c>
      <c>interact</c>
      <c>object</c>
      <c><xref target="response-interact"/> of &SELF;</c>
      <c>subject</c>
      <c>object</c>
      <c><xref target="response-subject"/> of &SELF;</c>
      <c>instance_id</c>
      <c>string</c>
      <c><xref target="response-dynamic-handles"/> of &SELF;</c>
      <c>error</c>
      <c>object</c>
      <c><xref target="response-error"/> of &SELF;</c>
</texttable>

</section>
</section>
<section anchor="IANA-interaction-response"><name>GNAP Interaction Mode Responses</name>

<t>This document defines a means for the AS to provide to the client instance information that is required to complete a particular interaction mode, for which IANA is asked to create and maintain a new registry titled "GNAP Interaction Mode Responses". Initial values for this registry are given in <xref target="IANA-interaction-response-contents"/>. Future assignments and modifications to existing assignment are to be made through the Specification Required registration policy <xref target="RFC8126"/>.</t>

<t>The DE is expected to ensure that all registrations follow the template presented in <xref target="IANA-interaction-response-template"/>.
If the name of the registration matches the name of an interaction start mode, the DE is expected to ensure that the response parameter is unambiguously associated with the interaction start mode of the same name.</t>

<section anchor="IANA-interaction-response-template"><name>Registration Template</name>

<dl newline="true">
  <dt>Name:</dt>
  <dd>
    <t>An identifier for the parameter.</t>
  </dd>
  <dt>Specification document(s):</dt>
  <dd>
    <t>Reference to the document(s) that specify the
  value, preferably including a URI that can be used
  to retrieve a copy of the document(s). An indication of the
  relevant sections may also be included but is not required.</t>
  </dd>
</dl>

</section>
<section anchor="IANA-interaction-response-contents"><name>Initial Contents</name>

<texttable>
      <ttcol align='left'>Name</ttcol>
      <ttcol align='left'>Specification document(s)</ttcol>
      <c>redirect</c>
      <c><xref target="response-interact"/> of &SELF;</c>
      <c>app</c>
      <c><xref target="response-interact"/> of &SELF;</c>
      <c>user_code</c>
      <c><xref target="response-interact"/> of &SELF;</c>
      <c>user_code_uri</c>
      <c><xref target="response-interact"/> of &SELF;</c>
      <c>finish</c>
      <c><xref target="response-interact"/> of &SELF;</c>
      <c>expires_in</c>
      <c><xref target="response-interact"/> of &SELF;</c>
</texttable>

</section>
</section>
<section anchor="IANA-subject-response"><name>GNAP Subject Information Response Fields</name>

<t>This document defines a means to return subject information from the AS to the client instance, for which IANA is asked to create and maintain a new registry titled "GNAP Subject Information Response Fields". Initial values for this registry are given in <xref target="IANA-subject-response-contents"/>. Future assignments and modifications to existing assignment are to be made through the Specification Required registration policy <xref target="RFC8126"/>.</t>

<t>The DE is expected to ensure that all registrations follow the template presented in <xref target="IANA-subject-response-template"/>.
The DE is expected to ensure that registrations for the same name with different types are sufficiently close in functionality so as not to cause confusion for developers.</t>

<section anchor="IANA-subject-response-template"><name>Registration Template</name>

<dl newline="true">
  <dt>Name:</dt>
  <dd>
    <t>An identifier for the parameter.</t>
  </dd>
  <dt>Type:</dt>
  <dd>
    <t>The JSON type allowed for the value.</t>
  </dd>
  <dt>Specification document(s):</dt>
  <dd>
    <t>Reference to the document(s) that specify the
  value, preferably including a URI that can be used
  to retrieve a copy of the document(s). An indication of the
  relevant sections may also be included but is not required.</t>
  </dd>
</dl>

</section>
<section anchor="IANA-subject-response-contents"><name>Initial Contents</name>

<texttable>
      <ttcol align='left'>Name</ttcol>
      <ttcol align='left'>Type</ttcol>
      <ttcol align='left'>Specification document(s)</ttcol>
      <c>sub_ids</c>
      <c>array of objects</c>
      <c><xref target="response-subject"/> of &SELF;</c>
      <c>assertions</c>
      <c>array of objects</c>
      <c><xref target="response-subject"/> of &SELF;</c>
      <c>updated_at</c>
      <c>string</c>
      <c><xref target="response-subject"/> of &SELF;</c>
</texttable>

</section>
</section>
<section anchor="IANA-error-code"><name>GNAP Error Codes</name>

<t>This document defines a set of errors that the AS can return to the client instance, for which IANA is asked to create and maintain a new registry titled "GNAP Error Codes". Initial values for this registry are given in <xref target="IANA-error-code-contents"/>. Future assignments and modifications to existing assignment are to be made through the Specification Required registration policy <xref target="RFC8126"/>.</t>

<t>The DE is expected to ensure that all registrations follow the template presented in <xref target="IANA-error-code-template"/>.
The DE is expected to ensure that the error response is sufficiently unique from other errors to provide actionable information to the client instance.
The DE is expected to ensure that the definition of the error response specifies all conditions in which the error response is returned, and what the client instance's expected action is.</t>

<section anchor="IANA-error-code-template"><name>Registration Template</name>

<dl newline="true">
  <dt>Error:</dt>
  <dd>
    <t>A unique string code for the error.</t>
  </dd>
  <dt>Specification document(s):</dt>
  <dd>
    <t>Reference to the document(s) that specify the
  value, preferably including a URI that can be used
  to retrieve a copy of the document(s). An indication of the
  relevant sections may also be included but is not required.</t>
  </dd>
</dl>

</section>
<section anchor="IANA-error-code-contents"><name>Initial Contents</name>

<texttable>
      <ttcol align='left'>Error</ttcol>
      <ttcol align='left'>Specification document(s)</ttcol>
      <c>invalid_request</c>
      <c><xref target="response-error"/> of &SELF;</c>
      <c>invalid_client</c>
      <c><xref target="response-error"/> of &SELF;</c>
      <c>invalid_interaction</c>
      <c><xref target="response-error"/> of &SELF;</c>
      <c>invalid_flag</c>
      <c><xref target="response-error"/> of &SELF;</c>
      <c>invalid_rotation</c>
      <c><xref target="response-error"/> of &SELF;</c>
      <c>key_rotation_not_supported</c>
      <c><xref target="response-error"/> of &SELF;</c>
      <c>invalid_continuation</c>
      <c><xref target="response-error"/> of &SELF;</c>
      <c>user_denied</c>
      <c><xref target="response-error"/> of &SELF;</c>
      <c>request_denied</c>
      <c><xref target="response-error"/> of &SELF;</c>
      <c>unknown_interaction</c>
      <c><xref target="response-error"/> of &SELF;</c>
      <c>too_fast</c>
      <c><xref target="response-error"/> of &SELF;</c>
      <c>too_many_attempts</c>
      <c><xref target="response-error"/> of &SELF;</c>
</texttable>

</section>
</section>
<section anchor="IANA-key-proof-methods"><name>GNAP Key Proofing Methods</name>

<t>This document defines methods that the client instance can use to prove possession of a key, for which IANA is asked to create and maintain a new registry titled "GNAP Key Proofing Methods". Initial values for this registry are given in <xref target="IANA-key-proof-methods-contents"/>. Future assignments and modifications to existing assignment are to be made through the Specification Required registration policy <xref target="RFC8126"/>.</t>

<t>The DE is expected to ensure that all registrations follow the template presented in <xref target="IANA-key-proof-methods-template"/>.
The DE is expected to ensure that registrations for the same name with different types are sufficiently close in functionality so as not to cause confusion for developers.
The DE is expected to ensure that the proofing method provides sufficient coverage of and binding to the protocol messages to which it is applied.
The DE is expected to ensure that the proofing method definition clearly enumerates how all requirements in <xref target="binding-keys"/> are fulfilled by the definition.</t>

<section anchor="IANA-key-proof-methods-template"><name>Registration Template</name>

<dl newline="true">
  <dt>Method:</dt>
  <dd>
    <t>A unique string code for the key proofing method.</t>
  </dd>
  <dt>Type:</dt>
  <dd>
    <t>The JSON type allowed for the value.</t>
  </dd>
  <dt>Specification document(s):</dt>
  <dd>
    <t>Reference to the document(s) that specify the
  value, preferably including a URI that can be used
  to retrieve a copy of the document(s). An indication of the
  relevant sections may also be included but is not required.</t>
  </dd>
</dl>

</section>
<section anchor="IANA-key-proof-methods-contents"><name>Initial Contents</name>

<texttable>
      <ttcol align='left'>Method</ttcol>
      <ttcol align='left'>Type</ttcol>
      <ttcol align='left'>Specification document(s)</ttcol>
      <c>httpsig</c>
      <c>string</c>
      <c><xref target="httpsig-binding"/> of &SELF;</c>
      <c>httpsig</c>
      <c>object</c>
      <c><xref target="httpsig-binding"/> of &SELF;</c>
      <c>mtls</c>
      <c>string</c>
      <c><xref target="mtls"/> of &SELF;</c>
      <c>jwsd</c>
      <c>string</c>
      <c><xref target="detached-jws"/> of &SELF;</c>
      <c>jws</c>
      <c>string</c>
      <c><xref target="attached-jws"/> of &SELF;</c>
</texttable>

</section>
</section>
<section anchor="IANA-key-formats"><name>GNAP Key Formats</name>

<t>This document defines formats for a public key value, for which IANA is asked to create and maintain a new registry titled "GNAP Key Formats". Initial values for this registry are given in <xref target="IANA-key-formats-contents"/>. Future assignments and modifications to existing assignment are to be made through the Specification Required registration policy <xref target="RFC8126"/>.</t>

<t>The DE is expected to ensure that all registrations follow the template presented in <xref target="IANA-key-formats-template"/>.
The DE is expected to ensure the key format specifies the structure and serialization of the key material.</t>

<section anchor="IANA-key-formats-template"><name>Registration Template</name>

<dl newline="true">
  <dt>Format:</dt>
  <dd>
    <t>A unique string code for the key format.</t>
  </dd>
  <dt>Specification document(s):</dt>
  <dd>
    <t>Reference to the document(s) that specify the
  value, preferably including a URI that can be used
  to retrieve a copy of the document(s). An indication of the
  relevant sections may also be included but is not required.</t>
  </dd>
</dl>

</section>
<section anchor="IANA-key-formats-contents"><name>Initial Contents</name>

<texttable>
      <ttcol align='left'>Format</ttcol>
      <ttcol align='left'>Specification document(s)</ttcol>
      <c>jwk</c>
      <c><xref target="key-format"/> of &SELF;</c>
      <c>cert</c>
      <c><xref target="key-format"/> of &SELF;</c>
      <c>cert#S256</c>
      <c><xref target="key-format"/> of &SELF;</c>
</texttable>

</section>
</section>
<section anchor="IANA-as-discovery"><name>GNAP Authorization Server Discovery Fields</name>

<t>This document defines a discovery document for an AS, for which IANA is asked to create and maintain a new registry titled "GNAP Authorization Server Discovery Fields". Initial values for this registry are given in <xref target="IANA-as-discovery-contents"/>. Future assignments and modifications to existing assignment are to be made through the Specification Required registration policy <xref target="RFC8126"/>.</t>

<t>The DE is expected to ensure that all registrations follow the template presented in <xref target="IANA-as-discovery-template"/>.
The DE is expected to ensure that registrations for the same name with different types are sufficiently close in functionality so as not to cause confusion for developers.
The DE is expected to ensure that the values in the discovery document are sufficient to provide optimization and hints to the client instance, but that knowledge of the discovered value is not required for starting a transaction with the AS.</t>

<section anchor="IANA-as-discovery-template"><name>Registration Template</name>

<dl newline="true">
  <dt>Name:</dt>
  <dd>
    <t>An identifier for the parameter.</t>
  </dd>
  <dt>Type:</dt>
  <dd>
    <t>The JSON type allowed for the value.</t>
  </dd>
  <dt>Specification document(s):</dt>
  <dd>
    <t>Reference to the document(s) that specify the
  value, preferably including a URI that can be used
  to retrieve a copy of the document(s). An indication of the
  relevant sections may also be included but is not required.</t>
  </dd>
</dl>

</section>
<section anchor="IANA-as-discovery-contents"><name>Initial Contents</name>

<texttable>
      <ttcol align='left'>Name</ttcol>
      <ttcol align='left'>Type</ttcol>
      <ttcol align='left'>Specification document(s)</ttcol>
      <c>grant_request_endpoint</c>
      <c>string</c>
      <c><xref target="discovery"/> of &SELF;</c>
      <c>interaction_start_modes_supported</c>
      <c>array of strings</c>
      <c><xref target="discovery"/> of &SELF;</c>
      <c>interaction_finish_methods_supported</c>
      <c>array of strings</c>
      <c><xref target="discovery"/> of &SELF;</c>
      <c>key_proofs_supported</c>
      <c>array of strings</c>
      <c><xref target="discovery"/> of &SELF;</c>
      <c>sub_id_formats_supported</c>
      <c>array of strings</c>
      <c><xref target="discovery"/> of &SELF;</c>
      <c>assertion_formats_supported</c>
      <c>array of strings</c>
      <c><xref target="discovery"/> of &SELF;</c>
      <c>key_rotation_supported</c>
      <c>boolean</c>
      <c><xref target="discovery"/> of &SELF;</c>
</texttable>

</section>
</section>
</section>
<section anchor="implementation"><name>Implementation Status</name>

<ul empty="true"><li>
  <t>Note: To be removed by RFC editor before publication.</t>
</li></ul>

<t><strong>GNAP Authorization Service in Rust</strong> implementation by David Skyberg.
<eref target="https://github.com/dskyberg/gnap">https://github.com/dskyberg/gnap</eref> Prototype implementation of AS and client in Rust. MIT license.</t>

<t><strong>GNAP JS Client</strong> from Interop Alliance, implementation by Dmitri Zagidulin. <eref target="https://github.com/interop-alliance/gnap-client-js">https://github.com/interop-alliance/gnap-client-js</eref> Prototype implementation of client in JavaScript. MIT License.</t>

<t><strong>Rafiki</strong> from Interledger Foundation. <eref target="https://github.com/interledger/rafiki">https://github.com/interledger/rafiki</eref> Production implementation of AS in JavaScript. Apache 2.0 license.</t>

<t><strong>Sample GNAP Client in PHP</strong> implementation by Aaron Parecki. <eref target="https://github.com/aaronpk/gnap-client-php">https://github.com/aaronpk/gnap-client-php</eref> Prototype implementation of web application client and CLI client in PHP, with common support library. CC0 license.</t>

<t><strong>SUNET Auth Server</strong> from SUNET. <eref target="https://github.com/SUNET/sunet-auth-server">https://github.com/SUNET/sunet-auth-server</eref> Production implementation of AS in Python. BSD license.</t>

<t><strong>Trustbloc</strong> from Gen Digital. <eref target="https://github.com/trustbloc/docs/blob/main/readthedocs/designs/auth.md">https://github.com/trustbloc/docs/blob/main/readthedocs/designs/auth.md</eref> Production implementation of AS and client in Go. Apache 2.0 license.</t>

<t><strong>Verified.ME</strong> from SecureKey. <eref target="https://verified.me/">https://verified.me/</eref> Production implementation of AS, client and RS. Proprietary license.</t>

<t><strong>XYZ</strong> from Bespoke Engineering, implementation by Justin Richer. <eref target="https://github.com/bspk/oauth.xyz-java">https://github.com/bspk/oauth.xyz-java</eref> Advanced prototype implementation of AS, client, and RS in Java, with common support library. Prototype implementation of SPA client in JavaScript. Apache 2.0 license.</t>

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

<t>In addition to the normative requirements in this document, implementors are strongly encouraged to consider these additional security considerations in implementations and deployments of GNAP.</t>

<section anchor="security-tls"><name>TLS Protection in Transit</name>

<t>All requests in GNAP made over untrusted network connections have to be made over TLS as outlined in <xref target="BCP195"/>
to protect the contents of the request and response from manipulation and interception by an attacker.
This includes all requests from a client instance to the AS, all requests from the client instance to
an RS, and any requests back to a client instance such as the push-based interaction finish method.
Additionally, all requests between a browser and other components, such as during redirect-based
interaction, need to be made over TLS or use equivalent protection such as a network connection local to the browser ("localhost").</t>

<t>Even though requests from the client instance to the AS are signed, the signature method alone does not protect
the request from interception by an attacker. TLS protects the response as well as the request,
preventing an attacker from intercepting requested information as it is returned. This is particularly
important in the core protocol for security artifacts such as nonces and for
personal information such as subject information.</t>

<t>The use of key-bound access tokens does not negate the requirement for protecting calls to the RS with TLS.
While the keys and signatures associated a bound access token will prevent an attacker from using a stolen
token, without TLS an attacker would be able to watch the data being sent to the RS and returned from the RS
during legitimate use of the client instance under attack. Additionally, without TLS an attacker would be
able to profile the calls made between the client instance and RS, possibly gaining information about the functioning
of the API between the client software and RS software that would be otherwise unknown to the attacker.</t>

<t>Note that connections from the end user and RO's browser also need to be be protected with TLS. This applies during initial
redirects to an AS's components during interaction, during any interaction with the resource owner, and during
any redirect back to the client instance. Without TLS protection on these portions of the process, an
attacker could wait for a valid request to start and then take over the resource owner's interaction session.</t>

</section>
<section anchor="security-signing"><name>Signing Requests from the Client Software</name>

<t>Even though all requests in GNAP need to be transmitted over TLS or its equivalent, the use of TLS
alone is not sufficient to protect all parts of a multi-party and multi-stage protocol like GNAP,
and TLS is not targeted at tying multiple requests to each other over time.
To account for this, GNAP makes use of message-level protection and key presentation mechanisms
that strongly associate a request with a key held by the client instance (see <xref target="secure-requests"/>).</t>

<t>During the initial request from a client instance to the AS, the client instance has to identify and
prove possession of a cryptographic key. If the key is known to the AS, such as if it is previously
registered or dereferenceable to a trusted source, the AS can associate a set of policies to the
client instance identified by the key. Without the requirement that the client instance prove that it holds
that key, the AS could not trust that the connection came from any particular client and could
not apply any associated policies.</t>

<t>Even more importantly, the client instance proving possession of a key on the first request allows
the AS to associate future requests with each other by binding all future requests in that
transaction to the same key. The access token used for grant continuation
is bound to the same key and proofing mechanism used by the client instance in its initial request,
which means that the client instance needs to prove possession of that same key in future requests
allowing the AS to be sure that the same client instance is executing the follow-ups for a given
ongoing grant request. Therefore, the AS has to ensure that all subsequent requests for a grant are
associated with the same key that started the grant, or the most recent rotation of that key.
This need holds true even if the initial key is previously unknown to the AS, such as would be
the case when a client instance creates an ephemeral key for its request.
Without this ongoing association, an attacker would be able to impersonate a client instance
in the midst of a grant request, potentially stealing access tokens and subject information
with impunity.</t>

<t>Additionally, all access tokens in GNAP default to be associated with the key that was presented
during the grant request that created the access token. This association allows an RS to know that
the presenter of the access token is the same party that the token was issued to, as identified
by their keys. While non-bound bearer tokens are an option in GNAP, these types of tokens
have their own tradeoffs discussed in <xref target="security-bearer-tokens"/>.</t>

<t>TLS functions at the transport layer, ensuring that only the parties on either end of that
connection can read the information passed along that connection. Each time a new connection
is made, such as for a new HTTP request, a new trust is re-established that is mostly unrelated to previous
connections. While modern TLS does make use of session resumption, this still needs to be augmented
with authentication methods to determine the identity of parties on the
connections. In other words, it is not possible with TLS alone to know that the same party is making
a set of calls over time, since each time a new TLS connection is established, both the client and the server (or the server only when using <xref target="mtls"/>) have to validate
the other party's identity. Such a verification can be achieved via methods described in <xref target="I-D.ietf-uta-rfc6125bis"/>, but these are not enough to establish the identity of the client instance in many cases.</t>

<t>To counter this, GNAP defines a set of key binding methods in <xref target="binding-keys"/> that allow authentication and
proof of possession by the caller, which is usually the client instance. These methods are intended to be used in
addition to TLS on all connections.</t>

</section>
<section anchor="security-mtls"><name>MTLS Message Integrity</name>

<t>The <xref target="mtls">MTLS key proofing mechanism</xref> provides a means for a client instance to present a key
using a certificate at the TLS layer. Since TLS protects the entire HTTP message in transit,
verification of the TLS client certificate presented with the message provides a sufficient binding
between the two. However, since TLS is functioning at a separate layer from HTTP, there is no
direct connection between the TLS key presentation and the message itself, other than the fact that
the message was presented over the TLS channel. That is to say, any HTTP message can be presented
over the TLS channel in question with the same level of trust. The verifier is responsible for
ensuring the key in the TLS client certificate is the one expected for a particular request. For
example, if the request is a <xref target="request">grant request</xref>, the AS needs to compare the TLS client
certificate presented at the TLS layer to the key identified in the request content itself (either
by value or through a referenced identifier).</t>

<t>Furthermore, the prevalence of the TLS-terminating reverse proxy (TTRP) pattern in deployments adds
a wrinkle to the situation. In this common pattern, the TTRP validates the TLS connection and then forwards the HTTP message contents onward to an internal system for processing. The system
processing the HTTP message no longer has access to the original TLS connection's information and
context. To compensate for this, the TTRP could inject the TLS client certificate into the forwarded
request as a header parameter using <xref target="RFC9111"/>, giving the downstream
system access to the certificate information. The TTRP has to be trusted to provide accurate
certificate information, and the connection between the TTRP and the downstream system also has to
be protected. The TTRP could provide some additional assurance, for example, by adding its own
signature to the Client-Cert header field using <xref target="I-D.ietf-httpbis-message-signatures"/>. This
signature would be effectively ignored by GNAP (since it would not use GNAP's <spanx style="verb">tag</spanx> parameter
value) but would be understood by the downstream service as part
of its deployment.</t>

<t>Additional considerations for different types of deployment patterns and key distribution
mechanisms for MTLS are found in <xref target="security-mtls-patterns"/>.</t>

</section>
<section anchor="security-mtls-patterns"><name>MTLS Deployment Patterns</name>

<t>GNAP does not specify how a client instance's keys could be made known to the AS ahead of time.
Public Key Infrastructure (PKI) can be used to manage the keys used by client instances when calling
the AS, allowing the AS to trust a root key from a trusted authority. This method is particularly
relevant to the MTLS key proofing method, where the client instance
presents its certificate to the AS as part of the TLS connection. An AS using PKI to validate the
MTLS connection would need to ensure that the presented certificate was issued by a trusted certificate
authority before allowing the connection to continue. PKI-based certificates would allow a key to be revoked
and rotated through management at the certificate authority without requiring additional registration
or management at the AS. The PKI required to manage mutually-authenticated TLS has historically been
difficult to deploy, especially at scale, but it remains an appropriate solution for systems where
the required management overhead is not an impediment.</t>

<t>MTLS in GNAP need not use a PKI backing, as self-signed certificates and certificates from untrusted
authorities can still be presented as part of a TLS connection. In this case, the verifier would
validate the connection but accept whatever certificate was presented by the client software. This
specific certificate can then be bound to all future connections from that client software by
being bound to the resulting access tokens, in a trust-on-first-use pattern. See <xref target="security-mtls"/>
for more considerations on MTLS as a key proofing mechanism.</t>

</section>
<section anchor="security-keys"><name>Protection of Client Instance Key Material</name>

<t>Client instances are identified by their unique keys, and anyone with access to a client instance's key material
will be able to impersonate that client instance to all parties. This is true for both calls to the AS
as well as calls to an RS using an access token bound to the client instance's unique key. As a consequence, it is of utmost importance for a client instance to protect its private key material.</t>

<t>Different types of client software have different methods for creating, managing, and registering
keys. GNAP explicitly allows for ephemeral clients such as single-page applications (SPAs) and single-user clients (such as
mobile applications) to create and present their own keys during the initial grant request without any explicit pre-registration step. The client
software can securely generate a keypair on-device and present the public key, along with proof of holding the associated
private key, to the AS as part of the initial request. To facilitate trust in these ephemeral keys,
GNAP further allows for an extensible set of client information to be passed with the request. This
information can include device posture and third-party attestations of the client software's provenance
and authenticity, depending on the needs and capabilities of the client software and its deployment.</t>

<t>From GNAP's perspective, each distinct key is a different client instance. However, multiple client
instances can be grouped together by an AS policy and treated similarly to each other. For instance,
if an AS knows of several different keys for different servers within a cluster, the AS can
decide that authorization of one of these servers applies to all other servers within the cluster. An AS
that chooses to do this needs to be careful with how it groups different client keys together in its policy,
since the breach of one instance would have direct effects on the others in the cluster.</t>

<t>Additionally, if an end user controls multiple instances of a single type of client software, such as
having an application installed on multiple devices, each of these instances is expected to have a
separate key and be issued separate access tokens. However, if the AS is able to group these separate
instances together as described above, it can streamline the authorization process for new instances
of the same client software. For example, if two client instances can present proof of a valid installation
of a piece of client software, the AS would be able to associate the approval of the first instance of this
software to all related instances. The AS could then choose to bypass an explicit prompt of the resource
owner for approval during authorization, since such approval has already been given. An AS doing such
a process would need to take assurance measures that the different instances are in fact correlated
and authentic, as well as ensuring the expected resource owner is in control of the client instance.</t>

<t>Finally, if multiple instances of client software each have the same key, then from GNAP's perspective,
these are functionally the same client instance as GNAP has no reasonable way to differentiate between
them. This situation could happen if multiple instances within a cluster can securely share secret
information among themselves. Even though there are multiple copies of the software, the shared key
makes these copies all present as a single instance. It is considered bad practice to share keys between
copies of software unless they are very tightly integrated with each other and can be closely managed.
It is particularly bad practice to allow an end user to copy keys between client instances and to
willingly use the same key in multiple instances.</t>

</section>
<section anchor="security-as"><name>Protection of Authorization Server</name>

<t>The AS performs critical functions in GNAP, including authenticating client software, managing interactions
with end users to gather consent and provide notice, and issuing access tokens for client instances
to present to resource servers. As such, protecting the AS is central to any GNAP deployment.</t>

<t>If an attacker is able to gain control over an AS, they would be able to create fraudulent tokens and
manipulate registration information to allow for malicious clients. These tokens and clients would
be trusted by other components in the ecosystem under the protection of the AS.</t>

<t>If the AS is using signed access tokens, an attacker in control of the AS's signing keys would
be able to manufacture fraudulent tokens for use at RS's under the protection of the AS.</t>

<t>If an attacker is able to impersonate an AS, they would be able to trick legitimate client instances
into making signed requests for information which could potentially be proxied to a real AS. To combat
this, all communications to the AS need to be made over TLS or its equivalent, and the software
making the connection has to validate the certificate chain of the host it is connecting to.</t>

<t>Consequently, protecting, monitoring, and auditing the AS is paramount to preserving the security
of a GNAP-protected ecosystem. The AS presents attackers with a valuable target for attack.
Fortunately, the core focus and function of the AS is to provide security for the ecosystem, unlike
the RS whose focus is to provide an API or the client software whose focus is to access the API.</t>

</section>
<section anchor="security-symmetric"><name>Symmetric and Asymmetric Client Instance Keys</name>

<t>Many of the cryptographic methods used by GNAP for key-proofing can support both asymmetric and symmetric
cryptography, and can be extended to use a wide variety of mechanisms.
Implementers will find useful the available guidelines on cryptographic key management provided in <xref target="RFC4107"/>. While symmetric
cryptographic systems have some benefits in speed and simplicity, they have a distinct drawback
that both parties need access to the same key in order to do both signing and verification of
the message.
When more than two parties share the same symmetric key,
data origin authentication is not provided.  Any party that knows the
symmetric key can compute a valid MAC; therefore, the
contents could originate from any one of the parties.</t>

<t>Use of symmetric cryptography means that when the client instance calls the AS to request a token, the
AS needs to know the exact value of the client instance's key (or be able to derive it) in
order to validate the key proof signature. With asymmetric keys, the client needs only to
send its public key to the AS to allow for verification that the client holds the associated
private key, regardless of whether that key was pre-registered or not with the AS.</t>

<t>Symmetric keys also have the expected advantage of providing better protection against quantum
threats in the future. Also, these types of keys (and their secure derivations) are widely
supported among many cloud-based key management systems.</t>

<t>When used to bind to an access token, a key value must be known by the RS in order
to validate the proof signature on the request. Common methods for communicating these proofing
keys include putting information in a structured access token and allowing the RS to look
up the associated key material against the value of the access token. With symmetric cryptography,
both of these methods would expose the signing key to the RS, and in the case of an structured
access token, potentially to any party that can see the access token itself unless the token's
payload has been encrypted. Any of these parties would then be able to make calls using the
access token by creating a valid signature using the shared key. With asymmetric cryptography, the RS needs
to know only the public key associated with the token in order to validate the request, and therefore the RS cannot
create any new signed calls.</t>

<t>While both signing approaches are allowed, GNAP treats these two classes of keys somewhat
differently. Only the public portion of asymmetric keys are allowed to be sent by value
in requests to the AS when establishing a connection. Since sending a symmetric key (or
the private portion of an asymmetric key) would expose the signing material to any parties
on the request path, including any attackers, sending these kinds of keys by value is prohibited.
Symmetric keys can still be used by client instances, but only if the client instance can send a reference to the key and
not its value. This approach allows the AS to use pre-registered symmetric keys as well
as key derivation schemes to take advantage of symmetric cryptography but without requiring
key distribution at runtime, which would expose the keys in transit.</t>

<t>Both the AS and client software can use systems such as hardware security modules to strengthen
their key security storage and generation for both asymmetric and symmetric keys (see also <xref target="key-protection"/>).</t>

</section>
<section anchor="security-access-tokens"><name>Generation of Access Tokens</name>

<t>The content of access tokens need to be such that only the generating AS would be able to
create them, and the contents cannot be manipulated by an attacker to gain different or additional
access rights.</t>

<t>One method for accomplishing this is to use a cryptographically random value for the access token,
generated by the AS using a secure randomization function with sufficiently high entropy. The odds of
an attacker guessing the output of the randomization function to collide with a valid access token
are exceedingly small, and even then the attacker would not have any control over what the
access token would represent since that information would be held close by the AS.</t>

<t>Another method for accomplishing this is to use a structured token that is cryptographically signed.
In this case, the payload of the access token declares to the RS what the token is good for, but
the signature applied by the AS during token generation covers this payload. Only the AS can create
such a signature and therefore only the AS can create such a signed token. The odds of an attacker
being able to guess a signature value with a useful payload are exceedingly small. This technique
only works if all targeted RS's check the signature of the access token. Any RS that does not
validate the signature of all presented tokens would be susceptible to injection of a modified
or falsified token. Furthermore, an AS has to carefully protect the keys used to sign access
tokens, since anyone with access to these signing keys would be able to create seemingly-valid
access tokens using them.</t>

</section>
<section anchor="security-bearer-tokens"><name>Bearer Access Tokens</name>

<t>Bearer access tokens can be used by any party that has access to the token itself, without any additional
information. As a natural consequence, any RS that a bearer token is presented to has the technical
capability of presenting that bearer token to another RS, as long as the token is valid. It also
means that any party that is able capture of the token value in storage or in transit is able to
use the access token. While bearer tokens are inherently simpler, this simplicity has been misapplied
and abused in making needlessly insecure systems. The downsides of bearer tokens have become more
pertinent lately as stronger authentication systems have caused some attacks to shift to target
tokens and APIs.</t>

<t>In GNAP, key-bound access tokens are the default due to their higher security properties. While
bearer tokens can be used in GNAP, their use should be limited to cases where the simplicity
benefits outweigh the significant security downsides. One common deployment pattern is to use a
gateway that takes in key-bound tokens on the outside, and verifies the signatures on the incoming
requests, but translates the requests to a bearer token for use by trusted internal systems. The
bearer tokens are never issued or available outside of the internal systems, greatly limiting the
exposure of the less secure tokens but allowing the internal deployment to benefit from the
advantages of bearer tokens.</t>

</section>
<section anchor="security-bound-tokens"><name>Key-Bound Access Tokens</name>

<t>Key-bound access tokens, as the name suggests, are bound to a specific key and must be
presented along with proof of that key during use. The key itself is not presented at the same
time as the token, so even if a token value is captured, it cannot be used to make a new request. This
is particularly true for an RS, which will see the token value but will not see the keys used
to make the request (assuming asymmetric cryptography is in use, see <xref target="security-symmetric"/>).</t>

<t>Key-bound access tokens provide this additional layer of protection only when the RS checks the
signature of the message presented with the token. Acceptance of an invalid presentation signature,
or failure to check the signature entirely, would allow an attacker to make calls with a captured
access token without having access to the related signing key material.</t>

<t>In addition to validating the signature of the presentation message itself,
the RS also needs to ensure that the signing key used is appropriate for the presented token.
If an RS does not ensure that the right keys were used to sign a message with a specific
token, an attacker would be able to capture an access token and sign the request with their own
keys, thereby negating the benefits of using key-bound access tokens.</t>

<t>The RS also needs to ensure that sufficient portions of the message are covered by the
signature. Any items outside the signature could still affect the API's processing decisions,
but these items would not be strongly bound to the token presentation. As such, an attacker
could capture a valid request, then manipulate portions of the request outside of the
signature envelope in order to cause unwanted actions at the protected API.</t>

<t>Some key-bound tokens are susceptible to replay attacks, depending on the details of the signing method
used. Key proofing mechanisms used with access tokens therefore need
to use replay protection mechanisms covered under the signature such as a per-message nonce, a
reasonably short time validity window, or other uniqueness constraints. The details of using these
will vary depending on the key proofing mechanism in use, but for example, HTTP Message Signatures
has both a <spanx style="verb">created</spanx> and <spanx style="verb">nonce</spanx> signature parameter as well as the ability to cover significant
portions of the HTTP message. All of these can be used to limit the attack surface.</t>

</section>
<section anchor="security-credentials"><name>Exposure of End-user Credentials to Client Instance</name>

<t>As a delegation protocol, one of the main goals of GNAP is to prevent the client software from being
exposed to any credentials or information about the end user or resource owner as a requirement
of the delegation process. By using the variety of interaction mechanisms, the resource owner can
interact with the AS without ever authenticating to the client software, and without the client
software having to impersonate the resource owner through replay of their credentials.</t>

<t>Consequently, no interaction methods defined in the GNAP core require the end user to enter their
credentials, but it is technologically possible for an extension to be defined to carry such values.
Such an extension would be dangerous as it would allow rogue client software to directly collect, store,
and replay the end user's credentials outside of any legitimate use within a GNAP request.</t>

<t>The concerns of such an extension could be mitigated through use of a challenge and response
unlocked by the end user's credentials. For example, the AS presents a challenge as part of
an interaction start method, and the client instance signs that challenge using a key derived
from a password presented by the end user. It would be possible for the client software to
collect this password in a secure software enclave without exposing the password to the rest
of the client software or putting it across the wire to the AS. The AS can validate this challenge
response against a known password for the identified end user. While an approach such as this does
not remove all of the concerns surrounding such a password-based scheme, it is at least
possible to implement in a more secure fashion than simply collecting and replaying
the password. Even so, such schemes should only ever be used by trusted clients due to
the ease of abusing them.</t>

</section>
<section anchor="security-mixup"><name>Mixing Up Authorization Servers</name>

<t>If a client instance is able to work with multiple AS's simultaneously, it is possible
for an attacker to add a compromised AS to the client instance's configuration and cause the
client software to start a request at the compromised AS. This AS could then proxy the client's
request to a valid AS in order to attempt to get the resource owner to approve access for
the legitimate client instance.</t>

<t>A client instance needs to always be aware of which AS it is talking to throughout a grant process, and ensure
that any callback for one AS does not get conflated with the callback to different AS. The interaction finish
hash calculation in <xref target="interaction-hash"/> allows a client instance to protect against this kind of substitution, but only if
the client instance validates the hash. If the client instance does not use an interaction finish method
or does not check the interaction finish hash value, the compromised AS can be granted a valid
access token on behalf of the resource owner. See <xref target="AXELAND2021"/> for details
of one such attack, which has been since addressed in this document by including the grant endpoint
in the interaction hash calculation. Note that the client instance still needs to validate the hash for
the attack to be prevented.</t>

</section>
<section anchor="security-client-userinfo"><name>Processing of Client-Presented User Information</name>

<t>GNAP allows the client instance to present assertions and identifiers of the current user to the AS as
part of the initial request. This information should only ever be taken by the AS as a hint, since the
AS has no way to tell if the represented person is present at the client software, without using
an interaction mechanism. This information does not guarantee the given user is there, but it does
constitute a statement by the client software that the AS can take into account.</t>

<t>For example, if a specific user is claimed to be present prior to interaction, but a different user
is shown to be present during interaction, the AS can either determine this to be an error or signal
to the client instance through returned subject information that the current user has changed from
what the client instance thought. This user information can also be used by the AS to streamline the
interaction process when the user is present. For example, instead of having the user type in their
account identifier during interaction at a redirected URI, the AS can immediately challenge the user
for their account credentials. Alternatively, if an existing session is detected, the AS can
determine that it matches the identifier provided by the client and subsequently skip an explicit
authentication event by the resource owner.</t>

<t>In cases where the AS trusts the client software more completely, due to policy
or by previous approval of a given client instance, the AS can take this user information as a
statement that the user is present and could issue access tokens and release subject information
without interaction. The AS should only take such action in very limited circumstances, as a
client instance could assert whatever it likes for the user's identifiers in its request. The AS
can limit the possibility of this by issuing randomized opaque identifiers to client instances to
represent different end user accounts after an initial login.</t>

<t>When a client instance presents an assertion to the AS, the AS needs to evaluate that assertion. Since
the AS is unlikely to be the intended audience of an assertion held by the client software, the AS will
need to evaluate the assertion in a different context. Even in this case, the AS can still evaluate
that the assertion was generated by a trusted party, was appropriately signed, and is within
any time validity windows stated by the assertion. If the client instance's audience identifier
is known to the AS and can be associated with the client instance's presented key, the AS can also
evaluate that the appropriate client instance is presenting the claimed assertion. All of this
will prevent an attacker from presenting a manufactured assertion, or one captured from an
untrusted system. However, without validating the audience of the assertion, a captured assertion
could be presented by the client instance to impersonate a given end user. In such cases, the assertion
offers little more protection than a simple identifier would.</t>

<t>A special case exists where the AS is the generator of the assertion being presented by the
client instance. In these cases, the AS can validate that it did issue the assertion and
it is associated with the client instance presenting the assertion.</t>

</section>
<section anchor="security-registration"><name>Client Instance Pre-registration</name>

<t>Each client instance is identified by its own unique key, and for some kinds of client software such as a
web server or backend system, this identification can be facilitated by registering a single key for a piece
of client software ahead of time. This registration can be associated with a set of display attributes to
be used during the authorization process, identifying the client software to the user. In these cases,
it can be assumed that only one instance of client software will exist, likely to serve many different
users.</t>

<t>A client's registration record needs to include its identifying key. Furthermore, it is the case that
any clients using symmetric cryptography for key proofing mechanisms need to have their keys pre-registered.
The registration should also include any information that would aid in the authorization process, such as
a display name and logo. The registration record can also limit a given client to ask for certain
kinds of information and access, or be limited to specific interaction mechanisms at runtime.</t>

<t>It also is sensible to pre-register client instances when the software is acting autonomously, without
the need for a runtime approval by a resource owner or any interaction with an end user. In these cases,
an AS needs to rest on the trust decisions that have been determined prior to runtime in determining
what rights and tokens to grant to a given client instance.</t>

<t>However, it does not make sense to pre-register many types of clients. Single-page applications (SPAs) and
mobile/desktop applications in particular present problems with pre-registration. For SPAs, the instances
are ephemeral in nature and long-term registration of a single instance leads to significant storage and
management overhead at the AS. For mobile applications, each installation of the client software is
a separate instance, and sharing a key among all instances would be detrimental to security as the
compromise of any single installation would compromise all copies for all users.</t>

<t>An AS can treat these classes of client software differently from each other, perhaps by allowing access
to certain high-value APIs only to pre-registered known clients, or by requiring an active end user
delegation of authority to any client software not pre-registered.</t>

<t>An AS can also provide warnings and caveats to resource owners during the authorization process, allowing
the user to make an informed decision regarding the software they are authorizing. For example, if the AS
has done vetting of the client software and this specific instance, it can present a different authorization
screen compared to a client instance that is presenting all of its information at runtime.</t>

<t>Finally, an AS can use platform attestations and other signals from the client instance at runtime
to determine whether the software making the request is legitimate or not. The details of such
attestations are outside the scope of the core protocol, but the <spanx style="verb">client</spanx> portion of a grant request
provides a natural extension point to such information through the <xref target="IANA-client-instance">Client Instance Fields registry</xref>.</t>

</section>
<section anchor="security-impersonation"><name>Client Instance Impersonation</name>

<t>If client instances are allowed to set their own user-facing display information, such as a display name and website
URL, a malicious client instance could impersonate legitimate client software for the purposes of tricking
users into authorizing the malicious client.</t>

<t>Requiring clients to pre-register does not fully mitigate this problem since many pre-registration
systems have self-service portals for management of client registration, allowing authenticated developers
to enter self-asserted information into the management portal.</t>

<t>An AS can mitigate this by actively filtering all self-asserted values presented by client software,
both dynamically as part of GNAP and through a registration portal, to limit the kinds of impersonation that
would be done.</t>

<t>An AS can also warn the resource owner about the provenance of the information it is displaying, allowing
the resource owner to make a more informed delegation decision. For example, an AS can visually differentiate
between a client instance that can be traced back to a specific developer's registration and an
instance that has self-asserted its own display information.</t>

</section>
<section anchor="security-client-hosted-logo"><name>Client-Hosted Logo URI</name>

<t>The <spanx style="verb">logo_uri</spanx> client display field defined in <xref target="request-display"/> allows the client instance to specify
a URI from which an image can be fetched for display during authorization decisions. When the URI points to
an externally hosted resource (as opposed to a data: URI), the <spanx style="verb">logo_uri</spanx> field presents challenges in addition to the
considerations in <xref target="security-impersonation"/>.</t>

<t>When a <spanx style="verb">logo_uri</spanx> is externally hosted, the client software (or the host of the asset) can change the contents of
the logo without informing the AS. Since the logo is considered an aspect of the client software's identity,
this flexibility allows for a more dynamically-managed client instance that makes use of the distributed systems.</t>

<t>However, this same flexibility allows the host of the asset to change the hosted file in a malicious way,
such as replacing the image content with malicious software for download or imitating a different piece
of client software. Additionally, the act of fetching the URI could accidentally leak information to the image host
in the HTTP Referer header field, if one is sent. Even though GNAP intentionally does not include security
parameters in front-channel URI's wherever possible, the AS still should take steps to ensure that
this information does not leak accidentally, such as setting a referrer policy on image links or
displaying images only from paged served from a URI with no sensitive security or identity information.</t>

<t>To avoid these issues, the AS can insist on the use of data: URIs, though that might not be practical for all
types of client software. Alternatively, the AS could pre-fetch the content of the URI and present its own copy
to the resource owner instead. This practice opens the AS to potential SSRF attacks, as discussed in <xref target="security-ssrf"/>.</t>

</section>
<section anchor="security-browser-interception"><name>Interception of Information in the Browser</name>

<t>Most information passed through the web-browser is susceptible to interception and possible manipulation by
elements within the browser such as scripts loaded within pages. Information in the URI is exposed
through browser and server logs, and can also leak to other parties through HTTP <spanx style="verb">Referer</spanx> headers.</t>

<t>GNAP's design limits the information passed directly through the browser, allowing for opaque URIs in most circumstances.
For the redirect-based interaction finish mechanism, named query parameters are used to carry
unguessable opaque values. For these, GNAP requires creation and validation of a cryptographic
hash to protect the query parameters added to the URI and associate them with an ongoing grant
process and values not passed in the URI. The client instance has to properly validate this hash to prevent an attacker from
injecting an interaction reference intended for a different AS or client instance.</t>

<t>Several interaction start mechanisms use URIs created by the AS and passed to the client instance.
While these URIs are opaque to the client instance, it's possible for the AS to include parameters,
paths, and other pieces of information that could leak security data or be manipulated by a party
in the middle of the transaction. An AS implementation can avoid this problem by creating URIs
using unguessable values that are randomized for each new grant request.</t>

</section>
<section anchor="security-callback-uri"><name>Callback URI Manipulation</name>

<t>The callback URI used in interaction finish mechanisms is defined by the client instance. This URI is
opaque to the AS, but can contain information relevant to the client instance's operations. In
particular, the client instance can include state information to allow the callback request to
be associated with an ongoing grant request.</t>

<t>Since this URI is exposed to the end user's browser, it is susceptible to both logging and manipulation
in transit before the request is made to the client software. As such, a client instance should
never put security-critical or private information into the callback URI in a cleartext form. For example,
if the client software includes a post-redirect target URI in its callback URI to the AS, this target URI
could be manipulated by an attacker, creating an open redirector at the client. Instead,
a client instance can use an unguessable identifier in the URI that can then be used by the client
software to look up the details of the pending request. Since this approach requires some form of statefulness
by the client software during the redirection process, clients that are not capable of holding state
through a redirect should not use redirect-based interaction mechanisms.</t>

</section>
<section anchor="security-redirect-status-codes"><name>Redirection Status Codes</name>

<t>As already described in <xref target="I-D.ietf-oauth-security-topics"/>, a server should never use the HTTP 307
status code to redirect a request that potentially contains user credentials. If an HTTP redirect
is used for such a request, the HTTP status code 303 "See Other" should be used instead.</t>

<t>The status code 307, as defined in the HTTP standard <xref target="HTTP"/>, requires the user agent
to preserve the method and content of a request, thus submitting the content of the POST
request to the redirect target. In the HTTP standard <xref target="HTTP"/>, only the status code 303 unambiguously enforces
rewriting the HTTP POST request to an HTTP GET request, which eliminates the POST content from the redirected request. For all other status codes, including
status code 302, user agents are allowed not to rewrite a POST request into a GET request and thus
to resubmit the contents.</t>

<t>The use of status code 307 results in a vulnerability when using the
<xref target="response-interact-finish"><spanx style="verb">redirect</spanx> interaction finish method</xref>. With this method, the AS
potentially prompts the RO to enter their credentials in a form that is then submitted back to the
AS (using an HTTP POST request). The AS checks the credentials and, if successful, may directly
redirect the RO to the client instance's redirect URI. Due to the use of status code 307, the RO's
user agent now transmits the RO's credentials to the client instance. A malicious client instance
can then use the obtained credentials to impersonate the RO at the AS.</t>

<t>Redirection away from the initial URI in an interaction session could also leak information found in that
initial URI through the HTTP Referer header field, which would be sent by the user agent to the redirect
target. To avoid such leakage, a server can first redirect to an internal interstitial page without any identifying
or sensitive information on the URI before processing the request. When the user agent is ultimately
redirected from this page, no part of the original interaction URI will be found in the Referer header.</t>

</section>
<section anchor="security-as-response"><name>Interception of Responses from the AS</name>

<t>Responses from the AS contain information vital to both the security and privacy operations of
GNAP. This information includes nonces used in cryptographic calculations, subject identifiers,
assertions, public keys, and information about what client software is requesting and was granted.</t>

<t>In addition, if bearer tokens are used or keys are issued alongside a bound access token, the
response from the AS contains all information necessary for use of the contained access token. Any
party that is capable of viewing such a response, such as an intermediary proxy, would be able
to exfiltrate and use this token. If the access token is instead bound to the client instance's
presented key, intermediaries no longer have sufficient information to use the token. They can
still, however, gain information about the end user as well as the actions of the client software.</t>

</section>
<section anchor="security-key-distribution"><name>Key Distribution</name>

<t>GNAP does not define ways for the client instances keys to be provided to the client instances,
particularly in light of how those keys are made known to the AS. These keys could be
generated dynamically on the client software or pre-registered at the AS in a static developer portal.
The keys for client instances could also be distributed as part of the deployment process of instances
of the client software. For example, an application installation framework could generate
a keypair for each copy of client software, then both install it into the client software
upon installation and registering that instance with the AS.</t>

<t>Alternatively, it's possible for the AS to generate keys to be used with access tokens that
are separate from the keys used by the client instance to request tokens. In this method,
the AS would generate the asymmetric keypair or symmetric key and return the public key or key
reference, to the client instance alongside the access
token itself. The means for the AS to return generated key values to the client instance
are out of scope, since GNAP does not allow the transmission of private or shared key
information within the protocol itself.</t>

<t>Additionally, if the token is bound to a key other than the client instance's presented key, this
opens a possible attack surface for an attacker's AS to request an access token then substitute
their own key material in the response to the client instance. The attacker's AS would need to
be able to use the same key as the client instance, but this setup would allow an attacker's AS
to make use of a compromised key within a system. This attack can be prevented by only binding
access tokens to the client instance's presented keys, and by having client instances have a strong
association between which keys they expect to use and the AS they expect to use them on.
This attack is also only able to be propagated on client instances that talk to more than
one AS at runtime, which can be limited by the client software.</t>

</section>
<section anchor="security-key-rotation"><name>Key Rotation Policy</name>

<t>When keys are rotated, there could be a delay in the propagation of that rotation to various components in the AS's ecosystem. The AS can define its own policy regarding the timeout of the previously-bound key, either making it immediately obsolete or allowing for a limited grace period during which both the previously-bound key and the current key can be used for signing requests. Such a grace period can be useful when there are multiple running copies of the client that are coordinated with each other. For example, the client software could be deployed as a cloud service with multiple orchestrated nodes. Each of these copies is deployed using the same key and therefore all the nodes represent the same client instance to the AS. In such cases, it can be difficult, or even impossible, to update the keys on all these copies in the same instant.</t>

<t>The need for accommodating such known delays in the system needs to be balanced with the risk of allowing an old key to still be used. Narrowly restricting the exposure opportunities for exploit at the AS in terms of time, place, and method makes exploit significantly more difficult, especially if the exception happens only once. For example, the AS can reject requests from the previously-bound key (or any previous one before it) to cause rotation to a new key, or at least ensure that the rotation happens in an idempotent way to the same new key.</t>

<t>See also the related considerations for token values in <xref target="security-network-management"/>.</t>

</section>
<section anchor="security-polling"><name>Interaction Finish Modes and Polling</name>

<t>During the interaction process, the client instance usually hands control of the user experience
over to another component, be it the system browser, another application, or some action
the resource owner is instructed to take on another device. By using an interaction finish
method, the client instance can be securely notified by the AS when the interaction is completed
and the next phase of the protocol should occur. This process includes information that the
client instance can use to validate the finish call from the AS and prevent some injection,
session hijacking, and phishing attacks.</t>

<t>Some types of client deployment are unable to receive an interaction finish message.
Without an interaction finish method to notify it, the client instance will need to poll the
grant continuation API while waiting for the resource owner to approve or deny the request.
An attacker could take advantage of this situation by capturing the interaction start
parameters and phishing a legitimate user into authorizing the attacker's waiting
client instance, which would in turn have no way of associating the completed interaction
from the targeted user with the start of the request from the attacker.</t>

<t>However, it is important to note that this pattern is practically indistinguishable
from some legitimate use cases. For example, a smart device emits a code for
the resource owner to enter on a separate device. The smart device has to poll
because the expected behavior is that the interaction will take place on the separate
device, without a way to return information to the original device's context.</t>

<t>As such, developers need to weigh the risks of forgoing an interaction finish
method against the deployment capabilities of the client software and its
environment. Due to the increased security, an interaction finish method should
be employed whenever possible.</t>

</section>
<section anchor="security-sessions"><name>Session Management for Interaction Finish Methods</name>

<t>When using an interaction finish method such as <spanx style="verb">redirect</spanx> or <spanx style="verb">push</spanx>, the client instance receives
an unsolicited inbound request from an unknown party over HTTPS. The client
instance needs to be able to successfully associate this incoming request with a specific pending
grant request being managed by the client instance. If the client instance is not careful and precise about
this, an attacker could associate their own session at the client instance with a stolen interaction
response. The means of preventing this varies by the type of client software and interaction methods in use.
Some common patterns are enumerated here.</t>

<t>If the end user interacts with the client instance through a web browser and the <spanx style="verb">redirect</spanx>
interaction finish method is used, the client instance can ensure that the incoming HTTP request
from the finish method is presented in the same browser session that the grant request was
started in. This technique is particularly useful when the <spanx style="verb">redirect</spanx> interaction start mode
is used as well, since in many cases the end user will follow the redirection with the
same browser that they are using to interact with the client instance.
The client instance can then store the relevant pending grant information in the
session, either in the browser storage directly (such as with a single-page application) or
in an associated session store on a back-end server. In both cases, when the incoming request
reaches the client instance, the session information can be used to ensure that the same party
that started the request is present as the request finishes.</t>

<t>Ensuring that the same party that started a request is present when that request finishes can
prevent phishing attacks, where an attacker starts a request at an honest client instance and
tricks an honest RO into authorizing it. For example, if an honest end user (that also acts as the
RO) wants to start a request through a client instance controlled by the attacker, the attacker can
start a request at an honest client instance and then redirect the honest end user to the
interaction URI from the attackers session with the honest client instance. If the honest end user
then fails to realize that they are not authorizing the attacker-controlled client instance (with which
it started its request) but instead the honest client instance when interacting with the AS, the attacker's
session with the honest client instance would be authorized. This would give the attacker access to
the honest end user's resources that the honest client instance is authorized to access. However,
if after the interaction the AS redirects the honest end user back to the client instance whose
grant request the end user just authorized, the honest end user is redirected to the honest client
instance. The honest client instance can then detect that the end user is not the party that started the
request, since the request at the honest client instance was started by the
attacker. This detection can prevent the attack. This is related to the discussion in <xref target="security-impersonation"/>, because again
the attack can be prevented by the AS informing the user as much as possible about the client
instance that is to be authorized.</t>

<t>If the end user does not interact with the client instance through a web browser or the interaction
start method does not use the same browser or device that the end user is interacting through
(such as the launch of a second device through a scannable code or presentation of a user code) the
client instance will not be able to strongly associate an incoming HTTP request with an established
session with the end user. This is also true when the <spanx style="verb">push</spanx> interaction finish method is used,
since the HTTP request comes directly from the interaction component of the AS. In these
circumstances, the client instance can at least ensure that the incoming HTTP
request can be uniquely associated with an ongoing grant request by making the interaction finish
callback URI unique for the grant when making the <xref target="request-interact-finish">interaction request</xref>.
Mobile applications and other client instances that generally serve only a single end user at a time
can use this unique incoming URL to differentiate between a legitimate incoming request and
an attacker's stolen request.</t>

</section>
<section anchor="security-interact-hash"><name>Calculating Interaction Hash</name>

<t>While the use of GNAP's signing mechanisms and token-protected grant API provides
significant security protections to the protocol, the interaction reference mechanism
is susceptible to monitoring, capture, and injection by an attacker. To combat this, GNAP
requires the calculation and verification of an interaction hash. A client instance
might be tempted to skip this step, but doing so leaves the client instance open to
injection and manipulation by an attacker that could lead to additional issues.</t>

<t>The calculation of the interaction hash value provides defense in depth, allowing a client
instance to protect itself from spurious injection of interaction references when using an
interaction finish method. The AS is protected during this attack through the
continuation access token being bound to the expected interaction reference,
but without hash calculation, the attacker could cause the client to make an
HTTP request on command, which could itself be manipulated -- for example, by including
a malicious value in the interaction reference designed to attack the AS.
With both of these in place, an attacker attempting to substitute the interaction reference
is stopped in several places.</t>

<figure title="Figure 11: Interaction hash attack"><artset><artwork  type="svg"><svg xmlns="http://www.w3.org/2000/svg" version="1.1" height="448" width="456" viewBox="0 0 456 448" class="diagram" text-anchor="middle" font-family="monospace" font-size="13px" stroke-linecap="round">
<path d="M 8,48 L 8,416" fill="none" stroke="black"/>
<path d="M 64,48 L 64,416" fill="none" stroke="black"/>
<path d="M 120,48 L 120,224" fill="none" stroke="black"/>
<path d="M 120,256 L 120,272" fill="none" stroke="black"/>
<path d="M 120,336 L 120,368" fill="none" stroke="black"/>
<path d="M 120,400 L 120,416" fill="none" stroke="black"/>
<path d="M 192,48 L 192,224" fill="none" stroke="black"/>
<path d="M 192,256 L 192,272" fill="none" stroke="black"/>
<path d="M 192,336 L 192,368" fill="none" stroke="black"/>
<path d="M 192,400 L 192,416" fill="none" stroke="black"/>
<path d="M 248,32 L 248,160" fill="none" stroke="black"/>
<path d="M 248,224 L 248,304" fill="none" stroke="black"/>
<path d="M 248,336 L 248,432" fill="none" stroke="black"/>
<path d="M 320,32 L 320,160" fill="none" stroke="black"/>
<path d="M 320,224 L 320,304" fill="none" stroke="black"/>
<path d="M 320,336 L 320,432" fill="none" stroke="black"/>
<path d="M 376,32 L 376,432" fill="none" stroke="black"/>
<path d="M 448,32 L 448,432" fill="none" stroke="black"/>
<path d="M 24,32 L 48,32" fill="none" stroke="black"/>
<path d="M 136,32 L 176,32" fill="none" stroke="black"/>
<path d="M 248,32 L 320,32" fill="none" stroke="black"/>
<path d="M 376,32 L 448,32" fill="none" stroke="black"/>
<path d="M 192,94 L 208,94" fill="none" stroke="black"/><path d="M 192,98 L 208,98" fill="none" stroke="black"/>
<path d="M 224,94 L 240,94" fill="none" stroke="black"/><path d="M 224,98 L 240,98" fill="none" stroke="black"/>
<path d="M 320,112 L 336,112" fill="none" stroke="black"/>
<path d="M 352,112 L 368,112" fill="none" stroke="black"/>
<path d="M 328,128 L 344,128" fill="none" stroke="black"/>
<path d="M 360,128 L 376,128" fill="none" stroke="black"/>
<path d="M 200,142 L 216,142" fill="none" stroke="black"/><path d="M 200,146 L 216,146" fill="none" stroke="black"/>
<path d="M 232,142 L 248,142" fill="none" stroke="black"/><path d="M 232,146 L 248,146" fill="none" stroke="black"/>
<path d="M 192,174 L 216,174" fill="none" stroke="black"/><path d="M 192,178 L 216,178" fill="none" stroke="black"/>
<path d="M 232,174 L 368,174" fill="none" stroke="black"/><path d="M 232,178 L 368,178" fill="none" stroke="black"/>
<path d="M 200,206 L 336,206" fill="none" stroke="black"/><path d="M 200,210 L 336,210" fill="none" stroke="black"/>
<path d="M 352,206 L 376,206" fill="none" stroke="black"/><path d="M 352,210 L 376,210" fill="none" stroke="black"/>
<path d="M 64,238 L 88,238" fill="none" stroke="black"/><path d="M 64,242 L 88,242" fill="none" stroke="black"/>
<path d="M 104,238 L 240,238" fill="none" stroke="black"/><path d="M 104,242 L 240,242" fill="none" stroke="black"/>
<path d="M 320,256 L 336,256" fill="none" stroke="black"/>
<path d="M 352,256 L 368,256" fill="none" stroke="black"/>
<path d="M 328,272 L 344,272" fill="none" stroke="black"/>
<path d="M 360,272 L 376,272" fill="none" stroke="black"/>
<path d="M 72,286 L 216,286" fill="none" stroke="black"/><path d="M 72,290 L 216,290" fill="none" stroke="black"/>
<path d="M 232,286 L 248,286" fill="none" stroke="black"/><path d="M 232,290 L 248,290" fill="none" stroke="black"/>
<path d="M 64,318 L 88,318" fill="none" stroke="black"/><path d="M 64,322 L 88,322" fill="none" stroke="black"/>
<path d="M 104,318 L 368,318" fill="none" stroke="black"/><path d="M 104,322 L 368,322" fill="none" stroke="black"/>
<path d="M 72,350 L 88,350" fill="none" stroke="black"/><path d="M 72,354 L 88,354" fill="none" stroke="black"/>
<path d="M 104,350 L 120,350" fill="none" stroke="black"/><path d="M 104,354 L 120,354" fill="none" stroke="black"/>
<path d="M 64,382 L 88,382" fill="none" stroke="black"/><path d="M 64,386 L 88,386" fill="none" stroke="black"/>
<path d="M 104,382 L 240,382" fill="none" stroke="black"/><path d="M 104,386 L 240,386" fill="none" stroke="black"/>
<path d="M 320,400 L 336,400" fill="none" stroke="black"/>
<path d="M 352,400 L 368,400" fill="none" stroke="black"/>
<path d="M 24,432 L 48,432" fill="none" stroke="black"/>
<path d="M 136,432 L 176,432" fill="none" stroke="black"/>
<path d="M 248,432 L 320,432" fill="none" stroke="black"/>
<path d="M 376,432 L 448,432" fill="none" stroke="black"/>
<path d="M 24,32 C 15.16936,32 8,39.16936 8,48" fill="none" stroke="black"/>
<path d="M 48,32 C 56.83064,32 64,39.16936 64,48" fill="none" stroke="black"/>
<path d="M 136,32 C 127.16936,32 120,39.16936 120,48" fill="none" stroke="black"/>
<path d="M 176,32 C 184.83064,32 192,39.16936 192,48" fill="none" stroke="black"/>
<path d="M 24,432 C 15.16936,432 8,424.83064 8,416" fill="none" stroke="black"/>
<path d="M 48,432 C 56.83064,432 64,424.83064 64,416" fill="none" stroke="black"/>
<path d="M 136,432 C 127.16936,432 120,424.83064 120,416" fill="none" stroke="black"/>
<path d="M 176,432 C 184.83064,432 192,424.83064 192,416" fill="none" stroke="black"/>
<polygon class="arrowhead" points="376,400 364,394.4 364,405.6" fill="black" transform="rotate(0,368,400)"/>
<polygon class="arrowhead" points="376,320 364,314.4 364,325.6" fill="black" transform="rotate(0,368,320)"/>
<polygon class="arrowhead" points="376,256 364,250.4 364,261.6" fill="black" transform="rotate(0,368,256)"/>
<polygon class="arrowhead" points="376,176 364,170.4 364,181.6" fill="black" transform="rotate(0,368,176)"/>
<polygon class="arrowhead" points="376,112 364,106.4 364,117.6" fill="black" transform="rotate(0,368,112)"/>
<polygon class="arrowhead" points="336,272 324,266.4 324,277.6" fill="black" transform="rotate(180,328,272)"/>
<polygon class="arrowhead" points="336,128 324,122.4 324,133.6" fill="black" transform="rotate(180,328,128)"/>
<polygon class="arrowhead" points="248,384 236,378.4 236,389.6" fill="black" transform="rotate(0,240,384)"/>
<polygon class="arrowhead" points="248,240 236,234.4 236,245.6" fill="black" transform="rotate(0,240,240)"/>
<polygon class="arrowhead" points="248,96 236,90.4 236,101.6" fill="black" transform="rotate(0,240,96)"/>
<polygon class="arrowhead" points="208,208 196,202.4 196,213.6" fill="black" transform="rotate(180,200,208)"/>
<polygon class="arrowhead" points="208,144 196,138.4 196,149.6" fill="black" transform="rotate(180,200,144)"/>
<polygon class="arrowhead" points="80,352 68,346.4 68,357.6" fill="black" transform="rotate(180,72,352)"/>
<polygon class="arrowhead" points="80,288 68,282.4 68,293.6" fill="black" transform="rotate(180,72,288)"/>
<g class="text">
<text x="36" y="52">User</text>
<text x="156" y="52">Attacker</text>
<text x="284" y="52">Client</text>
<text x="412" y="52">AS</text>
<text x="284" y="68">Instance</text>
<text x="216" y="100">1</text>
<text x="344" y="116">2</text>
<text x="352" y="132">3</text>
<text x="224" y="148">4</text>
<text x="224" y="180">5</text>
<text x="248" y="196">|</text>
<text x="320" y="196">|</text>
<text x="344" y="212">6</text>
<text x="96" y="244">A</text>
<text x="344" y="260">B</text>
<text x="352" y="276">C</text>
<text x="224" y="292">D</text>
<text x="120" y="308">|</text>
<text x="192" y="308">|</text>
<text x="96" y="324">E</text>
<text x="96" y="356">7</text>
<text x="96" y="388">F</text>
<text x="344" y="404">G</text>
</g>
</svg>
</artwork><artwork  type="ascii-art"><![CDATA[
 .----.        .------.       +--------+      +--------+
| User |      |Attacker|      | Client |      |   AS   |
|      |      |        |      |Instance|      |        |
|      |      |        |      |        |      |        |
|      |      |        +=(1)=>|        |      |        |
|      |      |        |      |        +-(2)->|        |
|      |      |        |      |        |<-(3)-+        |
|      |      |        |<=(4)=+        |      |        |
|      |      |        |      |        |      |        |
|      |      |        +==(5)================>|        |
|      |      |        |      |        |      |        |
|      |      |        |<================(6)==+        |
|      |      |        |      |        |      |        |
|      +==(A)================>|        |      |        |
|      |      |        |      |        +-(B)->|        |
|      |      |        |      |        |<-(C)-+        |
|      |<=================(D)=+        |      |        |
|      |      |        |      |        |      |        |
|      +==(E)================================>|        |
|      |      |        |      |        |      |        |
|      |<=(7)=+        |      |        |      |        |
|      |      |        |      |        |      |        |
|      +==(F)================>|        |      |        |
|      |      |        |      |        +-(G)->|        |
|      |      |        |      |        |      |        |
 `----`        `------`       +--------+      +--------+
]]></artwork></artset></figure>

<t><list style="symbols">
  <t>Prerequisites: The client instance can allow multiple end users to
  access the same AS. The attacker is attempting to associate their rights
  with the target user's session.</t>
  <t>(1) The attacker starts a session at the client instance.</t>
  <t>(2) The client instance creates a grant request with nonce CN1.</t>
  <t>(3) The AS responds to the grant request with a
  need to interact, nonce SN1, and a continuation token, CT1.</t>
  <t>(4) The client instructs the attacker to interact at the AS.</t>
  <t>(5) The attacker interacts at the AS.</t>
  <t>(6) The AS completes the interact finish with interact ref IR1 and
  interact hash IH1 calculated from (CN1 + SN1 + IR1 + AS).
  The attacker prevents IR1 from returning to the client instance.</t>
  <t>(A) The target user starts a session at the client instance.</t>
  <t>(B) The client instance creates a grant request with nonce CN2.</t>
  <t>(C) The AS responds to the grant request with a
  need to interact, nonce SN2, and a continuation token, CT2.</t>
  <t>(D) The client instance instructs the user to interact at the AS.</t>
  <t>(E) The target user interacts at the AS.</t>
  <t>(7) Before the target user can complete their interaction, the attacker
  delivers their own interact ref IR1 into the user's session. The attacker
  cannot calculate the appropriate hash because the attacker does not have
  access to CN2 and SN2.</t>
  <t>(F) The target user triggers the interaction finish in their own session
  with the attacker's IR1.</t>
  <t>(G) If the client instance is checking the interaction hash, the attack
  stops here because the hash calculation of (CN2 + SN2 + IR1 + AS) will fail.
  If the client instance does not check the interaction hash, the client instance
  will be tricked into submitting the interaction reference to the AS. Here, the AS will
  reject the interaction request because it is presented against CT2 and not
  CT1 as expected. However, an attacker who has potentially injected CT1 as
  the value of CT2 would be able to continue the attack.</t>
</list></t>

<t>Even with additional checks in place, client instances using interaction finish mechanisms are responsible
for checking the interaction hash to provide security to the overall system.</t>

</section>
<section anchor="security-client-storage"><name>Storage of Information During Interaction and Continuation</name>

<t>When starting an interactive grant request, a client application has a number of protocol elements
that it needs to manage, including nonces, references, keys, access tokens, and other elements.
During the interaction process, the client instance usually hands control of the user experience
over to another component, be it the system browser, another application, or some action
the resource owner is instructed to take on another device. In order for the client instance
to make its continuation call, it will need to recall all of these protocol elements at a future time. Usually
this means the client instance will need to store these protocol elements in some retrievable
fashion.</t>

<t>If the security protocol elements are stored on the end user's device, such as in browser
storage or in local application data stores, capture and exfiltration of this information could
allow an attacker to continue a pending transaction instead of the client instance. Client
software can make use of secure storage mechanisms, including hardware-based key and data
storage, to prevent such exfiltration.</t>

<t>Note that in GNAP, the client instance has to choose its interaction finish URI prior to making
the first call to the AS. As such, the interaction finish URI will often have a unique identifier
for the ongoing request, allowing the client instance to access the correct portion of its
storage. Since this URI is passed to other parties and often used through a browser,
this URI should not contain any security-sensitive information that would be
valuable to an attacker, such as any token identifier, nonce, or user information. Instead, a
cryptographically random value is suggested, and that value should be used to index into
a secure session or storage mechanism.</t>

</section>
<section anchor="security-continuation"><name>Denial of Service (DoS) through Grant Continuation</name>

<t>When a client instance starts off an interactive process, it will eventually need to continue the grant
request in a subsequent message to the AS. It's possible for a naive client implementation to continuously
send continuation requests to the AS while waiting for approval, especially if no interaction
finish method is used. Such constant requests could overwhelm the AS's ability to respond to both
these and other requests.</t>

<t>To mitigate this for well-behaved client software, the continuation response contains a <spanx style="verb">wait</spanx> parameter
that is intended to tell the client instance how long it should wait until making its next request.
This value can be used to back off client software that is checking too quickly by returning increasing
wait times for a single client instance.</t>

<t>If client software ignores the <spanx style="verb">wait</spanx> value and makes its continuation calls too quickly, or if the
client software assumes the absence of the <spanx style="verb">wait</spanx> values means it should poll immediately, the AS
can choose to return errors to the offending client instance, including possibly canceling the
ongoing grant request. With well-meaning client software these errors can indicate a need to change
the client software's programmed behavior.</t>

</section>
<section anchor="security-random-exhaustion"><name>Exhaustion of Random Value Space</name>

<t>Several parts of the GNAP process make use of unguessable randomized values, such as nonces,
tokens, user codes, and randomized URIs. Since these values are intended to be unique, a sufficiently
powerful attacker could make a large number of requests to trigger generation of randomized
values in an attempt to exhaust the random number generation space. While this attack is
particularly applicable to the AS, client software could likewise be targeted by an attacker
triggering new grant requests against an AS.</t>

<t>To mitigate this, software can ensure that its random values are chosen from a significantly
large pool that exhaustion of that pool is prohibitive for an attacker. Additionally, the
random values can be time-boxed in such a way as their validity windows are reasonably short.
Since many of the random values used within GNAP are used within limited portions of the protocol,
it is reasonable for a particular random value to be valid for only a small amount of time.
For example, the nonces used for interaction finish hash calculation need only to be valid while
the client instance is waiting for the finish callback and can be functionally expired
when the interaction has completed. Similarly, artifacts like access tokens and the interaction
reference can be limited to have lifetimes tied to their functional utility. Finally, each
different category of artifact (nonce, token, reference, identifier, etc.) can be
generated from a separate random pool of values instead of a single global value space.</t>

</section>
<section anchor="security-front-channel"><name>Front-channel URIs</name>

<t>Some interaction methods in GNAP make use of URIs accessed through the end user's browser,
known collectively as front-channel communication. These URIs are most notably present in
the <spanx style="verb">redirect</spanx> interaction <spanx style="verb">start</spanx> method and the <spanx style="verb">redirect</spanx> interaction <spanx style="verb">finish</spanx> mode. Since
these URIs are intended to be given to the end user, the end user and their browser will be
subjected to anything hosted at that URI including viruses, malware, and phishing scams. This
kind of risk is inherent to all redirection-based protocols, including GNAP when used in this way.</t>

<t>When talking to a new or unknown AS, a client instance might want to check the URI from the
interaction <spanx style="verb">start</spanx> against a blocklist and warn the end user before redirecting them. Many
client instances will provide an interstitial message prior to redirection in order to prepare
the user for control of the user experience being handed to the domain of the AS, and such a
method could be used to warn the user of potential threats. For instance, a rogue AS impersonating
a well-known service provider. Client software can also prevent this by managing an allowlist
of known and trusted AS's.</t>

<t>Alternatively, an attacker could start a GNAP request with a known and trusted AS but include
their own attack site URI as the callback for the redirect <spanx style="verb">finish</spanx> method. The attacker would then send
the interaction <spanx style="verb">start</spanx> URI to the victim and get them to click on it. Since the URI is at
the known AS, the victim is inclined to do so. The victim will then be prompted to approve the
attacker's application, and in most circumstances the victim will then be redirected to the
attacker's site whether or not the user approved the request. The AS could mitigate this partially
by using a blocklist and allowlist of interaction <spanx style="verb">finish</spanx> URIs during the client instance's
initial request, but this approach can be  especially difficult if the URI has any dynamic portion
chosen by the client software. The AS can couple these checks with policies associated with the
client instance that has been authenticated in the request. If the AS has any doubt about the
interaction finish URI, the AS can provide an interstitial warning to the end user before
processing the redirect.</t>

<t>Ultimately, all protocols that use redirect-based communication through the user's browser are
susceptible to having an attacker try to co-opt one or more of those URIs in order to harm the
user. It is the responsibility of the AS and the client software to provide appropriate warnings,
education, and mitigation to protect end users.</t>

</section>
<section anchor="security-assertions"><name>Processing Assertions</name>

<t>Identity assertions can be used in GNAP to convey subject information, both from the AS to the
client instance in a <xref target="response-subject">response</xref> and from the client instance to the AS in
a <xref target="request-subject">request</xref>. In both of these circumstances, when an assertion is passed in
GNAP, the receiver of the assertion needs to parse and process the assertion. As assertions are
complex artifacts with their own syntax and security, special care needs to be taken to prevent the
assertion values from being used as an attack vector.</t>

<t>All assertion processing needs to account for the security aspects of the assertion format in
use. In particular, the processor needs to parse the assertion from a JSON string object,
and apply the appropriate cryptographic processes to ensure the integrity of the assertion.</t>

<t>For example, when SAML 2 assertions are used, the receiver has to parse an XML document. There are
many well-known security vulnerabilities in XML parsers, and the XML standard itself can be
attacked through the use of processing instructions and entity expansions to cause problems
with the processor. Therefore, any system capable of processing SAML 2 assertions also needs to
have a secure and correct XML parser. In addition to this, the SAML 2 specification uses XML
Signatures, which have their own implementation problems that need to be accounted for. Similar
requirements exist for OpenID Connect's ID token, which is based on the JSON Web Token (JWT) format
and the related JSON Object Signing And Encryption (JOSE) cryptography suite.</t>

</section>
<section anchor="security-cuckoo"><name>Stolen Token Replay</name>

<t>If a client instance can request tokens at multiple AS's, and the client instance uses the same keys
to make its requests across those different AS's, then it is possible for an attacker to replay a
stolen token issued by an honest AS from a compromised AS, thereby binding the stolen token to
the client instance's key in a different context. The attacker can manipulate the client instance
into using the stolen token at an RS, particularly at an RS that is expecting a token from the
honest AS. Since the honest AS issued the token and the client instance presents the token with
its expected bound key, the attack succeeds.</t>

<t>This attack has several preconditions. In this attack, the attacker does not need access to the
client instance's key and cannot use the stolen token directly at the RS, but the attacker is able
to get the access token value in some fashion. The client instance also needs to be configured to
talk to multiple AS's, including the attacker's controlled AS. Finally, the client instance needs
to be able to be manipulated by the attacker to call the RS while using a token issued from the
stolen AS. The RS does not need to be compromised or made to trust the attacker's AS.</t>

<t>To protect against this attack, the client instance can use a different key for each AS that it
talks to. Since the replayed token will be bound to the key used at the honest AS, the
uncompromised RS will reject the call since the client instance will be using the key used at
the attacker's AS instead with the same token.
When the MTLS key proofing method is used, a client instance can use self-signed
certificates to use a different key for each AS that it talks to, as discussed in
<xref target="security-mtls-patterns"/>.</t>

<t>Additionally, the client instance can keep a strong association between the RS and a specific AS
that it trusts to issue tokens for that RS. This strong binding also helps against some forms of
<xref target="security-mixup">AS mix-up attacks</xref>. Managing this binding is outside the scope of GNAP core,
but it can be managed either as a configuration element for the client instance or dynamically
through <xref target="rs-request-without-token">discovering the AS from the RS</xref>.</t>

<t>The details of this attack are available in <xref target="HELMSCHMIDT2022"/> with additional discussion and considerations.</t>

</section>
<section anchor="security-stateless-tokens"><name>Self-contained Stateless Access Tokens</name>

<t>The contents and format of the access token are at the discretion of the AS, and are opaque
to the client instance within GNAP. As discussed in the companion document,
<xref target="I-D.ietf-gnap-resource-servers"/>, the AS and RS can make use of stateless access tokens
with an internal structure and format. These access tokens allow an RS to validate the token without
having to make any external calls at runtime, allowing for benefits in some deployments, the
discussion of which are outside the scope of this specification.</t>

<t>However, the use of such self-contained access tokens has an effect on the ability of the AS to
provide certain functionality defined within this specification. Specifically, since the access
token is self-contained, it is difficult or impossible for an AS to signal to all RS's within an
ecosystem when a specific access token has been revoked. Therefore, an AS in such an ecosystem
should probably not offer token revocation functionality to client instances, since the client
instance's calls to such an endpoint is effectively meaningless. However, a client instance calling
the token revocation function will also throw out its copy of the token, so such a placebo endpoint
might not be completely meaningless. Token rotation similarly difficult because the AS has to
revoke the old access token after a rotation call has been made. If the access tokens are
completely self-contained and non-revocable, this means that there will be a period of time during
which both the old and new access tokens are valid and usable, which is an increased security risk
for the environment.</t>

<t>These problems can be mitigated by keeping the validity time windows of self-contained access tokens
reasonably short, limiting the time after a revocation event that a revoked token could be used.
Additionally, the AS could proactively signal to RS's under its control identifiers for revoked
tokens that have yet to expire. This type of information push would be expected to be relatively
small and infrequent, and its implementation is outside the scope of this specification.</t>

</section>
<section anchor="security-network-management"><name>Network Problems and Token and Grant Management</name>

<t>If a client instance makes a call to rotate an access token but the network connection is dropped
before the client instance receives the response with the new access token, the system as a whole
can end up in an inconsistent state, where the AS has already rotated the old access token and
invalidated it, but the client instance only has access to the invalidated access token and not the
newly rotated token value. If the client instance retries the rotation request, it would fail
because the client is no longer presenting a valid and current access token. A similar situation
can occur during grant continuation, where the same client instance calls to continue or update
a grant request without successfully receiving the results of the update.</t>

<t>To combat this, both
<xref target="continue-request">grant Management</xref> and <xref target="token-management">token management</xref> can be designed to be
idempotent, where subsequent calls to the same function with the same credentials are meant to
produce the same results. For example, multiple calls to rotate the same access token need to
result in the same rotated token value, within a reasonable time window.</t>

<t>In practice, an AS can hold on to an old token value for such limited purposes. For example, to
support rotating access tokens over unreliable networks, the AS receives the initial request to
rotate an access token and creates a new token value and returns it. The AS also marks the old
token value as having been used to create the newly-rotated token value. If the AS sees the old
token value within a small enough time window, such as a few seconds since the first rotation
attempt, the AS can return the same rotated access token value. Furthermore, once the system has seen the
newly-rotated token in use, the original token can be discarded because the client instance has
proved that it did receive the token. The result of this is a system that is
eventually self-consistent without placing an undue complexity burden on the client instance
to manage problematic networks.</t>

</section>
<section anchor="security-ssrf"><name>Server-side Request Forgery (SSRF)</name>

<t>There are several places within GNAP where a URI can be given to a party causing it to fetch that
URI during normal operation of the protocol. If an attacker is able to control the value of one of
these URIs within the protocol, the attacker could cause the target system to execute a request on
a URI that is within reach of the target system but normally unavailable to the attacker. For
example, an attacker sending a URL of <spanx style="verb">http://localhost/admin</spanx> to cause the server to access an
internal function on itself, or <spanx style="verb">https://192.168.0.14/</spanx> to call a service behind a firewall.
Even if the attacker does not gain access to the results of the call, the side effects of such
requests coming from a trusted host can be problematic to the security and sanctity of such
otherwise unexposed endpoints. This can be particularly problematic if such a URI is used to
call non-HTTP endpoints, such as remote code execution services local to the AS.</t>

<t>In GNAP, the most vulnerable place in the core protocol is the
<xref target="interaction-pushback">push-based post-interaction finish method</xref>, as the client instance is
less trusted than the AS and can use this method to make the AS call an arbitrary URI. While it is
not required by the protocol, the AS can fetch other client-instance provided URIs such as the logo
image or home page, for verification or privacy-preserving purposes before displaying them to the
resource owner as part of a consent screen. Even if the AS does not fetch these URIs, their use in
GNAP's normal operation could cause an attack against the end user's browser as it fetches these
same attack URIs. Furthermore, extensions to GNAP that allow or require
URI fetch could also be similarly susceptible, such as a system for having the AS fetch a client
instance's keys from a presented URI instead of the client instance presenting the key by value.
Such extensions are outside the scope of this specification, but any system deploying such an
extension would need to be aware of this issue.</t>

<t>To help mitigate this problem, similar approaches to protecting parties against
<xref target="security-front-channel">malicious redirects</xref> can be used. For example, all URIs that can result
in a direct request being made by a party in the protocol can be filtered through an allowlist or
blocklist. For example, an AS that supports the <spanx style="verb">push</spanx> based interaction <spanx style="verb">finish</spanx> can compare the
callback URI in the interaction request to a known URI for a pre-registered client instance, or it
can ensure that the URI is not on a blocklist of sensitive URLs such as internal network addresses.
However, note that because these types of calls happen outside of the view of human interaction,
it is not usually feasible to provide notification and warning to someone before the request
needs to be executed, as is the case with redirection URLs. As such, SSRF is somewhat more difficult
to manage at runtime, and systems should generally refuse to fetch a URI if unsure.</t>

</section>
<section anchor="security-multiple-key-formats"><name>Multiple Key Formats</name>

<t>All keys presented by value are allowed to be in only a single format. While it would seem
beneficial to allow keys to be sent in multiple formats, in case the receiver doesn't understand
one or more of the formats used, there would be security issues with such a feature.
If multiple keys formats were allowed,
receivers of these key definitions would need to be able to make sure that it's the same
key represented in each field and not simply use one of the key formats without checking for
equivalence. If equivalence were not carefully checked, it is possible for an attacker to insert
their own key into one of the formats without needing to have control over the other formats. This
could potentially lead to a situation where one key is used by part of the system (such as
identifying the client instance) and a different key in a different format in the same message is
used for other things (such as calculating signature validity). However, in such cases, it is
impossible for the receiver to ensure that all formats contain the same key information since it is
assumed that the receiver cannot understand all of the formats.</t>

<t>To combat this, all keys presented by value have to be in exactly one supported format known
by the receiver as discussed in <xref target="key-format"/>. In most cases, a client instance is going to be configured with its keys in a
single format, and it will simply present that format as-is to the AS in its request. A client
instance capable of multiple formats can use <xref target="discovery">AS discovery</xref> to determine which formats
are supported, if desired. An AS should be generous in supporting many different key formats to
allow different types of client software and client instance deployments. An AS implementation
should try to support multiple formats to allow a variety of client software to connect.</t>

</section>
<section anchor="security-async"><name>Asynchronous Interactions</name>

<t>GNAP allows the RO to be contacted by the AS asynchronously, outside the regular flow of the
protocol. This allows for some advanced use cases, such as cross-user authentication or information
release, but such advanced use cases have some distinct issues that implementors need to be fully
aware of before using these features.</t>

<t>First, in many applications, the return of a subject information to the client instance could
indicate to the client instance that the end-user is the party represented by that information,
functionally allowing the end-user to authenticate to the client application. While the details of
a fully functional authentication protocol are outside the scope of GNAP, it is a common
exercise for a client instance to be requesting information about the end user. This is facilitated
by the several <xref target="interaction-start">interaction methods</xref> defined in GNAP that allow the end user
to begin interaction directly with the AS. However, when the subject of the information is
intentionally not the end-user, the client application will need some way to differentiate between
requests for authentication of the end user and requests for information about a different user.
Confusing these states could lead to an attacker having their account associated with a privileged
user. Client instances can mitigate this by having distinct code paths for primary end user
authentication and requesting subject information about secondary users, such as in a call center.
In such use cases, the client software used by the resource owner (the caller) and the end-user
(the agent) are generally distinct, allowing the AS to differentiate between the agent's corporate device
making the request and the caller's personal device approving the request.</t>

<t>Second, RO's interacting asynchronously do not usually have the same context as an end user in an
application attempting to perform the task needing authorization. As such, the asynchronous requests
for authorization coming to the RO from the AS might have very little to do with what the RO is
doing at the time. This situation can consequently lead to authorization fatigue on the part of the
RO, where any incoming authorization request is quickly approved and dispatched without the RO
making a proper verification of the request. An attacker can exploit this fatigue and get the RO
to authorize the attacker's system for access. To mitigate this, AS systems deploying asynchronous
authorization should only prompt the RO when the RO is expecting such a request, and significant
user experience engineering efforts need to be employed to ensure the RO can clearly make the
appropriate security decision. Furthermore, audit capability, and the ability to undo access
decisions that may be ongoing, is particularly important in the asynchronous case.</t>

</section>
<section anchor="security-compromised-rs"><name>Compromised RS</name>

<t>An attacker may aim to gain access to confidential or sensitive resources. The measures for hardening and monitoring resource server systems (beyond protection with access tokens) is out of the scope of this document, but the use of GNAP to protect a system does not absolve the resource server of following best practices.
GNAP generally considers a breach can occur, and therefore advises to prefer key-bound tokens whenever possible, which at least limits the impact of access token leakage by a compromised or malicious RS.</t>

</section>
<section anchor="security-as-keys"><name>AS-Provided Token Keys</name>

<t>While the most common token issuance pattern is to bind the access token to the client instance's
presented key, it is possible for the AS to provide a binding key along with an access token, as
shown by the <spanx style="verb">key</spanx> field of the token response in <xref target="response-token-single"/>. This practice allows
for an AS to generate and manage the keys associated with tokens independently of the keys known
to client instances.</t>

<t>If the key material is returned by value from the AS, then the client instance will simply use this
key value when presenting the token. This can be exploited by an attacker to issue a compromised token
to an unsuspecting client, assuming that the client instance trusts the attacker's AS to issue tokens
for the target RS. In this attack, the attacker first gets a token bound to a key under the attacker's
control. This token is likely bound to an authorization or account controlled by the attacker.
The attacker then re-issues that same token to the client instance, this time acting as an AS. The attacker
can return their own key to the client instance, tricking the client instance into using the attacker's
token. Such an attack is also possible when the key is returned by reference, if the attacker
is able to provide a reference meaningful to the client instance that references a key under the attacker's
control. This substitution attack is similar to some of the main issues found with bearer tokens
as discussed in <xref target="security-bearer-tokens"/>.</t>

<t>Returning a key with an access token should be limited to only circumstances where both the client and AS
can be verified to be honest, and further only when the tradeoff of not using a client instance's own keys
is worth the additional risk.</t>

</section>
</section>
<section anchor="privacy"><name>Privacy Considerations</name>

<t>The privacy considerations in this section are modeled after the list of privacy threats in <xref target="RFC6973"/>, "Privacy Considerations for Internet Protocols", and either explain how these threats are mitigated or advise how the threats relate to GNAP.</t>

<section anchor="surveillance"><name>Surveillance</name>

<t>Surveillance is the observation or monitoring of an individual's communications or activities. Surveillance can be conducted by observers or eavesdroppers at any point along the communications path.</t>

<t>GNAP assumes the TLS protection used throughout the spec is intact. Without the protection of TLS, there are many points throughout the use of GNAP that would lead to possible surveillance. Even with the proper use of TLS, surveillance could occur by several parties outside of the TLS-protected channels, as discussed in the sections below.</t>

<section anchor="surveillance-by-the-client"><name>Surveillance by the Client</name>

<t>The purpose of GNAP is to authorize clients to be able to access information on behalf of a user. So while it is expected that the client may be aware of the user's identity as well as data being fetched for that user, in some cases the extent of the client may be beyond what the user is aware of. For example, a client may be implemented as multiple distinct pieces of software, such as a logging service or a mobile app that reports usage data to an external backend service. Each of these pieces could gain information about the user without the user being aware of this action.</t>

<t>When the client software uses a hosted asset for its components, such as its logo image, the fetch of these assets can reveal user actions to the host. If the AS presents the logo URI to the resource owner in a browser page, the browser will fetch the logo URL from the authorization screen. This fetch will tell the host of the logo image that someone is accessing an instance of the client software and requesting access for it. This is particularly problematic when the host of the asset is not the client software itself, such as when a content delivery network is used.</t>

</section>
<section anchor="surveillance-by-the-authorization-server"><name>Surveillance by the Authorization Server</name>

<t>The role of the authorization server is to manage the authorization of client instances to protect access to the user's data. In this role, the authorization server is by definition aware of each authorization of a client instance by a user. When the authorization server shares user information with the client instance, it needs to make sure that it has the permission from that user to do so.</t>

<t>Additionally, as part of the authorization grant process, the authorization server may be aware of which resource servers the client intends to use an access token at. However, it is possible to design a system using GNAP in which this knowledge is not made available to the authorization server, such as by avoiding the use of the <spanx style="verb">locations</spanx> object in the authorization request.</t>

<t>If the authorization server's implementation of access tokens is such that it requires a resource server call back to the authorization server to validate them, then the authorization server will be aware of which resource servers are actively in use and by which users and which clients. To avoid this possibility, the authorization server would need to structure access tokens in such a way that they can be validated by the resource server without notifying the authorization server that the token is being validated.</t>

</section>
</section>
<section anchor="stored-data"><name>Stored Data</name>

<t>Several parties in the GNAP process are expected to persist data at least temporarily, if not semi-permanently, for the normal functioning of the system. If compromised, this could lead to exposure of sensitive information. This section documents the potentially sensitive information each party in GNAP is expected to store for normal operation. Naturally it is possible that any party is storing information for longer than technically necessary of the protocol mechanics (such as audit logs, etc).</t>

<t>The authorization server is expected to store subject identifiers for users indefinitely, in order to be able to include them in the responses to clients. The authorization server is also expected to store client key identifiers associated with display information about the client such as its name and logo.</t>

<t>The client is expected to store its client instance key indefinitely, in order to authenticate to the authorization server for the normal functioning of the GNAP flows. Additionally, the client will be temporarily storing artifacts issued by the authorization server during a flow, and these artifacts ought to be discarded by the client when the transaction is complete.</t>

<t>The resource server is not required to store any state for its normal operation, as far as its part in implementing GNAP. Depending on the implementation of access tokens, the resource server may need to cache public keys from the authorization server in order to validate access tokens.</t>

</section>
<section anchor="intrusion"><name>Intrusion</name>

<t>Intrusion refers to the ability of various parties to send unsolicited messages or cause denial of service for unrelated parties.</t>

<t>If the resource owner is different from the end user, there is an opportunity for the end user to cause unsolicited messages to be sent to the resource owner if the system prompts the resource owner for consent when an end user attempts to access their data.</t>

<t>The format and contents of subject identifiers are intentionally not defined by GNAP. If the authorization server uses values for subject identifiers that are also identifiers for communication channels, (e.g. an email address or phone number), this opens up the possibility for a client to learn this information when it was not otherwise authorized to access this kind of data about the user.</t>

</section>
<section anchor="correlation"><name>Correlation</name>

<t>The threat of correlation is the combination of various pieces of information related to an individual in a way that defies their expectations of what others know about them.</t>

<section anchor="privacy-correlation-client"><name>Correlation by Clients</name>

<t>The biggest risk of correlation in GNAP is when an authorization server returns stable consistent user identifiers to multiple different applications. In this case, applications created by different parties would be able to correlate these user identifiers out of band in order to know which users they have in common.</t>

<t>The most common example of this in practice is tracking for advertising purposes, such that a client shares their list of user IDs with an ad platform that is then able to retarget ads to applications created by other parties. In contrast, a positive example of correlation is a corporate acquisition where two previously unrelated clients now do need to be able to identify the same user between the two clients, such as when software systems are intentionally connected by the end user.</t>

<t>Another means of correlation comes from the use of <xref target="rs-request-without-token">RS-first discovery</xref>. A client instance knowing nothing other than an RS's URL could make an unauthenticated call to the RS and learn which AS protects the resources there. If the client instance knows something about the AS, such as it being a single-user AS or belonging to a specific organization, the client instance could, through association, learn things about the resource without ever gaining access to the resource itself.</t>

</section>
<section anchor="correlation-by-resource-servers"><name>Correlation by Resource Servers</name>

<t>Unrelated resource servers also have an opportunity to correlate users if the authorization server includes stable user identifiers in access tokens or in access token introspection responses.</t>

<t>In some cases a resource server may not actually need to be able to identify users, (such as a resource server providing access to a company cafeteria menu which only needs to validate whether the user is a current employee), so authorization servers should be thoughtful of when user identifiers are actually necessary to communicate to resource servers for the functioning of the system.</t>

<t>However, note that the lack of inclusion of a user identifier in an access token may be a risk if there is a concern that two users may voluntarily share access tokens between them in order to access protected resources. For example, if a website wants to limit access to only people over 18, and such does not need to know any user identifiers, an access token may be issued by an AS contains only the claim "over 18". If the user is aware that this access token doesn't reference them individually, they may be willing to share the access token with a user who is under 18 in order to let them get access to the website. (Note that the binding of an access token to a non-extractable client instance key also prevents the access token from being voluntarily shared.)</t>

</section>
<section anchor="correlation-by-authorization-servers"><name>Correlation by Authorization Servers</name>

<t>Clients are expected to be identified by their client instance key. If a particular client instance key is used at more than one authorization server, this could open up the possibility for multiple unrelated authorization servers to correlate client instances. This is especially a problem in the common case where a client instance is used by a single individual, as it would allow the authorization servers to correlate that individual between them. If this is a concern of a client, the client should use distinct keys with each authorization server.</t>

</section>
</section>
<section anchor="disclosure-in-shared-references"><name>Disclosure in Shared References</name>

<t>Throughout many parts of GNAP, the parties pass shared references between each other, sometimes in place of the values themselves. For example the <spanx style="verb">interact_ref</spanx> value used throughout the flow. These references are intended to be random strings and should not contain any private or sensitive data that would potentially leak information between parties.</t>

</section>
</section>


  </middle>

  <back>


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



<referencegroup anchor="BCP195" target="https://www.rfc-editor.org/info/bcp195">
  <reference anchor="RFC8996" target="https://www.rfc-editor.org/info/rfc8996">
    <front>
      <title>Deprecating TLS 1.0 and TLS 1.1</title>
      <author fullname="K. Moriarty" initials="K." surname="Moriarty"/>
      <author fullname="S. Farrell" initials="S." surname="Farrell"/>
      <date month="March" year="2021"/>
      <abstract>
        <t>This document formally deprecates Transport Layer Security (TLS) versions 1.0 (RFC 2246) and 1.1 (RFC 4346). Accordingly, those documents have been moved to Historic status. These versions lack support for current and recommended cryptographic algorithms and mechanisms, and various government and industry profiles of applications using TLS now mandate avoiding these old TLS versions. TLS version 1.2 became the recommended version for IETF protocols in 2008 (subsequently being obsoleted by TLS version 1.3 in 2018), providing sufficient time to transition away from older versions. Removing support for older versions from implementations reduces the attack surface, reduces opportunity for misconfiguration, and streamlines library and product maintenance.</t>
        <t>This document also deprecates Datagram TLS (DTLS) version 1.0 (RFC 4347) but not DTLS version 1.2, and there is no DTLS version 1.1.</t>
        <t>This document updates many RFCs that normatively refer to TLS version 1.0 or TLS version 1.1, as described herein. This document also updates the best practices for TLS usage in RFC 7525; hence, it is part of BCP 195.</t>
      </abstract>
    </front>
    <seriesInfo name="BCP" value="195"/>
    <seriesInfo name="RFC" value="8996"/>
    <seriesInfo name="DOI" value="10.17487/RFC8996"/>
  </reference>
  <reference anchor="RFC9325" target="https://www.rfc-editor.org/info/rfc9325">
    <front>
      <title>Recommendations for Secure Use of Transport Layer Security (TLS) and Datagram Transport Layer Security (DTLS)</title>
      <author fullname="Y. Sheffer" initials="Y." surname="Sheffer"/>
      <author fullname="P. Saint-Andre" initials="P." surname="Saint-Andre"/>
      <author fullname="T. Fossati" initials="T." surname="Fossati"/>
      <date month="November" year="2022"/>
      <abstract>
        <t>Transport Layer Security (TLS) and Datagram Transport Layer Security (DTLS) are used to protect data exchanged over a wide range of application protocols and can also form the basis for secure transport protocols. Over the years, the industry has witnessed several serious attacks on TLS and DTLS, including attacks on the most commonly used cipher suites and their modes of operation. This document provides the latest recommendations for ensuring the security of deployed services that use TLS and DTLS. These recommendations are applicable to the majority of use cases.</t>
        <t>RFC 7525, an earlier version of the TLS recommendations, was published when the industry was transitioning to TLS 1.2. Years later, this transition is largely complete, and TLS 1.3 is widely available. This document updates the guidance given the new environment and obsoletes RFC 7525. In addition, this document updates RFCs 5288 and 6066 in view of recent attacks.</t>
      </abstract>
    </front>
    <seriesInfo name="BCP" value="195"/>
    <seriesInfo name="RFC" value="9325"/>
    <seriesInfo name="DOI" value="10.17487/RFC9325"/>
  </reference>
</referencegroup>

<reference anchor="RFC2397">
  <front>
    <title>The "data" URL scheme</title>
    <author fullname="L. Masinter" initials="L." surname="Masinter"/>
    <date month="August" year="1998"/>
    <abstract>
      <t>A new URL scheme, "data", is defined. It allows inclusion of small data items as "immediate" data, as if it had been included externally. [STANDARDS-TRACK]</t>
    </abstract>
  </front>
  <seriesInfo name="RFC" value="2397"/>
  <seriesInfo name="DOI" value="10.17487/RFC2397"/>
</reference>

<reference anchor="RFC3339">
  <front>
    <title>Date and Time on the Internet: Timestamps</title>
    <author fullname="G. Klyne" initials="G." surname="Klyne"/>
    <author fullname="C. Newman" initials="C." surname="Newman"/>
    <date month="July" year="2002"/>
    <abstract>
      <t>This document defines a date and time format for use in Internet protocols that is a profile of the ISO 8601 standard for representation of dates and times using the Gregorian calendar.</t>
    </abstract>
  </front>
  <seriesInfo name="RFC" value="3339"/>
  <seriesInfo name="DOI" value="10.17487/RFC3339"/>
</reference>

<reference anchor="RFC3986">
  <front>
    <title>Uniform Resource Identifier (URI): Generic Syntax</title>
    <author fullname="T. Berners-Lee" initials="T." surname="Berners-Lee"/>
    <author fullname="R. Fielding" initials="R." surname="Fielding"/>
    <author fullname="L. Masinter" initials="L." surname="Masinter"/>
    <date month="January" year="2005"/>
    <abstract>
      <t>A Uniform Resource Identifier (URI) is a compact sequence of characters that identifies an abstract or physical resource. This specification defines the generic URI syntax and a process for resolving URI references that might be in relative form, along with guidelines and security considerations for the use of URIs on the Internet. The URI syntax defines a grammar that is a superset of all valid URIs, allowing an implementation to parse the common components of a URI reference without knowing the scheme-specific requirements of every possible identifier. This specification does not define a generative grammar for URIs; that task is performed by the individual specifications of each URI scheme. [STANDARDS-TRACK]</t>
    </abstract>
  </front>
  <seriesInfo name="STD" value="66"/>
  <seriesInfo name="RFC" value="3986"/>
  <seriesInfo name="DOI" value="10.17487/RFC3986"/>
</reference>

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

<reference anchor="RFC5646">
  <front>
    <title>Tags for Identifying Languages</title>
    <author fullname="A. Phillips" initials="A." role="editor" surname="Phillips"/>
    <author fullname="M. Davis" initials="M." role="editor" surname="Davis"/>
    <date month="September" year="2009"/>
    <abstract>
      <t>This document describes the structure, content, construction, and semantics of language tags for use in cases where it is desirable to indicate the language used in an information object. It also describes how to register values for use in language tags and the creation of user-defined extensions for private interchange. 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="47"/>
  <seriesInfo name="RFC" value="5646"/>
  <seriesInfo name="DOI" value="10.17487/RFC5646"/>
</reference>

<reference anchor="RFC7468">
  <front>
    <title>Textual Encodings of PKIX, PKCS, and CMS Structures</title>
    <author fullname="S. Josefsson" initials="S." surname="Josefsson"/>
    <author fullname="S. Leonard" initials="S." surname="Leonard"/>
    <date month="April" year="2015"/>
    <abstract>
      <t>This document describes and discusses the textual encodings of the Public-Key Infrastructure X.509 (PKIX), Public-Key Cryptography Standards (PKCS), and Cryptographic Message Syntax (CMS). The textual encodings are well-known, are implemented by several applications and libraries, and are widely deployed. This document articulates the de facto rules by which existing implementations operate and defines them so that future implementations can interoperate.</t>
    </abstract>
  </front>
  <seriesInfo name="RFC" value="7468"/>
  <seriesInfo name="DOI" value="10.17487/RFC7468"/>
</reference>

<reference anchor="RFC7515">
  <front>
    <title>JSON Web Signature (JWS)</title>
    <author fullname="M. Jones" initials="M." surname="Jones"/>
    <author fullname="J. Bradley" initials="J." surname="Bradley"/>
    <author fullname="N. Sakimura" initials="N." surname="Sakimura"/>
    <date month="May" year="2015"/>
    <abstract>
      <t>JSON Web Signature (JWS) represents content secured with digital signatures or Message Authentication Codes (MACs) using JSON-based data structures. Cryptographic algorithms and identifiers for use with this specification are described in the separate JSON Web Algorithms (JWA) specification and an IANA registry defined by that specification. Related encryption capabilities are described in the separate JSON Web Encryption (JWE) specification.</t>
    </abstract>
  </front>
  <seriesInfo name="RFC" value="7515"/>
  <seriesInfo name="DOI" value="10.17487/RFC7515"/>
</reference>

<reference anchor="RFC7517">
  <front>
    <title>JSON Web Key (JWK)</title>
    <author fullname="M. Jones" initials="M." surname="Jones"/>
    <date month="May" year="2015"/>
    <abstract>
      <t>A JSON Web Key (JWK) is a JavaScript Object Notation (JSON) data structure that represents a cryptographic key. This specification also defines a JWK Set JSON data structure that represents a set of JWKs. Cryptographic algorithms and identifiers for use with this specification are described in the separate JSON Web Algorithms (JWA) specification and IANA registries established by that specification.</t>
    </abstract>
  </front>
  <seriesInfo name="RFC" value="7517"/>
  <seriesInfo name="DOI" value="10.17487/RFC7517"/>
</reference>

<reference anchor="RFC6749">
  <front>
    <title>The OAuth 2.0 Authorization Framework</title>
    <author fullname="D. Hardt" initials="D." role="editor" surname="Hardt"/>
    <date month="October" year="2012"/>
    <abstract>
      <t>The OAuth 2.0 authorization framework enables a third-party application to obtain limited access to an HTTP service, either on behalf of a resource owner by orchestrating an approval interaction between the resource owner and the HTTP service, or by allowing the third-party application to obtain access on its own behalf. This specification replaces and obsoletes the OAuth 1.0 protocol described in RFC 5849. [STANDARDS-TRACK]</t>
    </abstract>
  </front>
  <seriesInfo name="RFC" value="6749"/>
  <seriesInfo name="DOI" value="10.17487/RFC6749"/>
</reference>

<reference anchor="RFC6750">
  <front>
    <title>The OAuth 2.0 Authorization Framework: Bearer Token Usage</title>
    <author fullname="M. Jones" initials="M." surname="Jones"/>
    <author fullname="D. Hardt" initials="D." surname="Hardt"/>
    <date month="October" year="2012"/>
    <abstract>
      <t>This specification describes how to use bearer tokens in HTTP requests to access OAuth 2.0 protected resources. Any party in possession of a bearer token (a "bearer") can use it to get access to the associated resources (without demonstrating possession of a cryptographic key). To prevent misuse, bearer tokens need to be protected from disclosure in storage and in transport. [STANDARDS-TRACK]</t>
    </abstract>
  </front>
  <seriesInfo name="RFC" value="6750"/>
  <seriesInfo name="DOI" value="10.17487/RFC6750"/>
</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="RFC8259">
  <front>
    <title>The JavaScript Object Notation (JSON) Data Interchange Format</title>
    <author fullname="T. Bray" initials="T." role="editor" surname="Bray"/>
    <date month="December" year="2017"/>
    <abstract>
      <t>JavaScript Object Notation (JSON) is a lightweight, text-based, language-independent data interchange format. It was derived from the ECMAScript Programming Language Standard. JSON defines a small set of formatting rules for the portable representation of structured data.</t>
      <t>This document removes inconsistencies with other specifications of JSON, repairs specification errors, and offers experience-based interoperability guidance.</t>
    </abstract>
  </front>
  <seriesInfo name="STD" value="90"/>
  <seriesInfo name="RFC" value="8259"/>
  <seriesInfo name="DOI" value="10.17487/RFC8259"/>
</reference>

<reference anchor="RFC8705">
  <front>
    <title>OAuth 2.0 Mutual-TLS Client Authentication and Certificate-Bound Access Tokens</title>
    <author fullname="B. Campbell" initials="B." surname="Campbell"/>
    <author fullname="J. Bradley" initials="J." surname="Bradley"/>
    <author fullname="N. Sakimura" initials="N." surname="Sakimura"/>
    <author fullname="T. Lodderstedt" initials="T." surname="Lodderstedt"/>
    <date month="February" year="2020"/>
    <abstract>
      <t>This document describes OAuth client authentication and certificate-bound access and refresh tokens using mutual Transport Layer Security (TLS) authentication with X.509 certificates. OAuth clients are provided a mechanism for authentication to the authorization server using mutual TLS, based on either self-signed certificates or public key infrastructure (PKI). OAuth authorization servers are provided a mechanism for binding access tokens to a client's mutual-TLS certificate, and OAuth protected resources are provided a method for ensuring that such an access token presented to it was issued to the client presenting the token.</t>
    </abstract>
  </front>
  <seriesInfo name="RFC" value="8705"/>
  <seriesInfo name="DOI" value="10.17487/RFC8705"/>
</reference>

<reference anchor="HTTP">
  <front>
    <title>HTTP Semantics</title>
    <author fullname="R. Fielding" initials="R." role="editor" surname="Fielding"/>
    <author fullname="M. Nottingham" initials="M." role="editor" surname="Nottingham"/>
    <author fullname="J. Reschke" initials="J." role="editor" surname="Reschke"/>
    <date month="June" year="2022"/>
    <abstract>
      <t>The Hypertext Transfer Protocol (HTTP) is a stateless application-level protocol for distributed, collaborative, hypertext information systems. This document describes the overall architecture of HTTP, establishes common terminology, and defines aspects of the protocol that are shared by all versions. In this definition are core protocol elements, extensibility mechanisms, and the "http" and "https" Uniform Resource Identifier (URI) schemes.</t>
      <t>This document updates RFC 3864 and obsoletes RFCs 2818, 7231, 7232, 7233, 7235, 7538, 7615, 7694, and portions of 7230.</t>
    </abstract>
  </front>
  <seriesInfo name="STD" value="97"/>
  <seriesInfo name="RFC" value="9110"/>
  <seriesInfo name="DOI" value="10.17487/RFC9110"/>
</reference>

<reference anchor="RFC9111">
  <front>
    <title>HTTP Caching</title>
    <author fullname="R. Fielding" initials="R." role="editor" surname="Fielding"/>
    <author fullname="M. Nottingham" initials="M." role="editor" surname="Nottingham"/>
    <author fullname="J. Reschke" initials="J." role="editor" surname="Reschke"/>
    <date month="June" year="2022"/>
    <abstract>
      <t>The Hypertext Transfer Protocol (HTTP) is a stateless application-level protocol for distributed, collaborative, hypertext information systems. This document defines HTTP caches and the associated header fields that control cache behavior or indicate cacheable response messages.</t>
      <t>This document obsoletes RFC 7234.</t>
    </abstract>
  </front>
  <seriesInfo name="STD" value="98"/>
  <seriesInfo name="RFC" value="9111"/>
  <seriesInfo name="DOI" value="10.17487/RFC9111"/>
</reference>


<reference anchor="I-D.ietf-httpbis-message-signatures">
   <front>
      <title>HTTP Message Signatures</title>
      <author fullname="Annabelle Backman" initials="A." surname="Backman">
         <organization>Amazon</organization>
      </author>
      <author fullname="Justin Richer" initials="J." surname="Richer">
         <organization>Bespoke Engineering</organization>
      </author>
      <author fullname="Manu Sporny" initials="M." surname="Sporny">
         <organization>Digital Bazaar</organization>
      </author>
      <date day="26" month="July" year="2023"/>
      <abstract>
	 <t>   This document describes a mechanism for creating, encoding, and
   verifying digital signatures or message authentication codes over
   components of an HTTP message.  This mechanism supports use cases
   where the full HTTP message may not be known to the signer, and where
   the message may be transformed (e.g., by intermediaries) before
   reaching the verifier.  This document also describes a means for
   requesting that a signature be applied to a subsequent HTTP message
   in an ongoing HTTP exchange.

	 </t>
      </abstract>
   </front>
   <seriesInfo name="Internet-Draft" value="draft-ietf-httpbis-message-signatures-19"/>
   
</reference>


<reference anchor="I-D.ietf-httpbis-digest-headers">
   <front>
      <title>Digest Fields</title>
      <author fullname="Roberto Polli" initials="R." surname="Polli">
         <organization>Team Digitale, Italian Government</organization>
      </author>
      <author fullname="Lucas Pardue" initials="L." surname="Pardue">
         <organization>Cloudflare</organization>
      </author>
      <date day="10" month="July" year="2023"/>
      <abstract>
	 <t>   This document defines HTTP fields that support integrity digests.
   The Content-Digest field can be used for the integrity of HTTP
   message content.  The Repr-Digest field can be used for the integrity
   of HTTP representations.  Want-Content-Digest and Want-Repr-Digest
   can be used to indicate a sender&#x27;s interest and preferences for
   receiving the respective Integrity fields.

   This document obsoletes RFC 3230 and the Digest and Want-Digest HTTP
   fields.

	 </t>
      </abstract>
   </front>
   <seriesInfo name="Internet-Draft" value="draft-ietf-httpbis-digest-headers-13"/>
   
</reference>


<reference anchor="I-D.ietf-secevent-subject-identifiers">
   <front>
      <title>Subject Identifiers for Security Event Tokens</title>
      <author fullname="Annabelle Backman" initials="A." surname="Backman">
         <organization>Amazon</organization>
      </author>
      <author fullname="Marius Scurtescu" initials="M." surname="Scurtescu">
         <organization>Coinbase</organization>
      </author>
      <author fullname="Prachi Jain" initials="P." surname="Jain">
         <organization>Fastly</organization>
      </author>
      <date day="24" month="June" year="2023"/>
      <abstract>
	 <t>Security events communicated within Security Event Tokens may support a variety of identifiers to identify subjects related to the event.  This specification formalizes the notion of Subject Identifiers as structured information that describes a subject and named formats that define the syntax and semantics for encoding Subject Identifiers as JSON objects.  It also establishes a registry for defining and allocating names for such formats as well as the JSON Web Token (JWT) &quot;sub_id&quot; Claim.
	 </t>
      </abstract>
   </front>
   <seriesInfo name="Internet-Draft" value="draft-ietf-secevent-subject-identifiers-18"/>
   
</reference>


<reference anchor="HASH-ALG" target="https://www.iana.org/assignments/named-information/named-information.xhtml#hash-alg">
  <front>
    <title>Named Information Hash Algorithm Registry</title>
    <author >
      <organization>IANA</organization>
    </author>
    <date year="n.d."/>
  </front>
</reference>
<reference anchor="OIDC" target="https://openid.net/specs/openid-connect-core-1_0.html">
  <front>
    <title>OpenID Connect Core 1.0 incorporating errata set 1</title>
    <author initials="N." surname="Sakimura">
      <organization></organization>
    </author>
    <author initials="J." surname="Bradley">
      <organization></organization>
    </author>
    <author initials="M." surname="Jones">
      <organization></organization>
    </author>
    <author initials="B." surname="de Medeiros">
      <organization></organization>
    </author>
    <author initials="C." surname="Mortimore">
      <organization></organization>
    </author>
    <date year="2014" month="November"/>
  </front>
</reference>
<reference anchor="SAML2" target="https://docs.oasis-open.org/security/saml/v2.0/saml-core-2.0-os.pdf">
  <front>
    <title>Assertions and Protocol for the OASIS Security Assertion Markup Language (SAML) V2.0</title>
    <author initials="S." surname="Cantor">
      <organization></organization>
    </author>
    <author initials="J." surname="Kemp">
      <organization></organization>
    </author>
    <author initials="R." surname="Philpott">
      <organization></organization>
    </author>
    <author initials="E." surname="Maler">
      <organization></organization>
    </author>
    <date year="2005" month="March"/>
  </front>
</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>




    </references>

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



<reference anchor="RFC4107">
  <front>
    <title>Guidelines for Cryptographic Key Management</title>
    <author fullname="S. Bellovin" initials="S." surname="Bellovin"/>
    <author fullname="R. Housley" initials="R." surname="Housley"/>
    <date month="June" year="2005"/>
    <abstract>
      <t>The question often arises of whether a given security system requires some form of automated key management, or whether manual keying is sufficient. This memo provides guidelines for making such decisions. When symmetric cryptographic mechanisms are used in a protocol, the presumption is that automated key management is generally but not always needed. If manual keying is proposed, the burden of proving that automated key management is not required falls to the proposer. 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="107"/>
  <seriesInfo name="RFC" value="4107"/>
  <seriesInfo name="DOI" value="10.17487/RFC4107"/>
</reference>

<reference anchor="RFC6202">
  <front>
    <title>Known Issues and Best Practices for the Use of Long Polling and Streaming in Bidirectional HTTP</title>
    <author fullname="S. Loreto" initials="S." surname="Loreto"/>
    <author fullname="P. Saint-Andre" initials="P." surname="Saint-Andre"/>
    <author fullname="S. Salsano" initials="S." surname="Salsano"/>
    <author fullname="G. Wilkins" initials="G." surname="Wilkins"/>
    <date month="April" year="2011"/>
    <abstract>
      <t>On today's Internet, the Hypertext Transfer Protocol (HTTP) is often used (some would say abused) to enable asynchronous, "server- initiated" communication from a server to a client as well as communication from a client to a server. This document describes known issues and best practices related to such "bidirectional HTTP" applications, focusing on the two most common mechanisms: HTTP long polling and HTTP streaming. This document is not an Internet Standards Track specification; it is published for informational purposes.</t>
    </abstract>
  </front>
  <seriesInfo name="RFC" value="6202"/>
  <seriesInfo name="DOI" value="10.17487/RFC6202"/>
</reference>

<reference anchor="RFC6973">
  <front>
    <title>Privacy Considerations for Internet Protocols</title>
    <author fullname="A. Cooper" initials="A." surname="Cooper"/>
    <author fullname="H. Tschofenig" initials="H." surname="Tschofenig"/>
    <author fullname="B. Aboba" initials="B." surname="Aboba"/>
    <author fullname="J. Peterson" initials="J." surname="Peterson"/>
    <author fullname="J. Morris" initials="J." surname="Morris"/>
    <author fullname="M. Hansen" initials="M." surname="Hansen"/>
    <author fullname="R. Smith" initials="R." surname="Smith"/>
    <date month="July" year="2013"/>
    <abstract>
      <t>This document offers guidance for developing privacy considerations for inclusion in protocol specifications. It aims to make designers, implementers, and users of Internet protocols aware of privacy-related design choices. It suggests that whether any individual RFC warrants a specific privacy considerations section will depend on the document's content.</t>
    </abstract>
  </front>
  <seriesInfo name="RFC" value="6973"/>
  <seriesInfo name="DOI" value="10.17487/RFC6973"/>
</reference>

<reference anchor="RFC7518">
  <front>
    <title>JSON Web Algorithms (JWA)</title>
    <author fullname="M. Jones" initials="M." surname="Jones"/>
    <date month="May" year="2015"/>
    <abstract>
      <t>This specification registers cryptographic algorithms and identifiers to be used with the JSON Web Signature (JWS), JSON Web Encryption (JWE), and JSON Web Key (JWK) specifications. It defines several IANA registries for these identifiers.</t>
    </abstract>
  </front>
  <seriesInfo name="RFC" value="7518"/>
  <seriesInfo name="DOI" value="10.17487/RFC7518"/>
</reference>

<reference anchor="RFC8707">
  <front>
    <title>Resource Indicators for OAuth 2.0</title>
    <author fullname="B. Campbell" initials="B." surname="Campbell"/>
    <author fullname="J. Bradley" initials="J." surname="Bradley"/>
    <author fullname="H. Tschofenig" initials="H." surname="Tschofenig"/>
    <date month="February" year="2020"/>
    <abstract>
      <t>This document specifies an extension to the OAuth 2.0 Authorization Framework defining request parameters that enable a client to explicitly signal to an authorization server about the identity of the protected resource(s) to which it is requesting access.</t>
    </abstract>
  </front>
  <seriesInfo name="RFC" value="8707"/>
  <seriesInfo name="DOI" value="10.17487/RFC8707"/>
</reference>

<reference anchor="RFC8792">
  <front>
    <title>Handling Long Lines in Content of Internet-Drafts and RFCs</title>
    <author fullname="K. Watsen" initials="K." surname="Watsen"/>
    <author fullname="E. Auerswald" initials="E." surname="Auerswald"/>
    <author fullname="A. Farrel" initials="A." surname="Farrel"/>
    <author fullname="Q. Wu" initials="Q." surname="Wu"/>
    <date month="June" year="2020"/>
    <abstract>
      <t>This document defines two strategies for handling long lines in width-bounded text content. One strategy, called the "single backslash" strategy, is based on the historical use of a single backslash ('\') character to indicate where line-folding has occurred, with the continuation occurring with the first character that is not a space character (' ') on the next line. The second strategy, called the "double backslash" strategy, extends the first strategy by adding a second backslash character to identify where the continuation begins and is thereby able to handle cases not supported by the first strategy. Both strategies use a self-describing header enabling automated reconstitution of the original content.</t>
    </abstract>
  </front>
  <seriesInfo name="RFC" value="8792"/>
  <seriesInfo name="DOI" value="10.17487/RFC8792"/>
</reference>

<reference anchor="RFC9396">
  <front>
    <title>OAuth 2.0 Rich Authorization Requests</title>
    <author fullname="T. Lodderstedt" initials="T." surname="Lodderstedt"/>
    <author fullname="J. Richer" initials="J." surname="Richer"/>
    <author fullname="B. Campbell" initials="B." surname="Campbell"/>
    <date month="May" year="2023"/>
    <abstract>
      <t>This document specifies a new parameter that is used to carry fine-grained authorization data in OAuth messages.</t>
    </abstract>
  </front>
  <seriesInfo name="RFC" value="9396"/>
  <seriesInfo name="DOI" value="10.17487/RFC9396"/>
</reference>

<reference anchor="RFC9440">
  <front>
    <title>Client-Cert HTTP Header Field</title>
    <author fullname="B. Campbell" initials="B." surname="Campbell"/>
    <author fullname="M. Bishop" initials="M." surname="Bishop"/>
    <date month="July" year="2023"/>
    <abstract>
      <t>This document describes HTTP extension header fields that allow a TLS terminating reverse proxy (TTRP) to convey the client certificate information of a mutually authenticated TLS connection to the origin server in a common and predictable manner.</t>
    </abstract>
  </front>
  <seriesInfo name="RFC" value="9440"/>
  <seriesInfo name="DOI" value="10.17487/RFC9440"/>
</reference>


<reference anchor="I-D.ietf-gnap-resource-servers">
   <front>
      <title>Grant Negotiation and Authorization Protocol Resource Server Connections</title>
      <author fullname="Justin Richer" initials="J." surname="Richer">
         <organization>Bespoke Engineering</organization>
      </author>
      <author fullname="Fabien Imbault" initials="F." surname="Imbault">
         <organization>acert.io</organization>
      </author>
      <date day="23" month="October" year="2023"/>
      <abstract>
	 <t>   GNAP defines a mechanism for delegating authorization to a piece of
   software, and conveying that delegation to the software.  This
   extension defines methods for resource servers (RS) to connect with
   authorization servers (AS) in an interoperable fashion.

	 </t>
      </abstract>
   </front>
   <seriesInfo name="Internet-Draft" value="draft-ietf-gnap-resource-servers-04"/>
   
</reference>


<reference anchor="I-D.ietf-oauth-security-topics">
   <front>
      <title>OAuth 2.0 Security Best Current Practice</title>
      <author fullname="Torsten Lodderstedt" initials="T." surname="Lodderstedt">
         <organization>SPRIND</organization>
      </author>
      <author fullname="John Bradley" initials="J." surname="Bradley">
         <organization>Yubico</organization>
      </author>
      <author fullname="Andrey Labunets" initials="A." surname="Labunets">
         <organization>Independent Researcher</organization>
      </author>
      <author fullname="Daniel Fett" initials="D." surname="Fett">
         <organization>Authlete</organization>
      </author>
      <date day="8" month="February" year="2024"/>
      <abstract>
	 <t>   This document describes best current security practice for OAuth 2.0.
   It updates and extends the threat model and security advice given in
   [RFC6749], [RFC6750], and [RFC6819] to incorporate practical
   experiences gathered since OAuth 2.0 was published and covers new
   threats relevant due to the broader application of OAuth 2.0.  It
   further deprecates some modes of operation that are deemed less
   secure or even insecure.

	 </t>
      </abstract>
   </front>
   <seriesInfo name="Internet-Draft" value="draft-ietf-oauth-security-topics-25"/>
   
</reference>


<reference anchor="I-D.ietf-uta-rfc6125bis">
   <front>
      <title>Service Identity in TLS</title>
      <author fullname="Peter Saint-Andre" initials="P." surname="Saint-Andre">
         <organization>independent</organization>
      </author>
      <author fullname="Rich Salz" initials="R." surname="Salz">
         <organization>Akamai Technologies</organization>
      </author>
      <date day="10" month="August" year="2023"/>
      <abstract>
	 <t>Many application technologies enable secure communication between two entities by means of Transport Layer Security (TLS) with Internet Public Key Infrastructure using X.509 (PKIX) certificates. This document specifies procedures for representing and verifying the identity of application services in such interactions.

 This document obsoletes RFC 6125.
	 </t>
      </abstract>
   </front>
   <seriesInfo name="Internet-Draft" value="draft-ietf-uta-rfc6125bis-15"/>
   
</reference>


<reference anchor="promise-theory" target="http://markburgess.org/promises.html">
  <front>
    <title>Promise theory</title>
    <author initials="M." surname="Burgess">
      <organization></organization>
    </author>
    <author initials="J." surname="Bergstra">
      <organization></organization>
    </author>
    <date year="2014" month="January"/>
  </front>
</reference>
<reference anchor="AXELAND2021" target="https://odr.chalmers.se/handle/20.500.12380/304105">
  <front>
    <title>Security Analysis of Attack Surfaces on the Grant Negotiation and Authorization Protocol</title>
    <author initials="Å." surname="Axeland">
      <organization></organization>
    </author>
    <author initials="O." surname="Oueidat">
      <organization></organization>
    </author>
    <date year="2021"/>
  </front>
</reference>
<reference anchor="HELMSCHMIDT2022" target="http://dx.doi.org/10.18419/opus-12203">
  <front>
    <title>Security Analysis of the Grant Negotiation and Authorization Protocol</title>
    <author initials="F." surname="Helmschmidt">
      <organization></organization>
    </author>
    <date year="2022"/>
  </front>
</reference>
<reference anchor="SP80063C" target="https://doi.org/10.6028/NIST.SP.800-63c">
  <front>
    <title>Digital Identity Guidelines: Federation and Assertions</title>
    <author initials="P." surname="Grassi">
      <organization></organization>
    </author>
    <author initials="E." surname="Nadeau">
      <organization></organization>
    </author>
    <author initials="J." surname="Richer">
      <organization></organization>
    </author>
    <author initials="S." surname="Squire">
      <organization></organization>
    </author>
    <author initials="J." surname="Fenton">
      <organization></organization>
    </author>
    <author initials="N." surname="Lefkovitz">
      <organization></organization>
    </author>
    <author initials="J." surname="Danker">
      <organization></organization>
    </author>
    <author initials="Y." surname="Choong">
      <organization></organization>
    </author>
    <author initials="K." surname="Greene">
      <organization></organization>
    </author>
    <author initials="M." surname="Theofanos">
      <organization></organization>
    </author>
    <date year="2017" month="June"/>
  </front>
</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>


<?line 7411?>

<section anchor="history"><name>Document History</name>

<ul empty="true"><li>
  <t>Note: To be removed by RFC editor before publication.</t>
</li></ul>

<t><list style="symbols">
  <t>18
  <list style="symbols">
      <t>Updates from IESG reviews.</t>
    </list></t>
  <t>17
  <list style="symbols">
      <t>Updates from IESG reviews.</t>
    </list></t>
  <t>16
  <list style="symbols">
      <t>Updates from AD review.</t>
      <t>Added security considerations on token substitution attack.</t>
    </list></t>
  <t>15
  <list style="symbols">
      <t>Editorial updates from shepherd review.</t>
      <t>Clarify character set constraints of user codes.</t>
    </list></t>
  <t>14
  <list style="symbols">
      <t>Update token rotation to use URI + management token.</t>
      <t>Fix key rotation with HTTP Signatures based on security analysis.</t>
    </list></t>
  <t>-13
  <list style="symbols">
      <t>Editoral changes from chair review.</t>
      <t>Clarify that user codes are ungessable.</t>
      <t>Fix user code examples.</t>
      <t>Clarify expectations for extensions to interaction start and finish methods.</t>
      <t>Fix references.</t>
      <t>Add IANA designated expert instructions.</t>
      <t>Clarify new vs. updated access tokens, and call out no need for refresh tokens in OAuth 2 comparison section.</t>
      <t>Add instructions on assertion processing.</t>
      <t>Explicitly list user reference lifetime management.</t>
    </list></t>
  <t>-12
  <list style="symbols">
      <t>Make default hash algorithm SHA256 instead of SHA3-512.</t>
      <t>Remove <spanx style="verb">previous_key</spanx> from key rotation.</t>
      <t>Defined requirements for key rotation methods.</t>
      <t>Add specificity to context of subject identifier being the AS.</t>
      <t>Editorial updates and protocol clarification.</t>
    </list></t>
  <t>-11
  <list style="symbols">
      <t>Error as object or string, more complete set of error codes</t>
      <t>Added key rotation in token management.</t>
      <t>Restrict keys to a single format per message.</t>
      <t>Discussed security issues of multiple key formats.</t>
      <t>Make token character set more strict.</t>
      <t>Add note on long-polling in continuation requests.</t>
      <t>Removed "Models" section.</t>
      <t>Rewrote guidance and requirements for extensions.</t>
      <t>Require all URIs to be absolute throughout protocol.</t>
      <t>Make response from RS a "<bcp14>SHOULD</bcp14>" instead of a "<bcp14>MAY</bcp14>".</t>
      <t>Added a way for the client instance to ask for a specific user's information, separate from the end-user.</t>
      <t>Added security considerations for asynchronous authorization.</t>
      <t>Added security considerations for compromised RS.</t>
      <t>Added interoperability profiles.</t>
      <t>Added implementation status section.</t>
    </list></t>
  <t>-10
  <list style="symbols">
      <t>Added note on relating access rights sent as strings to rights sent as objects.</t>
      <t>Expand proofing methods to allow definition by object, with single string as optimization for common cases.</t>
      <t>Removed "split_token" functionality.</t>
      <t>Collapse "user_code" into a string instead of an object.</t>
      <t>References hash algorithm identifiers from the existing IANA registry</t>
      <t>Allow interaction responses to time out.</t>
      <t>Added explicit protocol state discussion.</t>
      <t>Added RO policy use case.</t>
    </list></t>
  <t>-09
  <list style="symbols">
      <t>Added security considerations on redirection status codes.</t>
      <t>Added security considerations on cuckoo token attack.</t>
      <t>Made token management URL required on token rotation.</t>
      <t>Added considerations on token rotation and self-contained tokens.</t>
      <t>Added security considerations for SSRF.</t>
      <t>Moved normative requirements about end user presence to security considerations.</t>
      <t>Clarified default wait times for continuation requests (including polling).</t>
      <t>Clarified URI vs. URL.</t>
      <t>Added "user_code_uri" mode, removed "uri" from "user_code" mode.</t>
      <t>Consistently formatted all parameter lists.</t>
      <t>Updated examples for HTTP Signatures.</t>
    </list></t>
  <t>-08
  <list style="symbols">
      <t>Update definition for "Client" to account for the case of no end user.</t>
      <t>Change definition for "Subject".</t>
      <t>Expanded security and privacy considerations for more situations.</t>
      <t>Added cross-links from security and privacy considerations.</t>
      <t>Editorial updates.</t>
    </list></t>
  <t>-07
  <list style="symbols">
      <t>Replace user handle by opaque identifier</t>
      <t>Added trust relationships</t>
      <t>Added privacy considerations section</t>
      <t>Added security considerations.</t>
    </list></t>
  <t>-06
  <list style="symbols">
      <t>Removed "capabilities" and "existing_grant" protocol fields.</t>
      <t>Removed separate "instance_id" field.</t>
      <t>Split "interaction_methods_supported" into "interaction_start_modes_supported" and "interaction_finish_methods_supported".</t>
      <t>Added AS endpoint to hash calculation to fix mix-up attack.</t>
      <t>Added "privileges" field to resource access request object.</t>
      <t>Moved client-facing RS response back from GNAP-RS document.</t>
      <t>Removed oauthpop key binding.</t>
      <t>Removed dpop key binding.</t>
      <t>Added example DID identifier.</t>
      <t>Changed token response booleans to flag structure to match request.</t>
      <t>Updated signature examples to use HTTP Message Signatures.</t>
    </list></t>
  <t>-05
  <list style="symbols">
      <t>Changed "interaction_methods" to "interaction_methods_supported".</t>
      <t>Changed "key_proofs" to "key_proofs_supported".</t>
      <t>Changed "assertions" to "assertions_supported".</t>
      <t>Updated discovery and field names for subject formats.</t>
      <t>Add an appendix to provide protocol rationale, compared to OAuth2.</t>
      <t>Updated subject information definition.</t>
      <t>Refactored the RS-centric components into a new document.</t>
      <t>Updated cryptographic proof of possession methods to match current reference syntax.</t>
      <t>Updated proofing language to use "signer" and "verifier" generically.</t>
      <t>Updated cryptographic proof of possession examples.</t>
      <t>Editorial cleanup and fixes.</t>
      <t>Diagram cleanup and fixes.</t>
    </list></t>
  <t>-04
  <list style="symbols">
      <t>Updated terminology.</t>
      <t>Refactored key presentation and binding.</t>
      <t>Refactored "interact" request to group start and end modes.</t>
      <t>Changed access token request and response syntax.</t>
      <t>Changed DPoP digest field to 'htd' to match proposed FAPI profile.</t>
      <t>Include the access token hash in the DPoP message.</t>
      <t>Removed closed issue links.</t>
      <t>Removed function to read state of grant request by client.</t>
      <t>Closed issues related to reading and updating access tokens.</t>
    </list></t>
  <t>-03
  <list style="symbols">
      <t>Changed "resource client" terminology to separate "client instance" and "client software".</t>
      <t>Removed OpenID Connect "claims" parameter.</t>
      <t>Dropped "short URI" redirect.</t>
      <t>Access token is mandatory for continuation.</t>
      <t>Removed closed issue links.</t>
      <t>Editorial fixes.</t>
    </list></t>
  <t>-02
  <list style="symbols">
      <t>Moved all "editor's note" items to GitHub Issues.</t>
      <t>Added JSON types to fields.</t>
      <t>Changed "GNAP Protocol" to "GNAP".</t>
      <t>Editorial fixes.</t>
    </list></t>
  <t>-01
  <list style="symbols">
      <t>"updated_at" subject info timestamp now in ISO 8601 string format.</t>
      <t>Editorial fixes.</t>
      <t>Added Aaron and Fabien as document authors.</t>
    </list></t>
  <t>-00
  <list style="symbols">
      <t>Initial working group draft.</t>
    </list></t>
</list></t>

</section>
<section anchor="vs-oauth2"><name>Compared to OAuth 2.0</name>

<t>GNAP's protocol design differs from OAuth 2.0's in several fundamental ways:</t>

<t><list style="numbers">
  <t><strong>Consent and authorization flexibility:</strong>  <vspace blankLines='1'/>
OAuth 2.0 generally assumes the user has access to a web browser. The type of interaction available is fixed by the grant type, and the most common interactive grant types start in the browser. OAuth 2.0 assumes that the user using the client software is the same user that will interact with the AS to approve access.  <vspace blankLines='1'/>
GNAP allows various patterns to manage authorizations and consents required to fulfill this requested delegation, including information sent by the client instance, information supplied by external parties, and information gathered through the interaction process. GNAP allows a client instance to list different ways that it can start and finish an interaction, and these can be mixed together as needed for different use cases. GNAP interactions can use a browser, but don't have to. Methods can use inter-application messaging protocols, out-of-band data transfer, or anything else. GNAP allows extensions to define new ways to start and finish an interaction, as new methods and platforms are expected to become available over time. GNAP is designed to allow the end user and the resource owner to be two different people, but still works in the optimized case of them being the same party.</t>
  <t><strong>Intent registration and inline negotiation:</strong>  <vspace blankLines='1'/>
OAuth 2.0 uses different "grant types" that start at different endpoints for different purposes. Many of these require discovery of several interrelated parameters.  <vspace blankLines='1'/>
GNAP requests all start with the same type of request to the same endpoint at the AS. Next steps are negotiated between the client instance and AS based on software capabilities, policies surrounding requested access, and the overall context of the ongoing request. GNAP defines a continuation API that allows the client instance and AS to request and send additional information from each other over multiple steps. This continuation API uses the same access token protection that other GNAP-protected APIs use. GNAP allows discovery to optimize the requests but it isn't required thanks to the negotiation capabilities.  <vspace blankLines='1'/>
GNAP is able to handle the life-cycle of an authorization request, and therefore simplifies the mental model surrounding OAuth2. For instance, there's no need for refresh tokens when the API enables proper rotation of access tokens.</t>
  <t><strong>Client instances:</strong>  <vspace blankLines='1'/>
OAuth 2.0 requires all clients to be registered at the AS and to use a client_id known to the AS as part of the protocol. This client_id is generally assumed to be assigned by a trusted authority during a registration process, and OAuth places a lot of trust on the client_id as a result. Dynamic registration allows different classes of clients to get a client_id at runtime, even if they only ever use it for one request.  <vspace blankLines='1'/>
GNAP allows the client instance to present an unknown key to the AS and use that key to protect the ongoing request. GNAP's client instance identifier mechanism allows for pre-registered clients and dynamically registered clients to exist as an optimized case without requiring the identifier as part of the protocol at all times.</t>
  <t><strong>Expanded delegation:</strong>  <vspace blankLines='1'/>
OAuth 2.0 defines the "scope" parameter for controlling access to APIs. This parameter has been coopted to mean a number of different things in different protocols, including flags for turning special behavior on and off, including the return of data apart from the access token. The "resource" indicator (defined in <xref target="RFC8707"/>) and RAR extensions (as defined in <xref target="RFC9396"/>) expand on the "scope" concept in similar but different ways.  <vspace blankLines='1'/>
GNAP defines a rich structure for requesting access (analogous to RAR), with string references as an optimization (analogous to scopes). GNAP defines methods for requesting directly-returned user information, separate from API access. This information includes identifiers for the current user and structured assertions. The core GNAP protocol makes no assumptions or demands on the format or contents of the access token, but the RS extension allows a negotiation of token formats between the AS and RS.</t>
  <t><strong>Cryptography-based security:</strong>  <vspace blankLines='1'/>
OAuth 2.0 uses shared bearer secrets, including the client_secret and access token, and advanced authentication and sender constraint have been built on after the fact in inconsistent ways.  <vspace blankLines='1'/>
In GNAP, all communication between the client instance and AS is bound to a key held by the client instance. GNAP uses the same cryptographic mechanisms for both authenticating the client (to the AS) and binding the access token (to the RS and the AS). GNAP allows extensions to define new cryptographic protection mechanisms, as new methods are expected to become available over time. GNAP does not have a notion of "public clients" because key information can always be sent and used dynamically.</t>
  <t><strong>Privacy and usable security:</strong>  <vspace blankLines='1'/>
OAuth 2.0's deployment model assumes a strong binding between the AS and the RS.  <vspace blankLines='1'/>
GNAP is designed to be interoperable with decentralized identity standards and to provide a human-centric authorization layer. In addition to the core protocol, GNAP supports various patterns of communication between RSs and ASs through extensions. GNAP tries to limit the odds of a consolidation to just a handful of super-popular AS services.</t>
</list></t>

</section>
<section anchor="examples"><name>Example Protocol Flows</name>

<t>The protocol defined in this specification provides a number of
features that can be combined to solve many different kinds of
authentication scenarios. This section seeks to show examples of how the
protocol would be applied for different situations.</t>

<t>Some longer fields, particularly cryptographic information, have been
truncated for display purposes in these examples.</t>

<section anchor="example-auth-code"><name>Redirect-Based User Interaction</name>

<t>In this scenario, the user is the RO and has access to a web
browser, and the client instance can take front-channel callbacks on the same
device as the user. This combination is analogous to the OAuth 2.0
Authorization Code grant type.</t>

<t>The client instance initiates the request to the AS. Here the client instance
identifies itself using its public key.</t>

<figure><sourcecode type="http-message"><![CDATA[
POST /tx HTTP/1.1
Host: server.example.com
Content-Type: application/json
Signature-Input: sig1=...
Signature: sig1=...
Content-Digest: sha-256=...

{
    "access_token": {
        "access": [
            {
                "actions": [
                    "read",
                    "write",
                    "dolphin"
                ],
                "locations": [
                    "https://server.example.net/",
                    "https://resource.local/other"
                ],
                "datatypes": [
                    "metadata",
                    "images"
                ]
            }
        ],
    },
    "client": {
      "key": {
        "proof": "httpsig",
        "jwk": {
            "kty": "RSA",
            "e": "AQAB",
            "kid": "xyz-1",
            "alg": "RS256",
            "n": "kOB5rR4Jv0GMeLaY6_It_r3ORwdf8ci_JtffXyaSx8..."
        }
      }
    },
    "interact": {
        "start": ["redirect"],
        "finish": {
            "method": "redirect",
            "uri": "https://client.example.net/return/123455",
            "nonce": "LKLTI25DK82FX4T4QFZC"
        }
    }
}
]]></sourcecode></figure>

<t>The AS processes the request and determines that the RO needs to
interact. The AS returns the following response giving the client instance the
information it needs to connect. The AS has also indicated to the
client instance that it can use the given instance identifier to identify itself in
<xref target="request-instance">future requests</xref>.</t>

<figure><sourcecode type="http-message"><![CDATA[
HTTP/1.1 200 OK
Content-Type: application/json
Cache-Control: no-store

{
    "interact": {
      "redirect":
        "https://server.example.com/interact/4CF492MLVMSW9MKM",
      "finish": "MBDOFXG4Y5CVJCX821LH"
    }
    "continue": {
        "access_token": {
            "value": "80UPRY5NM33OMUKMKSKU"
        },
        "uri": "https://server.example.com/continue"
    },
    "instance_id": "7C7C4AZ9KHRS6X63AJAO"
}
]]></sourcecode></figure>

<t>The client instance saves the response and redirects the user to the
interaction start mode's "redirect" URI by sending the following HTTP message to the user's
browser.</t>

<figure><sourcecode type="http-message"><![CDATA[
HTTP 303 Found
Location: https://server.example.com/interact/4CF492MLVMSW9MKM
]]></sourcecode></figure>

<t>The user's browser fetches the AS's interaction URI. The user logs
in, is identified as the RO for the resource being requested, and
approves the request. Since the AS has a callback parameter that was sent in the initial request's interaction finish method, the AS
generates the interaction reference, calculates the hash, and
redirects the user back to the client instance with these additional values
added as query parameters.</t>

<figure><sourcecode type="http-message"><![CDATA[
NOTE: '\' line wrapping per RFC 8792

HTTP 302 Found
Location: https://client.example.net/return/123455\
  ?hash=x-gguKWTj8rQf7d7i3w3UhzvuJ5bpOlKyAlVpLxBffY\
  &interact_ref=4IFWWIKYBC2PQ6U56NL1
]]></sourcecode></figure>

<t>The client instance receives this request from the user's browser. The
client instance ensures that this is the same user that was sent out by
validating session information and retrieves the stored pending
request. The client instance uses the values in this to validate the hash
parameter. The client instance then calls the continuation URI using the associated continuation access token and presents the
interaction reference in the request content. The client instance signs
the request as above.</t>

<figure><sourcecode type="http-message"><![CDATA[
POST /continue HTTP/1.1
Host: server.example.com
Content-Type: application/json
Authorization: GNAP 80UPRY5NM33OMUKMKSKU
Signature-Input: sig1=...
Signature: sig1=...
Content-Digest: sha-256=...

{
    "interact_ref": "4IFWWIKYBC2PQ6U56NL1"
}
]]></sourcecode></figure>

<t>The AS retrieves the pending request by looking up the pending grant request associated with the presented continuation access token. Seeing that the grant is approved, the AS issues
an access token and returns this to the client instance.</t>

<figure><sourcecode type="http-message"><![CDATA[
NOTE: '\' line wrapping per RFC 8792

HTTP/1.1 200 OK
Content-Type: application/json
Cache-Control: no-store

{
    "access_token": {
        "value": "OS9M2PMHKUR64TB8N6BW7OZB8CDFONP219RP1LT0",
        "manage": "https://server.example.com/token/PRY5NM33O\
            M4TB8N6BW7OZB8CDFONP219RP1L",
        "access": [{
            "actions": [
                "read",
                "write",
                "dolphin"
            ],
            "locations": [
                "https://server.example.net/",
                "https://resource.local/other"
            ],
            "datatypes": [
                "metadata",
                "images"
            ]
        }]
    },
    "continue": {
        "access_token": {
            "value": "80UPRY5NM33OMUKMKSKU"
        },
        "uri": "https://server.example.com/continue"
    }
}
]]></sourcecode></figure>

</section>
<section anchor="example-device"><name>Secondary Device Interaction</name>

<t>In this scenario, the user does not have access to a web browser on
the device and must use a secondary device to interact with the AS.
The client instance can display a user code or a printable QR code.
The client instance is not able to accept callbacks from the AS and needs to poll
for updates while waiting for the user to authorize the request.</t>

<t>The client instance initiates the request to the AS.</t>

<figure><sourcecode type="http-message"><![CDATA[
POST /tx HTTP/1.1
Host: server.example.com
Content-Type: application/json
Signature-Input: sig1=...
Signature: sig1=...
Content-Digest: sha-256=...

{
    "access_token": {
        "access": [
            "dolphin-metadata", "some other thing"
        ],
    },
    "client": "7C7C4AZ9KHRS6X63AJAO",
    "interact": {
        "start": ["redirect", "user_code"]
    }
}
]]></sourcecode></figure>

<t>The AS processes this and determines that the RO needs to interact.
The AS supports both redirect URIs and user codes for interaction, so
it includes both. Since there is no interaction finish mode, the AS does not include
a nonce, but does include a "wait" parameter on the continuation
section because it expects the client instance to poll for results.</t>

<figure><sourcecode type="http-message"><![CDATA[
HTTP/1.1 200 OK
Content-Type: application/json
Cache-Control: no-store

{
    "interact": {
        "redirect": "https://srv.ex/MXKHQ",
        "user_code": {
            "code": "A1BC3DFF"
        }
    },
    "continue": {
        "access_token": {
            "value": "80UPRY5NM33OMUKMKSKU"
        },
        "uri": "https://server.example.com/continue/VGJKPTKC50",
        "wait": 60
    }
}
]]></sourcecode></figure>

<t>The client instance saves the response and displays the user code visually
on its screen along with the static device URI. The client instance also
displays the short interaction URI as a QR code to be scanned.</t>

<t>If the user scans the code, they are taken to the interaction
endpoint and the AS looks up the current pending request based on the
incoming URI. If the user instead goes to the static page and enters
the code manually, the AS looks up the current pending request based
on the value of the user code. In both cases, the user logs in, is
identified as the RO for the resource being requested, and approves
the request. Once the request has been approved, the AS displays to
the user a message to return to their device.</t>

<t>Meanwhile, the client instance periodically polls the AS every 60 seconds at
the continuation URI. The client instance signs the request using the
same key and method that it did in the first request.</t>

<figure><sourcecode type="http-message"><![CDATA[
POST /continue/VGJKPTKC50 HTTP/1.1
Host: server.example.com
Authorization: GNAP 80UPRY5NM33OMUKMKSKU
Signature-Input: sig1=...
Signature: sig1=...
Content-Digest: sha-256=...
]]></sourcecode></figure>

<t>The AS retrieves the pending request based on the pending grant request associated with the continuation access token and
determines that it has not yet been authorized. The AS indicates to
the client instance that no access token has yet been issued but it can
continue to call after another 60 second timeout.</t>

<figure><sourcecode type="http-message"><![CDATA[
HTTP/1.1 200 OK
Content-Type: application/json
Cache-Control: no-store

{
    "continue": {
        "access_token": {
            "value": "G7YQT4KQQ5TZY9SLSS5E"
        },
        "uri": "https://server.example.com/continue/ATWHO4Q1WV",
        "wait": 60
    }
}
]]></sourcecode></figure>

<t>Note that the continuation URI and access token have been rotated since they were
used by the client instance to make this call. The client instance polls the
continuation URI after a 60 second timeout using this new information.</t>

<figure><sourcecode type="http-message"><![CDATA[
POST /continue/ATWHO4Q1WV HTTP/1.1
Host: server.example.com
Authorization: GNAP G7YQT4KQQ5TZY9SLSS5E
Signature-Input: sig1=...
Signature: sig1=...
Content-Digest: sha-256=...
]]></sourcecode></figure>

<t>The AS retrieves the pending request based on the URI and access token,
determines that it has been approved, and issues an access
token for the client to use at the RS.</t>

<figure><sourcecode type="http-message"><![CDATA[
NOTE: '\' line wrapping per RFC 8792

HTTP/1.1 200 OK
Content-Type: application/json
Cache-Control: no-store

{
    "access_token": {
        "value": "OS9M2PMHKUR64TB8N6BW7OZB8CDFONP219RP1LT0",
        "manage": "https://server.example.com/token/PRY5NM33O\
            M4TB8N6BW7OZB8CDFONP219RP1L",
        "access": [
            "dolphin-metadata", "some other thing"
        ]
    }
}
]]></sourcecode></figure>

</section>
<section anchor="example-no-user"><name>No User Involvement</name>

<t>In this scenario, the client instance is requesting access on its own
behalf, with no user to interact with.</t>

<t>The client instance creates a request to the AS, identifying itself with its
public key and using MTLS to make the request.</t>

<figure><sourcecode type="http-message"><![CDATA[
POST /tx HTTP/1.1
Host: server.example.com
Content-Type: application/json

{
    "access_token": {
        "access": [
            "backend service", "nightly-routine-3"
        ],
    },
    "client": {
      "key": {
        "proof": "mtls",
        "cert#S256": "bwcK0esc3ACC3DB2Y5_lESsXE8o9ltc05O89jdN-dg2"
      }
    }
}
]]></sourcecode></figure>

<t>The AS processes this and determines that the client instance can ask for
the requested resources and issues an access token.</t>

<figure><sourcecode type="http-message"><![CDATA[
HTTP/1.1 200 OK
Content-Type: application/json
Cache-Control: no-store

{
    "access_token": {
        "value": "OS9M2PMHKUR64TB8N6BW7OZB8CDFONP219RP1LT0",
        "manage": "https://server.example.com/token",
        "access": [
            "backend service", "nightly-routine-3"
        ]
    }
}
]]></sourcecode></figure>

</section>
<section anchor="example-async"><name>Asynchronous Authorization</name>

<t>In this scenario, the client instance is requesting on behalf of a specific
RO, but has no way to interact with the user. The AS can
asynchronously reach out to the RO for approval in this scenario.</t>

<t>The client instance starts the request at the AS by requesting a set of
resources. The client instance also identifies a particular user.</t>

<figure><sourcecode type="http-message"><![CDATA[
POST /tx HTTP/1.1
Host: server.example.com
Content-Type: application/json
Signature-Input: sig1=...
Signature: sig1=...
Content-Digest: sha-256=...

{
    "access_token": {
        "access": [
            {
                "type": "photo-api",
                "actions": [
                    "read",
                    "write",
                    "dolphin"
                ],
                "locations": [
                    "https://server.example.net/",
                    "https://resource.local/other"
                ],
                "datatypes": [
                    "metadata",
                    "images"
                ]
            },
            "read", "dolphin-metadata",
            {
                "type": "financial-transaction",
                "actions": [
                    "withdraw"
                ],
                "identifier": "account-14-32-32-3",
                "currency": "USD"
            },
            "some other thing"
        ],
    },
    "client": "7C7C4AZ9KHRS6X63AJAO",
    "user": {
        "sub_ids": [ {
            "format": "opaque",
            "id": "J2G8G8O4AZ"
        } ]
  }
}
]]></sourcecode></figure>

<t>The AS processes this and determines that the RO needs to interact.
The AS determines that it can reach the identified user asynchronously
and that the identified user does have the ability to approve this
request. The AS indicates to the client instance that it can poll for
continuation.</t>

<figure><sourcecode type="http-message"><![CDATA[
HTTP/1.1 200 OK
Content-Type: application/json
Cache-Control: no-store

{
    "continue": {
        "access_token": {
            "value": "80UPRY5NM33OMUKMKSKU"
        },
        "uri": "https://server.example.com/continue",
        "wait": 60
    }
}
]]></sourcecode></figure>

<t>The AS reaches out to the RO and prompts them for consent. In this
example, the AS has an application that it can push notifications in
to for the specified account.</t>

<t>Meanwhile, the client instance periodically polls the AS every 60 seconds at
the continuation URI.</t>

<figure><sourcecode type="http-message"><![CDATA[
POST /continue HTTP/1.1
Host: server.example.com
Authorization: GNAP 80UPRY5NM33OMUKMKSKU
Signature-Input: sig1=...
Signature: sig1=...
]]></sourcecode></figure>

<t>The AS retrieves the pending request based on the continuation access token and
determines that it has not yet been authorized. The AS indicates to
the client instance that no access token has yet been issued but it can
continue to call after another 60 second timeout.</t>

<figure><sourcecode type="http-message"><![CDATA[
HTTP/1.1 200 OK
Content-Type: application/json
Cache-Control: no-store

{
    "continue": {
        "access_token": {
            "value": "BI9QNW6V9W3XFJK4R02D"
        },
        "uri": "https://server.example.com/continue",
        "wait": 60
    }
}
]]></sourcecode></figure>

<t>Note that the continuation access token value has been rotated since it was
used by the client instance to make this call. The client instance polls the
continuation URI after a 60 second timeout using the new token.</t>

<figure><sourcecode type="http-message"><![CDATA[
POST /continue HTTP/1.1
Host: server.example.com
Authorization: GNAP BI9QNW6V9W3XFJK4R02D
Signature-Input: sig1=...
Signature: sig1=...
]]></sourcecode></figure>

<t>The AS retrieves the pending request based on the handle and
determines that it has been approved and it issues an access
token.</t>

<figure><sourcecode type="http-message"><![CDATA[
NOTE: '\' line wrapping per RFC 8792

HTTP/1.1 200 OK
Content-Type: application/json
Cache-Control: no-store

{
    "access_token": {
        "value": "OS9M2PMHKUR64TB8N6BW7OZB8CDFONP219RP1LT0",
        "manage": "https://server.example.com/token/PRY5NM33O\
            M4TB8N6BW7OZB8CDFONP219RP1L",
        "access": [
            "dolphin-metadata", "some other thing"
        ]
    }
}
]]></sourcecode></figure>

</section>
<section anchor="example-oauth2"><name>Applying OAuth 2.0 Scopes and Client IDs</name>

<t>While GNAP is not designed to be directly compatible with
OAuth 2.0 <xref target="RFC6749"/>, considerations have been made to enable the use of
OAuth 2.0 concepts and constructs more smoothly within GNAP.</t>

<t>In this scenario, the client developer has a <spanx style="verb">client_id</spanx> and set of
<spanx style="verb">scope</spanx> values from their OAuth 2.0 system and wants to apply them to the
new protocol. Traditionally, the OAuth 2.0 client developer would put
their <spanx style="verb">client_id</spanx> and <spanx style="verb">scope</spanx> values as parameters into a redirect request
to the authorization endpoint.</t>

<figure><sourcecode type="http-message"><![CDATA[
NOTE: '\' line wrapping per RFC 8792

HTTP 302 Found
Location: https://server.example.com/authorize\
  ?client_id=7C7C4AZ9KHRS6X63AJAO\
  &scope=read%20write%20dolphin\
  &redirect_uri=https://client.example.net/return\
  &response_type=code\
  &state=123455
]]></sourcecode></figure>

<t>Now the developer wants to make an analogous request to the AS
using GNAP. To do so, the client instance makes an HTTP POST and
places the OAuth 2.0 values in the appropriate places.</t>

<figure><sourcecode type="http-message"><![CDATA[
POST /tx HTTP/1.1
Host: server.example.com
Content-Type: application/json
Signature-Input: sig1=...
Signature: sig1=...
Content-Digest: sha-256=...

{
    "access_token": {
        "access": [
            "read", "write", "dolphin"
        ],
        "flags": [ "bearer" ]
    },
    "client": "7C7C4AZ9KHRS6X63AJAO",
    "interact": {
        "start": ["redirect"],
        "finish": {
            "method": "redirect",
            "uri": "https://client.example.net/return?state=123455",
            "nonce": "LKLTI25DK82FX4T4QFZC"
        }
    }
}
]]></sourcecode></figure>

<t>The <spanx style="verb">client_id</spanx> can be used to identify the client instance's keys that it
uses for authentication, the scopes represent resources that the
client instance is requesting, and the <spanx style="verb">redirect_uri</spanx> and <spanx style="verb">state</spanx> value are
pre-combined into a <spanx style="verb">finish</spanx> URI that can be unique per request. The
client instance additionally creates a nonce to protect the callback, separate
from the state parameter that it has added to its return URI.</t>

<t>From here, the protocol continues as above.</t>

</section>
</section>
<section anchor="interoperability-profiles"><name>Interoperability Profiles</name>

<t>The GNAP specification has many different modes, options, and mechanisms, allowing it
to solve a wide variety of problems in a wide variety of deployments. The wide applicability
of GNAP makes it difficult, if not impossible, to define a set of mandatory-to-implement
features, since one environment's required feature would be impossible to do in another environment.
While this is a large problem in many systems, GNAP's back-and-forth negotiation process
allows parties to declare at runtime everything that they support and then have the other party
select from that the subset of items that they also support, leading to functional compatibility
in many parts of the protocol even in an open world scenario.</t>

<t>In addition, GNAP defines a set of interoperability profiles which gather together core requirements
to fix options into common configurations that are likely to be useful to large populations of
similar applications.</t>

<t>Conformant AS implementations of these profiles <bcp14>MUST</bcp14> implement at least the features as specified
in the profile and <bcp14>MAY</bcp14> implement additional features or profiles. Conformant client implementations
of these profiles <bcp14>MUST</bcp14> implement at least the features as specified, except where a subset of the
features allows the protocol to function (such as using polling instead of a push finish method for
the Secondary Device profile).</t>

<section anchor="web-based-redirection"><name>Web-based Redirection</name>

<t>Implementations conformant to the Web-based Redirection profile of GNAP <bcp14>MUST</bcp14> implement all of the following features:</t>

<t><list style="symbols">
  <t><em>Interaction Start Methods</em>: <spanx style="verb">redirect</spanx></t>
  <t><em>Interaction Finish Methods</em>: <spanx style="verb">redirect</spanx></t>
  <t><em>Interaction Hash Algorithms</em>: <spanx style="verb">sha-256</spanx></t>
  <t><em>Key Proofing Methods</em>: <spanx style="verb">httpsig</spanx> with no additional parameters</t>
  <t><em>Key Formats</em>: <spanx style="verb">jwks</spanx> with signature algorithm included in the key's <spanx style="verb">alg</spanx> parameter</t>
  <t><em>JOSE Signature Algorithm</em>: PS256</t>
  <t><em>Subject Identifier Formats</em>: <spanx style="verb">opaque</spanx></t>
  <t><em>Assertion Formats</em>: <spanx style="verb">id_token</spanx></t>
</list></t>

</section>
<section anchor="secondary-device"><name>Secondary Device</name>

<t>Implementations conformant to the Secondary Device profile of GNAP <bcp14>MUST</bcp14> implement all of the following features:</t>

<t><list style="symbols">
  <t><em>Interaction Start Methods</em>: <spanx style="verb">user_code</spanx> and <spanx style="verb">user_code_uri</spanx></t>
  <t><em>Interaction Finish Methods</em>: <spanx style="verb">push</spanx></t>
  <t><em>Interaction Hash Algorithms</em>: <spanx style="verb">sha-256</spanx></t>
  <t><em>Key Proofing Methods</em>: <spanx style="verb">httpsig</spanx> with no additional parameters</t>
  <t><em>Key Formats</em>: <spanx style="verb">jwks</spanx> with signature algorithm included in the key's <spanx style="verb">alg</spanx> parameter</t>
  <t><em>JOSE Signature Algorithm</em>: PS256</t>
  <t><em>Subject Identifier Formats</em>: <spanx style="verb">opaque</spanx></t>
  <t><em>Assertion Formats</em>: <spanx style="verb">id_token</spanx></t>
</list></t>

</section>
</section>
<section anchor="extensions"><name>Guidance for Extensions</name>

<t>Extensions to this specification have a variety of places to alter the protocol, including many
fields and objects that can have additional values in a registry <xref target="IANA">registry</xref> established by this
specification. For interoperability and to preserve the security of the protocol, extensions should
register new values with IANA by following the specified mechanism. While it may technically be
possible to extend the protocol by adding elements to JSON objects that are not governed by an
IANA registry, a recipient may ignore such values but is also allowed to reject them.</t>

<t>Most object fields in GNAP are specified with types, and those types can allow different but
related behavior. For example, the <spanx style="verb">access</spanx> array can include either strings or objects, as
discussed in <xref target="resource-access-rights"/>. The use of <xref target="polymorphism">JSON polymorphism</xref>
within GNAP allows extensions to define new fields by not only choosing a new name but also by
using an existing name with a new type. However, the extension's definition
of a new type for a field needs to fit the same kind of item being extended. For example, a
hypothetical extension could define a string value for the <spanx style="verb">access_token</spanx> request field,
with a URL to download a hosted access token request. Such an extension would be appropriate as
the <spanx style="verb">access_token</spanx> field still defines the access tokens being requested. However, if an extension
were to define a string value for the <spanx style="verb">access_token</spanx> request field, with the value instead
being something unrelated to the access token request such as a value or key format, this would
not be an appropriate means of extension. (Note that this specific extension example would create
another form of SSRF attack surface as discussed in <xref target="security-ssrf"/>.)</t>

<t>For another example, both interaction <xref target="request-interact-start">interaction start modes</xref> and
<xref target="binding-keys">key proofing methods</xref> can be defined as either strings or objects. An extension
could take a method defined as a string, such as <spanx style="verb">app</spanx>, and define an object-based version with
additional parameters. This extension should still define a method to launch an application on the
end user's device, just like <spanx style="verb">app</spanx> does when specified as a string.</t>

<t>Additionally, the ability to deal with different types for a field is not expected to be equal
between an AS and client software, with the client software being assumed to be both more varied
and more simplified than the AS. Furthermore, the nature of the negotiation process in GNAP allows
the AS more chance of recovery from unknown situations and parameters. As such, any extensions that
change the type of any field returned to a client instance should only do so when the client
instance has indicated specific support for that extension through some kind of request parameter.</t>

</section>
<section anchor="polymorphism"><name>JSON Structures and Polymorphism</name>

<t>GNAP makes use of polymorphism within the <xref target="RFC8259">JSON</xref> structures used for
the protocol. Each portion of this protocol is defined in terms of the JSON data type
that its values can take, whether it's a string, object, array, boolean, or number. For some
fields, different data types offer different descriptive capabilities and are used in different
situations for the same field. Each data type provides a different syntax to express
the same underlying semantic protocol element, which allows for optimization and
simplification in many common cases.</t>

<t>Even though JSON is often used to describe strongly typed structures, JSON on its own is naturally polymorphic.
In JSON, the named members of an object have no type associated with them, and any
data type can be used as the value for any member. In practice, each member
has a semantic type that needs to make sense to the parties creating and
consuming the object. Within this protocol, each object member is defined in terms
of its semantic content, and this semantic content might have expressions in
different concrete data types for different specific purposes. Since each object
member has exactly one value in JSON, each data type for an object member field
is naturally mutually exclusive with other data types within a single JSON object.</t>

<t>For example, a resource request for a single access token is composed of an object
of resource request descriptions while a request for multiple access tokens is
composed of an array whose member values are all objects. Both of these represent requests
for access, but the difference in syntax allows the client instance and AS to differentiate
between the two request types in the same request.</t>

<t>Another form of polymorphism in JSON comes from the fact that the values within JSON
arrays need not all be of the same JSON data type. However, within this protocol,
each element within the array needs to be of the same kind of semantic element for
the collection to make sense, even when the data types are different from each other.</t>

<t>For example, each aspect of a resource request can be described using an object with multiple
dimensional components, or the aspect can be requested using a string. In both cases, the resource
request is being described in a way that the AS needs to interpret, but with different
levels of specificity and complexity for the client instance to deal with. An API designer
can provide a set of common access scopes as simple strings but still allow
client software developers to specify custom access when needed for more complex APIs.</t>

<t>Extensions to this specification can use different data types for defined fields, but
each extension needs to not only declare what the data type means, but also provide
justification for the data type representing the same basic kind of thing it extends.
For example, an extension declaring an "array" representation for a field would need
to explain how the array represents something akin to the non-array element that it
is replacing. See additional discussion in <xref target="extensions"/>.</t>

</section>


  </back>

<!-- ##markdown-source:
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
rfN44iYcHjrsmcwaP1EFu5rQULGhhmGhnqOJFrGUOWbZ5JI3dEfOZMLAgsn7
mtFjtCql7vBRHXTSDPIpa1RWyP4OS0J1krvYj46Hwvm07hB2FIZ7D1tkJqNX
BXK2LN8lPIPJYuJS8dxcuf48OKMBsQJmAKU+YrQ6IR8VqFdQHGPt5Z8zWu2O
hYJ98r9my5PttL3srBRyZiU9IYGZkFSySr65KcUXGZdq7Z2dQDP5gxMl/qCn
mN0kxi0Kb3yAM/whVSuX1JUIh1REXcNqh3uynnnXQRpIlBNe0ccvPY+p3LX0
sab3aGQ5xj9jXcgsOJwrmQDw+3L3d7ZqhS/JcNRspoPxOs/6JxLrfvzwvxlZ
pfDhfw+BO2dYhDx+Zd07K/jpv5UO/1+syv02vzy/urq6uLiyAKlrceO3D6rt
fnGQhB/+C3FUfvtwXD7Z2t+eL21VSh/+axi26JEPmbj/r9tnn7ceL7/VF1ZH
h9vrk4NwafK5vng5ub4eb9R2zh/ixuVBc7B0OL/xEK5ux6dbY+jK5svOSvdS
ze76YfXL+vLFYfPpZr/XOr2vtyfVZO1ocy8p7+2Pd7uv7fr+4/jqslJqN587
pdeFq5Wtp/3dDjRy01+sdiYHJ9WFxfaoHB9U5l/GzYXS8fV2r73buWl+qd7v
3uyPLp/PRtXF84WFjc/r98nV6+pRs729O7/5MIRGdr9szG8txaXFxVb1vnG4
cfryWl6vfzmbO969qB725r+FvdH13nP35Wp99aS2cLDSGV8+JocP8zsbS8/b
tYd7aGTh6mxheWGw3Jw7Oa2Ei98udx9G95UvjS/7X9rHJ4/3643Hb2vl/eW1
3rfj/c/l0lXt883G4CJMtva35k7WnzehkXB01osn44f71fWj9ZXPp1t7x8np
09KX1fPn8Pjlfvzbb786KRauIGP5lWQFmEcAZUKTBN+YIxLunE2q0U52SRgg
m5zOXrM8hehsXV5ZmkPveuY4pXb+OvXmvYgGptr0DnyQxS3wiqrvrvcaSkWV
q5MJUCAB4WwUDZxfhKRXiSOrp1oV0z4FEEV4LD1IMKfg8gYScydZOUQ9mYWe
wYZxRBzkA05I+XuTOcCEqlVXKlW9TFYRYRLY1r5F3atJdieojOlvUVxAwuTc
tYB0ap+nk+8Yo5RkwnaehHWwj53EStII2bJQrXNsGe0i8joYA8oUtJt8ItVS
wButCypEjzSB3piLLSd56fm6JpYOyx01cgdp+vqfnKmP7aY+ail3xrdMDnQr
krenZu05bgCWnQxXjgPA6GOXEnSB0J9tP4eVZR+CSQeEaIn2J+hb/IJJQHqC
W0GdL6SwRVzjjeO81t12px2seTFWvDCrnKVmEtFJAWBXjUnk5v1DYbQPnWE7
+eCGQ45GCPFXO6w6buFnZRhpE5PbhLe5ocdx0kg1VMbgah2s6f3LaqZn0og8
VFRNmMbSbQ2tlvrhpN0LG9JAOEw1YFlYqS3hhkj4wJgQyak8fcRP+2Il2GSR
2wNl9dQ5NVJ9aXaTpAiJCorVNuy4y6b0m0CFOAvI62FOIjoJAvvYYKTT7Mro
BRwn8RDDs/U2uMa0H8aDki6efCtkYSDgPGnsHIyI6o0kLPYXVheLyUOo/sd+
hit5iw3MnS/yK5xBn4pA1HyjRh8tTSIezRBSz+6jh/A5VjOGpjElq7INjhFd
Ph4g1GYCy4TROy+UsK01nbwLrMQIyIfQrlqNgMi1yTQi4gzSwUH6Fg+PLUf1
QjNujQZSRUurGLXVqinDyPTOwiR6gCSALqcBTFkpvSo6iENpInI56M1oin0z
gsYqYAH7HJg1niGdChIRiLQnRUxjZ7dPwHBpke1HermVJO8WzJjYC3sO0GBg
Rw9fi1kenFl19LhDIfQbbUiKkcJToCVQwmGdEpSNPcT7R9IRI2Zu0ePDh1g2
ol1EeSSm5IdbcSvS1QmL2k1OP0FJaO5VzmwTZcnF80Ewol5HGfXoevS+AlNj
I/0A4jNc8Trrc6jkA/LIUOgciYyTYTwcaUK3cTh5azUCZ3oPMruFThsRgdPu
iLqjToRUDA/k8EkI4MCwuw4wVN2MYQ1mOXwXpu9iMYwd94yvqBB3cET5mKJn
ScxIG91voY5kKPBsAxr3uzp9fOaNYHCp1nJd/r4zlkrakgtAjh75sq0t0Amf
ZOMCiIqO/ZBzVNzl0A3tB05cBPxKVVfq20l3AeJmWDr9XnFzNo6GzSKZjGzT
FinTHHOGar1CM6yDh5oSHzBQz5H5EWMwBwKVpkaF7H9ukkFLCSxwjkLoS+9v
rLiKBsydIAfmg/xsHzF0+JOAxd2kofLYIW0EtUx0o1cfdbQPS38q9oZI9X4w
vQhinfj6EWSRg82SfGLNHX+SOTO/YnaBFdqTXa/tD0CTbOkAss5gTtKbhzcW
L60URKQkgfayv2l4+KmamYERGNKGg15b728Ma8LeYXHOl1Bx1GeOAQOWIyNP
bZaAw1xaGtBqfE29O41VyXC+eL1BbEp9zca81Yxgi3bo/JPBo8GJnuphDExM
HJESQYS22/5xBx8tojH+I5aF19K58zoPXb2RQVT8/onsqbgTK4Wsza4yCMBZ
xXGpcisosqRauRlZXymwsB0Cfmr6X6R4d0+KltPQh5rPQXPdwc0jl+ldhTKl
9k+qW8YNV9CJb4WPjqypsvRbmF2A/lEy3SoMm5ByVOf8Sk+lSlmVH80WR6oW
1Sok4JGB+unXPwrMwRk12mnGWSp9TLOpLhav78/mqq1B0qmXV142X28ORhfH
L/vRQn/jetwoR8tRszpZfGhstrbXis8PG0utx7Dy9N9a0Y3nx5ejrUr16HKx
9ry42F7aPR4cFtfvH2+7G/svg9vd8kkYJZvxabd02p2Mx1vN1sLx89rScbdo
Goni9sO3q0p4WRzuH2wdPW7ujm6bnf31KOrsHt/sLc6XWuvdq8bO6+ZFr1Rq
PF/3XhrLO0cylkx+0YdvCN580ajXbkeT4sbm3M7BxeFOf2unUll5Wtw/Wa49
DeurR1u7TxvLx3vbV/HD0+3yc3nvZON1Y3PZdOzwqPd8FHdPrpW6Wek2Dno7
tePGfvOyvbm9Wa2Xk9WNpW5pMl+tbZydVl7izvp18X68sFYMb76ZRvavjl5O
Dienj6+ji1ZcO9lY33s+3FwurhY7z9uPVzdPt1HU3JwLh8uds6VvFwvn8483
w9VVGQsu3/Zu+6FR257rvdba8ebL0XqzWVsO9y8Obg469/fb+ycXx+rWWqsv
tK8O1hdGLwvH5fvbzVJj3XRjJe7217YuSgu9y8Fm0t8ePm88b641bgZXrcrB
0W6v+bTV791Wq8/rN83WcLd4Unu6v76tfRuebptGtg9PD8rjuf2rpfr2abe7
eFZ62VrsFhtnK2qCNg7aS2vPN4e764Pd6sNgbe712+t2f658cHW+1Hw0jdzP
tzbWDk/HyXa5tN1YObjq7M03BmdnWxff1irF3vwqtLy+c3Z8dvx4cnvxVN+v
xeudrb2L2q1p5GC/ctroX+yXO/et7vVl2Dy8fSg3o/vbxsFqf3VpMhpsXWyv
djcOlnonC1ung2/rK3uHi+ffwq2uaWSp2l4YzT2uviz1BsWXwaDcO34tthon
zysnx82b6+Xj7V5YXGiuflsbr5d3z0dnsijp5LUP3xCPptfqH289bR60SqXK
41p98+K2eLq/fhNeHT0tL2/3l5ZWKrX5YdjcG33br+xujZrVk2slrnrW3Fye
7s+1dl+e51sX++OFVqf4ev18URzXjo5bg9L4IlmvRq/V/cfT6uPL5c2wUyu9
Lq9ezm+Ong9MI083k/ml59eV/cbq0kNnsz2Id+pXxxu97a3zZOfw8qm/u7tW
GZ/uvbZG57uXndpwdTLXu5rs6S2H0qHxvHGws1faWakcPixcTh57+7ebg+WH
m4XDh6txtL5wXb9e+NbYXFvvvtyszHcGh/HRWWuxbq3R1np3/G1jq3Z8u5RU
h91SvVIv7V91nw9PF3ZWhyt72wdKEbqNb2vVWljfXxnV5haPquHc0sL1gmmk
0hzfPx8+Vo5PK3PnB+WthZuXysl5by+8OB6d3y4Xz46aq8VS3D5/Lu3snQw2
jldXWqdq18hgPKmDHxooIOKjm87WYXjQqq3dXt4eVWrF8+bm5bB2GG0/7u1U
LlfD7eiic/O0VllRsmu4Ojh+nRwX985M344W5761V0er+8vP9dJO52yn2Xs6
bJ+eLV8dVjeul1dvX55qV4OH3vl8sxhtdodPD6crh8tX4bhqrdZJ93lpu7S7
Mp6sn60s7Z53dmut1fJBaf32udI+mmwfPF7dX7RfD5qLT8/fNh6qO1uvi3uP
eitiCuTD9cl+8erkYK/aODqqPnRvdxYv1zqluU5t7uJyeLaedNbXn/ZK9U5l
uFiOV9eb143dZPu1PDTduD44eeyvV+Yr/YP+fufi4GVv53gy11q+WQgbpavr
5GH1oDduTy4mq3tPN6vHR+PqoH6+t36zc31lGnnc7Y8fX5+bO89Xu7dLB/vt
bmXhdlQ57y/eLJ4/PpXuN8KDqLXZnZ+/KD0r0TH/8C08Pe8+VG5erOtg7rGy
VWs0XpOthc5ovnqw2qhtVE4ex+ft+cXO+XFvNa4Nap3F7ty3zbDxurr+dNor
jp4X1zfmrIM06lbnDhbuy7cL562L/srrevtsu7fdPaydlEaX/dvO6HDrcqe9
vNJa/7Z2dLJwPzi4au48xAtPJ6aR18n4dXxaG30r1i/ONidbxyvh4Vz1ZeN+
Ybe+uNdQnz9qrX7bPZ+c3PdP4+HmmXZIHGTdsYkG0WaPqouZb7IKMoS0uhKC
cyZzoG6+c8acoc/WOjbqe/q7YwYWM/UlVtrkuEcfTaGReNBjwuFwEN8rGxyc
akUXSc4BF2FNVqAPMvmq7A1gzV4jverE7x0wsTC1XRlDaD1yOlHYUUokFT4a
1cp+H/MoJAFffBkMdActiwNCO/JNXIp7O8sjywChMLRJziD021P7Txl0xrHk
2uQ+JBUDBI0toz0PA3DRWTgFKi+S/Hs6jfw7p72bpJBMVIV/oj4ZbyVRs3TJ
40uuVtBcWacnH21ABVAD2z05a+U621EXq4aYa4XIzYsuzdT+s+MQxiaHkAGU
m0iQBCfB4wGdMdlKOoCQVvEH7P52iqDusr5d/THjX9X2MHzARVIR5s8Ubrez
R9HBK9VHbPuIw8DujFNbQJlD6smtjU1lVUjhvumURgA6XVhdBHyiZ+MfqO6W
i0vzJSi1pkw//ZYu43Y8wB4U+P+zjnTV2ZQj/X07ynaS6xPnzpOc6XRxV+CI
r4/iqzKyB6Izphn0TBojjl3rn2ZyfOpBtgN37FK/mzLbGWc4+2N0Lq4AxWjH
64ATZQ1eREZIeJCQtDcNvncfJxIdLxo4JQEUZTdjjuOXPuCAfcLc6oONQT/J
FdFHyyA56doe7LrhoL9z0kr0i1hLJP4gcJzbTjjztt48tusbbwPDAkhQ3Lx0
mSHiiGxCLVde4bDc7Ww6mZIQNny3z6EpS8Cngt35MP0yDKdUW4YEDnVnFLwd
KBYi4ZyCVU9qkrYzJVpEP+DUtrnxAXw0je7vtpwGe7Pn3552XIdUTMJeM6s0
e7qLPbtswXuWzc1Q0qtW9mGuG7FuoUI5Hnq3tjXwgbKrwREvhxm02Wfla13C
IdCv7J+319Mezd0wVJe1OXxWcoRW7PhqB0/RnQWvK8EeWkj4r0nBrg/hZlDr
SgoGtZnXd2qvOMnL7lmqYyHikCQQAKKKJV5w8wJQWHE7eb1Oe5TxcUH0p7aR
dwdAoWNE7CvU2wANKCBEjHSMkCgEBh699DGOqTQupTEPnsDtHVJKpHq1/lRI
nqKxM3oN9WONHxPY7rJjJpIKbG3UbY1gC0C+Nk8p7npZ+BnPeD2cYESkpxNC
+QMa/ZrwXdRHJhSEpaH2VatK5Mo1J2X7qmVQ+k2aKo2Q8bFcJB24/tifiul7
nrSc1JWAQWIkBqO34B1HE9YtZu9tPHo20qO6j61btRGhf1dUWtWhXxIuaHbq
+9UX+DxJJgE/5dumdj58GohZP29Dyej+BFI/JWoGa81aL3W0jZ71g6Q4CZOK
8Dk7iRSZEG6S0p+t7KM/7F7+cT6/N3Fw/5Uo/Zq93hchaMxl8bvYPzxZLi9u
lK8P1692a5W5g8rJm2Sy0sGfgaDodfGbn38cYJG17NMq6Ng+EMUf9jeBT0V8
Tn/Y04SNXP0JHxN4lqCRP+hdMj4lTKT9Ub9S2psEjbzDo+RuJPO/H5QS0VeX
jrt7ICcQy48nAjK1SY8VjuGXfOpea8fLN3nTuky5ljgBUzHfytXqEAgPbcgU
NC2gEUQRJ8SiOCNRFAjY6K/fSlfrndfK5kZlq14tdS97X5YPr8fXk8dB+3j+
vtJ8/rx7cHgf7ZR3WpJ0rM1+EYFGbseQkC4moJvDRNmSad0PGnyfRNQmy68I
wBw41sivhSlY9XByg7Rp8GsB9scfnAbdWDvqtoYgENdWV81fGVA+Q3T44X/r
mSriDQfyOz9vP9Vj7HD6ywX3o588if2Y7/+jyf1mQ7bVPtO4Sxa2NZh9zi5g
I+GP10sQmi98/89zSsrPhzhNtD55gLs/sPgwl7ABfrQE439yKTN1GvXSaFwL
l3tPC/HuTRJWDtrz6tY+aLcaS3V1y74O7yed5dWr1tVqq3rSOphbxzDG59fD
/fm13s5jtby7+bj/clVqXZ2W4spy+2Ht/vCo1jx9vd++6C5uPXxeOm/Xo9PP
czdLna3qyvNcZf5ztBtBIyff1ttz1+3rg7B6Nj9/XVvpfq6PT7sb1cbzl+XP
y6XO0uv4amurOeyuR+X5rY3eoFkbnQ7D0ZfJoHa9RdURa+Uv+98qpYe1i9fy
1vzKU7VdrSabu9fl5d5Dsv2tXtkPn69Ka43R6c1m87r1dBOuLI9WHvZLC5OL
l955fwSNlPY/r1ycK7F4/GWldLwwWvjyWmpsrD6fXd2/bpzWTuLDwWi+1L5f
fu6u3/Q27893kkrly+vuaTh6eXhcq33GRuZXe0ufh63x9dV4fqU3fNivvuzt
ndysnT7ttV4XW1Cn8bcq97cq97cq93+dKveWk8ToTOgzSzhLmmtTsm4pjefq
OJQ1Va7jdnS+HBjHIzg8tIspXTrq3o53uooiOxRxNwbuOMIWuBGHHCRk/81T
NHGSkgcIc0eIJ9Y4wecmrhsPj8AMAerpYgTIXGuH91Hb1z3QEjAQ224bj4HF
STDqDuM2ZPcrEdgA6NUh6DjJ8BMC58EC/UJ0Z/0hkTHXAUaCmWGwFKKndA1y
RnWiiDFknMTlLNDiPzSUjISPp1ejmhgiMyOwN1aX6wuezpRGHD+FVFM55MrI
yaIBJ4IsccVMAR3KAKzJAVjtz5SIqRWwbrftNHt7Nrz1QTXLi0Lek658BfeS
+ZaEtu//+OeoycAXZzflPHY7OuieF4qwXY1WYEftipR2KFCS2r9kzgxmN7vZ
5jyv/HGlx6UwIO/o9sJdcUdkeY5fygzsDXhyAF3u92KCUrM3lsUYGPhi9t6o
hLWQzn4xwTsZmDiRCe/ZLSqDghvAUkUX3wf1RhEv/T9pUrjQ6H8QGX1xYW11
dmGxOF8qhsnzZjgbeg0KpQf89uv2/Zfy0nM3HD+MRvtLL0+lyuPO4P7+ZbBc
f467N98ai5/3T69Xl0Zf4GbbP57U2p1KZ+NkOLl4uJk/ef1Sr1YXh8l11F1u
vvY3xvHrZPn87OV4/ew3n/HB8/Sj9keqLjxrbyyJrTGEKBgUp0X1erEPmV5o
ifiNDOnNr8/Hi3sH18l+u1Q53I4+D6+3OouN3aPFyuJ6rfftZWmztN3cXWxF
S5cnT60XzNJr7JXOKoPH9dXBJHnuVbd2nsvN+GL/5DLZqZ9uzrfPlxfWyp2x
rVf/BK3w35QixYp+oOzUUWc8qOZQmSNo+Ica2YSYgJw3qCSgxGG5YRoiAKX/
Iz4b98h6vDc/fNZge42+/OhZSx2SfFmQJgEywqvw63Vjc/9xs1uqflvdrqyW
oqW9+snhZafTXB7vHfaSsdLL66+fMXH26HO0+vK4vdm/rJauO/HR9ea388Yg
Lp3H+8nNy/JCbf51pZysHbSXd2s7T9RF41TCFcx8P1csOF4IEQ3vEAu2GyIr
Gmyx8DM8Xm5/CrkTXchMhPTTPJMdzeqcjIQOsyPX+Jq13WHOXYXHTp2lSJeT
8PX09431V9xYP+HOcm6tGWxVCcWf0Zcf3Zh/aGt6N+dPunt/5PZ1Z+7Xi8vz
rZers7lWdBnVzg8eNpqbtZXL/Unt8+eT3erFffO0PD96upzrrXQ6ybBx/7z3
uhafjHbps5uV7dfKemfu6Ox0++Kof7i5fXXW2Fp4jkvVw4Wbx9f6Venb4fi1
PJxU1tc+V5KLUj0sl1fnyks3O0c97nvrPDk4fVrc3t48XjmonN/MPdfWjnpr
k/rL2ua3L2try7WTy2G5823pde76/HprPO5+ri1/Pq5frg62h52EGknmb5pX
O3NbvXLzYvk5Ki31P78szl3PD543d5PmU/hUq6wv7q8+Xl5sTu6r0cLa8HHv
4Gy9tzCK65sXY2pkOI7G60fHcWMv/Ly8HG8v9C8fV8drler9XL1b32o93z/t
tsrVb+FNdNV5edlZbB2t9ud3d9eev5x8O6tRIyetVmepVbvsbJwli72Xrc5l
0qydvETNUbf5sHD1+exvHSjH0aKToRAXwbL7mYvZgu23U5uaTGJhsWCCyW6h
Vfz+D8Sj+NFcXnjpLpUYOS3dECEzPCqeRqwFFwSiZ5DTygbRYKIV+NWiLbFy
kHim8nIaHJxmcCp1OqMuD05Qt0ykJRCWIIxOYm+KgCjvYoOh1RtinwaQ4ZLg
ErwgAYkGYl9bXJwDfDQINiEQbn64KZV057tpf1YgqZdEmUDS/NLySmANluKI
vx7t7W0sP25slBsHAke9U756HK8svpweled2Nqrfdqp79wubZ1vrG+Pz8tHm
9cvxZnmy3jq+WC8fHUEjB3NL+5fn80tnnf5rZae/dPZ0tHS+ef56PHdWql5U
lsOF9a2TraW5806/f3LVfqhvXSyfvV6X7i+2xrsP9WPUHx+3xsebe+Ojx/LL
yeb53KX6+9Ej/PfWnP7bY7l0VDsbH7WuNy/OzjY3N4Yn1Yv2cXS+j3V19bnK
N/XvzZOL8vzRa2Pr+Kl9HnWG48rmw0lje/9bWGsvXV+tb0dPR6XjznxFjX19
79FAb2OMBuG3t7bL5ZON8tlqGZ7ZaB2of2+VwSX+2XKJf/G4xKENb0XND7jE
sY1ULY3tEv/CLvEvU1zi0EbKLf6jLnGMFKXc4v8/e2+63DaSrYv+x1MwXBG3
7N2krMFDuc/d54ZGS7ImixpsVXVYIAmSsEiABYCi6Gr/vE92X+zmmjJXAqAs
u6r7VO9yxNmnyyKQyGHlmte3nta6xJ8udolj8My6xf/2wHqZvS1g3EJ/MIam
wfVnhk7fbiTvd94sR+93538bXvRXt57/NM0/rr0aDQ+ef0o6T3999Xrt+euN
3tN3+WV/Ez3xs93pwXH7qn0+fv1ypXNVZMfdu+VJMYpedSarN29Gz3ZH7bOz
fqeYTF8/T5N2uJbPTo+GxZvifP78aPcVjHH5dOfgIn5z2U9P2ms3s3R7srny
7tc371+MXka36dlm0f7bzdnb03a2GT277RxNss31q9O7Ty8+rSTb0eYAQ3hH
hzdrP83PTm/vfoqHV5OL4+n53/aGf+sdFxfR0+ju+d76yfu70dv8tugP8/Or
X7sv9+ab3fnL1cvd5HR3dA5j9JM1Q0bL7eerL5f/9n6Ur+3dvhiupRvrJyuv
4lfLL84/xudnR7trg+W7w8u/XTybHtwN5t2b4tls69nhaH4LY3xMwrcvr9by
0xfb+bvDtLveebe7t74/nL3pFedP+weD3uzg+W1xZ1jV92Dgvz4YiAJUlzi4
jgFfyaIxiuax6W9g0TCIx6a/hUUjUKJi09/EopFWyx0SvpZFwyBfKHr8MotG
abeo3PGhLBpZc33k8uEsGgZhNv3tLBoZSSly+dUsGgap0ODXsmhkrYZN/y4W
jbx199XvY9GYKTP9nSwaBjn/d7JoG8/9t0eOmdHlU0wY9r/HrW6Qf8dGbJiH
HjUbj6hHw6N/3GMRQcwqzDjat8BocBnlZD4EY2fzaCuCdfJ7QruNtmRhB/it
NEkYtoNj3Ph+UsSZCksWCMdBTQRULM5HgsI22VH3xhgurtVRjNGsuUMRL0W/
Mf8bAJ17gNeNFoRad9CFhlc1EGFuP+o3rMn4SYFt0FBkU7YgqfO02lyL/g8G
YAryFAEWC4JkgfYnjZM3ewxRr7oZGGvRTKorJZI8wYw+1UoT6nbYwkavBFPo
GrghaiL68Ut/bU2gSi5L4GdESUvHGnkyqOmwYbvgVLr/LQxpQ9+qICBSIAw9
OAPpuuuV7swsEjz40oAyyNZUO0htVxuOJgNFVn4RdbPRm5uryd0TbJ22XUYN
ODtSB5WAAVCUOYSw16y+DktqQfSjV4Ncn7srQTmuFGK1TXSDXjQZpXMMuU5A
NYuRVO9rweefFbsitjTa5W8/eLiWX+uUADjNr3FKIPxmjVPChZxsUysXCn9s
JvrEdr57bojOoqQrANIzv0LX66WE4EDsTaiUs3ihaespCLqjMB4jsik1zSt1
YsP4tW0UogrkYgf0Wu4M5WpMqbA8aHhVMH4eDX613M9yiaumK9MpFdfoenob
XrfdH1XHH2bGXkUQVMPvLVhFqIqF4twOaT4RjmQwmmEdru+SV4YDdVXRNXxN
l20X80l1eYgqTAfY5H0i3zXnZfwNCcuv/x4W4+pAnOLialQFoc7ihCHR4DIB
xKqVA7Qdtpdbb2/u7VlAVCc+ELqLs18UtCO3qjDcbDKJMgTEohE6c2rPkBBE
rZ6yubYLpgwFsapW3c2VUTxL/T0T6J+QjqZFRI1fFCgmdOwLEem11/gVEaxV
Qgr80YjPfhYOkM/Yn0ql9VIQ+BjMxEGUMZDuVxUBQs8Fehvym1LIoaLqq/Oj
vXeN7UnaHXpf/foqUn3tH1A+analuvtQPCEU7HcKOLNXVl3ioCH9x807G9hm
cZqNbIfFxmNp7Tyh0PkTSvvZXYcMcikwb8gHiWDsyzINhy1ZQmIrFeu60j/P
4+mVF6u+R/gQ+jwNjZ2cn0lFekAlpAhm7Grv2hakmzjnosVCKyBZrIC1mvW6
5cqQnXkR2QJ0Wzy85+OPE+7m2Byp67MxDG+jyoICWdDr7bMm96RsI6T31vbB
9tm2V27v4z4bxqzqTQh6NmlE40kxt5jO9S51q8P2FII56s6MjRFoKcbpTyKP
WzALnPKu8nsvcrEjbfOD9RJMAW/UYPTW4S0tAKErGR8LKmPkacN2MZPZ0JH8
yXBvO67HsMUrQyzBPOPCr1pJKFX2fy+R/E9zpanDxh/+vUn1i6OH35Pq/5pJ
9XGu6iIrMUKSZLXljiev44vp8dV592ilOC3O2y+Ku9XOs+7GYPZqfDJ493pt
72Rjbfb+Zbfofk3p2wNikX+G0re1QMuqvzei+f6w87obH8f77fNPeytH8V6+
Nz6aX13uLF9dvo2PP26vHp4Nnh1vvV0++nRufhsudyh69GJvtHFyvvI2Ptjc
z0J4Nt5POuOd2cG7/U/v22ac5PR5d9M8N+5N378zt208ml69Nv83L37tYQHb
0c1ePIt77/Ynex/TONw9Xe7uHr44mL/6dPVuf/Xq3d706t1w2Hm3kV+1n3/s
rC7fXq0+H3Y3918t0TFiw5+HHOVS//zXVvuitb4S7xytHs42Ty8/zNPRRXG2
ilfo7Gp9dfj8ffTuPI2f76y+XY3P0s3ls+6zXvZ+57i9u/fuxU83Se/FT6fn
6y/nu79uXpy0rt5u916EB2uruy9eYUnbq0/Tw3j24vhD/uxs483G2u3W8e0s
G74vtnZf9N+tDk9eLnffpsetZy+PZ51fT1px/ya73VsbXgwO370663/EAEH0
5miWDNOjZLZ225m+bB+9iX7d3+50Zlf9yXY7fB1N2s9X7442RltHh+833r59
d3f46vjXN/vhu37/08HONnpKW++i5fOkDwvcyMJPa+FJdjJf2XwRPpuevZwd
9MK1k/Ds+KIYzPO7T3G8lu5fTqafli9Pnt+cTj9+2kIg0tm7D9vHny6XP+Yf
N9s3B62Td+Gb9uRqsP3x6OObrcPBqzhr353vtYuVzZWzF7+utT+dDvrTt99D
W9/l8Xd5/NeSx9awtx53ruvKq/aR+IBibi1mbJw8kv4YAl6lzdOlEixkTacr
V28W3BeU0Kb0IvCrYHH9nAfc5fsVxK75CO5/Y7q6r6KR22yI0yAB5+FIgKzQ
jR8muev8WWpOgv1W/D5VzmXHRquU0cSZlBd5O7TUgDH0q+ZT1P4LOiEQXD4a
+9KQReO2BRYLsa5/0LiC5yPniy4KB/SAvT252QRuv9nYTqAh5hw+nIrrOGe9
ax1i27KGts9MqXuwQp5ktwyh2s9SAGQ1pjS5OMFXhGeocARBpcx6qDUSxhWY
/tNCUgRLLhRxvD+VxlCqhAIdVYgTGbox8XvmQIziSMCjxrK3p64aTpgjmkM4
JgPXEC2uFQ6wvzO6DyGhEVaRMxQlNpaHcilCix0KvBVUefB54H5OJ2aPpORP
bRM2GKWwzJy7s8BAAbyvzpRjbT0Jx8hhMvX/SAr5l+NCOn5xXzWjfu5rSxjF
F58FX1PC6IExhp30VmpmQu0vw9fIzc07QyVynn/EtkwWz7bzNi7ywEH/Hcat
K1EbHSVsF73Q5LtVi4Wrynw0ciushr1e3jTkkN1UNBZqDe/mKJTXKe23H7zm
aN8QhfrKINQXYlAwpd8TbnJEv8A1R8Glpe/Bpe/Bpbrg0uNviC4tPfm9oaTv
YaK/bJjo3xgnQl99jmCJ8aeoV4J7V7eEe4ErwcI1/RpHAZGczdmqARG5TAdd
NC9fWhi3wZFyTx8v9b7VncdF0bf9bq/LGf/XJZRdxpQowPNQpw7KSgogfLBv
wtz7On8Q2xL2p1kxxAVIDYoL9f3JImWkHYa5UtavtVZwHWgQZa+Be6Xj6uJA
2P3S9n9qIIyx6UNHwCe06c3vIbL/QJfcd4/cd4+cI6L/1OTh/+i4V22l3vKz
l0HwTbEuP871S/ANka5ylOuX4CviXJtJ/mZvc32wt7k/fL96NOquHfV7r19l
vwRXl8/MRDZebsbwK//feOfj+9WLT925mcyOvKl/P73t7G6k4eWzonN58Uuw
/P7ydNh7vR3rUd69TfF/++2ZfHvSSU5HXTN6D5a5q0f+JViPu2unw24CG7PR
2Uv2R2bxZluPlvdGy7k/v6tJZzz6FJZH+SWwT6yMeq+Ht1fwxOa+GeV00h1f
wHf9kWheK93xjfnqOgYPfwl4Wz92XhsZkLydXo1f3R6sHpljv4vfXx5l5iBq
9uT5bWd8NDKHM9gbXf0SvDnb/mn17dnp1tuL0eHb0XDvYmdv1l7ZP9kbpO6t
3eU3/L8yr/j96t3k6vL58t7HX4J0EM3s03F3d/+2s/qeZpr0PnnzGBejqF3e
VfPcL0HSy2BWaiT36+roBmfMJNdNjoZ1q/slMOMv4/ibhuyXt+OD9epoV/T7
xvn5zmbNKL8EQFn51ZxH4ctTcx5TmtPw6mw5LS63Xx20L45uzs5XzkIjEZ73
Tz+dvju+XJ4fvl45P9y5etfb2dnsrq5svh0X+4fjo+I8ebv89vLm2dvx1dXV
9vDTaTLZ6O2MDs5WJ7O3o727c7MnGwfd7UlxcVM8a5/3jqOzjeRolH56f/l2
frljKGtreNBZ6+XRxdXz4+1RdvlxeHz2rnfWHR9dtM/3w9OV0ftfgvBmOOut
Tl70xle7PXPC7z5dHLTHd9Pzj+Z2XexfdLdOw6Odi1/DT/vx29Wdg6vL3nbn
4/bdxcf91Wj7fPnwcvhLcPf+YuOiMx62L5Ph6PD1pH16cXpztTv5dHp2VPTO
ds7an4Y3F9tHbTP7tYvL2d3R65WLs/FPz8KL0/nF6+XljqGTjbvT1zs30cfh
ZriycXvw7mL1aHt/6/D1/kpnZKTpp6P47cVPny4ue5fdrd6Lt+O709Pxq9ed
m7vzs0/7KxdrG/3OL8G7i8PTi95uZ+v92tXy/t3x+crJ4er+vL0yHJ+uDieH
q8VJlIzWoqT39mL34u7g8ujy/Pz0+en5s7X357PZ+dpw65fg/cejvfefTvev
dne235+vJMe7O3sX70Yn75ONt+G70+3z9p6ii41X9vTlJjCdmPu6tpG/f3dT
w52eDzuX53gLzt7dDN7Kfdm27wzOxr8EO4WhR5+6kot5SDSa9nZPZ91PKdzr
PLy8mPY2n487qz/dutu58erAMKUKD/vUu9z/FblS5U7tjztr+8X7d6ef4LfL
+f4E+KzhJ2sXsbkPZuavZu/f7axctfd7NC+z/mT5zdLh7Ci9OHw7eT68uNtb
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
HsQbJkPp2UjJdALIXc4LVFYy+rqS0KJyd6P4djHMnHSItp7YxTEOGA7PBIr0
649wJtBqjLGDnD6gLAWg5jiZ0p5CT/QZJunMQgpeicW1GPoQoeYSQQbilId1
lbHUdUmoXgdE7qlTTCVjj8En6q4nJiLpjFj/FEqQt1mjtgJHmQK8vDLt+N54
EA9gYKL+zcBp2P+TFXAbbGQq1zMOLIXZDl44MSvvKLWqhBhvX5KplgqD4b6P
0ZNDIYFEQeqhm9w2qbE5q+iiojbng6nZL3Q74neQ1ktYwahLlL000KwsK5iX
NCKM8YQUERJQvip5UJQsJWxb9lwINwIlwhtT0uEMaRoT0KKAul7SAIF4C9XX
ce6kk18Cjs3SbiIS4eI3k08H9CHVR0skFzsRarK+bXyB3iXAUsTewdwAypVx
9U/2grlWQ6DTIDswY///7X1rcxzHleX3+hUdUOySsLshEnwzhrMBvkSKD1AA
aUnmOIgCuhoosdGF7eoGCGvo3755z33kzaxqEJIl2zFrxcSYAOqRlXnz5n2e
w5VBF6nfhDbZaQ7j3+qaw0lnZ1iWopqd1sFLPEYlikvmBQ1KKPmot+YjcXix
UpGKn31abzFmScsn1eZ8FO+KinwVW7pIafSd0ILv7c5l0a/tZyPYXjlLNjKJ
r7v8b3jd3smyPdrrV3+ibNsCdTdtA4QzbFe2opLdh2sU1Zhi/zjPKX+360s5
Y0+SN2tVvce07PQ8KSfFgc3cTimph+uGkmqdIqkiE2QabQRZVWG3AtpUuIOE
c09PvAP0ju8zEEPdpkQlBisWS2El8KNn4go0QP2cRXBIk3W0dI2P6DGjHJ29
tbJZnnJyQj4R0H19YC6zvPKHhYt5Fzb4PBYeL9GLHAyoZstjiReSG7aBptQk
Q6GPbVej8cQiJQK18eXfdHUUzWK1HEtlzmqjKzfGTXCkwod7ge3I6Dw9Rpm8
K2cV8LKK9vhU3M7KtsARhdtzospBTgSV+fR+c/bUE4eTwwqTJB2kgVgw5wGs
uJXaF1sWqPhJY7FZX2umC1Uk36jfdi6ZRmUy6JAndCqV365YEw6HLmJppZSl
aoUdT2LdaRxQQ9LCOHk/gmBZWP3+VVVzup36cT3WqcmGnTJXj6prywPFGYz6
3sraExA9QNxHogfOhE/VE7GrGLJkL+qigVVmmJ+OQKRD1USrxNXUTDAkkuZt
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
Ia+MTNQw6anCztqG2PVEoAsL1hnNRt4lSrg4VGaZsKAOlA3UjmMwAyojRwx7
m1cfu/2BP+HsGLrUFEmRNig9okrzGEjKEGIiIHKNmIs23yaRG9DmVNL+lXPO
m/nSSpvqQBneWwciEl77t7/9bUAE4iNJ5xVvtnffDr5efEJBwNfXN64Xz5p2
cV/bZGShNsKHE4ENnaqjt+EL7vue8a9/aptZYUUEo+ezkyU9oj68/mBjYyP+
xf1OH/YYycv7ZFOMNm/dxt+Kn6E/13iRpYzx/oB/6/4Sfvfefkf//Zz8JFdy
3UB+qV1AycS1Yf/fzsIpUa3647iZhq0zW+v89S/dG9YMiG31QJTXPZv5WbX4
etUQ9BZ1MDbAQ/414keXGxd5MBzaXDmucNaXdNmqQQBdsu15XfKbz/aTDOMz
/4+kVN3yUk1IutooEAi/4u+tD91I1n46+5hczE9Y0BPWdna3skGvVfT7re+2
HuZ/+FiP6U+fzv86up7/rZwe8uOCgOZ/I8Fc+7j98NZ85+a3p9e+eVW9LH+8
/eH54sP8xvbO2Xhy96D+8O1iMvnhvNz9dDeId5wpnZPPyYRYJUEyB4jx0iKt
aZp4za3nGkf9uzPBhhqN0W7LPoCqG+9HUZIUvJc+drW+vr554+atW53vJ0+T
HvDyxcu3zzdvPX5xd/PpDzff3vzu6Z8f5Z/6ufhMGohavt4eCYwq4k6ZykPc
Q3kTXQ4vHADa7l3oNLH/tbVrwCPsVCl7hxVQHNanmVnt8NyDBvVeoUOzVF5C
fQsOH0DiCJ3dWBR00YsSL7ksoWWmQVSz3rCQb5YXFV7PiveTJbxwDeYSaIQg
RhhVap9WV2U+2Lx2bbD94kuq+xGhTY0ecVzmfjDKRwDJMkXcI5JRnu5HKVyh
wsLh8bU+4uubj57evLf56uWfXu1+f+/Vi1cmUFGG1149fLz99Idvbv5469Gf
vn30w93N6y+frRVRjtYkul71nQo95wX+ikZJevrda+/e7Px46/WrGze2X717
8erF7ot3TlLdrsr2Rs9n2UCyLRwrMsP9dx7deXRz68/3Xjzb2b39w+0bW99u
ba+lWyEXnpagzzWBxgLM5UDC6x5tI5G+bj8aeS/Bn4kLhQJoAIRH9zFuFBQE
Kn/uwuPUqnG1StAGN67dGDwl97h4Kcfc/cGvEQU/IdKdohjJDMrdiiXkidAa
8LPz/sSEEHxhmA7wKbmm79JsyEjYK6lJTiVaPgpGZCHZ/UQxbQx2a1EYpgvM
hHRhS64dKFtj3uYsOZeIyLOyb0g6B4fyhkLZY9pOnt3xW2gprVxFlVv8CT3S
4hFXu4wvnEBsExoF7kguSu4zIk4zyjYlWcmOVLzefvvk/uDKf10ZIN96FpyM
E6TCwwioU/funXubhcrO5krZ+dJZ9F9ht/0f+twHn0aHh8sX37/96e78u8md
8Z36xtmNd0d/PV1+e2v/ZHv64nxr+qeTl58eTiY/0k3/27dQP7j5/On33z9/
8ePDR5tvvrv97tbt1y+vX7Q3hfK4TYoyEsgfJ7kQzM7ZwExkdrLV7ar6E5Uh
CuLvnxeCccLY7lwpmWBUQkWQ562C23J5osATFibHfd9lAStpQldXeZGC8ELA
iljR1vsscn2xMxQlzWVDSQ052peIvZlclQIuoz8gIq4XvVtBd5ouiQRU+0dI
MZm2SKwONK6cVqvdJNX2f7+zlLiH9zli0ncu/Q5elZd9Op36xH+tY6ilYqVw
l652c9o0qHxTbAu5Iq3x7BBeIUSjjF8r1z/o3apKSJ/4seSCC7WiqkwpFy06
kN28NcRCjCzgeez279Jmv6HJtdr3NTtme/feq803r569eLdz++bbh3df3374
/Z3tPz+8++jx0+3Xbzav39t5c/3l22veXeLysy8YNXjp1yaL/5XYUa9Wv8q/
KHromRl2kUO+yhlf6Yj3O+GZo/sF5/sXOt6/wOnOx3Gxs32Ro93rZEcH+/Nf
Upf6X9Q6jkoF4OJGDPyYw239IUKOxV0cH8yyCv3VqYOw6+gODe5RLf6SQQoo
tm+jkb87jIeEu7rXJCAfT6OjpQOXQMf1yZwYhSjY/90Oft3/jFp5KSMhzsnC
BSg9Oy4N3lxU6ngEmZ2CCTBBDjVOKsCk9xZSBthYM/FrIpL/0wOKql9GcW8O
1pijbcEQc2GG4+5YFdrq9wB/abxn6PtP/3KJgErdXiaSYmK+oc+wlBDykvp+
BjUotcCTEVaY/NzVmbZNQcVmmlenJzivaS5i3uv6oOtWBNx2tDypANTYQaXV
uDBPuXWlDMdDEHVfZaJFSs6eKDTfomnFMErOXK6uDmqIlwf1B1Td1Ovp/P6B
liTU4rTt/DTspa9f/fDi2Xf+3I0S0lHx8tu1resPH914/PRpJzr3r3p8fP2n
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
/h8ixOpINZgGAA==

-->

</rfc>

