Checkout Sessions

List of endpoints

Description Endpoint

Creating a Checkout Session

POST /payments/v1/checkout/sessions

Confirming a Checkout Session

POST/payments/v1/checkout/sessions/{ID}/confirm

 

What is a Checkout Session?

A Checkout Session is the basis for displaying a form to your payer on your website. The goal of a Checkout Session is to collect the payer's information (name, address, etc.) and the payment information (card or bank account details).

How do Checkout Sessions work?

  1. You create a Checkout Session to generate either a URL or a session ID, depending on your implementation.

  2. Your payer accesses the UI form on your website where they fill it out and confirm it.

  3. You get a postMessage that contains a URL you need for confirming the Checkout Session.

  4. You confirm the Checkout Session and receive the payment method token and mandate ID in the response (if you immediately charged the first payment, you also receive the payment reference).

  5. You charge the recurring payments using the payment method token and the mandate ID.

 

1. Creating a Checkout Session

Quick overview: Which types of Checkout Sessions are available?

Self-Managed Recurring Payments

imageCard

imageElements

tokenization (save card)

tokenization_and_pay (save card and charge first payment)

new_mandate (use saved card for new plan)

imageDirect debit

imageElements

tokenization (save bank account) for: SEPA, BACS, ACH, EFT Canada

tokenization_and_pay (save bank account and charge first payment) for: SEPA and ACH

 

Flywire-Managed Recurring Payments

Any available payment method

imageCheckout

 

 

One Off Payment

imageCard

imageElements

 

Any available payment method

imageCheckout

 

 

Pre-Authorization Payment

imageCard

imageElements

 

Request

Self-Managed Recurring Payments

Your payer will see a zero amount payment after this type of Checkout Session. 
Tokenizing a card requires a payment. Since there is no payment when the payer only saves (tokenizes) their card, Flywire creates a payment with an amount of 0 in the background for the purpose of tokenization. Your payer will be able to see this "0 charge" payment in their bank statement.

Parameters for the Request Body

charge_intent object

payor object

You have the option to pass payer information to pre-fill the fields of the UI form.

For a description of all fields and their valid values form see:

options object

Contains settings for the UI form.

form object

POST /payments/v1/checkout/sessions
curl https://base-url-placeholder/checkout/sessions
  -X POST 
  -H "Content-Type: application/json" 
  -H "X-Authentication-Key: {api_key}"
  -d '{
    "type": "tokenization",
    "charge_intent": {
	   "mode": "subscription"
    },
   "payor": {
		"first_name": "Peter",
		"last_name": "Payer",
		"address": "123 High Street",
		"city": "London",
		"country": "GB",
		"state": "",
		"phone": "0044123456789",
		"email": "[email protected]",
		"zip": "SW1A 1AA"
    },
	"options": {
        "form": {
            "action_button": "save",
            "locale": "en",
            "show_flywire_logo": true
        }
    },
    "schema": "cards",
    "payor_id": "MyPayerID",
    "recipient_id": "FLW"
}'
				

Mandatory emails

Self-managed recurring payments require you to send mandatory emails to your payer.

 

You have two options for charging the first payment:

Parameters for the Request Body

charge_intent object

payor object

You have the option to pass payer information to pre-fill the fields of the UI form.

For a description of all fields and their valid values form see:

options object

Contains settings for the UI form.

form object

recipient object

Contains the fields of the recipient.

fields array

It depends on the recipient which fields are optional or required. If a field is required, you must provide it here. Optional fields can be left out.

items array

POST /payments/v1/checkout/sessions
curl https://base-url-placeholder/checkout/sessions
  -X POST 
  -H "Content-Type: application/json" 
  -H "X-Authentication-Key: {api_key}"
  -d '{
    "type": "tokenization_and_pay",
    "charge_intent": {
        "mode": "subscription"
    },
   "payor": {
		"first_name": "Peter",
		"last_name": "Payer",
		"address": "123 High Street",
		"city": "London",
		"country": "GB",
		"state": "",
		"phone": "0044123456789",
		"email": "[email protected]",
		"zip": "SW1A 1AA"
    },
    "options": {
        "form": {
            "action_button": "save",
            "locale": "en",
            "show_flywire_logo": true
        }
    },
	"recipient": {
   		"fields": [
            {
                "id": "custom_field_1",
                "value": "ID12345"
            },
			{
				"id": "custom_field_2",
				"value": "2020"
			}
        ]
	},
    "items": [
        {
            "id": "default",
            "amount": 33000
        }
    ],
    "notifications_url": "https://webhook.site/9bf9cf8d-1d8c-46d1-b147-ca5841ff2ede",
    "external_reference": "Payment ID12456",
    "recipient_id": "FLW",
    "schema": "cards",
    "payor_id": "MyPayerID"
}

Parameters for the Request Body

charge_intent object

payor object

You have the option to pass payer information to pre-fill the fields of the UI form.

