This guide is intended for Acquiring Partners who provide APIs and/or SDKs to their Partners, allowing them to integrate a Hosted Checkout or drop-in embedded checkout component. Typically, this integration requires both client-side and server-side components to render and manage the checkout experience, with the Acquiring Partner responsible for hosting and controlling the payment form.
To support Klarna in this setup, Acquiring Partners are expected to:
- Support Klarna's interoperability data points as part of their own API offerings.
- Implement interoperability logic and optionally support Express Checkout-style flows.
- Dynamically retrieve Klarna’s presentation instructions to build the payment selector.
- Initiate the Klarna Purchase Journey via a pop-up using Klarna’s SDK (avoiding full-page redirects).
- Authorize the payment using Klarna’s APIs.
- A payment server to interact with Klarna’s Payment Authorize API.
- A client-side component that integrates Klarna’s SDK and launches the Klarna purchase window as a pop-up.
- A webhook listener to receive and handle asynchronous payment status updates from Klarna.
- The customer navigates to the Partner’s checkout page.
- The Partner initiates a checkout session with the Acquiring Partner and sends the interoperability data points.
- The Partner either redirects the customer to the Acquiring Partner’s Hosted Checkout Page URL or embeds the checkout element directly on the page.
- The Acquiring Partner’s client-side component initializes Klarna’s SDK and integrates it into the payment selector interface.
- The customer selects Klarna as their payment method and clicks the Klarna Payment button.
- The Acquiring Partner uses a combination of the Authorize Payment API and Klarna’s SDK to initiate the Klarna purchase flow. The interoperability data points shared by the Partner is also forwarded at this stage.- Happy path: The payment transaction is created immediately, and the customer is redirected to the order confirmation page.
- Step-up required: Klarna’s purchase journey is launched in a pop-up window for additional verification.
 
- (If Step-up is required) The Acquiring Partner monitors the payment status asynchronously via Klarna Webhooks.
- (If Step-up is required) Upon successful completion of the Klarna purchase journey, the Acquiring Partner calls the Payment Authorize API a second time to finalize the transaction.
sequenceDiagram
  autonumber
  participant C as Customer
  participant P as Partner
  participant AP as Acquiring Partner
  participant K as Klarna
  C->>P: Visit checkout page
  P->>AP: Create checkout session
  Note over P,AP: Share interoperability data points
  AP->>P: Return checkout session
  P->>AP: Load embedded element or redirect to hosted checkout
  AP->>K: Initialize Klarna SDK
  Note over AP,K: Share interoperability data points
  AP->>K: Request presentation instructions (SDK)
  K->>AP: Return assets and instructions
  AP->>AP: Render payment selector
  C->>AP: Select Klarna payment method
  AP->>AP: Update Klarna presentation<br>Show Klarna payment button
  C->>AP: Click Klarna payment button
  AP->>+K: Trigger authorize handler (SDK)
  Note over AP,K: First Authorize API call with interoperability data points
  alt Step-up required
    K->>-K: Start Klarna purchase journey
    C->>K: Complete purchase on Klarna
    K->>AP: Webhook + client notification
    Note over K,AP: Payment request completed
    AP->>K: Authorize Payment API (final)
    K->>AP: Payment approved
    AP->>P: Webhook + client notification
    Note over P,AP: Order completed
    AP->>C: Redirect to confirmation page
  else Instant approval
    K->>AP: Payment approved
    AP->>P: Webhook + client notification
    Note over P,AP: Order completed
    AP->>C: Redirect to confirmation page
  else Declined
    K->>AP: Payment declined
    AP->>P: Webhook + client notification
    Note over P,AP: Payment declined
    AP->>C: Return to checkout
    Note over C,AP: Display error message
  end
- Accept data points from the Partner and build the payment form
- Initiation of the payment with Klarna: Authorize the payment
- Handle step-up scenario
- Monitor the payment request state
- Final authorization