<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0, user-scalable=yes">
<title>Financial_API_JWT_Secured_Authorization_Response_Mode</title>
<style type="text/css">
body {
font-family: Helvetica, arial, sans-serif;
font-size: 14px;
line-height: 1.6;
padding-top: 10px;
padding-bottom: 10px;
background-color: white;
padding: 30px; }
body > *:first-child {
margin-top: 0 !important; }
body > *:last-child {
margin-bottom: 0 !important; }
a {
color: #4183C4; }
a.absent {
color: #cc0000; }
a.anchor {
display: block;
padding-left: 30px;
margin-left: -30px;
cursor: pointer;
position: absolute;
top: 0;
left: 0;
bottom: 0; }
h1, h2, h3, h4, h5, h6 {
margin: 20px 0 10px;
padding: 0;
font-weight: bold;
-webkit-font-smoothing: antialiased;
cursor: text;
position: relative; }
h1:hover a.anchor, h2:hover a.anchor, h3:hover a.anchor, h4:hover a.anchor, h5:hover a.anchor, h6:hover a.anchor {
background: url() no-repeat 10px center;
text-decoration: none; }
h1 tt, h1 code {
font-size: inherit; }
h2 tt, h2 code {
font-size: inherit; }
h3 tt, h3 code {
font-size: inherit; }
h4 tt, h4 code {
font-size: inherit; }
h5 tt, h5 code {
font-size: inherit; }
h6 tt, h6 code {
font-size: inherit; }
h1 {
font-size: 28px;
color: black; }
h2 {
font-size: 24px;
border-bottom: 1px solid #cccccc;
color: black; }
h3 {
font-size: 18px; }
h4 {
font-size: 16px; }
h5 {
font-size: 14px; }
h6 {
color: #777777;
font-size: 14px; }
p, blockquote, ul, ol, dl, li, table, pre {
margin: 15px 0; }
hr {
background: transparent url() repeat-x 0 0;
border: 0 none;
color: #cccccc;
height: 4px;
padding: 0;
}
body > h2:first-child {
margin-top: 0;
padding-top: 0; }
body > h1:first-child {
margin-top: 0;
padding-top: 0; }
body > h1:first-child + h2 {
margin-top: 0;
padding-top: 0; }
body > h3:first-child, body > h4:first-child, body > h5:first-child, body > h6:first-child {
margin-top: 0;
padding-top: 0; }
a:first-child h1, a:first-child h2, a:first-child h3, a:first-child h4, a:first-child h5, a:first-child h6 {
margin-top: 0;
padding-top: 0; }
h1 p, h2 p, h3 p, h4 p, h5 p, h6 p {
margin-top: 0; }
li p.first {
display: inline-block; }
li {
margin: 0; }
ul, ol {
padding-left: 30px; }
ul :first-child, ol :first-child {
margin-top: 0; }
dl {
padding: 0; }
dl dt {
font-size: 14px;
font-weight: bold;
font-style: italic;
padding: 0;
margin: 15px 0 5px; }
dl dt:first-child {
padding: 0; }
dl dt > :first-child {
margin-top: 0; }
dl dt > :last-child {
margin-bottom: 0; }
dl dd {
margin: 0 0 15px;
padding: 0 15px; }
dl dd > :first-child {
margin-top: 0; }
dl dd > :last-child {
margin-bottom: 0; }
blockquote {
border-left: 4px solid #dddddd;
padding: 0 15px;
color: #777777; }
blockquote > :first-child {
margin-top: 0; }
blockquote > :last-child {
margin-bottom: 0; }
table {
padding: 0;border-collapse: collapse; }
table tr {
border-top: 1px solid #cccccc;
background-color: white;
margin: 0;
padding: 0; }
table tr:nth-child(2n) {
background-color: #f8f8f8; }
table tr th {
font-weight: bold;
border: 1px solid #cccccc;
margin: 0;
padding: 6px 13px; }
table tr td {
border: 1px solid #cccccc;
margin: 0;
padding: 6px 13px; }
table tr th :first-child, table tr td :first-child {
margin-top: 0; }
table tr th :last-child, table tr td :last-child {
margin-bottom: 0; }
img {
max-width: 100%; }
span.frame {
display: block;
overflow: hidden; }
span.frame > span {
border: 1px solid #dddddd;
display: block;
float: left;
overflow: hidden;
margin: 13px 0 0;
padding: 7px;
width: auto; }
span.frame span img {
display: block;
float: left; }
span.frame span span {
clear: both;
color: #333333;
display: block;
padding: 5px 0 0; }
span.align-center {
display: block;
overflow: hidden;
clear: both; }
span.align-center > span {
display: block;
overflow: hidden;
margin: 13px auto 0;
text-align: center; }
span.align-center span img {
margin: 0 auto;
text-align: center; }
span.align-right {
display: block;
overflow: hidden;
clear: both; }
span.align-right > span {
display: block;
overflow: hidden;
margin: 13px 0 0;
text-align: right; }
span.align-right span img {
margin: 0;
text-align: right; }
span.float-left {
display: block;
margin-right: 13px;
overflow: hidden;
float: left; }
span.float-left span {
margin: 13px 0 0; }
span.float-right {
display: block;
margin-left: 13px;
overflow: hidden;
float: right; }
span.float-right > span {
display: block;
overflow: hidden;
margin: 13px auto 0;
text-align: right; }
code, tt {
margin: 0 2px;
padding: 0 5px;
white-space: nowrap;
border: 1px solid #eaeaea;
background-color: #f8f8f8;
border-radius: 3px; }
pre code {
margin: 0;
padding: 0;
white-space: pre;
border: none;
background: transparent; }
.highlight pre {
background-color: #f8f8f8;
border: 1px solid #cccccc;
font-size: 13px;
line-height: 19px;
overflow: auto;
padding: 6px 10px;
border-radius: 3px; }
pre {
background-color: #f8f8f8;
border: 1px solid #cccccc;
font-size: 13px;
line-height: 19px;
overflow: auto;
padding: 6px 10px;
border-radius: 3px; }
pre code, pre tt {
background-color: transparent;
border: none; }
sup {
font-size: 0.83em;
vertical-align: super;
line-height: 0;
}
kbd {
display: inline-block;
padding: 3px 5px;
font-size: 11px;
line-height: 10px;
color: #555;
vertical-align: middle;
background-color: #fcfcfc;
border: solid 1px #ccc;
border-bottom-color: #bbb;
border-radius: 3px;
box-shadow: inset 0 -1px 0 #bbb
}
* {
-webkit-print-color-adjust: exact;
}
@media screen and (min-width: 914px) {
body {
width: 854px;
margin:0 auto;
}
}
@media print {
table, pre {
page-break-inside: avoid;
}
pre {
word-wrap: break-word;
}
}
</style>
</head>
<body>
<h1 id="toc_0">Financial Services – Financial API: JWT Secured Authorization Response Mode for OAuth 2.0</h1>
<h2 id="toc_1">Warning</h2>
<p>This document is not an OIDF International Standard. It is distributed for review and comment. It is subject to change without notice and may not be referred to as an International Standard.</p>
<p>Recipients of this draft are invited to submit, with their comments, notification of any relevant patent rights of which they are aware and to provide supporting documentation.</p>
<h2 id="toc_2">Copyright notice & license</h2>
<p>The OpenID Foundation (OIDF) grants to any Contributor, developer, implementer, or other interested party a non-exclusive, royalty free, worldwide copyright license to reproduce, prepare derivative works from, distribute, perform and display, this Implementers Draft or Final Specification solely for the purposes of (i) developing specifications, and (ii) implementing Implementers Drafts and Final Specifications based on such documents, provided that attribution be made to the OIDF as the source of the material, but that such attribution does not indicate an endorsement by the OIDF.</p>
<p>The technology described in this specification was made available from contributions from various sources, including members of the OpenID Foundation and others. Although the OpenID Foundation has taken steps to help ensure that the technology is available for distribution, it takes no position regarding the validity or scope of any intellectual property or other rights that might be claimed to pertain to the implementation or use of the technology described in this specification or the extent to which any license under such rights might or might not be available; neither does it represent that it has made any independent effort to identify any such rights. The OpenID Foundation and the contributors to this specification make no (and hereby expressly disclaim any) warranties (express, implied, or otherwise), including implied warranties of merchantability, non-infringement, fitness for a particular purpose, or title, related to this specification, and the entire risk as to implementing this specification is assumed by the implementer. The OpenID Intellectual Property Rights policy requires contributors to offer a patent promise not to assert certain patent claims against other contributors and against implementers. The OpenID Foundation invites any interested party to bring to its attention any copyrights, patents, patent applications, or other proprietary rights that may cover technology that may be required to practice this specification.</p>
<h2 id="toc_3">Foreword</h2>
<p>The OpenID Foundation (OIDF) promotes, protects and nurtures the OpenID community and technologies. As a non-profit international standardizing body, it is comprised by over 160 participating entities (workgroup participants). The work of preparing implementer drafts and final international standards is carried out through OIDF workgroups in accordance with the OpenID Process. Participants interested in a subject for which a workgroup has been established has the right to be represented in that workgroup. International organizations, governmental and non-governmental, in liaison with OIDF, also take part in the work. OIDF collaborates closely with other standardizing bodies in the related fields.</p>
<p>Final drafts adopted by the Workgroup through consensus are circulated publicly for the public review for 60 days and for the OIDF members for voting. Publication as an OIDF Standard requires approval by at least 50 % of the members casting a vote. There is a possibility that some of the elements of this document may be the subject to patent rights. OIDF shall not be held responsible for identifying any or all such patent rights.</p>
<p>Financial API consists of the following parts:</p>
<ul>
<li>Part 1: Read-Only API Security Profile</li>
<li>Part 2: Read and Write API Security Profile</li>
<li>Part 3: Client Initiated Backchannel Authentication Profile</li>
</ul>
<p>Future parts may follow.</p>
<p>These parts are intended to be used with <a href="https://tools.ietf.org/html/rfc6749">RFC6749</a>, [RFC6750], [RFC7636], and <a href="http://openid.net/specs/openid-connect-core-1_0.html">OIDC</a>.</p>
<h2 id="toc_4">Introduction</h2>
<p>Fintech is an area of future economic growth around the world and Fintech organizations need to improve the security of their operations and protect customer data. It is common practice of aggregation services to use screen scraping as a method to capture data by storing users' passwords. This brittle, inefficient, and insecure practice creates security vulnerabilities which require financial institutions to allow what appears to be an automated attack against their applications and to maintain a whitelist of aggregators. A new draft standard, proposed by this workgroup would instead utilize an API model with structured data and a token model, such as OAuth [RFC6749, RFC6750].</p>
<p>The Financial API aims to provide specific implementation guidelines for online financial services to adopt by developing a REST/JSON data model protected by a highly secured OAuth profile.</p>
<p>This document defines the new mode "jwt" for responses from the authorization endpoint of an authorization server. The response mode "jwt" enables clients to request the transmission of the credentials issued by the authorization server along with additional data in JWT format. This mechanism enhances the security of the standard authorization response since it adds sender authentication, audience restriction as well as protection from replay, credential leakage, and mix-up attacks. </p>
<h3 id="toc_5">Notational Conventions</h3>
<p>The keywords "shall", "shall not",
"should", "should not", "may", and
"can" in this document are to be interpreted as described in
ISO Directive Part 2 [ISODIR2].
These keywords are not used as dictionary terms such that
any occurrence of them shall be interpreted as keywords
and are not to be interpreted with their natural language meanings.</p>
<h1 id="toc_6">**Financial Services – Financial API: JWT Secured Authorization Response Mode for OAuth 2.0 **</h1>
<p>[TOC]</p>
<h2 id="toc_7">1. Normative references</h2>
<p>The following referenced documents are indispensable for the application of this document. For dated references, only the edition cited applied. For undated references, the latest edition of the referenced document (including any amendments) applies.</p>
<p><a href="https://tools.ietf.org/html/rfc7230">RFC7230</a> - Hypertext Transfer Protocol -- HTTP/1.1</p>
<p><a href="https://tools.ietf.org/html/rfc6749">RFC6749</a> - The OAuth 2.0 Authorization Framework</p>
<p><a href="https://tools.ietf.org/html/rfc6819">RFC6819</a> - OAuth 2.0 Threat Model and Security Considerations</p>
<p><a href="https://tools.ietf.org/html/rfc7519">RFC7519</a> - JSON Web Token (JWT)</p>
<p><a href="https://tools.ietf.org/html/bcp195">BCP195</a> - Recommendations for Secure Use of Transport Layer Security (TLS) and Datagram Transport Layer Security (DTLS)</p>
<p><a href="http://openid.net/specs/openid-connect-core-1_0.html">OIDC</a> - OpenID Connect Core 1.0 incorporating errata set 1</p>
<p><a href="http://openid.net/specs/openid-connect-discovery-1_0.html">OIDD</a> - OpenID Connect Discovery 1.0 incorporating errata set 1</p>
<p><a href="http://openid.net/specs/oauth-v2-multiple-response-types-1_0.html">OIDM</a> - OAuth 2.0 Multiple Response Type Encoding Practices</p>
<p><a href="https://tools.ietf.org/html/draft-ietf-oauth-security-topics">draft-ietf-oauth-security-topics</a> - OAuth 2.0 Security Best Current Practice</p>
<h2 id="toc_8">2. Terms and definitions</h2>
<p>For the purpose of this document, the terms defined in <a href="https://tools.ietf.org/html/rfc6749">RFC6749</a>, [RFC6750], [RFC7636], <a href="http://openid.net/specs/openid-connect-core-1_0.html">OpenID Connect Core</a> apply.</p>
<h2 id="toc_9">3. Symbols and Abbreviated terms</h2>
<p><strong>API</strong> – Application Programming Interface</p>
<p><strong>CSRF</strong> - Cross Site Request Forgery</p>
<p><strong>FAPI</strong> - Financial API</p>
<p><strong>FI</strong> – Financial Institution</p>
<p><strong>HTTP</strong> – Hyper Text Transfer Protocol</p>
<p><strong>OIDF</strong> - OpenID Foundation</p>
<p><strong>REST</strong> – Representational State Transfer</p>
<p><strong>TLS</strong> – Transport Layer Security</p>
<h2 id="toc_10">4. Response Mode "jwt"</h2>
<p>This draft defines the additional response mode "jwt" for OAuth authorization requests in accordance with <a href="http://openid.net/specs/oauth-v2-multiple-response-types-1_0.html">OIDM</a>. The response mode "jwt" causes the authorization server to encode the authorization response as a JWT. </p>
<h3 id="toc_11">4.1. The JWT Response Document</h3>
<p>The JWT contains the credentials issued for a particular response type along with the following additional data utilized to secure the transmission:</p>
<ul>
<li><code>iss</code> - the issuer URL of the authorization server that created the response</li>
<li><code>aud</code> - the client_id of the client the response is intended for</li>
<li><code>exp</code> - experation of the JWT</li>
<li><code>s_hash</code> - the hash of the state value as defined in FAPI Part 2</li>
</ul>
<p>The "state" parameter value is not included in the JWT because it functions as trust anchor to identify and check the authenticity of the authorization response <em>before</em> the JWT is processed by the client. The <code>s_hash</code> claim of the JWT will provide a cryptographically protected binding between the state and the response parameters. </p>
<p>When used in conjunction with the response type "code", the code is conveyed as additional field "code" of the JWT. The following is an example JWT:</p>
<div><pre><code class="language-none">{
"iss":"https://accounts.example.com",
"aud":"s6BhdRkqt3",
"exp":1311281970,
"s_hash":"44D41668D199FF3D525FA357A25525D738AADF2A7B1E2C819A39E38500ABAED9",
"code":"PyyFaux2o7Q0YfXBU32jhw.5FXSQpvr8akv9CeRDSd0QA"
}</code></pre></div>
<p>Note: The response mode "jwt" can be combined with other response types, the respective syntax and behavior is out of scope of this draft.</p>
<p>The JWT may be signed or signed & encrypted. If the JWT is both signed and encrypted, the JSON document will be signed then encrypted, with the result being a Nested JWT, as defined in <a href="https://tools.ietf.org/html/rfc7519">RFC7519</a>.</p>
<h3 id="toc_12">4.2 The JWT Secured Response</h3>
<p>The response mode "jwt" causes the authorization server to add two parameters to the redirect to the client:</p>
<ul>
<li>state - the state value as specified in <a href="https://tools.ietf.org/html/rfc6749">RFC6749</a></li>
<li>response - the JWT as defined in section 4.1</li>
</ul>
<p>This is an example response: </p>
<div><pre><code class="language-none">GET /cb?state=S8NJ7uqk5fY4EjNvP_G_FtyJu6pUsvH9jsYni9dMAJw&
response=eyJhbGciOiJSUzI1NiIsInR5cCI6IkpXVCJ9.eyJpc3MiOiJodHRwczovL2FjY291bnR
zLmV4YW1wbGUuY29tIiwiYXVkIjoiczZCaGRSa3F0MyIsImp0aSI6IjI3MzBkYzJmLWM5YzYtNGJl
NC05N2M5LTYyMjNkMThmMmIxMyIsIm5vbmNlIjoibi0wUzZfV3pBMk1qIiwiZXhwIjoxMzExMjgxO
TcwLCJjX2hhc2giOiI0NDIyRTBFMDk0RjM0RTk3Qzg1MkVCNUY5QjI4MzlEODEyMDA2NkMyN0VGNj
ZBQTI4QzNEREM3Q0U3QTc5ODE1Iiwic19oYXNoIjoiNDRENDE2NjhEMTk5RkYzRDUyNUZBMzU3QTI
1NTI1RDczOEFBREYyQTdCMUUyQzgxOUEzOUUzODUwMEFCQUVEOSJ9.ldPh3w3QAkkbz3voa3F2pvr
uWQwNBv3AYV9xpcuVLZi5Da4tjepxayjO4_flznYuu9EZbyYA1lb9uzu0rSSSiwEJ5Ms9ZEvB4l1x
XNLT5TRV00erXb6Y1JsvxHjanB0I8-FUHdP-HMA0Zhg9UVohAc2qiO6wDcEfi5y_1fST4Y
Host: client.example.com</code></pre></div>
<h3 id="toc_13">4.3 Processing rules</h3>
<p>The client is obliged to process the JWT secured response as follows:</p>
<p>Assumption: the client stored the issuer it sent the authorization request to and is also able to obtain the key material to check the JWT's signature and, if needed, to decrypt the JWT independent of the JWT in the authorization response.</p>
<ol>
<li>The "state" parameter MUST be checked to be linked to the user agent's local state in order to prevent CSRF. Note: The state value is treated as a one-time-use XSRF token. It MUST be invalidated after the check was performed.</li>
<li>(OPTIONAL) The JWT is decrypted using the key material registered with the expected issuer of the response. </li>
<li>Check the signature of the JWT using the JWK set of the expected issuer. Note: the client MUST obtain the JWK set from local data and MUST NOT follow the <code>iss</code> claim of the JWT to obtain key material. This is done to prevent DoS (see Security Considerations) </li>
<li>Check whether the JWT's <code>iss</code> claim matches the expected <code>iss</code> value of the local state (set before the authorization request was sent). </li>
</ol>
<h2 id="toc_14">6. Security considerations</h2>
<h3 id="toc_15">6.1 DoS using specially crafted JWTs</h3>
<p>JWTs could be crafted to have an issuer that resolves to a JWK set URL with
huge content, or is delivered very slowly, consuming server networking
bandwidth and compute capacity. The resolved JWK set URL could also be used to
DDoS targets on the web.</p>
<p>The client therefore MUST use key material obtained independent of the JWT from a secure source to check its signature. </p>
<h3 id="toc_16">6.2 Code Replay</h3>
<p>An authorization code (obtained on a different device with the same client) could be injected into an authorization response in order to impersonate the legitimate resource owner (see <a href="https://tools.ietf.org/html/draft-ietf-oauth-security-topics">draft-ietf-oauth-security-topics</a>). </p>
<p>The JWT secured response mode enables clients to detect such an attack. The signature binds the authorization code to the state value sent by the client and therewith transitively to the respective user agent.</p>
<h3 id="toc_17">6.3 Mix-Up</h3>
<p>Mix-up is an attack on scenarios where an OAuth client interacts with
multiple authorization servers. The goal of the attack is to obtain an
authorization code or an access token by tricking the client into
sending those credentials to the attacker instead of using them at
the respective endpoint at the authorization/resource server.</p>
<p>The JWT secured response mode enables clients to detect this attack by providing an identification of the sender (<code>iss</code>) and the intended audience of the authorization response (<code>aud</code>). </p>
<h3 id="toc_18">6.5 Code Leakage</h3>
<p>Authorization servers MAY encrypt the authorization response therewith providing a mechanism to prevent leakage of authorization codes in the user agent. </p>
<h2 id="toc_19">7. Privacy considerations</h2>
<p>TBD</p>
<h2 id="toc_20">10. Acknowledgement</h2>
<p>The following people contributed to this document:</p>
<ul>
<li>Torsten Lodderstedt (YES), Editor</li>
<li>Nat Sakimura (Nomura Research Institute) -- Chair</li>
<li>Dave Tonge (Momentum Financial Technology) -- UK Implementation Entity Liaison</li>
<li>Joseph Heenan (Authlete)</li>
<li>Tom Jones (Independent)</li>
<li>Ralph Bragg (Raidiam)</li>
<li>Brian Campbell (Ping Identity)</li>
<li>Vladimir Dzhuvinov (Connect2ID)</li>
</ul>
<h2 id="toc_21">11. Bibliography</h2>
<ul>
<li>[OFX2.2] Open Financial Exchange 2.2</li>
<li>[HTML4.01] “HTML 4.01 Specification,” World Wide Web Consortium Recommendation REC-html401-19991224, December 1999</li>
<li>[RFC7662] OAuth 2.0 Token Introspection</li>
<li>[DDA] Durable Data API, (2015), FS-ISAC</li>
<li>[SoK] Mainka, C., Mladenov, V., Schwenk, J., and T. Wich: SoK: Single Sign-On Security – An Evaluation of OpenID Connect</li>
</ul>
</body>
</html>