For a description of all fields and their valid values form see:

options object

Contains settings for the UI form.

form object

recipient object

Contains the fields of the recipient.

fields array

It depends on the recipient which fields are optional or required. If a field is required, you must provide it here. Optional fields can be left out.

items array

POST /payments/v1/checkout/sessions
curl https://base-url-placeholder/checkout/sessions
  -X POST
  -H "Content-Type: application/json"
  -H "X-Authentication-Key: {api_key}"
  -d '{
    "type": "tokenization_and_pay",
	"charge_intent": {
		"capture": "manual",
		"authorization": "preauth",
		"mode": "subscription"
	},
   "payor": {
		"first_name": "Peter",
		"last_name": "Payer",
		"address": "123 High Street",
		"city": "London",
		"country": "GB",
		"state": "",
		"phone": "0044123456789",
		"email": "[email protected]",
		"zip": "SW1A 1AA"
    },
    "options": {
        "form": {
            "action_button": "save",
            "locale": "en",
            "show_flywire_logo": true
        }
    },
	"recipient": {
   		"fields": [
            {
                "id": "custom_field_1",
                "value": "ID12345"
            },
			{
				"id": "custom_field_2",
				"value": "2020"
			}
        ]
	},
    "items": [
        {
            "id": "default",
            "amount": 33000,
        }
    ],
    "notifications_url": "https://webhook.site/9bf9cf8d-1d8c-46d1-b147-ca5841ff2ede",
    "external_reference": "Payment ID12456",
    "recipient_id": "FLW",
    "schema": "cards",
    "payor_id": "MyPayerID"
}
Your payer will see a zero amount payment after this type of Checkout Session. 
Tokenizing a card requires a payment. Since there is no payment when the payer only saves (tokenizes) their card, Flywire creates a payment with an amount of 0 in the background for the purpose of tokenization. Your payer will be able to see this "0 charge" payment in their bank statement.

Parameters for the Request Body

charge_intent object

options object

Contains settings for the UI form.

form object

POST /payments/v1/checkout/sessions
curl https://base-url-placeholder/checkout/sessions
  -X POST 
  -H "Content-Type: application/json" 
  -H "X-Authentication-Key: {api_key}"
  -d '{
    "type": "new_mandate",
    "charge_intent": {
        "mode": "subscription",
		"payment_method_token": "UW6JqAuMcJje-SyR3iIG"
    },
    "options": {
        "form": {
            "action_button": "save",
            "locale": "en",
            "show_flywire_logo": true
        }
    },
    "schema": "cards",
    "payor_id": "MyPayerID",
    "recipient_id": "FLW"
}'
The form works and looks slightly different for each direct debit scheme.

Parameters for the Request Body

charge_intent object

payor object

You have the option to pass payer information to pre-fill the fields of the UI form.

For a description of all fields and their valid values form see:

options object

Contains settings for the UI form.

form object

For BACS

Since BACS is only available in the UK you can only use recipients that have GBP as their billing currency. If you are trying to use a non-GPB recipient you'll receive a 422 error, see Response after creating a Checkout Session.

POST /payments/v1/checkout/sessions
curl https://base-url-placeholder/checkout/sessions
  -X POST 
  -H "Content-Type: application/json" 
  -H "X-Authentication-Key: {api_key}"
  -d '{
    "type": "tokenization",
    "charge_intent": {
        "mode": "subscription"
    },
   "payor": {
		"first_name": "Peter",
		"last_name": "Payer",
		"address": "123 High Street",
		"city": "London",
		"country": "GB",
		"state": "",
		"phone": "0044123456789",
		"email": "[email protected]",
		"zip": "SW1A 1AA"
    },
    "options": {
        "form": {
			"action_button": "save",
			"locale": "en",				
            "show_flywire_logo": true
        }
    },										
    "schema": "dd_sepa",
    "payor_id": "payorCCC",
    "recipient_id": "UUI"
}

Saving the bank account and creating the first payment at the same time (tokenization_and_pay) is currently only available for SEPA and ACH.

Mandatory emails

Self-managed recurring payments require you to send mandatory emails to your payer.

Parameters for the Request Body

charge_intent object

payor object

You have the option to pass payer information to pre-fill the fields of the UI form.

For a description of all fields and their valid values form see:

options object

Contains settings for the UI form.

form object

recipient object

Contains the fields of the recipient.

fields array

It depends on the recipient which fields are optional or required. If a field is required, you must provide it here. Optional fields can be left out.

items array

