Moving money with Treasury using CreditReversal objects
Learn how you can return funds from received credits that add money to your Treasury financial account.
Reversing a ReceivedCredit creates a CreditReversal. You can reverse ReceivedCredits
only in some scenarios (detailed in the following table). Whether you can reverse a ReceivedCredit
depends on the network and source flow.
The reversal_
sub-hash on the ReceivedCredit
object can have the following combination of values, which determines if you can reverse the ReceivedCredit
.
RESTRICTED REASON | DEADLINE (EPOCH TIMESTAMP) | EXAMPLE SCENARIO |
---|---|---|
source_ | null | A Stripe network ReceivedCredit that’s the result of a flow other than an OutboundPayment . Stripe restricts users from reversing such ReceivedCredits . |
network_ | null | Network constraints prevent Stripe from allowing reversal on some ReceivedCredits , such as a ReceivedCredit from a wire transfer. |
null | {{TIMESTAMP}} | A ReceivedCredit , which is reversible, but only until the timestamp in deadline . ACH ReceivedCredits have a deadline that determines how long you have to reverse them. |
deadline_ | {{TIMESTAMP}} | A ReceivedCredit that’s reversible before the timestamp in deadline , but is no longer reversible because the deadline has passed. ACH ReceivedCredits have a limited time of when they’re reversible after they’re created. |
already_ | null | A ReceivedCredit that’s already reversed has this restricted_ . It might have a non-null deadline value. |
null | null | You can reverse ReceivedCredits anytime if they have null for both restricted_ and deadline . |
Creating a CreditReversal
Use POST /v1/treasury/credit_
to create a CreditReversal
. Set the received_
parameter in the body of the request to the value of the ReceivedCredit
ID to reverse.
Note
You can’t update CreditReversals
, so you must set any optional metadata on creation.
The following request creates a CreditReversal
based on the ReceivedCredit
ID value on the required received_
parameter. The request also sets an optional metadata value.
If successful, the response returns the new CreditReversal
object.
{ "id": "{{CREDIT_REVERSAL_ID}}", "object": "credit_reversal", "amount": 1000, "currency": "usd", "financial_account": "{{FINANCIAL_ACCOUNT_ID}}", "hosted_regulatory_receipt_url": "https://payments.stripe.com/regulatory-receipt/{{URL_ID}}", "livemode": false, "metadata": { "csr_id": "CSR-12"
Retrieve a CreditReversal
Use GET /v1/treasury/credit_
to retrieve the CreditReversal
with the associated ID.
The response returns the specific CreditReversal
object.
List CreditReversals
Use GET /v1/treasury/credit_
to retrieve a list of CreditReversals
for the financial account with the ID provided in the required financial_
parameter. You can filter the list by standard list parameters, status
, or by ReceivedCredit
ID using the received_
parameter.
{ // Standard list parameters "limit", "starting_after", "ending_before", // Filter by status "status": "processing" | "posted", // Filter by FinancialAccount (Required) "financial_account": "{{FINANCIAL_ACCOUNT_ID}}", // Filter by ReceivedCredit "received_credit": "{{RECEIVED_CREDIT_ID}}" }
The following request returns the three most recent credit reversals with a status of posted
for the specified financial account.
If successful, the response returns the relevant list of CreditReversal objects.
Testing CreditReversals
To test CreditReversals, you must first create test mode ReceivedCredits. Then use POST /v1/treasury/credit_
and specify the test mode ReceivedCredit
ID in the received_
parameter to create a test mode CreditReversal
.
CreditReversal Webhooks
Stripe emits the following CreditReversal
events to your webhook endpoint:
treasury.
oncredit_ reversal. created CreditReversal
creation.treasury.
when thecredit_ reversal. posted CreditReversal
posts.