Mayson Monorepo Documentation
    Preparing search index...

    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

    interface PaymentIntent {
        id: string;
        object: "payment_intent";
        amount: number;
        amount_capturable: number;
        amount_details?: Stripe.PaymentIntent.AmountDetails;
        amount_received: number;
        application: string | Application;
        application_fee_amount: number;
        automatic_payment_methods: Stripe.PaymentIntent.AutomaticPaymentMethods;
        canceled_at: number;
        cancellation_reason: Stripe.PaymentIntent.CancellationReason;
        capture_method: Stripe.PaymentIntent.CaptureMethod;
        client_secret: string;
        confirmation_method: Stripe.PaymentIntent.ConfirmationMethod;
        created: number;
        currency: string;
        customer: string | Stripe.Customer | DeletedCustomer;
        customer_account: string;
        description: string;
        excluded_payment_method_types: Stripe.PaymentIntent.ExcludedPaymentMethodType[];
        hooks?: Stripe.PaymentIntent.Hooks;
        last_payment_error: Stripe.PaymentIntent.LastPaymentError;
        latest_charge: string | Stripe.Charge;
        livemode: boolean;
        metadata: Metadata;
        next_action: Stripe.PaymentIntent.NextAction;
        on_behalf_of: string | Stripe.Account;
        payment_details?: Stripe.PaymentIntent.PaymentDetails;
        payment_method: string | Stripe.PaymentMethod;
        payment_method_configuration_details: Stripe.PaymentIntent.PaymentMethodConfigurationDetails;
        payment_method_options: Stripe.PaymentIntent.PaymentMethodOptions;
        payment_method_types: string[];
        presentment_details?: Stripe.PaymentIntent.PresentmentDetails;
        processing: Stripe.PaymentIntent.Processing;
        receipt_email: string;
        review: string | Stripe.Review;
        setup_future_usage: Stripe.PaymentIntent.SetupFutureUsage;
        shipping: Stripe.PaymentIntent.Shipping;
        source: string | CustomerSource | DeletedCustomerSource;
        statement_descriptor: string;
        statement_descriptor_suffix: string;
        status: Stripe.PaymentIntent.Status;
        transfer_data?: Stripe.PaymentIntent.TransferData;
        transfer_group: string;
    }
    Index

    Properties

    id: string

    Unique identifier for the object.

    object: "payment_intent"

    String representing the object's type. Objects of the same type share the same value.

    amount: number

    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: number

    Amount that can be captured from this PaymentIntent.

    amount_received: number

    Amount that this PaymentIntent collects.

    application: string | Application

    ID of the Connect application that created the PaymentIntent.

    application_fee_amount: number

    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: Stripe.PaymentIntent.AutomaticPaymentMethods

    Settings to configure compatible payment methods from the Stripe Dashboard

    canceled_at: number

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

    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).

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

    client_secret: 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.

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

    created: number

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

    currency: string

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

    customer: string | Stripe.Customer | DeletedCustomer

    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.

    customer_account: string

    ID of the Account representing the customer that this PaymentIntent belongs to, if one exists.

    Payment methods attached to other Accounts 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 Account 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 Account instead.

    description: string

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

    excluded_payment_method_types: Stripe.PaymentIntent.ExcludedPaymentMethodType[]

    The list of payment method types to exclude from use with this payment.

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

    latest_charge: string | Stripe.Charge

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

    livemode: boolean

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

    metadata: Metadata

    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.

    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: string | Stripe.Account

    You can specify the settlement merchant as the connected account using the on_behalf_of attribute on the charge. See the PaymentIntents use case for connected accounts for details.

    payment_method: string | Stripe.PaymentMethod

    ID of the payment method used in this PaymentIntent.

    payment_method_configuration_details: Stripe.PaymentIntent.PaymentMethodConfigurationDetails

    Information about the payment method configuration used for this PaymentIntent.

    payment_method_options: Stripe.PaymentIntent.PaymentMethodOptions

    Payment-method-specific configuration for this PaymentIntent.

    payment_method_types: 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.

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

    receipt_email: 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: string | Stripe.Review

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

    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 information for this PaymentIntent.

    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: 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: 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 of this PaymentIntent, one of requires_payment_method, requires_confirmation, requires_action, processing, requires_capture, canceled, or succeeded. Read more about each PaymentIntent status.

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

    transfer_group: string

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