はじめに
Dodo PaymentsをN8Nを通じて数千のアプリやサービスに接続します。支払いイベントが発生したときにN8Nワークフローをトリガーすることで、ワークフローを自動化し、メールの送信、スプレッドシートの更新、タスクの作成、データベース操作などを行います。
この統合には、ワークフロー設定からのN8N Webhook URLが必要です。
始め方
Webhookセクションを開く
Dodo Paymentsダッシュボードで、Webhooks → + エンドポイントを追加に移動し、統合のドロップダウンを展開します。 N8NでWebhookを作成
N8Nで新しいワークフローを作成し、トリガーとしてWebhookノードを追加します。POST Webhookとして設定し、Webhook URLをコピーします。
Webhook URLを貼り付ける
N8NのWebhook URLをエンドポイント設定に貼り付けます。
変換を設定
データをN8Nワークフロー用にフォーマットするために変換コードを編集します。
テストと作成
サンプルペイロードでテストし、作成をクリックして統合を有効にします。
ワークフローを有効化
N8Nでワークフローを有効化してWebhookイベントの受信を開始します。
完了!
🎉 支払いイベントが自動的にN8Nワークフローをトリガーします。
変換コードの例
基本Webhookペイロード
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;
}
サブスクリプションイベントハンドラー
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;
}
争議アラートハンドラー
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クォータを確認