Den nyttolast som skickas till din webhook-endpoint när ett rättighetsbeviljande skapas, levereras, misslyckas eller återkallas.
Documentation Index
Fetch the complete documentation index at: https://docs.dodopayments.com/llms.txt
Use this file to discover all available pages before exploring further.
| Händelse | Beskrivning |
|---|---|
entitlement_grant.created | En ny beviljande rad skapades. Status är delivered omedelbart för licensnycklar, och pending för varje annan integration. |
entitlement_grant.delivered | Beviljandet övergår till levererat. Kunden har nu åtkomst till den berättigade plattformen, filen eller licensnyckeln. |
entitlement_grant.failed | Leverans misslyckades och försöks inte igen. Inspektera error_code och error_message. |
entitlement_grant.revoked | Åtkomst drogs tillbaka. Inspektera revocation_reason för att förstå varför. |
EntitlementGrantResponse nyttolast dokumenterad i schemat nedan.
id från och med nu, även om dess status ändras. Använd denna händelse för att registrera att uppfyllande pågår.
För licensnycklar infogas raden direkt med status: "delivered" och delivered_at ifyllda, så en enda created-händelse följs av inga ytterligare tillståndsändringar om inte beviljandet senare återkallas.
För alla andra integrationer anländer raden med status: "pending". En delivered eller failed-händelse följer när leveransen slutförs:
oauth_url som kunden måste besöka för att slutföra samtycket. Beviljandet förblir pending tills kunden godkänner.pending endast kort medan plattformsanropet körs, för att sedan flytta till delivered.pending till delivered. Kunden har nu åtkomsten som beskrivs av rättigheterna. Använd denna händelse för att låsa upp beroende funktioner i dina egna system, till exempel för att tillhandahålla en arbetsyta, skicka ett anpassat välkomstmail eller markera en “uppfylld” flagga.
Nyttolastens delivered_at-fält fångar när leveransen slutfördes. För beviljanden som anlände delivered vid skapandet, kommer du att få created och delivered-händelser back-to-back.
error_code och error_message förklarar felet. Vanliga orsaker inkluderar en återkallad OAuth-token, en nekad plattformsbehörighet eller ett saknat mål (t.ex., en raderad Discord-gille).
revocation_reason registrerar utlösaren.
revocation_reason | Utlösare |
|---|---|
subscription_cancelled | Kundens prenumeration avbröts (subscription.cancelled händelse). |
subscription_on_hold | Prenumerationen är på paus på grund av misslyckad förnyelse (subscription.on_hold). Återhämtbar: En lyckad omprovning leder till en ombeviljning. |
subscription_expired | Prenumerationen nådde slutet av dess period (subscription.expired). |
plan_changed | Planen ändrades; gamla beviljanden återkallas innan nya utfärdas (subscription.plan_changed). |
refund | En återbetalning behandlades för den ursprungliga engångsbetalningen (refund.succeeded). |
manual | En handlare återkallade beviljandet via API eller instrumentpanelen. Manuella återkallelser återbeviljas inte automatiskt vid prenumerationsförnyelser. |
license_key_disabled | Licensnyckeln bakom en licensnyckel-beviljande inaktiverades. Beviljandet återaktiveras automatiskt om nyckeln återaktiveras. |
platform_external | Plattformsidan av en integration gick ur synk (till exempel, en Discord-roll togs bort manuellt, GitHub-appen förlorade repository-åtkomst, eller en avstämningspass upptäckte ett saknat mål). Beviljandet återbeviljas inte automatiskt vid prenumerationsförnyelser förrän den underliggande plattformsfrågan är löst. |
data är alltid ett EntitlementGrantResponse-objekt. Två integrationstyper bifogar extra kapslade objekt:
license_key ingår när rättighetsintegrationstypen är license_key. Det innehåller den genererade nyckeln, utgångsdatum och aktiveringsanvändning.digital_product_delivery ingår när integrationstypen är digital_files. Det innehåller försignerade nedladdnings-URL:er, den valfria instructions, och den valfria external_url.null; den relevanta konfigurationen fångas i själva rättigheten, inte i beviljandet.
entitlement_grant.delivered)entitlement_grant.delivered)entitlement_grant.created)entitlement_grant.revoked)entitlement_grant.failed)entitlement_grant.delivered innan du låser upp beroende funktioner. En payment.succeeded händelse talar om för dig att pengarna gått igenom; det talar inte om för dig att kunden har GitHub-repot eller Discord-rollen än. delivered-händelsen är den sanningskälla för uppfyllande.revocation_reason till retention flöden. En subscription_on_hold återkallelse innebär vanligtvis att kundens kort misslyckades och nästa förnyelse kommer att nybevilja åtkomst. En manual eller subscription_cancelled återkallelse är avsiktlig. Behandla dem olika i kundmeddelandena.id som din idempotensnyckel. Ett enda beviljande avger högst ett created-händelse och högst en slutlig händelse (delivered eller failed), och högst ett revoked-händelse. Återleveranser från webhooksystemet kan upprepa händelser; dupplikat på grant id plus type.license_key och digital_product_delivery för att känna igen integrationstypen. Grant nyttolasten i sig bär inte integrationstypen, men exakt ett av dessa kapslade objekt fylls i för licensnyckel och digitala filer rättigheter.oauth_url för kunden. entitlement_grant.created-händelsen för Discord, GitHub, eller Notion prenumerantflöden inkluderar en oauth_url och oauth_expires_at. Maila det till kunden eller visa det i din app för att låsa upp leveransen.Detailed view of a single entitlement grant: who it's for, its lifecycle state, and any integration-specific delivery payload.
Identifier of the business that owns the grant.
Timestamp when the grant was created.
Identifier of the customer the grant was issued to.
Identifier of the entitlement this grant was issued from.
Unique identifier of the grant.
Arbitrary key-value metadata recorded on the grant.
Lifecycle status of the grant.
Pending, Delivered, Failed, Revoked Timestamp when the grant was last modified.
Timestamp when the grant transitioned to delivered, when applicable.
Digital-product-delivery payload, present when the entitlement
integration is digital_files.
Machine-readable code reported when delivery failed, when applicable.
Human-readable message reported when delivery failed, when applicable.
License-key delivery payload, present when the entitlement integration
is license_key.
Timestamp when oauth_url stops being valid, when applicable.
Customer-facing OAuth URL for OAuth-style integrations. Populated
during the customer-portal accept flow; null until the customer
completes that step, and on grants for non-OAuth integrations.
Identifier of the payment that triggered this grant, when applicable.
Reason recorded when the grant was revoked, when applicable.
Timestamp when the grant transitioned to revoked, when applicable.
Identifier of the subscription that triggered this grant, when applicable.