Early bird discounts live! Claim your offer

plan.sync_completed

Plan synced to PSP catalog (Stripe / PayPal / Razorpay / Paystack).

When this fires

The plan finishes syncing to one or more external payment-provider catalogs (Stripe, PayPal, Razorpay, Paystack). Fires once per provider sync run, not per plan.

Required ability

project-subscription-plan:view-any — token must carry this at mint time to subscribe an endpoint to this event.

Payload

{
  "id": "evt_01HX...",
  "type": "plan.sync_completed",
  "created_at": "2026-05-18T10:05:00Z",
  "api_version": "2026-05-01",
  "project_id": "prj_01HX...",
  "data": {
    "plan_id": "pln_01HX...",
    "providers": ["stripe", "paypal"],
    "synced_at": "2026-05-18T10:04:58Z"
  }
}

Field reference

FieldTypeNotes
idstring ULIDUnique event id, prefixed evt_. Use for idempotent processing.
typestringAlways plan.sync_completed for this event.
created_atISO 8601 timestampServer-side emission time.
api_versionstringWebhook API contract version.
project_idstring ULIDProject this event belongs to.
data.plan_idstring ULIDPlan that was synced.
data.providersarray of stringSlugs of providers the plan now exists on (stripe, paypal, razorpay, paystack,..).
data.synced_atISO 8601 timestampWhen the sync run completed (slightly earlier than created_at).

Caveats

  • This event fires per successful sync run — partial failures retry on a follow-up run rather than emitting a separate event per provider.
  • Errors during sync surface in the dashboard, not as webhook events.

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