POST /payments/v1/checkout/sessions
curl https://base-url-placeholder/checkout/sessions
  -X POST 
  -H "Content-Type: application/json" 
  -H "X-Authentication-Key: {api_key}"
  -d '{
    "type": "tokenization_and_pay",
    "charge_intent": {
        "mode": "subscription"
    },
   "payor": {
		"first_name": "Peter",
		"last_name": "Payer",
		"address": "123 High Street",
		"city": "London",
		"country": "GB",
		"state": "",
		"phone": "0044123456789",
		"email": "[email protected]",
		"zip": "SW1A 1AA"
    },
    "options": {
        "form": {
			"action_button": "save",
			"locale": "en",				
            "show_flywire_logo": true
        }
    },
	"recipient": {
   		"fields": [
            {
                "id": "custom_field_1",
                "value": "ID12345"
            },
			{
				"id": "custom_field_2",
				"value": "2020"
			}
        ]
	},
    "items": [
        {
            "id": "default",
            "amount": 3300
        }
    ],
    "notifications_url": "https://webhook.site/9bf9cf8d-1d8c-46d1-b147-ca5841ff2ede",
    "external_reference": "Payment ID12456",
    "recipient_id": "UUI",
    "schema": "dd_sepa",
	"payor_id": "payorCCC"
}'

 

Flywire-Managed Recurring Payments

Parameters for the Request Body

charge_intent object

payor object

You have the option to pass payer information to pre-fill the fields of the UI form.

For a description of all fields and their valid values form see:

options object

Contains settings for the UI form.

form object

recipient object

Contains the fields of the recipient.

fields array

It depends on the recipient which fields are optional or required. If a field is required, you must provide it here. Optional fields can be left out.

items array

POST /payments/v1/checkout/sessions
curl https://base-url-placeholder/checkout/sessions
  -X POST
  -H "Content-Type: application/json"
  -H "X-Authentication-Key: {api_key}"
  -d '{
    "type": "recurring",
    "charge_intent": {
        "mode": "installment"
    },
   "payor": {
		"first_name": "Peter",
		"last_name": "Payer",
		"address": "123 High Street",
		"city": "London",
		"country": "GB",
		"state": "",
		"phone": "0044123456789",
		"email": "[email protected]",
		"zip": "SW1A 1AA"
    },
    "options": {
        "form": {
            "locale": "en",
			"show_payor_information": true
        }
    },
	"recipient": {
   		"fields": [
            {
                "id": "custom_field_1",
                "value": "ID12345"
            },
			{
				"id": "custom_field_2",
				"value": "2020"
			}
        ]
	},
    "items": [
        {
            "id": "default",
            "amount": 33000
        }
    ],
    "notifications_url": "https://webhook.site/9bf9cf8d-1d8c-46d1-b147-ca5841ff2ede",
    "external_reference": "My payment reference",
    "recipient_id": "TQQ",
    "payor_id": "my_payer_ID"
}

One Off Payment

You have two options for One Off payments, depending on which payment methods you want to make available: 

image With Elements:

You choose the payment method for the payer by using a specific element.

Available payment methods for One Off payments with elements are:

  • imageCard

image With Checkout:

You let the payer choose from all available payment methods in the Checkout Experience.

 

Parameters for the Request Body

charge_intent object

payor object

You have the option to pass payer information to pre-fill the fields of the UI form.

For a description of all fields and their valid values form see:

options object

Contains settings for the UI form.

form object

recipient object

Contains the fields of the recipient.

fields array

It depends on the recipient which fields are optional or required. If a field is required, you must provide it here. Optional fields can be left out.

items array

Mandatory emails

If you use the default setting false, you have to send the mandatory emails to your payer yourself, see One Off Payments: Emails to Your Payer.

POST /payments/v1/checkout/sessions
curl https://base-url-placeholder/checkout/sessions
  -X POST
  -H "Content-Type: application/json"
  -H "X-Authentication-Key: {api_key}"
  -d '{
    "type": "one_off",
	"schema": "cards",
    "charge_intent": {
        "mode": "one_off"
    },
   "payor": {
		"first_name": "Peter",
		"last_name": "Payer",
		"address": "123 High Street",
		"city": "London",
		"country": "GB",
		"state": "",
		"phone": "0044123456789",
		"email": "[email protected]",
		"zip": "SW1A 1AA"
    },
	"options": {
        "form": {
            "action_button": "save",
            "locale": "en",
            "show_flywire_logo": true
        }
    },							
	"recipient": {
   		"fields": [
            {
                "id": "custom_field_1",
                "value": "ID12345"
            },
			{
				"id": "custom_field_2",
				"value": "2020"
			}
        ]
	},
    "items": [
        {
            "id": "default",
            "amount": 33000
        }
    ],
    "notifications_url": "https://webhook.site/9bf9cf8d-1d8c-46d1-b147-ca5841ff2ede",
    "external_reference": "My payment reference",
    "recipient_id": "TQQ",
    "payor_id": "my_payer_ID",
    "enable_email_notifications": true
}

Parameters for the Request Body

charge_intent object

payor object

You have the option to pass payer information to pre-fill the fields of the UI form.

For a description of all fields and their valid values form see:

options object

Contains settings for the UI form.

form object

recipient object

Contains the fields of the recipient.

fields array

It depends on the recipient which fields are optional or required. If a field is required, you must provide it here. Optional fields can be left out.

