Implementation Guide
Getting Started
Customers who want to make use of the nrich API for Financial Data are just three API calls away from getting access to the financial data of their users.
- Create a Widget link for one-time account information access
- Exchange an authorization code for an access token
- Fetching the financial data
1. Flow initiation
{
"redirect_uri": "https://my-app.example.com/callback",
"language": "de",
"accounts": [],
"sync_period": 90
}
Please note that the redirect_uri
is the only mandatory parameter as it will lead the user back to your application. All other parameters are optional, but some will have a direct effect on the user flow.
To shorten the flow for your users and achieve maximum conversion, we highly recommend to use the accounts
parameter. In case the IBAN or other information (e.g. Account Number or PAN) of the users are known they can be passed on as an account id
.
"accounts": [
{ "id": "DE82900948150000002881" }
]
To optimize conversion, you might consider asking the user for their account details before initiating the widget. This will allow the user to skip the bank selection screen and they will be prompted to directly authorize with their bank.
The sync_period
defines the number of days of transaction history requested from the financial institution. The default value is set to 90
but can be set higher depending on the use case.
{
"location": "https://finx.finleap.cloud/?token=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJoYWhhIjoiaSBtYWRlIHlvdSBsb29rIn0.jk1WqP6S28bNuP5MwwlZHR_5GlksWsEZPMztWUAIiJY",
"id": "3ca31c37-986a-454e-ad64-8e97143c86bc"
}
Forward the user to the location
provided in the WidgetLink response. This can be achieved by using:
- an Overlay/PopUp iframe
- a redirect in the same or a new window
The Widget UI will guide the user through the process of selecting the financial sources they want to provide access to. We will then fetch the financial data associated with the user's selection.
Read more about the Widget UI integration here
Looking for ongoing access instead?
In case you would like to initiate an ongoing account access please review the Multibanking Implementation Guide
2. Exchange authorization code
After successful completion of the flow, users are redirected to your specified redirect_uri
with the following query parameters:
state
: Your provided identifier to maintain session state and identify the returning usersuccess
: Boolean indicating successful flow completioncode
: Authorization code valid for 1 hour, used to obtain an access token (only present on successful completion)cancel
: Boolean indicating if the user canceled the flow (only present when canceled)flow_id
: Unique identifier for accessing flow-specific resources
https://example.com/callback?code=eyJhbGciO...&state=7fe78733&success=true&flow_id=3ca31c37-...
Exchanging the Code for Tokens
Request an access token by calling POST /auth/token with the following payload
// Request
{
"grant_type": "authorization_code",
"code": "eyJhbGciOiJIUzI1NiIsInR5cCI6Ikp...",
"redirect_uri": "https://my-app.example.com/callback"
}
// Response
{
"access_token": "AoFmNJLDTW8jQtGSJ1iZeeoLiwNZ2ihz3iiCHGpuvE439nppuY...",
"expires_in": 3600,
"scope": "accounts=ro balance=ro transactions=ro offline",
"token_type": "Bearer",
"refresh_token": "RTfI2WNyK78NozupDH9ai8GPRbjjdVsXPPt..."
}
Using and Maintaining Tokens
- Include the
access_token
in theAuthorization
header for all API requests - For ongoing access, store the
refresh_token
securely - Each refresh token usage returns a new refresh token that must replace the previous one
- Access is revoked if:
- No user activity occurs within 90 days
- The refresh token isn't regularly renewed
Token lengths
Token lengths can vary. Avoid fixed-size database fields for storing tokens. If a size limit is required, allocate at least 2048 bytes per token field.
Token lifetimes
Type | Lifetime |
---|---|
Authorization code | 1 hour |
Access token | 1 hour |
Refresh token | 90 days |
3. Fetch financial data
Please view the Fetching Account & Transaction Data section for a detailed overview.
Updated 14 days ago