跳转到主要内容

介绍

在支付事件发生时自动执行无服务器函数和后台作业。使用 Inngest 可靠的函数执行平台处理支付、发送通知、更新数据库和运行复杂的工作流。
此集成需要您从函数配置中获取 Inngest webhook URL。

开始使用

1

打开 Webhook 部分

在您的 Dodo Payments 仪表板中,导航到 Webhooks → + 添加端点 并展开集成下拉菜单。
添加端点和集成下拉菜单
2

选择 Inngest

选择 Inngest 集成卡片。
3

创建 Inngest 函数

在 Inngest 中创建一个新函数,并从函数配置中复制 webhook URL。
4

粘贴 Webhook URL

将 Inngest webhook URL 粘贴到端点配置中。
5

配置转换

编辑转换代码以格式化事件以适应您的 Inngest 函数。
6

测试并创建

使用示例有效负载进行测试,然后单击 创建 以激活集成。
7

完成!

🎉 现在,支付事件将自动触发您的 Inngest 函数。

转换代码示例

基本事件有效负载

basic_event.js
function handler(webhook) {
  if (webhook.eventType === "payment.succeeded") {
    const p = webhook.payload.data;
    webhook.payload = {
      name: "payment.succeeded",
      data: {
        payment_id: p.payment_id,
        amount: (p.total_amount / 100).toFixed(2),
        currency: p.currency || "USD",
        customer_email: p.customer.email,
        customer_name: p.customer.name,
        payment_method: p.payment_method || "unknown"
      },
      user: {
        email: p.customer.email
      },
      ts: Math.floor(new Date(webhook.payload.timestamp).getTime() / 1000)
    };
  }
  return webhook;
}

订阅事件处理程序

subscription_event.js
function handler(webhook) {
  const s = webhook.payload.data;
  switch (webhook.eventType) {
    case "subscription.active":
      webhook.payload = {
        name: "subscription.started",
        data: {
          subscription_id: s.subscription_id,
          customer_email: s.customer.email,
          customer_name: s.customer.name,
          product_id: s.product_id,
          amount: (s.recurring_pre_tax_amount / 100).toFixed(2),
          frequency: s.payment_frequency_interval,
          next_billing: s.next_billing_date
        },
        user: {
          email: s.customer.email
        },
        ts: Math.floor(new Date(webhook.payload.timestamp).getTime() / 1000)
      };
      break;
    case "subscription.cancelled":
      webhook.payload = {
        name: "subscription.cancelled",
        data: {
          subscription_id: s.subscription_id,
          customer_email: s.customer.email,
          cancelled_at: s.cancelled_at,
          cancel_at_next_billing: s.cancel_at_next_billing_date
        },
        user: {
          email: s.customer.email
        },
        ts: Math.floor(new Date(webhook.payload.timestamp).getTime() / 1000)
      };
      break;
  }
  return webhook;
}

争议事件处理程序

dispute_event.js
function handler(webhook) {
  if (webhook.eventType.startsWith("dispute.")) {
    const d = webhook.payload.data;
    webhook.payload = {
      name: webhook.eventType,
      data: {
        dispute_id: d.dispute_id,
        payment_id: d.payment_id,
        amount: (d.amount / 100).toFixed(2),
        status: d.dispute_status,
        stage: d.dispute_stage,
        remarks: d.remarks || "",
        urgent: webhook.eventType === "dispute.opened"
      },
      user: {
        email: d.customer?.email || "unknown"
      },
      ts: Math.floor(new Date(webhook.payload.timestamp).getTime() / 1000)
    };
  }
  return webhook;
}

常见的 Inngest 用例

  • 发送确认邮件
  • 更新客户记录
  • 处理退款
  • 生成发票
  • 更新库存
  • 欢迎新订阅者
  • 处理取消
  • 发送续订提醒
  • 更新计费周期
  • 处理失败的支付
  • 更新收入指标
  • 跟踪客户行为
  • 生成报告
  • 将数据同步到分析平台
  • 计算流失率

提示

  • 使用描述性事件名称以更好地组织函数
  • 包含用户上下文以执行函数
  • 为事件排序设置适当的时间戳
  • 在事件之间保持数据结构一致
  • 使用 Inngest 的重试和错误处理功能

故障排除

  • 验证 webhook URL 是否正确且处于活动状态
  • 检查 Inngest 函数是否已部署并处于活动状态
  • 确保事件名称与函数触发器匹配
  • 查看 Inngest 函数日志以查找错误
  • 检查有效负载结构是否符合 Inngest 的预期
  • 验证事件名称是否格式正确
  • 确保包含所有必需字段
  • 使用 Inngest 的 webhook 测试工具进行测试