payment.capturedBuyer-initiatedPayment captured
Paystack confirmed funds. Same time as order.created.
When this fires
Paystack confirmed funds. Always fires at the same moment as order.created.
High frequency
This event is buyer-initiated, which means it can fire at checkout-traffic volume during busy periods. Make sure your handler responds in under ten seconds; queue any heavy work.
Sample payload
This is the exact envelope shape we POST to your endpoint — outer wrapper plus the per-event data payload. Field values are randomised on each render so you see the general shape, not a fixed example.
json
{
"id": "080e582e-2666-49ca-b31f-1fae9fd4257c",
"event": "payment.captured",
"created": "2026-06-12T15:00:35.768Z",
"data": {
"orderId": "ce3bwp74cbyn0000000000000",
"orderNumber": "TY-1ZY9KAS",
"amountKobo": 1433951,
"reference": "PSK_L82KF7B0EM",
"channel": "card"
}
}Use cases
- Reconcile against your Paystack ledger at end-of-day.
- Increment a real-time revenue dashboard.
- Settle commissions or splits to creators / affiliates.
Subscribe in the dashboard
To start receiving this event, add it to a webhook's subscription list in Developers → Webhooks. Wildcard subscriptions ( payment.*) work too — see the webhooks guide for the matching rules.