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

はじめに

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

始め方

1

Webhookセクションを開く

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

N8Nを選択

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

N8NでWebhookを作成

N8Nで新しいワークフローを作成し、トリガーとしてWebhookノードを追加します。POST Webhookとして設定し、Webhook URLをコピーします。
4

Webhook URLを貼り付ける

N8NのWebhook URLをエンドポイント設定に貼り付けます。
5

変換を設定

データをN8Nワークフロー用にフォーマットするために変換コードを編集します。
6

テストと作成

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

ワークフローを有効化

N8Nでワークフローを有効化してWebhookイベントの受信を開始します。
8

完了!

🎉 支払いイベントが自動的にN8Nワークフローをトリガーします。

変換コードの例

基本Webhookペイロード

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;
}

人気のN8Nユースケース

  • 支払い確認のためのGmail/Outlookメールを送信
  • Mailchimp/ConvertKitでメールシーケンスを作成
  • Webhookを介してSlack/Discord通知を送信
  • Google Sheetsに自動的にレコードを作成
  • Telegram/WhatsAppメッセージを送信
  • HubSpot/Salesforceに連絡先を追加
  • Pipedrive/Closeで取引を作成
  • Airtableで顧客レコードを更新
  • Monday.comで活動を記録
  • PostgreSQL/MySQLデータベースにデータを同期
  • Asana/Trelloでタスクを作成
  • NotionにTo-Doアイテムを追加
  • Googleカレンダーでカレンダーイベントを作成
  • Twilioを介してSMS通知を送信
  • 争議のためにGitHubの問題を作成
  • 支払いデータを変換および強化
  • データベースにイベントを保存(PostgreSQL、MongoDB)
  • メトリクスと分析を集約
  • レポートとエクスポートを生成
  • 複雑なマルチステップワークフローをトリガー

ヒント

  • N8Nノードの解析を容易にするためにペイロード構造をシンプルに保つ
  • すべてのイベントで一貫したフィールド名を使用
  • ワークフローのタイミングとスケジューリングのためにタイムスタンプを含める
  • 有効化する前にサンプルデータでワークフローをテスト
  • 条件付きロジックとルーティングのためにN8NのIFノードを使用
  • カスタムデータ変換のためにN8NのCodeノードを活用
  • Switchノードを使用して異なるイベントタイプを異なるパスにルーティング
  • 失敗したWebhook配信を処理するためのエラーワークフローを設定

トラブルシューティング

  • Webhook URLが正しくアクセス可能であることを確認
  • N8Nでワークフローが有効化されていることを確認
  • WebhookノードがPOSTメソッドとして設定されていることを確認
  • N8Nの実行履歴でWebhook配信をテスト
  • ファイアウォール/ネットワーク設定が着信Webhookを許可していることを確認
  • 設定されている場合はN8NのWebhook認証設定を確認
  • N8Nノード設定のフィールド名を確認
  • ノードで期待されるフォーマットとデータ型が一致していることを確認
  • N8Nのテスト機能を使用して着信データを検査
  • 変換コードが有効なJSONを返すことを確認
  • Webhookノードのレスポンスフォーマット設定を確認
  • Setノードを使用してフィールドの名前変更や再構成を行う
  • 詳細なエラーメッセージのためにN8Nの実行ログを確認
  • ノード接続設定と認証情報を確認
  • ペイロードにすべての必須フィールドが含まれていることを確認
  • サンプルデータで個々のノードをテスト
  • 失敗をキャッチして処理するためにエラーワークフローを有効化
  • 接続されたサービスのレート制限とAPIクォータを確認