Auth Code SCA
If you are creating users using authorization code or registration code to integrate with our API, then this is the right place.
When making a request to an SCA protected endpoint, a 403 Forbidden HTTP status code is returned together with a one-time token (OTT).
Your customer will now expect to authenticate themselves by entering their Wise password as well as an OTP code.
We created a library to make your integration easier. There's also a sample app showcasing how to use that library.
Below is a sequence diagram showing this flow.
Here is a step-by-step workflow with example commands to process a payment (which may vary slightly depending on the exact versions of utilities used).
Similar example is also available in our code samples repository.
Your customer makes a request which requires strong authentication. The call is made using our SCA helper library from your frontend.
import { create, Mode } from '@transferwise/approve-api-action-helpers';const request = create({ mode: Mode.PRODUCTION });const res = await request('/tw-fund-payment', { method: 'POST', data: { ... } });
Your server forwards the request to Wise Platform API.
$ curl -i -X POST 'https://api.sandbox.transferwise.tech/v3/profiles/{profileId}/transfers/{transferId}/payments' \-H 'Content-Type: application/json' \-H 'Authorization: Bearer <your api token>' \-d '{"type": "BALANCE"}'
The request is declined with HTTP status 403 / Forbidden
with the following response headers
X-2FA-Approval-Result
:REJECTED
X-2FA-Approval
containing the one-time token (OTT) value which is what needs to be signed
HTTP/1.1 403 ForbiddenDate: Fri, 03 Jan 2020 12:34:56 GMTContent-Type: application/json;charset=UTF-8x-2fa-approval-result: REJECTEDx-2fa-approval: be2f6579-9426-480b-9cb7-d8f1116cc8b9...{"timestamp": "2020-01-03T12:34:56.789+0000","status": 403,"error": "Forbidden","message": "You are forbidden to send this request","path": "/v3/profiles/{profileId}/transfers/{transferId}/payments"}
Your server reflects the response status and the header
x-2fa-approval
back to your frontend.Our frontend library now understands that SCA is required and asks the customer to pass challenges (such as password).
When customer has completed challenges, our frontend library automatically triggers the initial call (1) again, but this time it includes the OTT (
x-2fa-approval
header) and sends it to your backend.
$ curl -i -X POST 'https://api.sandbox.transferwise.tech/v3/profiles/{profileId}/transfers/{transferId}/payments' \-H 'Content-Type: application/json' \-H 'Authorization: Bearer <your api token>' \-H 'x-2fa-approval: be2f6579-9426-480b-9cb7-d8f1116cc8b9' \-d '{"type": "BALANCE"}'
Your server repeats the initial request above with the addition of the one-time token.
HTTP/1.1 200 OKDate: Fri, 03 Jan 2020 12:34:56 GMTContent-Type: application/json;charset=UTF-8x-2fa-approval-result: APPROVED{"type": "BALANCE","status": "COMPLETED","errorCode": null}
Customer has authenticated and the action is completed. You will receive a response with x-2fa-approval-result
status APPROVED
in headers.
In case you would love to provide a customized experience to your user.
You can explore the one time token feature on how you can use our SCA APIs.