Struct PaymentIntent

Source
pub struct PaymentIntent {
Show 39 fields pub amount: i64, pub amount_capturable: i64, pub amount_details: Option<PaymentFlowsAmountDetails>, pub amount_received: i64, pub application: Option<Expandable<Application>>, pub application_fee_amount: Option<i64>, pub automatic_payment_methods: Option<PaymentFlowsAutomaticPaymentMethodsPaymentIntent>, pub canceled_at: Option<i64>, pub cancellation_reason: Option<PaymentIntentCancellationReason>, pub capture_method: PaymentIntentCaptureMethod, pub client_secret: Option<String>, pub confirmation_method: PaymentIntentConfirmationMethod, pub created: i64, pub currency: Currency, pub customer: Option<Expandable<Customer>>, pub description: Option<String>, pub id: PaymentIntentId, pub last_payment_error: Option<Box<ApiErrors>>, pub latest_charge: Option<Expandable<Charge>>, pub livemode: bool, pub metadata: HashMap<String, String>, pub next_action: Option<PaymentIntentNextAction>, pub on_behalf_of: Option<Expandable<Account>>, pub payment_method: Option<Expandable<PaymentMethod>>, pub payment_method_configuration_details: Option<PaymentMethodConfigBizPaymentMethodConfigurationDetails>, pub payment_method_options: Option<PaymentIntentPaymentMethodOptions>, pub payment_method_types: Vec<String>, pub presentment_details: Option<PaymentFlowsPaymentIntentPresentmentDetails>, pub processing: Option<PaymentIntentProcessing>, pub receipt_email: Option<String>, pub review: Option<Expandable<Review>>, pub setup_future_usage: Option<PaymentIntentSetupFutureUsage>, pub shipping: Option<Shipping>, pub source: Option<Expandable<PaymentSource>>, pub statement_descriptor: Option<String>, pub statement_descriptor_suffix: Option<String>, pub status: PaymentIntentStatus, pub transfer_data: Option<TransferData>, pub transfer_group: Option<String>,
}
Expand description

A PaymentIntent guides you through the process of collecting a payment from your customer. We recommend that you create exactly one PaymentIntent for each order or customer session in your system. You can reference the PaymentIntent later to see the history of payment attempts for a particular session.

A PaymentIntent transitions through multiple statuses throughout its lifetime as it interfaces with Stripe.js to perform authentication flows and ultimately creates at most one successful charge.

Related guide: Payment Intents API

For more details see <https://stripe.com/docs/api/payment_intents/object>.

Fields§

§amount: i64

Amount intended to be collected by this PaymentIntent. A positive integer representing how much to charge in the smallest currency unit (e.g., 100 cents to charge $1.00 or 100 to charge ¥100, a zero-decimal currency). The minimum amount is $0.50 US or equivalent in charge currency. The amount value supports up to eight digits (e.g., a value of 99999999 for a USD charge of $999,999.99).

§amount_capturable: i64

Amount that can be captured from this PaymentIntent.

§amount_details: Option<PaymentFlowsAmountDetails>§amount_received: i64

Amount that this PaymentIntent collects.

§application: Option<Expandable<Application>>

ID of the Connect application that created the PaymentIntent.

§application_fee_amount: Option<i64>

The amount of the application fee (if any) that will be requested to be applied to the payment and transferred to the application owner’s Stripe account. The amount of the application fee collected will be capped at the total amount captured. For more information, see the PaymentIntents use case for connected accounts.

§automatic_payment_methods: Option<PaymentFlowsAutomaticPaymentMethodsPaymentIntent>

Settings to configure compatible payment methods from the Stripe Dashboard.

§canceled_at: Option<i64>

Populated when status is canceled, this is the time at which the PaymentIntent was canceled. Measured in seconds since the Unix epoch.

§cancellation_reason: Option<PaymentIntentCancellationReason>

Reason for cancellation of this PaymentIntent, either user-provided (duplicate, fraudulent, requested_by_customer, or abandoned) or generated by Stripe internally (failed_invoice, void_invoice, automatic, or expired).

§capture_method: PaymentIntentCaptureMethod

Controls when the funds will be captured from the customer’s account.

§client_secret: Option<String>

The client secret of this PaymentIntent. Used for client-side retrieval using a publishable key.

The client secret can be used to complete a payment from your frontend. It should not be stored, logged, or exposed to anyone other than the customer. Make sure that you have TLS enabled on any page that includes the client secret.

Refer to our docs to accept a payment and learn about how client_secret should be handled.

§confirmation_method: PaymentIntentConfirmationMethod

Describes whether we can confirm this PaymentIntent automatically, or if it requires customer action to confirm the payment.

§created: i64

Time at which the object was created. Measured in seconds since the Unix epoch.

§currency: Currency

Three-letter ISO currency code, in lowercase. Must be a supported currency.

§customer: Option<Expandable<Customer>>

ID of the Customer this PaymentIntent belongs to, if one exists.

Payment methods attached to other Customers cannot be used with this PaymentIntent.

