Vai al contenuto principale

Introduzione

Esegui funzioni serverless e lavori in background automaticamente quando si verificano eventi di pagamento. Elabora pagamenti, invia notifiche, aggiorna database e gestisci flussi di lavoro complessi con la piattaforma di esecuzione delle funzioni affidabile di Inngest.
Questa integrazione richiede l’URL del webhook di Inngest dalla configurazione della tua funzione.

Iniziare

1

Apri la Sezione Webhook

Nel tuo dashboard di Dodo Payments, vai a Webhooks → + Aggiungi Endpoint ed espandi il menu a discesa delle integrazioni.
Aggiungi Endpoint e menu a discesa delle integrazioni
2

Seleziona Inngest

Scegli la scheda di integrazione Inngest.
3

Crea Funzione Inngest

In Inngest, crea una nuova funzione e copia l’URL del webhook dalla configurazione della funzione.
4

Incolla URL Webhook

Incolla l’URL del webhook di Inngest nella configurazione dell’endpoint.
5

Configura Trasformazione

Modifica il codice di trasformazione per formattare gli eventi per la tua funzione Inngest.
6

Testa & Crea

Testa con payload di esempio e fai clic su Crea per attivare l’integrazione.
7

Fatto!

🎉 Gli eventi di pagamento attiveranno ora automaticamente le tue funzioni Inngest.

Esempi di Codice di Trasformazione

Payload di Evento di Base

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

Gestore di Evento di Abbonamento

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

Gestore di Evento di Controversia

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

Casi d’Uso Comuni di Inngest

  • Invia email di conferma
  • Aggiorna i record dei clienti
  • Elabora rimborsi
  • Genera fatture
  • Aggiorna l’inventario
  • Dai il benvenuto ai nuovi abbonati
  • Elabora cancellazioni
  • Invia promemoria di rinnovo
  • Aggiorna i cicli di fatturazione
  • Gestisci pagamenti non riusciti
  • Aggiorna le metriche di fatturato
  • Monitora il comportamento dei clienti
  • Genera report
  • Sincronizza i dati con le piattaforme di analisi
  • Calcola i tassi di abbandono

Suggerimenti

  • Usa nomi di eventi descrittivi per una migliore organizzazione delle funzioni
  • Includi il contesto dell’utente per l’esecuzione della funzione
  • Imposta timestamp appropriati per l’ordinamento degli eventi
  • Struttura i dati in modo coerente tra gli eventi
  • Usa le funzionalità di retry e gestione degli errori di Inngest

Risoluzione dei Problemi

  • Verifica che l’URL del webhook sia corretto e attivo
  • Controlla che la funzione Inngest sia distribuita e attiva
  • Assicurati che i nomi degli eventi corrispondano ai trigger delle funzioni
  • Controlla i log delle funzioni Inngest per errori
  • Controlla che la struttura del payload corrisponda alle aspettative di Inngest
  • Verifica che i nomi degli eventi siano formattati correttamente
  • Assicurati che tutti i campi richiesti siano inclusi
  • Testa con lo strumento di test del webhook di Inngest