Early bird discounts live! Claim your offer

subscription.created

New subscription becomes active via paid checkout, access code, or trial.

Always precedes member.joined for paid plans and member.trial_joined when trial_ends_at is set.

When this fires

A new subscription is created as the result of a successful paid checkout, an access-code redemption, or a trial activation.

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.created",
  "created_at": "2026-05-18T10:05:00Z",
  "api_version": "2026-05-01",
  "project_id": "prj_01HX...",
  "data": {
    "subscription_id": "sub_01HX...",
    "plan_id": "pln_01HX...",
    "subscriber_id": "usr_01HX...",
    "trial_ends_at": null,
    "access_code": null
  }
}

Field reference

FieldTypeNotes
idstring ULIDUnique event id, prefixed evt_. Use for idempotent processing.
typestringAlways subscription.created for this event.
created_atISO 8601 timestampServer-side emission time.
api_versionstringWebhook API contract version.
project_idstring ULIDProject this event belongs to.
data.subscription_idstring ULIDSubscription identifier.
data.plan_idstring ULIDPlan the subscription is on.
data.subscriber_idstring ULIDThe subscriber's project-scoped user id.
data.trial_ends_atISO 8601 timestamp | nullSet when the subscription started in trial state; otherwise null.
data.access_codestring | nullMasked code (last 5 chars only) when redemption is the trigger.

Caveats

  • Listeners should treat this event as the canonical "the subscription exists" signal — don't act on payment.succeeded alone.
  • For trials, subscription.trial_started fires alongside; for paid checkouts, payment.succeeded follows.

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