Working Group: | FAPI | ||
Authors: | Nat Sakimura (Nat.Consulting) |
John Bradley (Yubico) |
Edmund Jay (Illumila) |
Date: | December 18, 2024 |
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.
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.
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 participant). 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 have 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.
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 subject to patent rights. OIDF shall not be held responsible for identifying any or all such patent rights.
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. They are all in lower case to rule out the dictionary meaning use of these words so that they can be translated easily. Following is a summary of the keywords.
Kind | Keywords |
---|---|
Requirement | shall, shall not |
Recommendation | should, should not |
Permission | may |
Possibility | can, cannot |
FAPI 1.0 consists of the following parts:
These parts are intended to be used with RFC6749, RFC6750, RFC7636, and OIDC.
FAPI is a highly secured OAuth profile that aims to provide specific implementation guidelines for security and interoperability. The FAPI security profile can be applied to APIs in any market area that requires a higher level of security than provided by standard OAuth or OpenID Connect. Among other security enhancements, this specification provides a secure alternative to screen scraping. Screen scraping accesses user’s data and functions by impresonating a user through password sharing. 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.
This document is Part 1 of FAPI Security Profile 1.0. It specifies a baseline security profile of OAuth that is suitable for protecting APIs with a moderate inherent risk. Importantly, this profile does not provide non-repudiation (signing of authorization requests and responses) and sender-constrained access tokens. If such features or a higher level of security is desired, the use of FAPI Security Profile 1.0 - Part 2: Advanced is recommended.
Although it is possible to code an OpenID provider and relying party from first principles using this specification, the main audience for this specification is parties who already have a certified implementation of OpenID Connect and want to achieve a higher level of security. Implementers are encouraged to understand the security considerations contained in Section 7.6 before embarking on a ‘from scratch’ implementation.
This document specifies the method for an application to:
The following documents are referred to in the text in such a way that some or all of their content constitutes requirements of this document. For dated references, only the edition cited applies. For undated references, the latest edition of the referenced document (including any amendments) applies.
RFC4122 - A Universally Unique IDentifier (UUID) URN Namespace
RFC6749 - The OAuth 2.0 Authorization Framework
RFC7636 - Proof Key for Code Exchange by OAuth Public Clients
RFC6125 - Representation and Verification of Domain-Based Application Service Identity within Internet Public Key Infrastructure Using X.509 (PKIX) Certificates in the Context of Transport Layer Security (TLS)
BCP212 - OAuth 2.0 for Native Apps
BCP195 - Recommendations for Secure Use of Transport Layer Security (TLS) and Datagram Transport Layer Security (DTLS)
OIDC - OpenID Connect Core 1.0 incorporating errata set 1
RFC8705 - OAuth 2.0 Mutual TLS Client Authentication and Certificate Bound Access Tokens
OIDD - OpenID Connect Discovery 1.0 incorporating errata set 1
RFC7231 - Hypertext Transfer Protocol (HTTP/1.1): Semantics and Content
For the purpose of this document, the terms defined in RFC6749, RFC6750, RFC7636, OpenID Connect Core apply.
API | – | Application Programming Interface |
CAA | – | Certificate Authority Authorization |
CORS | – | Cross-Origin Resource Sharing |
CSRF | – | Cross Site Request Forgery |
DNSSEC | – | Domain Name System Security Extensions |
FAPI | – | FAPI |
HTTP | – | Hyper Text Transfer Protocol |
IP | – | Internet Protocol |
JARM | – | JWT Secured Authorization Response Mode |
JSON | – | JavaScript Object Notation |
JWT | – | JSON Web Token |
OIDF | – | OpenID Foundation |
RP | – | Relying Party |
RSA | – | Rivest–Shamir–Adleman |
REST | – | Representational State Transfer |
TLS | – | Transport Layer Security |
URI | – | Uniform Resource Identifier |
UTF | – | Unicode Transformation Format |
UUID | – | Universally Unique IDentifier |
The OIDF FAPI security profile specifies security requirements for API resources protected by the OAuth 2.0 Authorization Framework that consists of RFC6749, RFC6750, RFC7636, and other specifications.
FAPI Security Profile 1.0 - Part 1: Baseline and Part 2: Advanced specify different levels of security. The characteristics required of the tokens are different and the methods to obtain tokens are explained separately. This document specifies the baseline security provisions.
Some APIs, such as ones that provide potentially sensitive information, require a greater level of protection than basic RFC6749 requires. FAPI provides such greater protection.
As a profile of the OAuth 2.0 Authorization Framework, this document mandates the following to the baseline profile of the FAPI Security Profile 1.0.
A public client
S256
as the code challenge method for the RFC7636;Further, if it is desired to obtain a persistent identifier of the authenticated user, then the public client
openid
in the scope
value;
andnonce
parameter defined in Section
3.1.2.1 of OIDC in
the authentication request.If openid
is not in the scope
value, then
the public client
shall include the state
parameter defined in Section
4.1.1 of RFC6749;
shall verify that the scope
received in the token
response is either an exact match, or contains a subset of the
scope
sent in the authorization request if the request was
passed in the front channel and was not integrity protected;
and
shall only use authorization server metadata obtained from the metadata document published by the authorization server at its well known endpoint as defined in OIDD or RFC8414.
NOTE: Adherence to RFC7636 means that the
token request includes code_verifier
parameter in the
request.
In addition to the provisions for a public client, a confidential client
The FAPI endpoints are OAuth 2.0 protected resource endpoints that return protected information for the resource owner associated with the submitted access token.
The resource server with the FAPI endpoints
shall support the use of the HTTP GET method as in Section 4.3.1 of RFC7231;
shall accept access tokens in the HTTP header as in Section 2.1 of OAuth 2.0 Bearer Token Usage RFC6750;
shall not accept access tokens in the query parameters stated in Section 2.3 of OAuth 2.0 Bearer Token Usage RFC6750;
shall verify that the access token is neither expired nor revoked;
shall verify that the scope associated with the access token authorizes access to the resource it is representing;
shall identify the associated entity to the access token;
shall only return the resource identified by the combination of the entity implicit in the access and the granted scope and otherwise return errors as in Section 3.1 of RFC6750;
shall encode the response in UTF-8 if applicable;
shall send the Content-type
HTTP header
Content-Type: application/json
if applicable;
shall send the server date in HTTP Date header as in Section 7.1.1.2 of RFC7231;
shall set the response header x-fapi-interaction-id
to the value received from the corresponding FAPI client request header
or to a RFC4122 UUID
value if the request header was not provided to track the interaction,
e.g.,
x-fapi-interaction-id: c770aef3-6784-41f7-8e0e-ff5f97bddb3a
;
shall log the value of x-fapi-interaction-id
in the
log entry; and
shall not reject requests with a
x-fapi-customer-ip-address
header containing a valid IPv4
or IPv6 address.
NOTE: While this document does not specify the exact method to obtain the entity associated with the access token and the granted scope, the protected resource can use OAuth Token Introspection RFC7662.
Further, the resource server
should support the use of Cross Origin Resource Sharing (CORS) [CORS] and or other methods as appropriate to enable JavaScript clients to access the endpoint if it decides to provide access to JavaScript clients.
NOTE: Providing access to JavaScript clients has other security implications. Before supporting those clients RFC6819 should be consulted.
The client supporting this document
shall send access tokens in the HTTP header as in Section 2.1 of OAuth 2.0 Bearer Token Usage RFC6750; and
(withdrawn);
Further, the client
may send the last time the customer logged into the client in the
x-fapi-auth-date
header where the value is supplied as a
HTTP-date as in Section 7.1.1.1 of RFC7231, e.g.,
x-fapi-auth-date: Tue, 11 Sep 2012 19:43:31 GMT
;
may send the customer’s IP address if this data is available in
the x-fapi-customer-ip-address
header, e.g.,
x-fapi-customer-ip-address: 2001:DB8::1893:25c8:1946
or
x-fapi-customer-ip-address: 198.51.100.119
; and
may send the x-fapi-interaction-id
request header,
in which case the value shall be a RFC4122 UUID to the server to help
correlate log entries between client and server, e.g.,
x-fapi-interaction-id: c770aef3-6784-41f7-8e0e-ff5f97bddb3a
.
As confidential information is being exchanged, all interactions shall be encrypted with TLS (HTTPS).
The recommendations for Secure Use of Transport Layer Security in BCP195 shall be followed, with the following additional requirements:
Endpoints for the use by web browsers should use mechanisms to ensure
that connections cannot be downgraded using TLS stripping attacks. A
preloaded HTTP Strict Transport Security policy (see PRELOAD and RFC6797) can be used for
this purpose. Some top-level domains, like .bank
and
.insurance
, have set such a policy and therefore protect
all second-level domains below them.
For a comprehensive protection against network attackers, all endpoints should additionally use DNSSEC to protect against DNS spoofing attacks that can lead to the issuance of rogue domain-validated TLS certificates.
NOTE: Even if an endpoint uses only organization validated (OV) or extended validation (EV) TLS certificates, rogue domain-validated certificates can be used to impersonate the endpoints and conduct man-in-the-middle attacks. CAA records RFC8659 can help to mitigate this risk.
Authorization request and response are not authenticated. For higher risk scenarios, they should be authenticated. See FAPI Security Profile 1.0 - Part 2: Advanced, which uses request objects to achieve the message source authentication.
The authorization request does not have message integrity protection and hence request tampering and parameter injection are possible. Where such protection is desired, FAPI Security Profile 1.0 - Part 2: Advanced should be used.
The response is integrity protected when the ID Token is returned from the authorization endpoint.
It is possible to leak information through the logs if the parameters were recorded in the logs and the access to the logs are compromised. Strict access control to the logs in such cases should be enforced.
Care should be taken so that the sensitive data will not be leaked through the referrer.
If the access token is a bearer token, it is possible to exercise the stolen token. Since the access token can be used against multiple URIs, the risk of leaking is much larger than the refresh token, which is used only against the token endpoint. Thus, the lifetime of the access token should be much shorter than that of the refresh token. Refer to Section 16.18 of OIDC for more discussion on the lifetimes of access tokens and refresh tokens.
When native apps are used as either public clients, dynamically registered confidential clients or user-agents receiving the authorization response for a server based confidential client, the recommendations for OAuth 2.0 for Native Apps in BCP212 shall be followed, with the following additional requirements:
When registering redirect URIs, authorization servers
These requirements mean that FAPI Security Profile 1.0 compliant implementations can only support native apps through the use of “claimed HTTPS scheme URI redirection”.
NOTE: Nothing in this document seeks to disallow fixed urls in the form https://localhost:port-number/callback, as these are particularly useful in non-production systems or in clients used in development, to facilitate faster and easier development.
To achieve the full security benefits, it is important the implementation of this specification, and the underlying OpenID Connect and OAuth specifications, are both complete and correct.
The OpenID Foundation provides tools that can be used to confirm that an implementation is correct:
https://openid.net/certification/
The OpenID Foundation maintains a list of certified implementations:
https://openid.net/developers/certified/
Deployments that use this specification should use a certified implementation.
Organizations who need to support multiple “brands” with individual
authorization endpoints from a single authorization server deployment
shall use a separate issuer
per brand. This can be achieved
either at the domain level
(e.g. https://brand-a.auth.example.com
and
https://brand-b.auth.example.com
) or with different paths
(e.g. https://auth.example.com/brand-a
and
https://auth.example.com/brand-b
)
As stated in 5.2.2.0-22 clients shall only use metadata values obtained via metadata documents as defined in OIDD. Communicating metadata through other means (e.g. via email) opens up a social engineering attack vector.
Note that the requirement to use OIDD is not a requirement to support dynamic client registration.
There are many factors to be considered in terms of privacy when implementing this document. However, since this document is a profile of OAuth and OpenID Connect, all of them are generic and apply to OAuth or OpenID Connect and are not specific to this document. Implementers are advised to perform a thorough privacy impact assessment and manage identified risks appropriately.
NOTE: Implementers can consult documents like ISO29100 and [ISO29134] for this purpose.
Privacy threats to OAuth and OpenID Connect implementations include the following:
policy_url
or by other means can be inappropriate.These threats can be mitigated by choosing appropriate options in
OAuth or OpenID, or by introducing some operational rules. For example,
“attacker observing personal data in authorization request” can be
mitigated by either using authorization request by reference using
request_uri
or by encrypting the request object. Similarly,
“attacker observing personal data in authorization endpoint response”
can be mitigated by encrypting the ID Token or JARM
response.
The following people contributed to this document:
[ISODIR2] - ISO/IEC Directives, Part 2 - Principles and rules for the structure and drafting of ISO and IEC documents [ISODIR2]: https://www.iso.org/sites/directives/current/part2/index.xhtml
ISO29100 ISO/IEC 29100 Information technology — Security techniques — Privacy framework
Copyright (c) 2023 The OpenID Foundation.
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.
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.