While the callback feature is mandatory, we would like to emphasize that it is mainly a fail-safe feature. We strongly advice that it is not your primary mean of checking for payment updates.
When a change or update from the back-end system are made on a payment or transaction, Swedbank Pay will perform a callback to inform the payee (merchant) about this update.
Why Is The Callback Important?
Providing a callbackUrl in POST requests is mandatory. Below we provide
three example scenarios of why this is important:
- If the payer closes the payment window, the merchant will never know what
happened to the payment if callbackUrlis not implemented.
- If the payer stops up in a payment app such as Vipps or Swish, the payer
will never come back to the merchant. This means that the merchant won’t
know what happened to the payment unless callbackUrlis implemented.
- If a payer experiences a network error or something else happens that
prevents the payer from being redirected from Swedbank Pay back to the
merchant website, the callbackUrlis what ensures that you receive the information about what happened with the payment.
Technical Information
- When a change or update from the back-end system is made on a payment or transaction, Swedbank Pay will perform an asynchronous server-to-server callback to inform the payee (merchant) about this update.
- It is important to know that the callback is asynchronous, and not real-time. As we can’t guarantee when you get the callback, there could be a delay between when the payer is returned back to the merchant and when the callback arrives. If the merchant chooses to wait for the callback, the payer might be left at the merchant’s page until the response comes.
- Swedbank Pay will make an HTTP POSTto thecallbackUrlthat was specified when the payee (merchant) created the payment.
- When the callbackUrlreceives such a callback, an HTTPGETrequest must be made on the payment or on the transaction. The retrieved payment or transaction resource will give you the necessary information about the recent change/update.
- For unscheduled and recur transactions, no callback will be given for card transactions, only Trustly.
- As it isn’t scaled to be a primary source of updates, no given response time
can be guaranteed, and a callback might fail. It will be retried if that
should happen. Below are the retry timings, in seconds from the initial
transaction time:
    - 30 seconds
- 60 seconds
- 360 seconds
- 432 seconds
- 864 seconds
- 1265 seconds
 
- A callback should return a 200 OKresponse.
To understand the nature of the callback, the type of transaction, its status,
etc., you need to perform a GET request on the received URL and inspect the
response. The transaction type or any other information can not and should not
be inferred from the URL. See URL usage for more information.
For paymentOrder implementations (Online Payments, Checkout v2 and Payment
Menu v1), it is critical that you do not use the paymentId or
transactionId when performing a GET to retrieve the payment’s status. Use
the paymentOrderId.
Callback IP Addresses
The callbacks are currently sent from either 51.107.183.58 or 91.132.170.1
in both the test and production environment.
Starting from March
12th 2025, callbacks will be sent from one of the IP addresses in this interval,
and we strongly advise you to whitelist them as soon as possible:
20.91.170.120–127 (20.91.170.120/29).
FAQ – Change of IP Addresses for Callbacks
We will be updating the IP addresses from which callbacks for e-commerce payments are sent. This change will affect the external integration for both test and production environments.
The current IP addresses are 91.132.170.1 and 51.107.183.58. The new IP range
will be 20.91.170.120 – 127, with the prefix (20.91.170.120/29).
- 
    Update your firewall rules to allow incoming traffic from the new IP addresses. 
- 
    Ensure these changes are made by March 12th, 2025, to avoid potential disruptions in the callback functionality. 
- 
    Date: March 12, 2025 
- 
    Time: 12:00 CET – 13:00 CET 
- 
    Grace period: See further details below. 
We need to update and deploy new outbound IP addresses from our Azure Cloud environment. To ensure uninterrupted communication between our system and your systems, all merchants and partners must update their firewalls with the new IP range and prefix.
This applies to all merchants, regardless of integration method. No technical code changes are required, but firewall adjustments must be made in your infrastructure, typically handled by your IT or infrastructure providers.
By migrating callbacks to the Azure Cloud, we are enhancing our ability to scale and manage traffic dynamically.
This means:
- 
    Improved operational stability – We can handle more concurrent callback requests without performance degradation. 
