Refunding Payments
API/Endpoint Usage Flow for Refund Process:
- Customer requests a refund:
 The customer contacts your support team or uses a self-service option in your platform to request a refund.
- Create a refund request:
 Upon receiving a refund request, your platform should initiate a POST request to the refunds endpoint, including required parameters such as the buyer's email, refund amount, and currency.
Note - your BitPay ledger must hold funds in excess of the refund amount before you can create the refund request. If you need to verify your ledger balance, you can use an API call, or manually check using your merchant dashboard.
- Instant Payment Notification (IPN) for refund initiation:
 BitPay sends an IPN to your specified notification URL when the refund is initiated, providing you with the refund details. Your platform should handle the IPN by validating the received data and updating the refund status accordingly.
- Customer accepts the refund:
 The customer receives an email from BitPay with a link to accept the refund. They need to click the link and provide the required information, such as their wallet address, within a specified time frame.
- Monitor webhooks/IPNs (Instant Payment Notifications) for refund status updates:
 BitPay sends additional IPNs to your specified notification URL as the refund status changes, such as when the refund is successfully processed or expires. Your platform should handle these IPNs by updating the refund status and notifying the customer accordingly.
- Refund completed:
 Once the refund has been processed successfully, your platform should have already updated the refund status based on the received IPN. Notify the customer that their refund has been completed.
Manual Flow for Refund Process:
- Customer requests a refund:
 The customer contacts your support team or uses a self-service option in your platform to request a refund.
- Create a refund request:
 Log in to your BitPay merchant dashboard. Navigate to the "Payments" tab. From here, locate the payment that you need to refund. You may need to expand the time range selection. Click on the payment, and then click "Refund" in the top-right corner. You will be prompted to provide the amount to be refunded, and possibly an email address depending on how the customer paid.
Note - your BitPay ledger must hold funds in excess of the refund amount before you can create the refund request. Check the balance on the "Overview" tab.
- Monitor refund status:
 You can view the status of the refund from the "Payments" tab if you would like to do so.
- Customer accepts the refund:
 The customer receives an email from BitPay with a link to accept the refund. They need to click the link and provide the required information, such as their wallet address, within a specified time frame.
- Refund completed:
 You will see the payment as "Refunded" in your merchant dashboard.
Updated about 1 month ago
