Trao Quyền
Tải trọng được gửi đến điểm cuối webhook của bạn khi một quyền được tạo, giao hàng, thất bại hoặc bị thu hồi.
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.
Sự Kiện Webhook Trao Quyền
Các sự kiện này được kích hoạt mỗi khi quyền của khách hàng thay đổi trạng thái, ví dụ khi một license key được tạo, một vai trò Discord được gán, một liên kết tải xuống được cung cấp hoặc quyền truy cập bị từ chối. Đăng ký các sự kiện này để giữ cho ứng dụng của bạn đồng bộ với những gì mỗi khách hàng có thể truy cập.| Sự Kiện | Mô Tả |
|---|---|
entitlement_grant.created | Một dòng cấp quyền mới đã được tạo. Trạng thái là delivered ngay lập tức đối với các license key, và pending cho mọi tích hợp khác. |
entitlement_grant.delivered | Quyền chuyển sang được giao hàng. Khách hàng hiện có quyền truy cập vào nền tảng, tập tin hoặc license key đã được cấp. |
entitlement_grant.failed | Giao hàng thất bại và không được thử lại. Kiểm tra error_code và error_message. |
entitlement_grant.revoked | Quyền truy cập đã bị rút lại. Kiểm tra revocation_reason để hiểu lý do. |
EntitlementGrantResponse được tài liệu hóa trong sơ đồ dưới đây.
Kích Hoạt Sự Kiện
entitlement_grant.created
Một dòng cấp quyền vừa được chèn. Quyền luôn có mộtid ổn định từ lúc này, ngay cả khi trạng thái của nó thay đổi. Sử dụng sự kiện này để ghi lại rằng việc thực hiện đang diễn ra.
Đối với license keys dòng được chèn trực tiếp với status: "delivered" và delivered_at đã được điền, vì vậy một sự kiện created duy nhất được theo sau mà không có sự thay đổi trạng thái nào nữa trừ khi quyền sau đó bị thu hồi.
Đối với mọi tích hợp khác dòng đến với status: "pending". Một sự kiện delivered hoặc failed theo sau khi hoàn thành giao hàng:
- Tích hợp dựa trên OAuth (Discord, GitHub, Notion) bao gồm một
oauth_urlmà khách hàng phải truy cập để hoàn tất ủy quyền. Quyền vẫn ởpendingcho đến khi khách hàng ủy quyền. - Tích hợp trực tiếp qua nền tảng (Telegram, Framer, Digital Files) chỉ ở
pendingtrong một thời gian ngắn trong khi cuộc gọi nền tảng diễn ra, sau đó chuyển đếndelivered.
entitlement_grant.delivered
Quyền đã chuyển từpending sang delivered. Khách hàng hiện có quyền truy cập như đã mô tả trong quyền. Sử dụng sự kiện này để mở khóa các tính năng phụ thuộc trong hệ thống của bạn, ví dụ để cung cấp một không gian làm việc, gửi email chào mừng tùy chỉnh hoặc đánh dấu một cờ “đã hoàn thành”.
Trường delivered_at của tải trọng ghi lại khi quá trình giao hàng hoàn tất. Đối với những quyền đã nhận delivered khi tạo, bạn sẽ nhận sự kiện created và delivered liên tiếp.
entitlement_grant.failed
Giao hàng đã được thử nghiệm nhưng thất bại với lỗi không thể thử lại. Các trườngerror_code và error_message giải thích lý do thất bại. Nguyên nhân phổ biến bao gồm token OAuth bị thu hồi, quyền nền tảng bị từ chối, hoặc mục tiêu bị thiếu (ví dụ, một guild Discord đã bị xóa).
entitlement_grant.revoked
Quyền truy cập đã bị rút lại ở cấp độ nền tảng: vai trò Discord bị xóa, cộng tác viên GitHub bị xóa, key giấy phép bị vô hiệu hóa, URL tải xuống tệp không còn được cấp phát. Trườngrevocation_reason ghi lại kích hoạt.
revocation_reason | Kích Hoạt |
|---|---|
subscription_cancelled | Đăng ký của khách hàng đã bị hủy (sự kiện subscription.cancelled). |
subscription_on_hold | Đăng ký đang bị tạm giữ do gia hạn thất bại (subscription.on_hold). Có thể khôi phục: một lần thử lại thành công sẽ cấp quyền lại. |
subscription_expired | Đăng ký đã đạt đến ngày kết thúc nhiệm kỳ (subscription.expired). |
plan_changed | Kế hoạch đã thay đổi; quyền cũ bị thu hồi trước khi cấp quyền mới (subscription.plan_changed). |
refund | Đã xử lý một khoản hoàn tiền cho thanh toán một lần ban đầu (refund.succeeded). |
manual | Một nhà cung cấp hủy bỏ quyền thông qua API hoặc bảng điều khiển. Khi thu hồi thủ công, sẽ không tự động cấp lại khi gia hạn đăng ký. |
license_key_disabled | Key sau một quyền cấp license-key đã bị vô hiệu hóa. Quyền được kích hoạt lại tự động nếu key được tái kích hoạt. |
platform_external | Phía nền tảng của một tích hợp không đồng bộ (ví dụ, vai trò Discord bị xóa thủ công, Ứng dụng GitHub mất quyền truy cập kho, hoặc kiểm tra đối chiếu phát hiện thiếu mục tiêu). Quyền sẽ không tự động cấp lại khi gia hạn đăng ký cho đến khi vấn đề nền tảng cơ bản được giải quyết. |
Biến Thể Payload
Trườngdata luôn là một đối tượng EntitlementGrantResponse. Hai kiểu tích hợp đính kèm thêm các đối tượng con:
license_keyđược bao gồm khi kiểu tích hợp quyền làlicense_key. Nó chứa key đã tạo, ngày hết hạn và sử dụng kích hoạt.digital_product_deliveryđược bao gồm khi kiểu tích hợp làdigital_files. Nó chứa các URL tải xuống đã ký trước, tùy chọninstructionsvà tùy chọnexternal_url.
null; cấu hình liên quan được ghi lại trong chính quyền, không phải trong cấp quyền.
Payload Ví Dụ
License key được giao (entitlement_grant.delivered)
Tệp kỹ thuật số được giao (entitlement_grant.delivered)
Vai trò Discord được tạo và đang chờ xử lý (entitlement_grant.created)
Quyền bị thu hồi khi hủy đăng ký (entitlement_grant.revoked)
Giao hàng thất bại (entitlement_grant.failed)
Mẹo Tích Hợp
- Chờ
entitlement_grant.deliveredtrước khi mở khóa các tính năng phụ thuộc. Một sự kiệnpayment.succeededcho bạn biết tiền đã được giải ngân; nó không cho bạn biết rằng khách hàng đã có repo GitHub hoặc vai trò Discord. Sự kiệndeliveredlà nguồn sự thật cho việc thực hiện. - Lập bản đồ
revocation_reasonđến luồng giữ chân người dùng. Một quyền hồi lạisubscription_on_holdthường có nghĩa là thẻ của khách hàng đã thất bại và lần gia hạn tiếp theo sẽ cấp lại quyền. Một quyền hồi lạimanualhoặcsubscription_cancelledlà có chủ ý. Xử lý chúng khác nhau trong thông báo khách hàng. - Sử dụng quyền
idnhư là khóa idempotency của bạn. Một quyền duy nhất phát ra nhiều nhất một sự kiệncreatedvà nhiều nhất một sự kiện cuối cùng (deliveredhoặcfailed), và nhiều nhất một sự kiệnrevoked. Các đợt giao lại từ hệ thống webhook có thể lặp lại các sự kiện; loại bỏ trùng lặp trên cấp quyềnidcộngtype. - Kiểm tra
license_keyvàdigital_product_deliveryđể nhận biết kiểu tích hợp. Bản thân tải trọng quyền không mang kiểu tích hợp, nhưng chính xác một trong các đối tượng con này được điền cho các quyền license-key và tệp kỹ thuật số. - Đối với các quyền dựa trên OAuth, hiển thị
oauth_urlcho khách hàng. Sự kiệnentitlement_grant.createdcho luồng thuê bao Discord, GitHub hoặc Notion bao gồm mộtoauth_urlvàoauth_expires_at. Gửi email nó cho khách hàng hoặc hiển thị trong ứng dụng của bạn để giải phóng việc giao hàng.
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.