- Created by CBB Admin , last modified on Aug 07, 2020
You are viewing an old version of this page. View the current version.
Compare with Current View Page History
« Previous Version 5 Next »
Restful APIs
The API adheres to RESTful API concepts where possible and sensible to do so.
However, the priority is to have an API that is simple to understand and easy to use. In instances where following RESTful principles would be convoluted and complex, the principles have not been followed.
References:
The highest level Data Description Language used is the JSON Schema : http://json-schema.org/
Best Practice has also been taken from the Data Description Language for APIs; JSON API : http://jsonapi.org/
The Interface Description Language used is the Swagger Specification version 3.0.0 (also known as Open API) : http://swagger.io/
ISO 20022
In keeping with that requirement, the API payloads are designed using the ISO 20022 message elements and components where available.
The principles we have applied to re-use of ISO message elements and components are:
Only elements that are required for the functioning of the API endpoint will be included in the API payload. API endpoints are defined for specific use-cases (not to be generically extensible for all use-cases).
We will modify ISO 20022 elements where the existing standard does not cater for an API context (such as filtering, pagination etc.).
An idempotency key is used to guard against the creation of duplicate resources when using the POST API endpoints (where indicated).
If an idempotency key is required for an API endpoint:
The x-idempotency-key provided in the header must be at most 40 characters in size. If a larger x-idempotency-key length is provided, the ASPSP must reject the request with a status code is 400 (Bad Request).
The AISP/PISP must not change the request body while using the same x-idempotency-key. If the AISP/PISP changes the request body, the ASPSP must not modify the end resource. The ASPSP may treat this as a fraudulent action.
The ASPSP must treat a request as idempotent if it had received the first request with the same x-idempotency-key from the same AISP/PISP in the preceding 24 hours.
The ASPSP must not create a new resource for a POST request if it is determined to be an idempotent request.
The ASPSP must respond to the request with the current status of the resource (or a status which is at least as current as what is available on existing online channels) and a HTTP status code of 201 (Created).
The ASPSP may use the message signature, along with the x-idempotency-key to ensure that the request body has not changed.
If an idempotency key is not required for an API endpoint:
The ASPSP must ignore the idempotency key if provided.
The APIs require TLS 1.2 Mutual Authentication and this may be used as a means of non-repudiation. However, it would be difficult to maintain digital records and evidence of non-repudiation if the API only relied on TLS 1.2.
A solution for non-repudiation that does not rely on TLS, would be achieved by providing a JWS with detached content (as defined in RFC 7515 - Appendix F) in the HTTP header of each API request.
The HTTP body would form an un-encoded payload as defined in RFC 7797.
The JWS would be signed using an algorithm that supports asymmetric keys.
A request would be signed by a AISP/PISP's private key and a response would be signed by the ASPSP's private key.
Not all API requests and responses are signed. Whether message signing is mandatory, supported or not supported is documented along with each API.
Message encryption is implemented through JSON Web Encryption (JWE).
The approach differs from message signing in that:
The entire request or response payload is delivered in the form of an encrypted JWT.
The definition of a given request or response in the Swagger specification represents the decrypted payload.
The JWE will not be represented in its encrypted form in the Swagger specifications.
Sending or expecting to receive an encrypted payload is denoted by setting the Accept or Content-type header to application/jose+jwe.
If an ASPSP does not support message encryption then should reject any requests with a Content-type or Accept headers that indicate that message encryption is required.
A REST resource should have a unique identifier (e.g. a primary key) that may be used to identify the resource. These unique identifiers are used to construct URLs to identify and address specific resources.
However, considering that some of the resources described in these specifications do not have a primary key in the system of record, the Id field will be optional for some resources.
An ASPSP that chooses to populate optional Id fields must ensure that the values are unique and immutable.
The functionality, endpoints and fields within each resource are categorised as 'Mandatory', 'Conditional' or 'Optional'.
Mandatory
Functionality, endpoints and fields marked as Mandatory are required in all cases for regulatory compliance and/or for the API to function and deliver essential customer outcomes.
For functionalities and endpoints:
An ASPSP must implement an endpoint that is marked Mandatory.
An ASPSP must implement functionality that is marked Mandatory.
For fields:
A AISP/PISP must specify the value of a Mandatory field.
An ASPSP must process a Mandatory field when provided by the AISP/PISP in an API request.
An ASPSP must include meaningful values for Mandatory fields in an API response.
Conditional
Functionality, endpoints and fields marked as Conditional may be required in some cases for regulatory compliance (for example, if these are made available to the USER/CUSTOMER in the ASPSP's existing Online Channel, or if ASPSPs (or a subset of ASPSPs) have been mandated by a regulatory requirement).
For functionalities and endpoints:
An ASPSP must implement functionality and endpoints marked as Conditional if these are required for regulatory compliance.
For fields:
All fields that are not marked as Mandatory are Conditional.
A AISP/PISP may specify the value of a Conditional field.
An ASPSP must process a Conditional field when provided by the AISP/PISP in an API request, and must respond with an error if it cannot support a particular value of a Conditional field.
An ASPSP must include meaningful values for Conditional fields in an API response if these are required for regulatory compliance.
Optional
Functionality and endpoints marked as Optional are not necessarily required for regulatory compliance but may be implemented to enable desired customer outcomes.
For functionalities and endpoints:
An ASPSP may implement an Optional endpoint.
An ASPSP may implement Optional functionality.
For fields:
There are no Optional fields.
For any endpoints which are implemented by an ASPSP, the fields are either Mandatory or Conditional.
The API requests and responses must use a UTF-8 character encoding. This is the default character encoding for JSON (RFC 7158 - https://tools.ietf.org/html/rfc7158#section-8.1)
However, an ASPSP's downstream system may not accept some UTF-8 characters, such as emoji characters (e.g. "J" may not be an acceptable Payment Reference). If the ASPSP rejects the message with a UTF-8 character that cannot be processed, the ASPSP must respond with an HTTP 400 (Bad Request) status code.
All date-time fields in responses must include the timezone. For Example:
2020-04-05T10:43:07+03:00 2020-05-03T14:43:41Z |
---|
The API allows the AISP to ask an ASPSP to create a new account-access-consent resource.
All dates in the query string are represented in ISO-8601 date-time format and must not include the timezone. For example:
2020-04-05T10:43:07 2020-04-05 |
---|
All dates in the HTTP headers are represented as RFC 7231 Full Dates. An example is below:
Tue, 10 Mar 2020 19:43:31 GMT+03:00 |
---|
All dates in the JWT claims are expressed as a JSON number, representing the number of seconds from 1970-01-01T0:0:0Z as measured in GMT until the date/time.
//Wed, 12 Feb 2020 14:45:00 GMT+03:00 1581507900 |
---|
The path of the URI must follow the structure below
[participant-path-prefix]/open-banking/[version]/[resource-group]/[resource]/[resource-id]/[sub-resource]
This consists of the following elements:
[participant-path-prefix]
An optional ASPSP specific path prefix.open-banking
The constant string "open-banking".[version]
The version of the APIs expressed as /v[major-version].[minor-version]/.[resource-group]
The resource-group identifies the group of endpoints, to access the API (as "aisp", "pisp").[resource]/[resource-id]
Details the resource.[sub-resource]
Details the sub-resource.
An ASPSP must use the same participant-path-prefix and host name for all its resources.
Examples:
https://xyz.com/apis/open-banking/v1.1/pisp/domestic-payments
https://xyz.com/apis/open-banking/v1.1/aisp/account-access-consents
https://xyz.com/apis/open-banking/v3.1/aisp/accounts
https://xyz.com/apis/open-banking/v3.1/aisp/accounts/1234
https://xyz.com/apis/open-banking/v3.1/aisp/accounts/1234/transactions
Header Value | Notes | POST Requests | GET Requests | DELETE Requests | PUT Requests | PATCH |
x-fapi-auth-date | The time when the User/Customer last logged in with the AISP/PISP. e.g., x-fapi-auth-date: Mon, 11 May 2020 19:43:31 GMT+03:00 | Optional | Optional | Optional | Do not use | Optional |
x-fapi-customer-ip-address | The User’s/Customer’s IP address if the User/Customer is currently logged in with the AISP/PISP. | Optional | Optional | Optional | Do not use | Optional |
x-fapi-interaction-id | An RFC4122 UID used as a correlation Id. | Optional | Optional | Optional | Optional | Optional |
Authorization | Standard HTTP Header; Allows Credentials to be provided to the Authorisation / Resource Server depending on the type of resource being requested. For OAuth 2.0 / OIDC, this comprises of either the Basic / Bearer Authentication Schemes. | Mandatory | Mandatory | Mandatory | Mandatory | Mandatory |
Content-Type | Standard HTTP Header; Represents the format of the payload being provided in the request. | Mandatory | Do not use | Do not use | Mandatory | Mandatory |
Accept | Standard HTTP Header; Determine the Content-Type that is required from the Server. | Optional | Optional | Do not use | Optional | Optional |
x-idempotency-key | Custom HTTP Header; Unique request identifier to support idempotency. | Optional | Do not use | Do not use | Do not use | Do not use |
x-jws-signature | Header containing a detached JWS signature of the body of the payload. | API specific | API specific | API specific | Mandatory | API specific |
x-customer-user-agent | The header indicates the user-agent that the User/Customer is using. | Optional | Optional | Optional | Optional | Optional |
Header Value | Notes | Mandatory? |
Content-Type | Standard HTTP Header; Represents the format of the payload returned in the response. | Mandatory |
x-jws-signature | Header containing a detached JWS signature of the body of the payload. | API specific |
x-fapi-interaction-id | An RFC4122 UID used as a correlation Id. | Mandatory |
Retry-After | Header indicating the time (in seconds) that the AISP/PISP should wait before retrying an operation. | Optional |
The following are the HTTP response codes for the different HTTP methods, across all Read/Write API endpoints.
Situation | HTTP Status | Notes | Returned by POST | Returned by GET | Returned by DELETE | Returned by PUT | Returned by PATCH |
Request completed successfully | 200 OK | PUT will be specified to return the updated resource. A 200 status code is therefore appropriate. | No | Yes | No | Yes | Yes |
Normal execution. The request has succeeded. | 201 Created | The operation results in the creation of a new resource. | Yes | No | No | No | No |
Delete operation completed successfully | 204 No Content |
| No | No | Yes | No | No |
Request has malformed, missing or non-compliant JSON body, URL parameters or header fields. | 400 Bad Request | The requested operation will not be carried out. | Yes | Yes | Yes | Yes | Yes |
Authorization header missing or invalid token | 401 Unauthorized | The operation was refused access. | Yes | Yes | Yes | Yes | Yes |
Token has incorrect scope or a security policy was violated. | 403 Forbidden | The operation was refused access. | Yes | Yes | Yes | Yes | Yes |
The AISP/PISP tried to access the resource with a method that is not defined | 404Not found |
| Yes | Yes | Yes | Yes | Yes |
The AISP/PISP tried to access the resource with a method that is not supported. | 405 Method Not Allowed |
| Yes | Yes | Yes | Yes | Yes |
The request contained an Accept header other than permitted media types and a character set other than UTF-8 | 406 Not Acceptable |
| Yes | Yes | Yes | Yes | Yes |
The operation was refused as too many requests have been made within a certain timeframe. | 429 Too Many Requests | ASPSPs may throttle requests when they are made in excess of their fair usage policy. | Yes | Yes | No | Yes | Yes |
Something went wrong on the API gateway or micro-service | 500 Internal Server Error | The operation failed. | Yes | Yes | Yes | Yes | Yes |
An ASPSP MAY return other standard HTTP status codes (e.g. from gateways and other edge devices) as described in RFC 7231 - Section 6.
ASPSPs must respond with error response in the OAuth/OIDC flow with mandatory alignment of the error codes to those specified in OpenID Connect Core Specification Section 3.1.2.6.
ASPSPs must respond with Open Banking Error Response Structure for all errors during API Calls.
An ASPSP must provide limited support of filtering on GET operations that return multiple records.
The filter parameters, are always specific to particular field(s) of the resource, and follow the rules/formats defined under the resource's data dictionary.
In case of DateTime type filter parameters, values must be specified in ISO8601 format. If the DateTime contains a timezone, the ASPSP may ignore the timezone component.
The filter values will be assumed to refer to the same timezone as the timezone in which the resource is maintained.
An ASPSP MAY provide a paginated response for GET operations that return multiple records.
In such a situation, the ASPSP MUST:
If a subsequent page of resource records exists, the ASPSP must provide a link to the next page of resources in the Links.Next field of the response. The absence of a next link would indicate that the current page is the last page of results.
If a previous page of resource records exists, the ASPSP must provide a link to the previous page of resources in the Links.Prev field of the response. The absence of a prev link would indicate that the current page is the first page of results.
For a paginated responses, the ASPSP may ensure that the number of records on a page are within reasonable limits, the minimum and maximum level for number of records may be decided based on agreement between ASPSP and AISP/PISP.
Additionally, the ASPSP MAY provide:
A link to the first page of results in the Links.First field.
A link to the last page of results in the Links.Last field.
The total number of pages in the Meta.TotalPages field.
As with all other responses, the ASPSP MUST include a "self" link to the resource in the Links.Self field as described in the Links sections.
This standard does not specify how the pagination parameters are passed by the ASPSP and each ASPSP may employ their own mechanisms to paginate the response.
If the original request from the AISP included filter parameters, the paginated response must return only results that match the filter.
ASPSPs are not expected to implement pagination with transaction isolation. The underlying data-set may change between two subsequent requests. This may result in situations where the same transaction is returned on more than one page.
Archiving of resources will be for ASPSPs to define based on their internal Legal and Regulatory requirements.
A number of resources in the specification include a section for Supplementary Data. This is intended to allow ASPSPs to accept or provide information in a request or response that is not catered for by other sections of the resource definition.
The Supplementary Data section is defined as an empty JSON object in the specification.
Wherever used, an ASPSP must define and document (on their developer portal) their own structure, usage and (mandatory/optional) requirements for Supplementary Data.
An ASPSP must not use Supplementary Data if an element already exists in the OBF standard that fulfils the requirement.
This flow assumes that the following steps have been completed successfully:
Step 1: Request Account Information
Step 2: Setup Account Request
Step 3: Authorise Consent
The AISP attempts to provide an expired or missing access token to the ASPSP in an attempt to Request Data
This flow assumes that the following Steps have been completed successfully:
Step 1: Request Account Information
Step 2: Setup Account Request
Step 3: Authorise Consent
The AISP provides a malformed request to the ASPSP in an attempt to setup an Account Request.
This flow assumes that the following Steps have been completed successfully:
Step 1: Request Account Information
Step 2: Setup Account Request
Step 3: Authorise Consent
The AISP provides a (valid) access token which does not have a valid scope (or link to the correct Permissions) to Request Data.
This flow assumes that the following Steps have been completed successfully:
Step 1: Request Account Information
Step 2: Setup Account Request
Step 3: Authorise Consent
The AISP provides a (valid) access token which is used to generate a burst of multiple requests to retrieve an Accounts resource.
The ASPSP may optionally choose to return a 429 Response.
This flow assumes that the following Steps have been completed successfully:
Step 1: Request Account Information
Step 2: Setup Account Request
Step 3: Authorise Consent Flow fails to succeed due to the USER/CUSTOMER providing invalid credentials to the ASPSP, resulting in no Authorization Code being generated.
- No labels