subscription.trial_converting
Trial about to convert — fires 24h before trial_ends_at.
Fires exactly once per trial, 24 hours before trial_ends_at. Driven by the
hourly the trial-conversion notifier job.
When this fires
Fires 24 hours before trial_ends_at to give consumers a window to send conversion-reminder messaging. Emitted once per trial.
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.trial_converting",
"created_at": "2026-05-24T10: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": "2026-05-25T10:05:00Z"
}
}Field reference
| Field | Type | Notes |
|---|---|---|
id | string ULID | Unique event id, prefixed evt_. Use for idempotent processing. |
type | string | Always subscription.trial_converting 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 trial is on. |
data.subscriber_id | string ULID | Subscriber's project-scoped user id. |
data.trial_ends_at | ISO 8601 timestamp | When the trial window ends. |
Caveats
- Idempotency is enforced server-side: each trial receives this event at most once.
- If
trial_ends_atis moved closer than 24h after the trial has already started, the notice may not fire.
Related events
subscription.trial_started— predecessor.subscription.activated,member.converted— fire on successful conversion.subscription.trial_expired— alternative path if conversion fails.- Subscription events overview — back to family overview.
How is this guide?