If setup_future_usage is set and this PaymentIntent’s payment method is not card_present, then the payment method attaches to the Customer after the PaymentIntent has been confirmed and any required actions from the user are complete. If the payment method is card_present and isn’t a digital wallet, then a generated_card payment method representing the card is created and attached to the Customer instead.

§description: Option<String>

An arbitrary string attached to the object. Often useful for displaying to users.

§id: PaymentIntentId

Unique identifier for the object.

§last_payment_error: Option<Box<ApiErrors>>

The payment error encountered in the previous PaymentIntent confirmation. It will be cleared if the PaymentIntent is later updated for any reason.

§latest_charge: Option<Expandable<Charge>>

ID of the latest Charge object created by this PaymentIntent. This property is null until PaymentIntent confirmation is attempted.

§livemode: bool

Has the value true if the object exists in live mode or the value false if the object exists in test mode.

§metadata: HashMap<String, String>

Set of key-value pairs that you can attach to an object. This can be useful for storing additional information about the object in a structured format. Learn more about storing information in metadata.

§next_action: Option<PaymentIntentNextAction>

If present, this property tells you what actions you need to take in order for your customer to fulfill a payment using the provided source.

§on_behalf_of: Option<Expandable<Account>>

The account (if any) for which the funds of the PaymentIntent are intended. See the PaymentIntents use case for connected accounts for details.

§payment_method: Option<Expandable<PaymentMethod>>

ID of the payment method used in this PaymentIntent.

§payment_method_configuration_details: Option<PaymentMethodConfigBizPaymentMethodConfigurationDetails>

Information about the payment method configuration used for this PaymentIntent.

§payment_method_options: Option<PaymentIntentPaymentMethodOptions>

Payment-method-specific configuration for this PaymentIntent.

§payment_method_types: Vec<String>

The list of payment method types (e.g. card) that this PaymentIntent is allowed to use. A comprehensive list of valid payment method types can be found here.

§presentment_details: Option<PaymentFlowsPaymentIntentPresentmentDetails>§processing: Option<PaymentIntentProcessing>

If present, this property tells you about the processing state of the payment.

§receipt_email: Option<String>

Email address that the receipt for the resulting payment will be sent to. If receipt_email is specified for a payment in live mode, a receipt will be sent regardless of your email settings.

§review: Option<Expandable<Review>>

ID of the review associated with this PaymentIntent, if any.

§setup_future_usage: Option<PaymentIntentSetupFutureUsage>

Indicates that you intend to make future payments with this PaymentIntent’s payment method.

If you provide a Customer with the PaymentIntent, you can use this parameter to attach the payment method to the Customer after the PaymentIntent is confirmed and the customer completes any required actions. If you don’t provide a Customer, you can still attach the payment method to a Customer after the transaction completes.

If the payment method is card_present and isn’t a digital wallet, Stripe creates and attaches a generated_card payment method representing the card to the Customer instead.

When processing card payments, Stripe uses setup_future_usage to help you comply with regional legislation and network rules, such as SCA.

§shipping: Option<Shipping>

Shipping information for this PaymentIntent.

§source: Option<Expandable<PaymentSource>>

This is a legacy field that will be removed in the future. It is the ID of the Source object that is associated with this PaymentIntent, if one was supplied.

§statement_descriptor: Option<String>

Text that appears on the customer’s statement as the statement descriptor for a non-card charge. This value overrides the account’s default statement descriptor. For information about requirements, including the 22-character limit, see the Statement Descriptor docs.

Setting this value for a card charge returns an error. For card charges, set the statement_descriptor_suffix instead.

§statement_descriptor_suffix: Option<String>

Provides information about a card charge. Concatenated to the account’s statement descriptor prefix to form the complete statement descriptor that appears on the customer’s statement.

§status: PaymentIntentStatus

Status of this PaymentIntent, one of requires_payment_method, requires_confirmation, requires_action, processing, requires_capture, canceled, or succeeded. Read more about each PaymentIntent status.

§transfer_data: Option<TransferData>

The data that automatically creates a Transfer after the payment finalizes. Learn more about the use case for connected accounts.

§transfer_group: Option<String>

A string that identifies the resulting payment as part of a group. Learn more about the use case for connected accounts.

Trait Implementations§

Source§

impl Clone for PaymentIntent

Source§

fn clone(&self) -> PaymentIntent

Returns a duplicate of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl Debug for PaymentIntent

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result<(), Error>

Formats the value using the given formatter. Read more
Source§

impl Deserialize for PaymentIntent

Source§

fn begin(out: &mut Option<PaymentIntent>) -> &mut dyn Visitor

The only correct implementation of this method is: Read more
Source§

impl Object for PaymentIntent

Source§

type Id = PaymentIntentId

The canonical id type for this object.
Source§

fn id(&self) -> &<PaymentIntent as Object>::Id

The id of the object.
Source§

fn into_id(self) -> <PaymentIntent as Object>::Id

The owned id of the object.
Source§

impl ObjectDeser for PaymentIntent

Source§

type Builder = PaymentIntentBuilder

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more