Partial authorization
Learn how to allow partial payments for card transactions.
Use partial authorizations to request approval for a portion of the originally requested amount for a card transaction when the available balance is insufficient to cover the full amount. This allows your customers to use the available balance on their card (such as a debit card), then use an alternative payment method to pay the remaining balance.
Before you begin
First, decide how you want to handle the portion of the originally requested amount that isn’t covered by the partial authorization. You can create a separate PaymentIntent for another form of payment, cancel the entire PaymentIntent, or capture only up to the partially authorized amount. Make sure to clearly communicate with your customer about how you’re proceeding with the transaction and any potential impact on them.
Compliance
You’re responsible for your compliance with all applicable laws, regulations, and network rules when using partial authorization. Consult the rules for the card networks that you want to use this feature with to make sure your sales comply with all applicable rules, which vary by network. For example, as of May 2024, American Express restricts usage of the feature to only debit and prepaid and doesn’t permit its use with recurring or cross-border transactions, while Visa requires you to use the feature across card types. The information provided on this page relating to your compliance with these requirements is for your general guidance, and isn’t legal, tax, accounting, or other professional advice. Consult with a professional if you’re unsure about your obligations.
Availability 
IC+ feature
You can access partial authorizations on IC+ pricing. Contact your sales representative or support to enable this feature.
Partial authorizations have the following restrictions:
- You can only use partial authorizations for online card payments.
- Only Visa, Mastercard, Discover, and Amex support partial authorizations.
- The issuer and card type determine whether they’re supported.
- Due to network restrictions, you can’t capture more than the authorized amount using overcapture if a transaction amount has been partially authorized.
- If you process charges on behalf of your Connect account using a transfer_amount, Stripe limits it to the partially authorized amount when the
transfer_
is greater than the partially authorized amount.amount - Stripe enforces a minimum charge amount on partially authorized charges, declining any PaymentIntent that falls short.
Use manual capture to create and confirm PaymentIntents 
To enable partial authorization for specific PaymentIntents, set if_
to the request_partial_authorization parameter.
Verify partial authorization status
Review the payment_method_details field on the latest_charge in the PaymentIntent confirmation response to determine whether the networks applied partial authorization for the payment:
- partial_authorization.status: Displays one of the following authorization statuses:
partially_
,authorized fully_
,authorized declined
, ornot_
.requested - amount_requested: Confirms your originally specified request amount.
- amount_authorized: Determines the authorized amount.
The example response below shows that the transaction is partially authorized for 70 USD, which is less than the originally requested 100 USD.
{ "id": "pi_foo", "amount": 7000, "amount_capturable": 7000, "amount_received": 0, "capture_method": "manual", ... // if latest_charge is expanded "latest_charge": { "id": "ch_foo", "object": "charge", "amount": 7000, "captured": false, "payment_method_details": { "card": { "amount_authorized": 7000, "amount_requested": 10000, "partial_authorization": { "status": "partially_authorized", } } } }, ... "status": "requires_capture" }
If the card issuer declines the authorization, this response returns a card_declined error.
Capture the partially authorized PaymentIntent
You can capture an authorized PaymentIntent up to the amount (or amount_capturable) that’s returned in the confirmation response.
A successful capture returns the PaymentIntent object with updated fields:
{ "id": "pi_foo", "amount": 7000, "amount_capturable": 0, "amount_received": 7000, "capture_method": "manual", "latest_charge": "ch_foo", ... "status": "succeeded", }
OptionalUse auto-capture to confirm and capture a PaymentIntent
We recommend using partial authorization with manual capture because it allows you to evaluate the partially authorized amount and decide whether to proceed with the capture. However, you can also use partial authorization with auto-capture. If you decide to use this option, proceed with caution; it’s possible that you might capture an insufficient amount.
You can enable partial authorization with auto-capture functionality by setting:
- request_partial_authorization to
if_
available - capture method to
automatic
(or leave it blank)
In the auto-capture flow, your transaction is automatically captured even if it’s partially authorized. The following example response indicates that the transaction is partially authorized and captured for 70 USD, less than the full 100 USD requested.
{ "id": "pi_foo", "amount": 7000, "amount_capturable": 0, "amount_received": 7000, "capture_method": "automatic", ... // if latest_charge is expanded "latest_charge": { "id": "ch_foo", "object": "charge", "amount": 7000, "amount_captured": 7000, "captured": true, "payment_method_details": { "card": { "amount_authorized": 7000, "amount_requested": 10000, "partial_authorization": { "status": "partially_authorized", } } } }, ... "status": "succeeded" }
OptionalIncrement with partial authorization
You can request partial authorization in the PaymentIntent increment authorization call to get approval for a portion of the requested increment amount when the available balance isn’t enough to cover the full amount.
Create and confirm a PaymentIntent
Create and confirm a PaymentIntent with incremental authorization enabled using the request_incremental_authorization parameter. This enables the incremental authorization feature on the PaymentIntent. See incremental authorization to learn more.
The following example response shows that the transaction is fully authorized for 100 USD:
{ "id": "pi_foo", "amount": 10000, "amount_capturable": 10000, "amount_received": 0, "capture_method": "manual", ... // if latest_charge is expanded "latest_charge": { "id": "ch_foo", "object": "charge", "amount": 10000, "captured": false, "payment_method_details": { "card": { "amount_authorized": 10000, "amount_requested": 10000, "partial_authorization": { "status": "not_requested", }, "incremental_authorization": { "status": "available" } } } }, ... "status": "requires_capture" }
Enable partial authorization on increment
To enable partial authorization on increments, set request_partial_authorization to if_
:
By default, Stripe retains the opt-in parameter for request_partial_authorization that you pass during PaymentIntent confirmation for increments. To disable partial authorizations for increments on a PaymentIntent that has opted for partial authorization, set payment_
to never
.
The example requests attempts to increment the PaymentIntent amount to 150 USD from 100 USD, but it’s partially authorized to 135 USD.
curl https://api.stripe.com/v1/payment_intents/pi_foo/increment_authorization \ -u
: \ -d "amount"=15000 \ -d "payment_method_options[card][request_partial_authorization]"="if_available" \ -d "expand[]"="latest_charge"sk_test_BQokikJOvBiI2HlWgH4olfQ2
The example response below shows the most recent Charge object associated with the partially authorized PaymentIntent object:
{ "id": "pi_foo", "amount": 13500, "amount_capturable": 13500, "amount_received": 0, "capture_method": "manual", ... // if latest_charge is expanded "latest_charge": { "id": "ch_foo", "object": "charge", "amount": 13500, "captured": false, "payment_method_details": { "card": { "amount_authorized": 13500, "amount_requested": 15000, "partial_authorization": { "status": "partially_authorized", } } } }, ... "status": "requires_capture" }
Test your integration 
To trigger a partial authorization while testing, use the partial authorization Stripe test card with any CVC, postal code, and future expiration date. Make sure to set request_partial_authorization to if_
to trigger partial authorization with the test card.
Test card number | Payment method | Description |
---|---|---|
pm_ | This card authorizes 70% of the amount specified in the confirmation request rounded down to the nearest unit (for example, cents) with partial authorization requested. Otherwise, it declines it with an insufficient funds error code. | |
pm_ | This card fully authorizes the initial authorization. For subsequent increments, this card authorizes 70% of the amount specified in the increment request rounded down to the nearest unit (for example, cents) with partial authorization requested. Otherwise, it returns insufficient funds. |