Early bird discounts live! Claim your offer

billing.payment_failed

Recurring charge against creator's payment method fails.

project_id is always null for billing events.

When this fires

A scheduled charge against the creator's payment method fails. The platform will continue to retry inside the grace window.

Required ability

billing:read — token must carry this at mint time to subscribe an endpoint to this event.

Payload

{
  "id": "evt_01HX...",
  "type": "billing.payment_failed",
  "created_at": "2026-04-18T10:05:00Z",
  "api_version": "2026-05-01",
  "project_id": null,
  "data": {
    "creator_id": "cre_01HX...",
    "invoice_id": "in_1Nxy..",
    "amount": "49.00",
    "currency": "USD",
    "attempt_count": 2,
    "reason": "card_declined"
  }
}

Field reference

FieldTypeNotes
idstring ULIDUnique event id, prefixed evt_. Use for idempotent processing.
typestringAlways billing.payment_failed for this event.
created_atISO 8601 timestampServer-side emission time.
api_versionstringWebhook API contract version.
project_idnullAlways null — account-level event.
data.creator_idstring ULIDCreator the invoice was addressed to.
data.invoice_idstringProvider invoice id.
data.amountstringAttempted amount in major units of currency.
data.currencystringISO 4217 currency code.
data.attempt_countintegerProvider-side retry count for this invoice.
data.reasonstringProvider-supplied or normalized rejection reason.

Caveats

  • Multiple billing.payment_failed events can fire for the same invoice_id as Stripe retries.
  • grace_period_warning](./grace-period-warning) and [billing.account_locked`](./account-locked) for that progression.

How is this guide?

On this page

MemberPass is a product designed by you — for you.

No boardroom full of executives deciding what we ships next. Our roadmap always shaped by you with your feedback.

Share feedback or a request