- 
    Faster recovery from technical issues or incidents – We can automatically redirect traffic in case of disruptions. 
- 
    Better monitoring and proactive issue resolution – We now have more tools to detect and address issues in real-time. 
We understand that some merchants may not complete the update before March 12. Therefore, we will continue to run callbacks from the current solution during a grace period.
However, it is important to migrate as soon as possible, as we will gradually phase out the old solution to reduce system maintenance and complexity.
We will:
- 
    Closely monitor traffic to ensure stable callbacks from the Azure Cloud. 
- 
    Actively monitor merchants and partners to ensure a smooth transition. 
We recommend that merchants allow both the old and new IP addresses during the transition period. This ensures stable callback functionality, even if network issues arise during the migration.
Merchants must implement IP blocking (IP allowlisting). FQDN (domain name blocking) is not supported in this case, as we use fixed IP addresses.
If you have any questions or need support during implementation, please contact your TOM/TAM or our support team.
Callback Example
Payment Order Callback
1
2
3
4
5
6
7
8
9
10
11
12
13
14
{
    "paymentOrder": {
        "id": "/psp/paymentorders/7e6cdfc3-1276-44e9-9992-7cf4419750e1",
        "instrument": "paymentorders"
    },
    "payment": {
        "id": "/psp/creditcard/payments/7e6cdfc3-1276-44e9-9992-7cf4419750e1",
        "number": 222222222
    },
    "transaction": {
        "id": "/psp/creditcard/payments/7e6cdfc3-1276-44e9-9992-7cf4419750e1/authorizations/ec2a9b09-601a-42ae-8e33-a5737e1cf177",
        "number": 333333333
    }
}
 
