Set up Klarna and charge recurring subscriptions using merchant-initiated transactions (MIT) with a saved payment method.
Klarna is a buy now, pay later (BNPL) payment method that offers flexible payment options and supports recurring payments through merchant-initiated transactions (MIT).
To connect a Klarna account, obtain the following credentials from the Klarna Business Portal.
Username: An API username which can be generated by navigating to Preferences → Settings → Manage Klarna API Credentials
Password: An API password which can be generated by navigating to Preferences → Settings → Manage Klarna API Credentials
Region: The region of the Klarna account. Enter EU for Europe, NA for North America, or OC for Oceania
Client ID(optional): Required only for Express Checkout. Obtain from your Klarna Business Portal and enter it here so Gr4vy can return it via the Create Session API to initialize the Klarna Payments Buttons SDK.
For Klarna, the default integration uses a redirect to the Klarna hosted payments page. A direct integration using the Klarna JavaScript SDK or mobile SDKs is also supported.
Gr4vy supports direct integration with Klarna using the Klarna Payments SDK or mobile SDKs, allowing you to embed the payment UI directly in your app while using Gr4vy to manage the transaction lifecycle. Two modes are supported: Standard Checkout (session-based) and Express Checkout (button-based, no session required).
To initiate Standard Checkout, create a transaction with integration_client set to web, ios, or android. For mobile, use your app deep link for redirect_url (for example, yourapp://).After the transaction is created, the API response includes a session_token which can be used to get the session data for that transaction.
POST /transactions/:transaction_id/session?token=:session_token
val paymentView = KlarnaPaymentView(context, "pay_over_time")paymentView.initialize(clientToken, "yourapp://")
Complete the transactionAfter the customer authorizes the payment through the Klarna SDK, Klarna returns an authorization_token. To finalize the transaction, send this token to Gr4vy as a query parameter on the default_completion_url returned in the session response.
Terminal
curl -X GET \ "<default_completion_url>&authorization_token=<AUTHORIZATION_TOKEN>"
Once the request completes successfully, the transaction moves to authorization_succeeded. It can then be captured, voided, or refunded through Gr4vy.
Klarna Express Checkout embeds the Klarna payment button directly in your page using the Klarna Payments Buttons SDK. The buyer authorizes the payment inside the SDK widget — no redirect to a hosted page is required. After authorization, your backend creates the Gr4vy transaction in a single call using the authorization_token returned by the SDK.Get the client IDThe Klarna Payments Buttons SDK requires a client_id to initialize. You can obtain this in one of two ways:
Via the Gr4vy API — Call the Create Payment Service Session endpoint for your Klarna connection. Gr4vy returns a clientId from the connector credentials without making any Klarna API call.
Terminal
POST /payment-services/{payment_service_id}/sessions
Response
{ "client_id": "klarna_live_client_..."}
Hardcoded — Copy the client_id from your Klarna Business Portal and embed it directly in your frontend. This is suitable when the client ID does not change per session.
Embed the Express Checkout buttonLoad the Klarna SDK and render the Express Checkout button. The klarnaAsyncCallback function must be defined before the SDK script tag so it is available when the SDK initializes.
MobileFor mobile applications, use the Klarna Mobile SDK. The SDK is initialized with a client_id and renders a KlarnaExpressCheckoutButton.iOS (Swift) — See the iOS integration guide.
Create the transactionOnce your server receives the authorization_token, create a Gr4vy transaction and pass the token in connection_options under the klarna-klarna key. Gr4vy forwards the token to Klarna to place the order directly — the transaction moves to authorization_succeeded without any redirect.
var res = await sdk.Transactions.CreateAsync(transactionCreate: new TransactionCreate() { Amount = 2999, Currency = "USD", Country = "US", PaymentMethod = new PaymentMethodRequest() { Method = "klarna", }, CartItems = new List<CartItem> { new CartItem() { Name = "Example Product", Quantity = 1, UnitAmount = 2999, Sku = "item-001", Type = "physical", }, }, ConnectionOptions = new Dictionary<string, object> { ["klarna-klarna"] = new Dictionary<string, object> { ["authorization_token"] = "<AUTHORIZATION_TOKEN>", }, },});
The authorization_token returned by the Klarna SDK expires within approximately 60 minutes. Create the Gr4vy transaction immediately after receiving it.
Klarna supports storing the buyer’s payment method during the first (customer-present) payment and charging future renewals as merchant-initiated transactions (MIT) using the saved payment method, typically with no redirect.
Webhooks must be configured for the Klarna payment service. After the buyer approves the payment, Klarna sends an authorization_token via webhook which Gr4vy uses to create the reusable customer token. Without this webhook, store: true will not work.