SetupIntent constructor

const SetupIntent({
  1. ApplicationOrId? application,
  2. bool? attachToSelf,
  3. PaymentFlowsAutomaticPaymentMethodsSetupIntent? automaticPaymentMethods,
  4. SetupIntentCancellationReason? cancellationReason,
  5. String? clientSecret,
  6. required DateTime created,
  7. BankAccountCustomerOrId? customer,
  8. String? description,
  9. List<SetupAttemptFlowDirectionsItem>? flowDirections,
  10. required String id,
  11. ApiErrors? lastSetupError,
  12. SetupAttemptOrId? latestAttempt,
  13. required bool livemode,
  14. MandateOrId? mandate,
  15. Map<String, String>? metadata,
  16. SetupIntentNextAction? nextAction,
  17. AccountOrId? onBehalfOf,
  18. PaymentMethodOrId? paymentMethod,
  19. PaymentMethodConfigBizPaymentMethodConfigurationDetails? paymentMethodConfigurationDetails,
  20. SetupIntentPaymentMethodOptions? paymentMethodOptions,
  21. required List<String> paymentMethodTypes,
  22. MandateOrId? singleUseMandate,
  23. required SetupIntentStatus status,
  24. required String usage,
})

SetupIntent

A SetupIntent guides you through the process of setting up and saving a customer's payment credentials for future payments. For example, you can use a SetupIntent to set up and save your customer's card without immediately collecting a payment. Later, you can use [PaymentIntents](https://stripe.com/docs/api#payment\_intents) to drive the payment flow. Create a SetupIntent when you're ready to collect your customer's payment credentials. Don't maintain long-lived, unconfirmed SetupIntents because they might not be valid. The SetupIntent transitions through multiple [statuses](https://stripe.com/docs/payments/intents#intent-statuses) as it guides you through the setup process. Successful SetupIntents result in payment credentials that are optimized for future payments. For example, cardholders in [certain regions](/guides/strong-customer-authentication) might need to be run through [Strong Customer Authentication](https://stripe.com/docs/strong-customer-authentication) during payment method collection to streamline later [off-session payments](https://stripe.com/docs/payments/setup-intents). If you use the SetupIntent with a [Customer](https://stripe.com/docs/api#setup\_intent\_object-customer), it automatically attaches the resulting payment method to that Customer after successful setup. We recommend using SetupIntents or [setup_future_usage](https://stripe.com/docs/api#payment\_intent\_object-setup\_future_usage) on PaymentIntents to save payment methods to prevent saving invalid or unoptimized payment methods. By using SetupIntents, you can reduce friction for your customers, even as regulations change over time. Related guide: [Setup Intents API](https://stripe.com/docs/payments/setup-intents)

Implementation

const SetupIntent({
  this.application,
  this.attachToSelf,
  this.automaticPaymentMethods,
  this.cancellationReason,
  this.clientSecret,
  required this.created,
  this.customer,
  this.description,
  this.flowDirections,
  required this.id,
  this.lastSetupError,
  this.latestAttempt,
  required this.livemode,
  this.mandate,
  this.metadata,
  this.nextAction,
  this.onBehalfOf,
  this.paymentMethod,
  this.paymentMethodConfigurationDetails,
  this.paymentMethodOptions,
  required this.paymentMethodTypes,
  this.singleUseMandate,
  required this.status,
  required this.usage,
});