V4 Linking Flow
This API is in BETA
Feedback is appreciated as we improve this flow. If there are any missing functionality that you're expecting reach out to our development team.
The linking flow is 100% optional
This flow is never required to utilize any of our existing checkout or pre-qual experience and is mainly designed so your users can login once and stay logged into your account forever.
Live Demo
You can see a live demo of this at https://demo.slopepay.com/account
Purpose
This new, optional, linking flow is designed for merchants where the user is already securely logged into your app and it is not expected to change their Slope account. This should reduce friction for customers as they would not be required to login to Slope anymore once their account has been linked to your app. The Slope customer may still revoke access to your app anytime from the Slope Buyer Portal.
Notes
Some important callout to be aware of:
- A
linkToken
may be revoked anytime by the user. Your app needs to graceful handle revokes and re-prompt them to re-link again. - Your app must store a mapping based on
userId
and not only oncustomerId
. For example, if you organization has 5 users, each user should independently link to Slope, each with their ownlinkToken
. That way users are not sharing the samelinkToken
and our system can identify the end user performing each request. - Once linked, you will still need to exchange the
linkToken
for anaccessToken
on the backend. This is the only foolproof way of ensuring the identity ofuserId
andcustomerId
accessToken
are short-lived and expire within 4 hours. They should not be stored on your backend and instead generated on the fly when needed to open a Slope modal.- There is currently no redirect flow option for the linking flow and can only be performed as an embedded iframe modal. If you'd like a redirect flow let us know and we can build that as needed!
How to use
- Initiate the link flow by setting
link
as theflow
param inSlope.js
SDK. See Slope.js SDK API for details. If the user grants access, you will receive thelinkToken
response back from theonSuccess
callback.
The publicKey
is your public API Key that is found in your merchant dashboard's developer page
window.SlopeJs.start({
publicKey: 'YOUR_API_PUBLIC_KEY',
flow: 'link',
onSuccess: (resp) => {
console.log('linkToken from Slope is:', resp.linkToken)
},
onFailure: (err) => {
},
onClose: () => {
},
})
- Store the
linkToken
on your backend servers and you will need it indefinitely. ThelinkToken
by itself is useless without your backend API secret to exchange for a short-livedaccessToken
- Exchange the
linkToken
for anaccessToken
by making a POST request to/v4/user-links/{linkToken}/access-token
You can see https://developers.slopepay.com/reference/post_v4-user-links-linktoken-access-token for details. This will return data about the user including theiruserId
andcustomerId
in which both need to be stored properly. - Now, to bypass the login step for any future SlopeJs modal, simply add
accessToken
as a param like this:
window.SlopeJs.start({
code: '{{CHECKOUT_ORDER_CODE}}',
accessToken: '{{ACCESS_TOKEN}}',
onSuccess: (resp) => {
},
onFailure: (err) => {
},
onClose: () => {
},
})
Updated 24 days ago