Recurring API extended Postman guide
This is a guide for the using the Recurring API with Postman, and is an extension of the Recurring API quick start guide which shows the recommended flow in both Postman and curl.
Setup
You must have already signed up as an organization with Vipps MobilePay and have your API keys. See Getting started guide for help.
Get these API key values for your sales unit (How to find the API keys):
client_id
- Client_id for a test sales unit.client_secret
- Client secret for a test sales unit.Ocp-Apim-Subscription-Key
- Subscription key for a test sales unit.merchantSerialNumber
- The unique ID for a test sales unit.
You will also need:
mobileNumber
- The phone number for the test app profile you have received or registered.
🔥 Do not store production keys in the Postman cloud. 🔥
To prevent your sensitive data and credentials from being synced to the Postman cloud, store them in the Current Value fields of your Postman environment.
Open Postman and do the following:
-
Import the following files:
-
Select to use the imported global environment.
-
In the global environment, update only the Current Value field with your own values for the following:
client_id
client_secret
Ocp-Apim-Subscription-Key
merchantSerialNumber
mobileNumber
Make API calls
For all the following, you will start by sending a request Get Access Token
.
This provides you with access to the API.
The access token is valid for 1 hour in the test environment and 24 hours in the production environment. See the API reference for details about the calls.
Create agreements
For details about the calls, see Agreement endpoints in the Recurring API Specifications.
Create a minimal agreement
-
Send request
Get Access Token
. This provides you with access to the API. -
Set
Idempotency-Key-Draft
value. -
Send the
Draft Agreement - Legacy pricing
request. This demonstrates how to create a simple agreement usingPOST:/recurring/v3/agreements
endpoint.Ctrl+click the link, it will take you to the landing page. Enter your test phone number and complete the authorization in the Vipps or MobilePay app in your mobile test app.
You should now have an active agreement. The variable
agreementId
is set in the environment. -
To get the information about an agreement, send
Get Agreement
. This usesGET:/recurring/v3/agreements/{agreementId}
. The variableagreementId
is set by theDraft Agreement
step.If you confirmed the agreement, the status should be ACTIVE in the response. If you didn't go through with the confirmation, the status will be PENDING for a maximum of 10 minutes, before it goes to
EXPIRED
.
Create an agreement with an initial charge
You can create more complex types of agreements by modifying the parameters in POST:/recurring/v3/agreements
endpoint.
-
Send
Draft Agreement - Legacy pricing and direct capture initial charge
. This demonstrates the addition of an initial charge.Ctrl+click on the link and complete the authorization.
When you use this, a charge is automatically created for the initial payment and charged. The
agreementId
andchargeId
are set in the environment. -
Set
Idempotency-Key-Draft
value. -
Send a request
Get Agreement
for information about this payment by using theGET:/recurring/v3/agreements/{agreementId}
endpoint.
Create an agreement with a reserve capture
When you use this, a charge is automatically created for the initial payment, and you can capture it when you provide the product or service.
For example, if a customer purchased a mobile phone with a data subscription, you could set up a recurring payment agreement where the price of the phone is registered as an initial payment with reserve capture. Then, you can capture the payment when you ship the phone.
-
Send
Draft Agreement - Legacy pricing and reserve initial charge
.Ctrl+click on the link and complete the authorization.
-
Set
Idempotency-Key-Draft
value. -
Send a request
Get Agreement
for information about this payment by using theGET:/recurring/v3/agreements/{agreementId}
endpoint. -
The
agreementId
andchargeId
are set in the environment. Take note of these values, because you will need them when you capture the reserved charge.
Getting access to user info
If you need to get access to some user information in addition to the recurring payment agreement, you can use the profile flow.
-
Send request
Draft Agreement - Profile sharing flow
.Provide the
scope
object in thePOST:/recurring/v3/agreements
call. This contains the information types that you want access to, separated by spaces (e.g., "name address email phoneNumber birthDate").Here, the
agreementId
andlanding_page_url
are retrieved from the response and set as variables. -
Once you complete the session, a unique identifier
sub
can be retrieved in the agreement details. Send a requestGet Agreement
for information about this payment by using theGET:/recurring/v3/agreements/{agreementId}
endpoint.In this example,
sub
is retrieved from the response and set as a variable. -
Send request
Get Userinfo
, from the User Info folder. This usesGET:/vipps-userinfo-api/userinfo/{sub}
with thesub
variable from the previous call.
Get a list of agreements
-
Send
List Agreements
to get a list of agreements by using theGET:/recurring/v3/agreements
endpoint.This includes a query
status=ACTIVE
, so it filters out other agreement states. -
Change or remove the query to see agreements with other states.
Update an agreement
-
Set
agreementId
to the ID of an ACTIVE agreement. -
Run
Get Agreement
to see the properties of the agreement. -
Run
Update agreement
which modifies some properties by using thePATCH:/recurring/v3/agreements/{agreementId}
endpoint. -
Run
Get Agreement
to see the updated properties.
Stop an agreement
-
Set
agreementId
to the ID of an ACTIVE agreement. -
Send the
Stop agreement
request, where the status is set toSTOPPED
in the body ofPATCH:/recurring/v3/agreements/{agreementId}
. -
Run
Get Agreement
to see that the status isSTOPPED
.
Create charges
You will need at least one ACTIVE agreement for these examples.
For details about the calls, see Charge endpoints in the Recurring API Specifications.
Create a charge
Charges for initial payments are created automatically. However, you need to create charge requests for the recurring payments.
A charge must be scheduled a minimum of two days before the payment will occur (it is a minimum one day in the test environment). See Direct Capture for more details about timing.
-
Set
agreementId
to the ID of an ACTIVE agreement. -
Set
Idempotency-Key-Create
value. -
Send
Create Charge - Direct capture
. This uses thePOST:/recurring/v3/agreements/{agreementId}/charges
endpoint.The
chargeId
variable is set for later use. -
Send
Get Charge
. This usesPOST:/recurring/v3/agreements/{agreementId}/charges/{chargeId}
to get information about the charge. The status will bePENDING
until the due date, when the payment is processed. -
If you run
Get Charge
again on the due date, the status should beCHARGED
.
Get a list of charges for an agreement
-
Set
agreementId
to the ID of an agreement. Note, you can get a list of all your agreements with theFetch Agreements
example. -
Send
List Charges
which usesGET:/recurring/v3/agreements/{agreementId}/charges
.This includes a query
chargeStatus=DUE
and filters out other charge states. -
Change or remove the query to see charges with other states.
Cancel a charge
You can cancel an existing charge before the user is charged.
-
Create a new charge, that we can safely cancel, by sending
Create Charge - Reserve capture
.The
chargeId
variable is set to this charge. -
Send
Cancel Charge
which usesDELETE:/recurring/v3/agreements/{agreementId}/charges/{chargeId}
.Send
Get Charge
to see the change of status.
Refund a charge
You can refund a charge that has already been charged.
-
Set
chargeId
to the ID of a charge with status of CHARGED. The easiest way to test this is to runDraft Agreement - Reserve initial charge
. This creates a charge that is immediately processed, and it sets theagreementId
andchargeId
to the corresponding values. -
Set
Idempotency-Key-Refund
value. -
Send
Get Charge
to see the change of status. -
Send
Refund Charge
which usesPOST:/recurring/v3/agreements/{agreementId}/charges/{chargeId}/refund
. -
Send
Get Charge
to see that the charge is all or partially refunded. To fully refund, set theamount
value to the amount remaining (amount
-amountRefunded
).
Capture reserved charge
When you create an agreement with a reserved charge, you will need to capture this charge.
-
In the environment, set
agreementId
andchargeId
to refer to the agreement and charge. If you ran Draft Agreement - Reserve initial charge, you can use the values set by the example. -
Set
Idempotency-Key-Capture
value. -
Send
Get Charge
, to see the status of this charge. -
Send
Capture reserved charge
which usesPOST:/recurring/v3/agreements/{agreementId}/charges/{chargeId}/capture
. -
Send
Get Charge
again, to see that the status is now "CHARGED".