Checkout API guide
The Checkout API provides an all-in-one solution for receiving payment for goods and services online using our trusted technology and brand. It combines several Vipps MobilePay products, including Login, ePayment, Recurring and Order management allowing a frictionless integration for merchants.
API version: 3.0.0.
Please note: There are some differences between the test and production environments. Read more about the test environment and its limitations.
Please note: Always use the most recent API version when integrating with Checkout. All endpoints are described in detail in our API Reference.
Migrating to V3? Consult our Migration Guide.
Checkout Features
Checkout API
Checkout works around the concept of a session, with a time to live of one hour. The API exposes endpoints for the merchant to interact with a session. These include:
- session initiation
- session status
Session types
A Checkout session support both one-time-payments and subscriptions by setting the type
property to PAYMENT
or SUBSCRIPTION
respectively at session initiation. A session in subscription mode may also include an optional one-time-payment, also referred to as initial charge.
Checkout frontend
Once a session is created, it is to be opened inside an iFrame embedded on the merchant website. The iFrame loads a web application that fetches all necessary information about the session from Vipps MobilePay.
Frontend SDK
We provide a frontend SDK to make opening the session on the merchant easy (the SDK is explained in detail later in this guide).
It is strongly recommended using the frontend SDK to make sure you get the latest improvements and bug fixes.
Shipping
In most situations a merchant wants to send goods to a customer using a shipping provider. Consult the shipping guide and the API spec for a detailed description of which shipping providers and features Checkout support.
Checkout Direct - Hosted checkout
With Checkout Direct you can easily implement an express checkout experience directly from a product page without going through a shopping cart. Checkout Direct decouples you from needing to embed an iFrame and lets us handle everything at checkout.vipps.no
before returning the customer to your shop after a payment is finished. To use Checkout Direct , follow the System integration guidelines and make sure you pick Option 2 under Step 2: Displaying the session to the user.
Checkout Elements
You can adjust the fields and values present in the Checkout by setting the configuration.elements
property in the
Create a Checkout session
endpoint.
For example, you might have a purchasing flow where you don't require an address because you're not sending physical goods,
or you don't need the customers to identify themselves because they are already logged into your system. Then, you can disable the
contact details panel by changing the configuration.elements
.
The Elements
mode is optionally set by the configuration.elements
property at session initiation, and defaults to Full
.
- Payment and contact info
- Payment only
If you need the address from a user, you can enable by using Elements PaymentAndContactInfo
, resulting in the following personal details form and payment form.
- Vipps
- MobilePay
If you don't need the contact details for a customer, you can disable it by using Elements PaymentOnly
, resulting in the following session:
- Vipps
- MobilePay
Remembering of customer data
Checkout supports easy fetching of user info with the built-in Login integration. With a functionality called "Remember Me", the user is can opt in to having this information being persisted across different Checkout sessions on the same machine.
Prefill customer data
We believe that simplicity is key to providing the best user experience. With prefillCustomer
, you can easily send in any information you have about your customer, making filling out forms in the Checkout a breeze.
All fields in prefillCustomer
are optional. We will prefill the form with whatever information you send and let your customers fill in the rest if any information is missing.
To further streamline the payment process, we've implemented a feature that automatically forwards the phone number to our landing page. This removes the hassle of having to fill in the phone number multiple times and makes it even easier for your customers to pay.
Even if your Checkout is set up with PaymentOnly
, you can still send in your customer's phone number to make the payment process smoother.
Custom consent
Sometimes you need to ask your customers for permission for certain actions, such as subscribing to technical updates. That's where our "custom consent" feature comes in handy!
When you enable "custom consent", a checkbox with a message appears at the bottom of the checkout page. Your customers can choose to check this box if they want to give their consent. You can make the checkbox optional or required, depending on your needs.
The message displayed next to the checkbox can contain up to one link, formatted in Markdown like this: [linkText](https://example.com)
. This allows you to direct customers to additional information or resources related to the consent request.
- Vipps
- MobilePay
Receipts
Checkout supports creating receipts that become visible to the user in the App. This can be useful in many cases, and is sometimes mandatory as described below.
To enable Checkout to create receipts, the orderSummary
property in the session initiation request must be set. Detailed information is available in the OpenAPI spec session initiation endpoint
Receipt information is a combination of a list of OrderLines and a BottomLine. An OrderLine is a description of each item present in the order. The BottomLine contains information regarding the order as a whole. It is possible to specify shipping costs in one or more OrderLines in the session initiation. If shipping is handled in Checkout and is not free, an order line with the shipping cost will be automatically added, even if shipping costs are specified in the session initiation.
If set up properly in the OrderSummary
property in the session initiation, the receipt will be created when payment is initiated (by sending it to Order Management API), and will be visible in the customer's app when the payment is successfully completed.
Further details regarding receipts in The Order Management API
Show order summary
In addition to automatically creating receipts, setting up the OrderSummary
property as described above enables the use of showOrderSummary: true
inside configuration
in the session initiation. This will display a simplified order summary, similar to the receipt, on top of the Checkout window. Use this feature if you would like to show what the user is paying for during the checkout. We show a simpler summary than the receipt using a subset of the properties inside OrderSummary
. For example, tax calculations are shown in the receipt, but not in the order summary. The following properties are honored: id
, name
, discount
, giftcard
, totalAmount
, productUrl
, isReturn
, isShipping
, currency
, giftCardAmount
, quantity
.
Receipts and Content monitoring
We offer Content monitoring as a way for Merchants to deal with the regulatory demands of content monitoring. For some merchants, we can utilize the merchant's webpage for content monitoring, continuously verifying that the actual products being sold coincides with the expected products. If you, as a merchant, don't have a permanent website that can be utilized for content monitoring, for example you don't have a user facing website or the website is ephemeral/short-lived, then you must utilize Content monitoring. In order to comply with Content monitoring, all transactions must be posted to the Order Management receipts functionality described in this section.
Recurring payments
You can offer recurring payments for Checkout through the recurring plugin for WooCommerce plugin.
If you offer both recurring and single payments, we recommend using our Recurring checkout alongside our standard checkout plugin.
We only offer static shipping options at the moment.
External payment methods
External payment methods are now supported in all markets.
External payment methods allow merchants to add means of payment which is currently not available natively within Checkout. When a customer selects this method for payment, they are redirected to an external URL as supplied by the merchant.
Compliance
In order for your payment method to be compliant, you need to have an agreement in place with the specified external payment provider (E.g. Klarna).
Allowed external payment methods
Below follows a list of allowed external payment methods.
Payment method |
---|
Klarna |
Flow and Implementation
When you initiate a session, you have the option of specifying a list of external payment methods, these consist of a key paymentMethod
identifying the payment method (one of the allowed external payment methods), and a string redirectUrl
. These external payment methods are then added to the list of available payment methods that the customer can choose from. Should a customer select one of the supplied external payment methods, they will be redirected to the supplied redirectUrl
.
Note: You are responsible for the subsequent steps in the checkout flow once a customer has selected this method of payment. This includes the confirmation page, order creation and so forth. As this flow is external to the Checkout context, Vipps MobilePay will not take responsibility for any of the required integration steps towards the external payment provider, nor any complications that could occur with the orders paid using this functionality
Extended payment capture deadlines
Special rules apply for payments made with Checkout: All payments started in Checkout can be captured up to 180 days after reservation, regardless of country or payment app.
We guarantee successful capture within 14 days after the reservation.
We cannot guarantee successful captures from 15 to 180 days after reservation, so there is chance of a failed capture, for example in the case of insufficient funds, expired cards, etc. See: Card payment deadlines may vary.
System integration guidelines
Be sure to always use the most updated version of the API when integrating.
See also: Checkout quick start guide.
Flow diagram
The standard flow for a Checkout consists of
- Initiating a session
- Displaying the session to the user
- Handling the result of the session
Step 1: Initiating a session
The merchant backend calls the session initiation endpoint:
Provide headers described in HTTP Headers.
All fields of the request body are described in our API Reference.
The response object consists of a token
and a checkoutFrontendUrl
, which are used in the next step
Configuration for use inside a native mobile application
Checkout can be used in an iOS or Android app to pay for goods and services. The Checkout frontend may then be opened directly inside a web view, instead of as an iFrame inside a merchant website.
In this situation, the merchant must provide a returnUrl
to direct the user back to an application.
The frontend application will automatically try to detect if the user is on a mobile device.
If so, it will do an "app switch" into the Vipps or MobilePay app, and then back to your application upon completion.
We recommend that you use WEB_REDIRECT
and implement universal links/asset links (starting with https
), as they contain built-in logic to handle both desktop and mobile flow. They are more secure than the deep link flow and provide a better user experience.
Please see Knowledge base: App flow recommendations for more details.
Configuration of external payment methods
To enable this feature, you need to populate the externalPaymentMethods
field in the configuration
property on session initiation request. Subsequently, you need to undertake integration work towards the payment provider. This may include both backend and frontend work (e.g., order confirmation pages).
Example
{
"externalPaymentMethods": [
{
"paymentMethod": "Klarna", // Required
"redirectUrl": "https://…", // Required: HTTPS
}
]
}
We also suggest polling the session to extract the customer information and the selected shipment method that can be used to, for example, populate fields in the external payment method provider, or to fulfill the subsequent steps.
Step 2: Displaying the session
Load the frontend SDK in the <head>
section of the merchant website.
<head>
<script src="https://checkout.vipps.no/vippsCheckoutSDK.js"></script>
</head>
- Option 1: iFrame
- Option 2: Checkout Direct (hosted checkout)
The most common flow includes embedding Checkout on the merchant website, typically as the step succeeding a shopping cart view.
Option 1: iFrame and Option 2: Checkout Direct can also work in combination on your site.
The frontend SDK exposes a global function called VippsCheckout
. Initialize this with the following parameters:
Parameter | Description | Optional |
---|---|---|
checkoutFrontendUrl | Specifies where to load the iFrame content from. Comes from session creation response | No |
iFrameContainerId | The ID of the HTML element to contain the Checkout iFrame | No |
token | Token identifying the session. Comes from session creation response. | No |
language | Can be set to nb , dk , fi , or en . This is optional and will default to 'en' English if not specified | Yes |
on | Listen to events from Checkout. See SDK events for more details. | Yes |
Example merchant website using Checkout frontend SDK to embed an iFrame with the session in plain html/js.
<html>
<head>
<title>Merchant website</title>
<script src="https://checkout.vipps.no/vippsCheckoutSDK.js"></script>
</head>
<body>
<button type="button" id="checkout-button">Checkout with Vipps</button>
<section id="vipps-checkout-frame-container">
<!-- This is where the iFrame will be embedded -->
</section>
<script>
document
.getElementById("checkout-button")
.addEventListener("click", function () {
// Relay an initiate session request to Checkout API through the merchant's backend
fetch("<MERCHANT BACKEND CREATE SESSION URL>", {
method: "POST",
})
.then((response) => response.json())
.then((data) => {
var vippsCheckout = VippsCheckout({
checkoutFrontendUrl: data.checkoutFrontendUrl,
iFrameContainerId: "vipps-checkout-frame-container",
language: "nb",
token: data.token,
});
})
.catch((error) => {
// Handle at least these two types of errors here:
// 1. Fetch to create session endpoint failed
// 2. Checkout frontend SDK not loaded resulting in VippsCheckout not being defined
});
});
</script>
</body>
</html>
Please note: Never leak the merchant credentials to the frontend. A Checkout session should always be created by the merchant backend
Please note: The Checkout frontend is not supposed to be open in its own browser window/tab. The only exception to this is when using Checkout inside a web view in a native mobile application.
Sticky Checkout session
The frontend SDK provides an alternative way to display the session, using a query parameter in the URL. This makes the session "sticky", meaning that the same session will open after a page refresh.
If the query parameter token
is present and the token attribute in the argument object to VippsCheckout
is not defined, the frontend SDK will load the iFrame with the token from the query parameter.
The SDK provides a helper method that will redirect the user to the current page with the token
query parameter added to the URL.
Please note: Make sure to initialize VippsCheckout
outside any user dependent execution blocks (like event handlers) to make sure that the iFrame is loaded every time a user lands on the page.
// Globally defined
var vippsCheckout = VippsCheckout({
checkoutFrontendUrl: data.checkoutFrontendUrl,
iFrameContainerId: 'checkout-iframe-container',
});
// Attach to checkout button
fetch("<MERCHANT BACKEND CREATE SESSION URL>", { method: "POST" })
.then((response) => response.json())
.then((data) => {
vippsCheckout.redirectToCurrentPageWithToken(data.token)
})
Frontend SDK events
You can listen to changes in Checkout by supplying callbacks to the on
option in the frontend SDK.
Each key in the map supplied to on
corresponds to an event and accepts a call callback-function with a data
parameter as a value.
Available events:
Parameter | Description | Type |
---|---|---|
shipping_option_selected | Is triggered when the user selects a shipping option or undefined when shipping option is deselected. | ShippingOption | undefined |
total_amount_changed | Is triggered when the total amount changes (for example, when a shipping option is selected). | Money |
session_status_changed | Is triggered upon changes in session status (for example, when payment is started). | SessionStarted | PaymentInitiated | PaymentSuccessful | PaymentFailed | SessionTerminated | SessionExpired |
shipping_address_changed | Is triggered when a new "delivered to" address is submitted or undefined when removed. | Address | undefined |
customer_information_changed | Is triggered when new customer information is submitted or undefined when removed. | Address | undefined |
Type definition
- ShippingOption
- Money
- Address
ShippingOption
Parameter | Type | Description |
---|---|---|
id | string | The merchants shipping option identification. |
brand | string | The name of the brand of the option (for example, "Posten" or "PostNord"). |
description | description | undefined | The description of the shipping option. |
product | string | The brand specific product (for example, "Servicepakke" or "Home delivery"). |
price | Money | The price of the shipping option. |
Money
Parameter | Type | Description |
---|---|---|
fractionalDenomination | number | Value of in minor units. For Norwegian kroner (NOK) that means 1 kr = 100 øre. Example: 499 kr = 49900 øre. |
currency | string | Three letter ISO-4217 currency code. |
Address
Parameter | Type |
---|---|
address | string |
city | string |
country | string |
email | string |
firstName | string |
lastName | string |
phone | string |
zip | string |
Example
window.VippsCheckout = {
checkoutFrontendUrl: data.checkoutFrontendUrl,
iFrameContainerId: "vipps-checkout-frame-container",
language: "nb",
token: data.token,
on: {
shipping_option_selected: function (data) {
// Do something when the shipping option is selected
},
total_amount_changed: function (data) {
// Do something when the total amount changed
},
session_status_changed: function (data) {
// Do something when status changed
},
shipping_address_changed: function (data) {
// Do something when shipping address changed
},
customer_information_changed: function (data) {
// Do something when customer information changed
},
},
};
A Checkout session hosted on Vipps MobilePay domain. Use cases include (but are not limited to)
- "Express checkout" of a single item, essentially skipping the shopping cart.
- Lack of own web shop. If the merchant does not have their own web solution the Checkout can be hosted by Vipps MobilePay instead
To check out a single item directly attach a click event handler to a button close to the product, preferably the Vipps MobilePay button that comes predefined with the Vipps/MobilePay look-and-feel.
The frontend SDK exposes a global function called VippsCheckoutDirect
. The click handler should call the function with the following parameters
Parameter | Description | Optional |
---|---|---|
checkoutFrontendUrl | Specifies where to load the iFrame content from. Comes from session creation response | No |
token | Token identifying the session. Comes from session creation response. | No |
language | Can be set to nb , en , fi , or dk . This is optional and will default to en English, if not specified | Yes |
<html>
<head>
<title>Merchant website</title>
<script async type="text/javascript" src="https://checkout.vipps.no/vippsCheckoutSDK.js"></script>
<script async type="text/javascript" src="https://checkout.vipps.no/checkout-button/v1/vipps-checkout-button.js"></script>
</head>
<body>
<vipps-mobilepay-button id="checkout-button"></vipps-mobilepay-button>
<script>
document
.getElementById("checkout-button")
.addEventListener("click", function () {
// Relay an initiate session request to Checkout API through the merchant's backend
fetch("<MERCHANT BACKEND CREATE SESSION URL>", {
method: "POST",
})
.then((response) => response.json())
.then((data) => {
VippsCheckoutDirect({
checkoutFrontendUrl: data.checkoutFrontendUrl,
language: "nb",
token: data.token,
});
})
.catch((error) => {
// Handle at least these two types of errors here:
// 1. Fetch to create session endpoint failed
// 2. Checkout frontend SDK not loaded resulting in VippsCheckoutDirect not being defined
});
});
</script>
</body>
</html>
Please note: Never leak the merchant credentials to the frontend. A Checkout session should always be created by the merchant backend
Step 3: Handling the result of the session
After the user has completed the checkout process, the merchant will be notified with transaction details through callback and polling, as described below.
Please note: It is highly recommended implementing polling in addition to callback. We don't guarantee delivery of the callback.
Please note: If external payment methods are enabled and the user selects this option for payment, the merchant will not be notified.
Callback Handling
The callback will be sent to a callback endpoint (click on the "Callbacks" tab) implemented by the merchant.
POST:{merchantInfo.callbackUrl}
The callbackAuthorizationToken
, provided by the merchant at session initiation, will be attached as the Authorization
header. Use this to authorize the caller.
The callback is fired when the sessionState
property changes to a terminal state (i.e., PaymentTerminated
, PaymentSuccessful
, or PaymentInitiationFailed
). This means that the callback is sent at most once per session (with exponential backoff retry in case the response isn't successful).
We recommend using a combination of both a callback and polling to get the most recent state for a session.
Every callback must be answered with a HTTP 2XX response
. In the eventuality that any other response is sent, we will retry with an exponential backoff until 2XX
is received again. The callback will be retried a maximum of 3 times.
Please keep in mind that we don't guarantee delivery of the callback, so it is highly recommended implementing polling in addition to callback.
It is critical that the endpoint receiving the callback is robust. It should also be able to receive any additional data not specified in the minimum example, so that it can be backwards compatible in accordance with our integration guidelines.
Session polling
Checkout exposes a polling endpoint.
The complete URL for polling is returned from the
session creation endpoint
as pollingUrl
.
Payment details
The sessionState
property of the callback/polling response gives information about the state of the payment. Values PaymentSuccessful
, PaymentTerminated
, and SessionExpired
are terminal states. Stop polling when receiving one of these states. The callback will only be sent once the session is in a terminal state.
The paymentDetails
property gives additional information about the transaction. The shape of the object differs based on paymentMethod
.
- Wallet (Vipps/MobilePay) and Card
- BankTransfer
Example callback/polling response for payment method Wallet
(Vipps/MobilePay) and Card
:
{
...
sessionState: "PaymentSuccessful",
paymentMethod: "Wallet",
paymentDetails: {
type: "wallet", // or "card"
state: "AUTHORISED",
amount: {
value: 1234,
currency: "NOK"
}
},
...
}
Additional details for Wallet
and Card
transactions can be retrieved from the underlying GET:payment endpoint (session with type: PAYMENT) or GET:charge endpoint (session with type: SUBSCRIPTION) that Checkout uses under the hood.
Example response for payment method BankTransfer
(only available in the Finnish market):
{
...
sessionState: "PaymentSuccessful",
paymentMethod: "BankTransfer",
paymentDetails: {
type: "BankTransfer",
amount: {
value: 1234,
currency: "EUR"
}
},
...
}
Bank transfer is instant
Subscription details
If the Checkout Session was initialized with type: SUBSCRIPTION
the subscriptionDetails
property of the callback/polling response gives information about the state of the agreement.
{
...
sessionState: "PaymentSuccessful",
paymentMethod: "Wallet",
subscriptionDetails: {
agreementId: "agr_123456",
state: "ACTIVE"
}
...
}
The agreementId
property is the reference to the recurring agreement, and may be used towards the Recurring API to make changes to the agreement.
Step 3a: Transaction operations
Depending on the payment method additional actions must be taken after a successful payment.
For payment methods Wallet
/Card
the amount will be reserved on the customer account until you capture it to complete the payment. Capture must be done in accordance with the terms and conditions you have with the user. Our recommendation is that this is not performed until the goods or services have been delivered. For more details, see capture regulations.
See the ePayment API payment operations (if Checkout Session is type: PAYMENT) or Recurring API charge operations (if Checkout Session is type: SUBSCRIPTION) for more information on how to perform capture/cancel/refund on a payment. The merchant credentials and the reference
are cross compatible between Checkout and ePayment/Recurring API's. The property referred to as reference
in Checkout is synonymous with chargeId
when doing charge/payment operations to Recurring.
Please note: That the eCom API is deprecated and should not be used, as it lacks full support for card transactions.
Please note: Checkout only supports sales units that are set up with type reserve/capture (as opposed to direct capture). Read more about reserve and capture
For payment method BankTransfer
(only in the Finnish market) the payment is instant. The transaction amount is settled immediately from the customer account to the merchant account. No additional actions need to be taken. Refunds must be handled by the merchant manually upon agreement between customer and merchant.