| Field | Type | Description | 
|---|---|---|
| paymentOrder | object | The payment order object. | 
| id | string | The relative URL and unique identifier of the paymentorderresource .     Please read about URL Usage     to understand how this and other URLs should be used in your solution. | 
| instrument | string | The payment method used in the payment. | 
| payment | object | The payment object. | 
| number | string | The attempt number which triggered the callback. | 
| transaction | object | The transaction object. | 
GET Response
When performing an HTTP GET request towards the URL found in the
transaction.id field of the callback, the response is going to include the
abbreviated example provided below.
The created authorization resource contains information about the
authorization transaction made against a paymentorders payment.
Capture Response
Response
1
2
3
HTTP/1.1 200 OK
Content-Type: application/json; charset=utf-8; version=3.x/2.0
api-supported-versions: 3.x/2.0
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
{
    "paymentorder": "/psp/paymentorders/7e6cdfc3-1276-44e9-9992-7cf4419750e1",
    "authorization": {
        "id": "/psp/paymentorders/7e6cdfc3-1276-44e9-9992-7cf4419750e1/currentpayment/ec2a9b09-601a-42ae-8e33-a5737e1cf177",
        "itemDescriptions": {
            "id": "/psp/paymentorders/7e6cdfc3-1276-44e9-9992-7cf4419750e1/currentpayment/ec2a9b09-601a-42ae-8e33-a5737e1cf177/itemDescriptions"
        },
        "transaction": {
            "id": "/psp/paymentorders/7e6cdfc3-1276-44e9-9992-7cf4419750e1/currentpayment/ec2a9b09-601a-42ae-8e33-a5737e1cf177",
            "created": "2016-09-14T01:01:01.01Z",
            "updated": "2016-09-14T01:01:01.03Z",
            "type": "Authorization",
            "state": "Completed",
            "number": 1234567890,
            "amount": 1000,
            "vatAmount": 250,
            "description": "Test transaction",
            "payeeReference": "ABC123", 
            "isOperational": false,
            "problem": {
                "type": "https://api.payex.com/psp/errordetail/paymentorders/3DSECUREERROR",
                "title": "Error when complete authorization",
                "status": 400,
                "detail": "Unable to complete 3DSecure verification!",
                "problems": [
                ] 
            "operations": [
                {
                    "href": "/psp/paymentorders/7e6cdfc3-1276-44e9-9992-7cf4419750e1/currentpayment/ec2a9b09-601a-42ae-8e33-a5737e1cf177",
                    "rel": "edit-authorization",
                    "method": "PATCH"
                }
            ]
        }
    }
}
 
| Field | Type | Description | |
|---|---|---|---|
| paymentOrder | string | The relative URL and unique identifier of the paymentresource .     Please read about URL Usage     to understand how this and other URLs should be used in your solution. | |
| id | string | The relative URL and unique identifier of the authorizationresource .     Please read about URL Usage     to understand how this and other URLs should be used in your solution. | |
| itemDescriptions | object | The object representation of the itemDescriptionsresource. | |
| id | string | The relative URL and unique identifier of the itemDescriptionsresource .     Please read about URL Usage     to understand how this and other URLs should be used in your solution. | |
| transaction | object | The object representation of the generic transactionresource, containing information about the current transaction. | |
| id | string | The relative URL and unique identifier of the transactionresource .     Please read about URL Usage     to understand how this and other URLs should be used in your solution. | |
| created | string | The ISO-8601 date and time of when the transaction was created. | |
| updated | string | The ISO-8601 date and time of when the transaction was updated. | |
| type | string | Indicates the transaction type. | |
| state | string | Indicates the state of the transaction, usually initialized,completedorfailed. If a partial authorization has been done and further transactions are possible, the state will beawaitingActivity. | |
| number | integer | The transaction number, useful when there’s need to reference the transaction in human communication. Not usable for programmatic identification of the transaction, whereidshould be used instead. | |
| amount | integer | The transaction amount (including VAT, if any) entered in the lowest monetary unit of the selected currency. E.g.: 10000=100.00SEK,5000=50.00SEK. | |
| vatAmount | integer | The payment’s VAT (Value Added Tax) amount, entered in the lowest monetary unit of the selected currency. E.g.:10000=100.00SEK,5000=50.00SEK.  ThevatAmountentered will not affect theamountshown on the payment page, which only shows the totalamount. This field is used to specify how much of the totalamountthe VAT will be. Set to0(zero) if there is no VATamountcharged. | |
| description | string | A textual description of the purchase. Maximum length is 40 characters. | |
| payeeReference | string(30) | A unique reference from the merchant system. Set per operation to     ensure an exactly-once delivery of a transactional operation. Length and     content validation depends on whether the transaction.numberor thepayeeReferenceis sent to the acquirer. If Swedbank Pay handles the     settlement, thetransaction.numberis sent to the acquirer and thepayeeReferencemust be in the format ofA-Za-z0-9andstring(30). If you handle the settlement,     Swedbank Pay will send thepayeeReferenceand it will be limited to the     format ofstring(12). All characters must be digits.               In Invoice PaymentspayeeReferenceis used as an invoice/receipt         number, if thereceiptReferenceis not defined. | |
| receiptReference | string | A unique reference to the transaction, provided by the merchant. Can be used as an invoice or receipt number as a supplement to payeeReference. | |
| failedReason | string | The human readable explanation of why the payment failed. | |
| isOperational | bool | trueif the transaction is operational; otherwisefalse. | |
| operations | array | The array of operations that are possible to perform on the transaction in its current state. | 
Sequence Diagram
The sequence diagram below shows the HTTP POST you will receive from Swedbank
Pay, and the two GET requests that you make to get the updated status.
sequenceDiagram
    Participant Merchant
    Participant SwedbankPay as Swedbank Pay
    activate SwedbankPay
    SwedbankPay->>+Merchant: POST <callbackUrl>
    deactivate SwedbankPay
    note left of Merchant: Callback by Swedbank Pay
    Merchant-->>+SwedbankPay: HTTP response
    Merchant->>+SwedbankPay: GET paymentorders payment
    deactivate Merchant
    note left of Merchant: First API request
    SwedbankPay-->>+Merchant: payment resource
    deactivate SwedbankPay