メインコンテンツへスキップ

はじめに

Dodo PaymentsをZapierを通じて数千のアプリやサービスに接続します。支払いイベントが発生したときにZapsをトリガーすることで、ワークフローを自動化し、メールの送信からスプレッドシートの更新、タスクの作成など、さまざまな作業を行うことができます。
この統合には、Zap の構成から Zapier の webhook URL が必要です。

始め方

1

Open the Webhook Section

Dodo Payments ダッシュボードで Webhooks → + Add Endpoint に移動し、統合のドロップダウンを展開します。
エンドポイントの追加と統合のドロップダウン
2

Select Zapier

Zapier 統合カードを選択します。
3

Create Zap in Zapier

Zapier で「Webhooks by Zapier」をトリガーとして新しい Zap を作成し、webhook URL をコピーします。
4

Paste Webhook URL

Zapier の webhook URL をエンドポイント構成に貼り付けます。
5

Configure Transformation

変換コードを編集して Zapier ワークフロー用にデータを整形します。
6

Test & Create

サンプルのペイロードでテストし、Create をクリックして統合を有効にします。
7

Done!

🎉 支払いイベントで Zapier ワークフローが自動的にトリガーされるようになります。

変換コードの例

基本的なウェブフックペイロード

basic_webhook.js
function handler(webhook) {
  if (webhook.eventType === "payment.succeeded") {
    const p = webhook.payload.data;
    webhook.payload = {
      event_type: webhook.eventType,
      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",
      timestamp: webhook.payload.timestamp
    };
  }
  return webhook;
}

サブスクリプションイベントハンドラー

subscription_webhook.js
function handler(webhook) {
  const s = webhook.payload.data;
  switch (webhook.eventType) {
    case "subscription.active":
      webhook.payload = {
        event_type: "subscription_started",
        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,
        timestamp: webhook.payload.timestamp
      };
      break;
    case "subscription.cancelled":
      webhook.payload = {
        event_type: "subscription_cancelled",
        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,
        timestamp: webhook.payload.timestamp
      };
      break;
  }
  return webhook;
}

争議アラートハンドラー

dispute_webhook.js
function handler(webhook) {
  if (webhook.eventType.startsWith("dispute.")) {
    const d = webhook.payload.data;
    webhook.payload = {
      event_type: webhook.eventType,
      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",
      timestamp: webhook.payload.timestamp
    };
  }
  return webhook;
}

人気のZapierユースケース

  • Gmail/Outlook から支払い確認メールを送信
  • Mailchimp/ConvertKit でメールシーケンスを作成
  • Slack/Discord 通知を送信
  • Google Sheets に記録を作成
  • HubSpot/Salesforce に連絡先を追加
  • Pipedrive/Close で案件を作成
  • Airtable で顧客レコードを更新
  • Monday.com にアクティビティを記録
  • Asana/Trello でタスクを作成
  • Notion に ToDo を追加
  • カレンダーイベントを作成
  • Twilio 経由で SMS 通知を送信

ヒント

  • Zapierの解析を容易にするためにペイロード構造をシンプルに保つ
  • すべてのイベントで一貫したフィールド名を使用する
  • ワークフローのタイミングのためにタイムスタンプを含める
  • 本番環境に移行する前にサンプルデータでZapをテストする
  • 条件付きロジックのためにZapierの組み込みフィルターを使用する

トラブルシューティング

  • webhook URL が正しくアクティブであることを確認
  • Zapier で Zap がオンになっていることを確認
  • ペイロード構造が Zapier の期待に沿っていることを確認
  • Zapier ダッシュボードで webhook 配信をテスト
  • Zapier アクションステップのフィールド名を確認
  • データ型が期待される形式と一致していることを確認
  • Zapier のテスト機能でマッピングをデバッグ
  • 変換コードが有効な JSON を返すことを確認