## Confirm a PayTo setup Use `stripe.confirmPayToSetup` in the [PayTo Payments with Setup Intents](/payments/payto/set-up-payment.md) flow when the customer submits your setup form. When called, it will confirm the `SetupIntent`, and send a request for authorization to the customer. When you confirm a `SetupIntent`, it needs to have an attached [PaymentMethod](/api/payment_methods.md). In addition to confirming the `SetupIntent`, this method can automatically create and attach a new `PaymentMethod` for you. If you've already attached a `PaymentMethod`, you can call this method without needing to provide any additional data. These use cases are detailed in the sections that follow. > Note that `stripe.confirmPayToSetup` might take some time to complete while waiting for customers to authorize the PayTo agreement. > During that time, you should disable your form from being resubmitted and show a waiting indicator like a spinner. > If you receive an error result, you should be sure to show that error to the customer, re-enable the form, and hide the waiting indicator. By default, `stripe.confirmPayToSetup` will poll for updates to the `SetupIntent`. If there's an error, or when handling `next_action`s manually by using the `handleActions: false` option, it returns a `Promise` which resolves with a `result` object. This object has either: * `result.setupIntent`: the successful [SetupIntent](/api/setup_intents). * `result.error`: an error. Refer to the [API reference](/api/errors) for all possible errors. **Syntax:** `stripe.confirmPayToSetup(...)` - `clientSecret` (string) **required** The [client secret](/api/setup_intents/object.md#setup_intent_object-client_secret) of the `SetupIntent`. - `data` (object) Data to be sent with the request. Refer to the [Setup Intents API](/api/setup_intents/confirm.md) for a full list of parameters. - `payment_method` (string | object) Either the `id` of an existing [PaymentMethod](/api/payment_methods.md), or an object containing data to create a `PaymentMethod` with. See the use case sections below for details. - `options` (object) An options object to control the behavior of this method. - `handleActions` (boolean) Set this to `false` if you want to manually handle polling for SetupIntent updates. Default is `true`. ### Use case: with a new PaymentMethod You can confirm the `SetupIntent` using `stripe.confirmPayToSetup` without passing in any additional data. This will automatically create and attach a new `PaymentMethod`. ### Data argument properties - `payment_method` (object) **required** Pass payment method billing details. - `billing_details` (object) **required** The [billing_details](/api/payment_methods/create.md#create_payment_method-billing_details) associated with the payment. The email is required if the customer is paying with PayID. - `email` (string) - `name` (string) **required** - `payto` (object) **required** The [PayTo payment method details](/api/payment_methods/create.md#create_payment_method-payto) associated with the customer's bank account. Either `pay_id` or `account_number` and `bsb_number` must be provided. - `pay_id` (string) - `account_number` (string) - `bsb_number` (string) ### Confirm with a new PaymentMethod ```js stripe .confirmPayToSetup('{SETUP_INTENT_CLIENT_SECRET}', { { payment_method: { billing_details: { name: 'Jenny Rosen', // Email is only required if `pay_id` is used email: 'jenny@example.com' }, payto: { pay_id: 'jenny@example.com' // Alternatively, provide bank account details account_number: '000123456', bsb_number: '000000' } } } }) .then(function(result) { if (result.error) { // Inform the customer that there was an error. } }); ``` ```es_next const {setupIntent, error} = await stripe.confirmPayToSetup( '{SETUP_INTENT_CLIENT_SECRET}', { payment_method: { billing_details: { name: 'Jenny Rosen', // Email is only required if `pay_id` is used email: 'jenny@example.com' }, payto: { pay_id: 'jenny@example.com' // Alternatively, provide bank account details account_number: '000123456', bsb_number: '000000' } } } ); ``` ### Use case: with an existing payment method Use `stripe.confirmPayToSetup` with an existing `PaymentMethod` by passing its `id` to `payment_method`. The `PaymentMethod` will be used to confirm the `SetupIntent`. ### Data argument properties - `payment_method` (string) **required** The `id` of an existing `PaymentMethod`. ### Confirm with existing payment method ```js stripe .confirmPayToPayment('{PAYMENT_INTENT_CLIENT_SECRET}', { payment_method: '{PAYMENT_METHOD_ID}' }) .then(function(result) { if (result.error) { // Inform the customer that there was an error. } }); ``` ```es_next const {setupIntent, error} = await stripe.confirmPayToPayment( '{PAYMENT_INTENT_CLIENT_SECRET}', { payment_method: '{PAYMENT_METHOD_ID}' }, ); ``` ### Use case: with an attached PaymentMethod If you have already attached a `PaymentMethod` to this `SetupIntent`, then you can confirm the `SetupIntent` using `stripe.confirmPayToSetup` without passing in any additional data. ### Confirm with an attached PaymentMethod ```js stripe .confirmPayToSetup('{SETUP_INTENT_CLIENT_SECRET}') .then(function(result) { if (result.error) { // Inform the customer that there was an error. } }); ``` ```es_next const {setupIntent, error} = await stripe.confirmPayToSetup('{SETUP_INTENT_CLIENT_SECRET}'); ``` ### Confirm a PayTo setup ```js stripe .confirmPayToSetup('{SETUP_INTENT_CLIENT_SECRET}', { { payment_method: { billing_details: { name: 'Jenny Rosen', // Email is only required if `pay_id` is used email: 'jenny@example.com' }, payto: { pay_id: 'jenny@example.com' // Alternatively, provide bank account details account_number: '000123456', bsb_number: '000000' } } } }) .then(function(result) { if (result.error) { // Inform the customer that there was an error. } }); ``` ```es_next const {setupIntent, error} = await stripe.confirmPayToSetup( '{SETUP_INTENT_CLIENT_SECRET}', { payment_method: { billing_details: { name: 'Jenny Rosen', // Email is only required if `pay_id` is used email: 'jenny@example.com' }, payto: { pay_id: 'jenny@example.com' // Alternatively, provide bank account details account_number: '000123456', bsb_number: '000000' } } } ); ```