subscription.refunded
Refund recorded against a subscription.
Dispatch site not yet wired. Subscribe an endpoint now and deliveries will land automatically once the firing site ships.
When this fires
A subscription-level refund settles. The subscription may or may not be terminated depending on provider behaviour and the refund's cause.
Required ability
project-subscription:view-any — token must carry this at mint time to subscribe an endpoint to this event.
Payload
{
"id": "evt_01HX...",
"type": "subscription.refunded",
"created_at": "2026-05-20T10:05:00Z",
"api_version": "2026-05-01",
"project_id": "prj_01HX...",
"data": {
"subscription_id": "sub_01HX...",
"plan_id": "pln_01HX...",
"subscriber_id": "usr_01HX...",
"amount": "29.00",
"currency": "USD",
"external_refund_id": "re_3Nxy..",
"reason": "requested_by_customer"
}
}Field reference
| Field | Type | Notes |
|---|---|---|
id | string ULID | Unique event id, prefixed evt_. Use for idempotent processing. |
type | string | Always subscription.refunded for this event. |
created_at | ISO 8601 timestamp | Server-side emission time. |
api_version | string | Webhook API contract version. |
project_id | string ULID | Project this event belongs to. |
data.subscription_id | string ULID | Subscription identifier. |
data.plan_id | string ULID | Plan the subscription is on. |
data.subscriber_id | string ULID | Subscriber's project-scoped user id. |
data.amount | string | Refunded amount in major units of currency, formatted as a string. |
data.currency | string | ISO 4217 currency code. |
data.external_refund_id | string | Provider-side refund identifier. |
data.reason | string | null | Reason code from the provider; absent when not supplied. |
Caveats
- DEFERRED — the dispatch site is not wired yet. Subscriptions taken now stay valid once it ships.
- A subscription may continue to be
activeafter a refund unless the provider's refund flow also cancels the underlying subscription. - For per-payment refunds (no subscription mutation), see
payment.refunded.
Related events
payment.refunded— payment-level analogue (also deferred).subscription.cancelled— often paired in practice.- Subscription events overview — back to family overview.
How is this guide?