Early bird discounts live! Claim your offer

payment.pending

Payment initiated, awaiting provider confirmation.

When this fires

A subscriber initiates checkout and is redirected to the provider, but the charge is not yet confirmed (bank transfer, crypto settlement, hosted-checkout sessions).

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": "payment.pending",
  "created_at": "2026-05-18T10:05:00Z",
  "api_version": "2026-05-01",
  "project_id": "prj_01HX...",
  "data": {
    "provider": "stripe",
    "plan_id": "pln_01HX...",
    "subscriber_id": "usr_01HX...",
    "session_id": "cs_test_..",
    "order_id": null
  }
}

Field reference

FieldTypeNotes
idstring ULIDUnique event id, prefixed evt_. Use for idempotent processing.
typestringAlways payment.pending for this event.
created_atISO 8601Server-side emission time.
api_versionstringWebhook API contract version.
project_idstring ULIDProject this event belongs to.
data.providerstringProvider slug.
data.plan_idstring ULIDPlan being purchased.
data.subscriber_idstring ULIDSubscriber's project-scoped user id.
data.session_idstring | nullProvider checkout-session id when applicable (Stripe Checkout, etc.).
data.order_idstring | nullProvider order id when applicable (PayPal, etc.).

Caveats

  • A pending payment is not yet a subscription. subscription_id is intentionally absent.
  • The same checkout may emit one payment.pending followed by either payment.succeeded or payment.failed. Use session_id / order_id to correlate.
  • Subscribers who close the provider page without completing will not produce a final outcome event — pending sessions can hang indefinitely.

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