items array

Mandatory emails

If you use the default setting false, you have to send the mandatory emails to your payer yourself, see One Off Payments: Emails to Your Payer.

POST /payments/v1/checkout/sessions
curl https://base-url-placeholder/checkout/sessions
  -X POST
  -H "Content-Type: application/json"
  -H "X-Authentication-Key: {api_key}"
  -d '{
    "type": "one_off",
    "charge_intent": {
        "mode": "one_off"
    },
   "payor": {
		"first_name": "Peter",
		"last_name": "Payer",
		"address": "123 High Street",
		"city": "London",
		"country": "GB",
		"state": "",
		"phone": "0044123456789",
		"email": "[email protected]",
		"zip": "SW1A 1AA"
    },
    "options": {
        "form": {
            "locale": "en"
			"show_payor_information": true
        }
    },
	"recipient": {
   		"fields": [
            {
                "id": "custom_field_1",
                "value": "ID12345"
            },
			{
				"id": "custom_field_2",
				"value": "2020"
			}
        ]
	},
    "items": [
        {
            "id": "default",
            "amount": 33000
        }
    ],
    "notifications_url": "https://webhook.site/9bf9cf8d-1d8c-46d1-b147-ca5841ff2ede",
    "external_reference": "My payment reference",
    "recipient_id": "TQQ",
    "payor_id": "my_payer_ID",
    "enable_email_notifications": true
}

Pre-Authorization Payment

Parameters for the Request Body

charge_intent object

payor object

You have the option to pass payer information to pre-fill the fields of the UI form.

For a description of all fields and their valid values form see:

options object

Contains settings for the UI form.

form object

recipient object

Contains the fields of the recipient.

fields array

It depends on the recipient which fields are optional or required. If a field is required, you must provide it here. Optional fields can be left out.

items array

POST /payments/v1/checkout/sessions
curl https://base-url-placeholder/checkout/sessions
  -X POST
  -H "Content-Type: application/json"
  -H "X-Authentication-Key: {api_key}"
  -d '{
    "type": "one_off",
	"charge_intent": {
		"capture": "manual",
		"authorization": "preauth",
		"mode": "one_off"
	},
   "payor": {
		"first_name": "Peter",
		"last_name": "Payer",
		"address": "123 High Street",
		"city": "London",
		"country": "GB",
		"state": "",
		"phone": "0044123456789",
		"email": "[email protected]",
		"zip": "SW1A 1AA"
    },
    "options": {
        "form": {
            "action_button": "save",
            "locale": "en",
            "show_flywire_logo": true
        }
    },
	"recipient": {
   		"fields": [
            {
                "id": "custom_field_1",
                "value": "ID12345"
            },
			{
				"id": "custom_field_2",
				"value": "2020"
			}
        ]
	},
    "items": [
        {
            "id": "default",
            "amount": 33000,
        }
    ],
    "notifications_url": "https://webhook.site/9bf9cf8d-1d8c-46d1-b147-ca5841ff2ede",
    "external_reference": "Payment ID12456",
    "recipient_id": "FLW",
    "schema": "cards",
    "payor_id": "MyPayerID"
}

Response

No matter which type of Checkout Session you created, the response is always the same.

 

hosted_form object

Only relevant when you render the form via iframe. More info:

warnings array

errors array

You can decide which information from the response you want to filter out in your backend before passing the URL to your frontend.

{
"id": "494d2e9d-c0c9-407c-9094-5b3b2a02c00f",
"expires_in_seconds": 1800,
"hosted_form": {
	"url": "https://payment-checkout.flywire.com/v1/form?session_id=494d2e9d-c0c9-407c-9094-5b3b2a02c00f",
	"method": "GET"
},
"warnings": []
}

When are warnings returned?

If the warning array contains warnings, it means that you tried to pre-fill the UI form with invalid values. You can use these warnings to check the data in your system for mistakes.

Are warnings an error?

No, warnings inform you of issues with field values, but you will still receive the URL and can display the form to your payer.

How do the warnings affect the form?

If a drop down field (like country) is affected by invalid values, the field will be empty, meaning no selection from the drop down is made yet. Your payer has to select the value from the drop down manually.

hosted_form object

Only relevant when you render the form via iframe. More info:

warnings array

errors array

You can decide which information from the response you want to filter out in your backend before passing the URL to your frontend.

{
"id": "e6bf6f63-46e0-4bd7-9bce-8106c02d0b3f",
"expires_in_seconds": 1800,
"hosted_form": {
	"url": "https://payment-checkout.flywire.com/v1/form?session_id=e6bf6f63-46e0-4bd7-9bce-8106c02d0b3f",
	"method": "GET"
},
"warnings": [
	{
		"source": "email",
		"errors": [
			{
				"text": "must be a valid email",
				"error_type": "invalid_email"
    		}
   		]
  	}
  ]
}

