Partially capturing or canceling payments no longer creates a RefundBreaking changes
What’s new
The following flows no longer result in a Refund
object created and linked to the payment:
- Partial capture
- Payment cancellation (both manual and automated)
Why is this a breaking change?
This change might break your integration in the following scenarios:
- If your integration expects a partial capture or payment cancellation to create a refund object.
- If your integration expects a partial capture to create two balance transactions.
For more details about possible effects on your integration, see the following breakdown.
Impact
This change affects your integration if you depend on the Refund
object or any related fields for capture reversals or for payment cancellation. Removal of the Refund
object affects the following fields or objects.
Refund object
- A
Refund
object representing the cancellation or capture reversal will no longer be created. - It won’t be returned when calling to get all refunds associated with the payment intent or charge.
- It won’t be present in any webhook events.
- It won’t be present on the
Charge
object in any API response. - It won’t be visible on the Dashboard.
PaymentIntent Object
- A new
cancellation_
value calledreason expired
will be introduced. This new value represents payments canceled because of authorization expiration. It replaces the formerly used value ofautomatic
.
Charge object
amount_
will be 0 instead ofcaptured nil
in payment cancellation flows.amount_
will no longer be updated by these actions.refunded refunded
will no longer betrue
for payment cancellation flows.
Balance transactions
- There will only be a single balance transaction for partial captures. There will no longer be a balance transaction representing the amount and fees reversed.
- The balance transaction representing the capture will show the amount captured instead of the amount authorized for the related payment.
Webhooks
- We’ll no longer send
charge.
andrefunded charge.
events.refund. updated - We’ll still send
charge.
,expired charge.
, andcaptured payment_
events for their respective flows.intent. canceled
Radar payment review
- If applicable, a Radar payment review will be closed upon payment cancellation with the reason
canceled
instead ofrefunded
.
Changes
Upgrade
Related changes
- Updates the Vault and Forward API to return a 402 status code for upstream request timeouts
- Deprecates manual capture method for Interac cards
- Payment Methods won’t allow modifying fields for Naver Pay once the object is first created
- Adds support for Klarna in the Hosted Invoice Page
- Adds ability to configure saved payment methods for one-time payments on the Hosted Invoice Page
- Adds support for saving and reusing Naver Pay payment methods
- Adds support for the Billie local payment method
- Adds support for the Satispay local payment method
- Makes the client parameter optional for WeChat Pay until confirmation
- Adds support for the New Zealand BECS Direct Debit local payment method