跳转到主要内容

订阅 Webhook 事件

以下 webhook 事件可用于跟踪订阅生命周期的变化:
事件描述
subscription.active订阅成功激活
subscription.updated订阅对象已更新(任何字段更改都会触发此事件)
subscription.on_hold由于续订失败,订阅被暂停
subscription.renewed订阅已续订至下一个计费周期
subscription.plan_changed订阅计划已升级、降级或修改
subscription.cancelled订阅已取消
subscription.failed在创建授权时,订阅创建失败
subscription.expired订阅已达到其期限

使用 subscription.updated 进行实时同步

每当任何订阅字段发生变化时,subscription.updated webhook 就会触发,使您能够在不轮询的情况下保持应用程序状态同步:
app.post('/webhooks/dodo', async (req, res) => {
  const event = req.body;
  
  if (event.type === 'subscription.updated') {
    const subscription = event.data;
    
    // Sync subscription changes to your database
    await syncSubscription(subscription.subscription_id, {
      status: subscription.status,
      next_billing_date: subscription.next_billing_date,
      metadata: subscription.metadata,
      // ... other fields you want to track
    });
    
    console.log(`Subscription ${subscription.subscription_id} updated`);
  }
  
  res.json({ received: true });
});
订阅 subscription.updated 以获取有关任何订阅更改的实时通知,消除轮询 API 以获取更新的需要。

Webhook 有效负载架构

Response struct representing subscription details

addons
Addon Cart Response Item · object[]
required

Addons associated with this subscription

billing
object
required

Billing address details for payments

cancel_at_next_billing_date
boolean
required

Indicates if the subscription will cancel at the next billing date

created_at
string<date-time>
required

Timestamp when the subscription was created

currency
enum<string>
required

Currency used for the subscription payments

可用选项:
AED,
ALL,
AMD,
ANG,
AOA,
ARS,
AUD,
AWG,
AZN,
BAM,
BBD,
BDT,
BGN,
BHD,
BIF,
BMD,
BND,
BOB,
BRL,
BSD,
BWP,
BYN,
BZD,
CAD,
CHF,
CLP,
CNY,
COP,
CRC,
CUP,
CVE,
CZK,
DJF,
DKK,
DOP,
DZD,
EGP,
ETB,
EUR,
FJD,
FKP,
GBP,
GEL,
GHS,
GIP,
GMD,
GNF,
GTQ,
GYD,
HKD,
HNL,
HRK,
HTG,
HUF,
IDR,
ILS,
INR,
IQD,
JMD,
JOD,
JPY,
KES,
KGS,
KHR,
KMF,
KRW,
KWD,
KYD,
KZT,
LAK,
LBP,
LKR,
LRD,
LSL,
LYD,
MAD,
MDL,
MGA,
MKD,
MMK,
MNT,
MOP,
MRU,
MUR,
MVR,
MWK,
MXN,
MYR,
MZN,
NAD,
NGN,
NIO,
NOK,
NPR,
NZD,
OMR,
PAB,
PEN,
PGK,
PHP,
PKR,
PLN,
PYG,
QAR,
RON,
RSD,
RUB,
RWF,
SAR,
SBD,
SCR,
SEK,
SGD,
SHP,
SLE,
SLL,
SOS,
SRD,
SSP,
STN,
SVC,
SZL,
THB,
TND,
TOP,
TRY,
TTD,
TWD,
TZS,
UAH,
UGX,
USD,
UYU,
UZS,
VES,
VND,
VUV,
WST,
XAF,
XCD,
XOF,
XPF,
YER,
ZAR,
ZMW
customer
object
required

Customer details associated with the subscription

metadata
object
required

Additional custom data associated with the subscription

meters
object[]
required

Meters associated with this subscription (for usage-based billing)

next_billing_date
string<date-time>
required

Timestamp of the next scheduled billing. Indicates the end of current billing period

on_demand
boolean
required

Wether the subscription is on-demand or not

payment_frequency_count
integer<int32>
required

Number of payment frequency intervals

payment_frequency_interval
enum<string>
required

Time interval for payment frequency (e.g. month, year)

可用选项:
Day,
Week,
Month,
Year
previous_billing_date
string<date-time>
required

Timestamp of the last payment. Indicates the start of current billing period

product_id
string
required

Identifier of the product associated with this subscription

quantity
integer<int32>
required

Number of units/items included in the subscription

recurring_pre_tax_amount
integer<int32>
required

Amount charged before tax for each recurring payment in smallest currency unit (e.g. cents)

status
enum<string>
required

Current status of the subscription

可用选项:
pending,
active,
on_hold,
cancelled,
failed,
expired
subscription_id
string
required

Unique identifier for the subscription

subscription_period_count
integer<int32>
required

Number of subscription period intervals

subscription_period_interval
enum<string>
required

Time interval for the subscription period (e.g. month, year)

可用选项:
Day,
Week,
Month,
Year
tax_inclusive
boolean
required

Indicates if the recurring_pre_tax_amount is tax inclusive

trial_period_days
integer<int32>
required

Number of days in the trial period (0 if no trial)

cancelled_at
string<date-time> | null

Cancelled timestamp if the subscription is cancelled

discount_cycles_remaining
integer<int32> | null

Number of remaining discount cycles if discount is applied

discount_id
string | null

The discount id if discount is applied

expires_at
string<date-time> | null

Timestamp when the subscription will expire

payment_method_id
string | null

Saved payment method id used for recurring charges

tax_id
string | null

Tax identifier provided for this subscription (if applicable)