422 Error: Creating the Checkout Session failed - Recipient currency is not GBP

When does this happen?

You tried to create a Checkout Session with a recipient that does not have GBP set as its currency.

What should you do? 

  • Use a different direct debit scheme (not BACS).

  • Alternative: Use a different recipient (if you can't use a different recipient, contact Flywire to change the settings of the recipient).


{
    "type": "https://developers.flywire.com",
    "title": "Unprocessable entity",
    "status": 422,
    "detail": "Invalid parameters",
    "errors": [
        {
            "source": "/",
            "param": "recipient_id",
            "type": "invalid_param",
            "message": "BACS direct debit requires GBP. The recipient ARA cannot receive payments in GBP."
        }
    ]
}

2. The Payer's Side: Filling out the Form

After you created the Checkout Session, your payer accesses the UI Form on your website. Depending on the UI Form, your payer goes through different steps to fill it out and send it.

What does the payer see on my page?

Self-Managed Recurring Payments

Flywire-Managed Recurring Payments

When creating a Checkout Session, you have the option to configure the form to skip the payer information page.

One Off Payment

It depends on which One Off Payment Checkout Session you created: 

When creating a Checkout Session, you have the option to configure the form to skip the payer information page.

Pre-Authorization Payment

3. The postMessage of the Event Listener

Self-Managed Recurring Payments

After your payer sent the form, the event listener will return a successful postMessage.

A successful postMessage confirms that the form was submitted and that you can confirm the Checkout Session now. However, it does not indicate payment success. Payment status updates will be sent via callback notifications, see Payment Status Notifications for details.

The postMessage contains the following information:

confirm_url object

Contains the confirm URL. The confirm URL is the full url for the request to confirm the session, already resolved with the correct session ID.

payor object

The email address your payer entered in the UI form. If you are handling emails yourself, you need to use this email address to send mandatory emails to your payer.

The payer's email address is returned so you can ensure you have the correct email address.

Even if you pre-filled the payer information with an email address, your payer might have changed it when filling out the form.

If you are handling emails yourself, you need to ensure you have the correct email address for the payer.

{
confirm_url: {
	method: "POST",
	url: "https://api-platform.flywire.com/payments/v1/checkout/sessions/494d2e9d-c0c9-407c-9094-5b3b2a02c00f/confirm",
},
payor: {
email: "[email protected]"
},
source: "checkout_session",
success: true
}

Flywire-Managed Recurring Payments

After your payer sent the form, the event listener will return a successful postMessage.

A successful postMessage confirms that the form was submitted and that you can confirm the Checkout Session now. However, it does not indicate payment success. Payment status updates will be sent via callback notifications, see Payment Status Notifications for details.

The postMessage contains the following information:

confirm_url object

Contains the confirm URL. The confirm URL is the full url for the request to confirm the session, already resolved with the correct session ID.

payor object

The email address your payer entered in the UI Form.

{
confirm_url: {
	method: "POST",
	url: "https://api-platform.flywire.com/payments/v1/checkout/sessions/494d2e9d-c0c9-407c-9094-5b3b2a02c00f/confirm",
	},
payor: {
email: "[email protected]"
},
source: "checkout_session",  
plan_id: "IPTQQ18EADF349BE",
success: true,
}

One Off Payment

It depends on which One Off Payment Checkout Session you created:

After your payer sent the form, the event listener will return a successful postMessage.

A successful postMessage confirms that the form was submitted and that you can confirm the Checkout Session now. However, it does not indicate payment success. Payment status updates will be sent via callback notifications, see Payment Status Notifications for details.

The postMessage contains the following information:

confirm_url object

Contains the confirm URL. The confirm URL is the full url for the request to confirm the session, already resolved with the correct session ID.

payor object

The email address your payer entered in the UI form. If you are handling emails yourself, you need to use this email address to send mandatory emails to your payer.

The payer's email address is returned so you can ensure you have the correct email address.

Even if you pre-filled the payer information with an email address, your payer might have changed it when filling out the form.

If you are handling emails yourself, you need to ensure you have the correct email address for the payer.

{
confirm_url: {
	method: "POST",
	url: "https://api-platform.flywire.com/payments/v1/checkout/sessions/494d2e9d-c0c9-407c-9094-5b3b2a02c00f/confirm",
},
payor: {
email: "[email protected]"
},
source: "checkout_session",
success: true
}

After your payer sent the form, the event listener will return a successful postMessage.

A successful postMessage confirms that the form was submitted and that you can confirm the Checkout Session now. However, it does not indicate payment success. Payment status updates will be sent via callback notifications, see Payment Status Notifications for details.

The postMessage contains the following information:

confirm_url object

Contains the confirm URL. The confirm URL is the full url for the request to confirm the session, already resolved with the correct session ID.

payor object

The email address your payer entered in the UI form. If you are handling emails yourself, you need to use this email address to send mandatory emails to your payer.

The payer's email address is returned so you can ensure you have the correct email address.

Even if you pre-filled the payer information with an email address, your payer might have changed it when filling out the form.

If you are handling emails yourself, you need to ensure you have the correct email address for the payer.

{
  confirm_url: {
    method: "POST",
    url: "https://api-platform.flywire.com/payments/v1/checkout/sessions/494d2e9d-c0c9-407c-9094-5b3b2a02c00f/confirm",
  },
  payor: {
    email: "[email protected]"
  },
  source: "checkout_session",  
  reference: "LRP688625939",
  success: true,
}

Pre-Authorization Payment

After your payer sent the form, the event listener will return a successful postMessage.

A successful postMessage confirms that the form was submitted and that you can confirm the Checkout Session now. However, it does not indicate payment success. Payment status updates will be sent via callback notifications, see Payment Status Notifications for details.

The postMessage contains the following information:

confirm_url object

Contains the confirm URL. The confirm URL is the full url for the request to confirm the session, already resolved with the correct session ID.

payor object

The email address your payer entered in the UI form. If you are handling emails yourself, you need to use this email address to send mandatory emails to your payer.

The payer's email address is returned so you can ensure you have the correct email address.

Even if you pre-filled the payer information with an email address, your payer might have changed it when filling out the form.

If you are handling emails yourself, you need to ensure you have the correct email address for the payer.

{
confirm_url: {
	method: "POST",
	url: "https://api-platform.flywire.com/payments/v1/checkout/sessions/494d2e9d-c0c9-407c-9094-5b3b2a02c00f/confirm",
},
payor: {
email: "[email protected]"
},
source: "checkout_session",
success: true
}

4. Confirming a Checkout Session

Request

As a security measure to ensure that you are the one who created the session, you have to confirm the Checkout Session.

 

How to Resolve the Path Placeholders of the Endpoint

You don't need to manually resolve the {ID} in the endpoint, as Flywire provides the fully resolved URL via the postMessage (see 3. The postMessage of the Event Listener).

Why should you use the confirm url from the postMessage?

It already contains the correct Checkout Session ID, no need to retrieve it from somewhere else.
You always receive the URL after the form has been sent. If you would try to confirm a Checkout Session before the form has been sent, you'll get an error message
You can only send the request to confirm the Checkout Session once. After a Checkout Session has been confirmed, you'll receive an error if you try to confirm it again.

Parameters for the Request Body

No request body needed.

POST/payments/v1/checkout/sessions/{ID}/confirm

curl https://base-url-placeholder/checkout/sessions/494d2e9d-c0c9-407c-9094-5b3b2a02c00f/confirm
  -X POST
  -H "Content-Type: application/json"
  -H "X-Authentication-Key: {api_key}"

Response

Self-Managed Recurring Payments

After you confirmed the Checkout Session, you receive the payment method token and mandate ID. If you created a Checkout Session of type tokenize_and_pay you also receive information about the payment that has been created.

If you provided a notifications URL for the payment, you’ll start receiving notifications that let you track the payment’s progress (see Payment Status Notifications).

The content of the response depends on which type of Checkout Session you created:

 

payment_method object

Contains information about the payment method the payer used and the payment method token.

You can display the card information in your UI for your payer to make it easier for them to identify which card they saved in your system.

mandate object

It is mandatory to include the mandate ID when charging a recurring payment.

surcharge object

Only returned if a surcharge applies to the payment. If a surcharge is applied and you are handling emails to your payer yourself, you need to include the surcharge information in the pre-notification email.

A surcharge may apply in certain situations, including, but not limited to, mismatches between card currency and payer country, as well as the use of certain card types. If a surcharge applies and the percentage of it depends on the individual settings for the recipient of the payment.

payor object

This information is returned so you can confirm the payer's country and email address.

Why is confirming the payer's country necessary?

Payments in the USA require delivering the receipt to the payer. If Flywire handles emails for you, Flywire will send the receipt automatically. If you are handling emails yourself, you need to ensure to send the receipt to your payer.

Why is confirming the payer's email address necessary?

Even if you pre-filled the payer information with an email address, your payer might have changed it when filling out the form.

If you are handling emails yourself, you need to ensure you have the correct email address for the payer.

{
"payment_method": {
	"token": "232301485cfa4b36bc28",
	"type": "card",
	"card_classification": "credit",
	"last_four_digits": "1111",
	"card_expiration": "03/2030",
	"country": "US",
	"brand": "visa",
	"issuer": "JPMORGAN CHASE BANK, N.A."
	},
"mandate": {
	"id": "MCRUC20230330uAM584YC",
	"currency": "EUR",
	"surcharge": {
		"percentage": 0.03
		}
	},
"payor": {     
	"country": "US",
	"email": "[email protected]",
	"state": "NY"
    }	
}

charge_info object

payment_method object

Contains information about the payment method the payer used and the payment method token.

You can display the card information in your UI for your payer to make it easier for them to identify which card they saved in your system.

mandate object

It is mandatory to include the mandate ID when charging a recurring payment.

surcharge object

Only returned if a surcharge applies to the payment. If a surcharge is applied and you are handling emails to your payer yourself, you need to include the surcharge information in the pre-notification email.

A surcharge may apply in certain situations, including, but not limited to, mismatches between card currency and payer country, as well as the use of certain card types. If a surcharge applies and the percentage of it depends on the individual settings for the recipient of the payment.

payor object

This information is returned so you can confirm the payer's country and email address.

Why is confirming the payer's country necessary?

Payments in the USA require delivering the receipt to the payer. If Flywire handles emails for you, Flywire will send the receipt automatically. If you are handling emails yourself, you need to ensure to send the receipt to your payer.

Why is confirming the payer's email address necessary?

Even if you pre-filled the payer information with an email address, your payer might have changed it when filling out the form.

If you are handling emails yourself, you need to ensure you have the correct email address for the payer.

{
"payment_reference": "RUC208967136",
"charge_info": {
	"amount": 100000,
	"currency": "EUR"
	},
"payment_method": {
	"token": "232301485cfa4b36bc28",
	"type": "card",
	"card_classification": "credit",
	"last_four_digits": "1111",
	"card_expiration": "03/2030",
	"country": "US",
	"brand": "visa",
	"issuer": "JPMORGAN CHASE BANK, N.A."
	},
"mandate": {
	"id": "MCRUC20230330uAM584YC",
	"currency": "EUR",
	"surcharge": {
		"percentage": 0.03
		}
	},
"payor": {     
	"country": "US",
	"email": "[email protected]",
	"state": "NY"
    }					
}

payment_method object

Contains information about the payment method the payer used and the payment method token.

You can display the card information in your UI for your payer to make it easier for them to identify which card they saved in your system.

mandate object

It is mandatory to include the mandate ID when charging a recurring payment.

surcharge object

Only returned if a surcharge applies to the payment. If a surcharge is applied and you are handling emails to your payer yourself, you need to include the surcharge information in the pre-notification email.

A surcharge may apply in certain situations, including, but not limited to, mismatches between card currency and payer country, as well as the use of certain card types. If a surcharge applies and the percentage of it depends on the individual settings for the recipient of the payment.

payor object

This information is returned so you can confirm the payer's country and email address.

Why is confirming the payer's country necessary?

Payments in the USA require delivering the receipt to the payer. If Flywire handles emails for you, Flywire will send the receipt automatically. If you are handling emails yourself, you need to ensure to send the receipt to your payer.

Why is confirming the payer's email address necessary?

Even if you pre-filled the payer information with an email address, your payer might have changed it when filling out the form.

If you are handling emails yourself, you need to ensure you have the correct email address for the payer.

{
"payment_method": {
	"token": "232301485cfa4b36bc28",
	"type": "card",
	"card_classification": "credit",
	"last_four_digits": "1111",
	"card_expiration": "03/2030",
	"country": "US",
	"brand": "visa",
	"issuer": "JPMORGAN CHASE BANK, N.A."
	},
"mandate": {
	"id": "MCRUC20230330uAM584YC",
	"currency": "EUR",
	"surcharge": {
		"percentage": 0.03
		}
	},
"payor": {     
	"country": "US",
	"email": "[email protected]",
	"state": "NY"
    }	
}

payment_method object

Contains information about the payment method the payer used and the payment method token.

mandate object

It is mandatory to include the mandate ID when charging a recurring payment.

payor object

This information is returned so you can confirm the payer's country and email address.

Why is confirming the payer's country necessary?

Payments in the USA require delivering the receipt to the payer. If Flywire handles emails for you, Flywire will send the receipt automatically. If you are handling emails yourself, you need to ensure to send the receipt to your payer.

Why is confirming the payer's email address necessary?

Even if you pre-filled the payer information with an email address, your payer might have changed it when filling out the form.

If you are handling emails yourself, you need to ensure you have the correct email address for the payer.

{
    "payment_method": {
        "token": "_jRS8z0CrDyDI2KshDPZ",
        "type": "direct_debit",
        "last_four_digits": "6789"
    },
    "mandate": {
        "id": "MUUI20230131XCGPRT"
    },
"payor": {     
	"country": "US",
	"email": "[email protected]",
	"state": "NY"
    }						
}

charge_info object

payment_method object

Contains information about the payment method the payer used and the payment method token.

mandate object

It is mandatory to include the mandate ID when charging a recurring payment.

payor object

This information is returned so you can confirm the payer's country and email address.

Why is confirming the payer's country necessary?

Payments in the USA require delivering the receipt to the payer. If Flywire handles emails for you, Flywire will send the receipt automatically. If you are handling emails yourself, you need to ensure to send the receipt to your payer.

Why is confirming the payer's email address necessary?

Even if you pre-filled the payer information with an email address, your payer might have changed it when filling out the form.

If you are handling emails yourself, you need to ensure you have the correct email address for the payer.

{
    "payment_reference": "RUC670821548",
    "charge_info": {
        "amount": 101300,
        "currency": "EUR"
    },
    "payment_method": {
        "token": "UW6JqAuMcJje-SyR3iIG",
        "type": "direct_debit",
        "last_four_digits": "6789"
    },
    "mandate": {
        "id": "MRUC20230330QBZ6MP"
    },
"payor": {     
	"country": "US",
	"email": "[email protected]",
	"state": "NY"
    }

Flywire-Managed Recurring Payments

If you provided a notifications URL for the payment, you’ll start receiving notifications that let you track the payment’s progress (refer to Payment Status Notifications) and the progress of the installment plan (refer to Installment Plan Status Notifications).

payor object

This information is returned so you can confirm the payer's country and email address.

Why is confirming the payer's country necessary?

Payments in the USA require delivering the receipt to the payer. If Flywire handles emails for you, Flywire will send the receipt automatically. If you are handling emails yourself, you need to ensure to send the receipt to your payer.

Why is confirming the payer's email address necessary?

Even if you pre-filled the payer information with an email address, your payer might have changed it when filling out the form.

If you are handling emails yourself, you need to ensure you have the correct email address for the payer.

{
"plan_id": "IPTQQ18EADF349BE",
"payor": {     
	"country": "US",
	"email": "[email protected]",
	"state": "NY"
    }						
}

One Off Payment

It depends on which kind of One Off Payment Checkout Session you created:

If you provided a notifications URL for the payment, you’ll start receiving notifications that let you track the payment’s progress (see Payment Status Notifications).

charge_info object

payor object

This information is returned so you can confirm the payer's country and email address.

Why is confirming the payer's country necessary?

Payments in the USA require delivering the receipt to the payer. If Flywire handles emails for you, Flywire will send the receipt automatically. If you are handling emails yourself, you need to ensure to send the receipt to your payer.

Why is confirming the payer's email address necessary?

Even if you pre-filled the payer information with an email address, your payer might have changed it when filling out the form.

If you are handling emails yourself, you need to ensure you have the correct email address for the payer.

{
"payment_reference": "RUC208967136",
"charge_info": {
	"amount": 100000,
	"currency": "EUR"
	},
"payor": {     
	"country": "US",
	"email": "[email protected]",
	"state": "NY"
    }	
}
If you provided a notifications URL for the payment, you’ll start receiving notifications that let you track the payment’s progress (see Payment Status Notifications).

charge_info object

payor object

This information is returned so you can confirm the payer's country and email address.

Why is confirming the payer's country necessary?

Payments in the USA require delivering the receipt to the payer. If Flywire handles emails for you, Flywire will send the receipt automatically. If you are handling emails yourself, you need to ensure to send the receipt to your payer.

Why is confirming the payer's email address necessary?

Even if you pre-filled the payer information with an email address, your payer might have changed it when filling out the form.

If you are handling emails yourself, you need to ensure you have the correct email address for the payer.

{
"payment_reference": "RUC208967136",
"charge_info": {
	"amount": 100000,
	"currency": "EUR"
	},
"payor": {     
	"country": "US",
	"email": "[email protected]",
	"state": "NY"
    }	
}

Pre-Authorization Payment

Keep in mind that for Pre-Authorization Payments, the payment amount is only being held on the card. The payment is not processed any further until you capture the funds.

If you provided a notifications URL for the payment, you’ll start receiving notifications that let you track the payment’s progress (see Payment Status Notifications).

charge_info object

payor object

This information is returned so you can confirm the payer's country and email address.

Why is confirming the payer's country necessary?

Payments in the USA require delivering the receipt to the payer. If Flywire handles emails for you, Flywire will send the receipt automatically. If you are handling emails yourself, you need to ensure to send the receipt to your payer.

Why is confirming the payer's email address necessary?

Even if you pre-filled the payer information with an email address, your payer might have changed it when filling out the form.

If you are handling emails yourself, you need to ensure you have the correct email address for the payer.

{
"payment_reference": "RUC208967136",
"charge_info": {
	"amount": 100000,
	"currency": "EUR"
	},
"payor": {     
	"country": "US",
	"email": "[email protected]",
	"state": "NY"
    }	
}

 

5. Charging Payments

For Self-Managed Recurring Payments

After tokenizing a card or bank account, you need to charge payments according to the payment schedule, see Creating a Payment within a Self-Managed Recurring Plan.

This is a manual step since Flywire doesn't know your payment schedule, meaning you have to ensure that recurring payments are created on time.

For Flywire-Managed Recurring Payments

You don't need to charge payments manually, Flywire handles this for you.

For One Off Payments

You already charged the payment by confirming the Checkout Session.

For Pre-Authorization Payments

You have to capture the funds during the holding period, see Capturing the Funds for a Pre-Authorization Payment.