Save directly without charging
Collect details of a present card and save them for online use.
Use SetupIntents to collect card details without charging the card. A SetupIntent can’t save a card_
PaymentMethod directly, but in most cases you can create a reusable generated_
PaymentMethod that represents the same card. From your customer’s perspective, they’re the same payment method.
You can use SetupIntents to collect card details on Visa, Mastercard, American Express, Discover, co-branded Interac, and co-branded eftpos cards. Single-branded Interac cards and single-branded eftpos cards aren’t supported.
Note
For businesses in certain verticals, Stripe offers a limited private beta feature that allows you to save digital wallet payment methods. To request access, contact stripe-terminal-betas@stripe.com.
Saving cards with Stripe Terminal using SetupIntents requires you to:
- Create or retrieve a Customer object.
- Create a SetupIntent object to track the process.
- Collect a payment method after collecting the customer’s consent.
- Submit the payment method details to Stripe.
Note
As of October 2024, we’ve changed the customer consent model to use the allow_
parameter instead of the legacy customer_
parameter. If your integration uses customer_
, you must update it to use allow_
before March 31, 2025. For guidance, see the changelog entry.
Note
The server-driven-based SetupIntents API is compatible with BBPOS WisePOS E and Stripe Reader S700.
Create or retrieve a customer
To charge a card saved with Stripe, you must attach it to a Customer.
When you include a customer in your SetupIntent before confirming, Stripe automatically attaches the generated card payment method to the Customer object you provide.
Include the following code on your server to create a new Customer
.
Create a SetupIntent
Note
We recommend providing a customer ID while creating a SetupIntent—doing so attaches the card payment method to the Customer
upon successful setup. If you don’t provide a customer ID, you must attach the payment method in a separate call.
A SetupIntent is an object that represents your intent to set up a customer’s payment method for future payments. The SetupIntent tracks the steps of this setup process. For Terminal, this includes collecting and recording cardholder consent.
You must create the SetupIntent on your server and include card_
on the payment_
parameter.
The SetupIntent contains a client secret, which is a key that’s unique to the individual SetupIntent. You must obtain the client secret from the SetupIntent on your server and pass it to the client side.
Collect a payment method for saving cards
After you create a SetupIntent, you need to collect a payment method and collect customer consent. Pass allow_redisplay as always
or limited
, indicating the degree to which a payment method can be shown in a customer checkout flow.
After you create a SetupIntent, you need to collect a payment method and collect customer consent. If the customer provides the required form of agreement or consent, set the customer_
Boolean to true.
Note
Collect customer consent verbally or with a checkbox in your application. You must comply with all applicable laws, rules, and regulations in your region.
You must call the process_setup_intent endpoint, which handles both collecting and confirming the SetupIntent. If the customer provides consent, set allow_
to either always
or limited
.
This method collects encrypted payment method data using the connected card reader, and associates the encrypted data with the SetupIntent.
Caution
Collecting a payment method happens locally and requires no authorization or updates to the SetupIntent object until the next step.
Cancel collection
Programmatic cancellation
You can cancel collecting a payment method by calling cancel_action.
Submit the payment method details to Stripe
Your previous call to process_setup_intent handles the confirm for you, so no further action is necessary.
A successful setup returns a succeeded
value for the SetupIntent’s status property, along with a SetupAttempt.payment_method_details.card_present.generated_card, which is a reusable card
payment method you can use for online payments.
Note
The SetupIntent.payment_method is a card_
PaymentMethod that represents the tokenization of the physically present card and isn’t chargeable online. Future payments use the generated card instead. From the customer’s perspective, they’re the same payment method.
The generated_
payment method automatically attaches to the customer you provided during SetupIntent creation. You can retrieve the generated_
payment method by expanding the SetupIntent’s latest_
property. Always check for a generated_
value, because for payment methods that don’t allow generated cards, the value is empty.
Alternatively, you can retrieve the attached payment method by fetching the list of payment methods that gets attached to the customer.
If you didn’t provide a customer during SetupIntent creation, you can attach the generated_
to a Customer object in a separate call.
If the setup isn’t successful, inspect the returned error to determine the cause. For example, failing to collect and notify Stripe of customer consent results in an error.
Compliance
You’re responsible for your compliance with all applicable laws, regulations, and network rules when saving a customer’s payment details. For example, the European Data Protection Board has issued guidance regarding saving payment details. These requirements generally apply if you want to save your customer’s payment method for future use, such as presenting a customer’s payment method to them in the checkout flow for a future purchase or charging them when they’re not actively using your website or app.
Add terms to your website or app that state how you plan to save payment method details and allow customers to opt in. If you plan to charge the customer while they’re offline, then at a minimum, make sure that your terms also cover the following:
- The customer’s agreement to your initiating a payment or a series of payments on their behalf for specified transactions.
- The anticipated timing and frequency of payments (for instance, whether charges are for scheduled installment or subscription payments, or for unscheduled top-ups).
- How the payment amount is determined.
- Your cancellation policy, if you’re setting up the payment method for a subscription service.
Make sure you keep a record of your customer’s written agreement to these terms.
When you save a payment method, it can only be used for the specific usage that you included in your terms. If you want to charge customers when they’re offline and also save the customer’s payment method to present to them as a saved payment method for future purchases, you must explicitly collect consent from the customer. One way to do so is with a “Save my payment method for future use” checkbox.
Save digital wallets
If your MCC is in one of the following ranges, you might be eligible to participate in a limited beta for saving digital wallet payment methods. For more details, contact stripe-terminal-betas@stripe.com.
- Car Rental Agencies (3351 - 3500)
- Lodging – Hotels, Motels, Resorts (3501 - 3999)
- Steamship and Cruise Lines (4411)
- Boat Rentals and Leasing (4457)
- Lodging - Hotels, Motels, Resorts, Central Reservations Services (Not Elsewhere Classified) (7011)
- Trailer Parks and Campgrounds (7033)
- Equipment, Tool, Furniture, and Appliance Rental and Leasing (7394)
- Car Rental Agencies (Not Elsewhere Classified) (7512)
- Truck and Utility Trailer Rentals (7513)
- Motor Home and Recreational Vehicle Rentals (7519)
When you save a digital wallet payment method, the generated_
has allow_
, because checkout flows are prohibited from presenting saved digital wallets as a payment option. You can only charge saved digital wallet payment methods for off_session payments.