Passer au contenu principal

Introduction

Envoyez automatiquement des e-mails transactionnels professionnels lorsque des événements de paiement se produisent. Livrez des confirmations de paiement, des mises à jour d’abonnement et des notifications importantes grâce à l’infrastructure de messagerie fiable de Resend et à d’excellents taux de délivrabilité.
Cette intégration nécessite votre clé API Resend pour l’authentification.

Prise en main

1

Ouvrir la section Webhook

Dans votre tableau de bord Dodo Payments, accédez à Webhooks → + Ajouter un point de terminaison et développez le menu déroulant des intégrations.
Ajouter un point de terminaison et menu déroulant des intégrations
2

Sélectionner Resend

Choisissez la carte d’intégration Resend.
3

Entrer la clé API

Fournissez votre clé API Resend dans la configuration.
4

Configurer la transformation

Modifiez le code de transformation pour formater les e-mails pour l’API de Resend.
5

Tester et créer

Testez avec des charges utiles d’exemple et cliquez sur Créer pour activer l’envoi d’e-mails.
6

Terminé !

🎉 Les événements de paiement déclencheront désormais automatiquement des e-mails transactionnels via Resend.

Exemples de code de transformation

E-mail de confirmation de paiement

payment_confirmation.js
function handler(webhook) {
  if (webhook.eventType === "payment.succeeded") {
    const p = webhook.payload.data;
    webhook.url = "https://api.resend.com/emails";
    webhook.payload = {
      from: "[email protected]",
      to: [p.customer.email],
      subject: "Payment Confirmation - $" + (p.total_amount / 100).toFixed(2),
      html: `
        <h2>Payment Successful!</h2>
        <p>Hi ${p.customer.name},</p>
        <p>Your payment of $${(p.total_amount / 100).toFixed(2)} has been processed successfully.</p>
        <ul>
          <li><strong>Payment ID:</strong> ${p.payment_id}</li>
          <li><strong>Amount:</strong> $${(p.total_amount / 100).toFixed(2)}</li>
          <li><strong>Date:</strong> ${new Date(webhook.payload.timestamp).toLocaleDateString()}</li>
          <li><strong>Method:</strong> ${p.payment_method || "Unknown"}</li>
        </ul>
        <p>Thank you for your business!</p>
      `,
      text: `Payment Successful! Your payment of $${(p.total_amount / 100).toFixed(2)} has been processed. Payment ID: ${p.payment_id}`
    };
  }
  return webhook;
}

E-mail de bienvenue d’abonnement

subscription_welcome.js
function handler(webhook) {
  if (webhook.eventType === "subscription.active") {
    const s = webhook.payload.data;
    webhook.url = "https://api.resend.com/emails";
    webhook.payload = {
      from: "[email protected]",
      to: [s.customer.email],
      subject: "Welcome to Your Subscription!",
      html: `
        <h2>Welcome to Your Subscription!</h2>
        <p>Hi ${s.customer.name},</p>
        <p>Your subscription has been activated successfully.</p>
        <ul>
          <li><strong>Subscription ID:</strong> ${s.subscription_id}</li>
          <li><strong>Product:</strong> ${s.product_id}</li>
          <li><strong>Amount:</strong> $${(s.recurring_pre_tax_amount / 100).toFixed(2)}/${s.payment_frequency_interval}</li>
          <li><strong>Next Billing:</strong> ${new Date(s.next_billing_date).toLocaleDateString()}</li>
        </ul>
        <p>You can manage your subscription anytime from your account dashboard.</p>
      `,
      text: `Welcome! Your subscription is now active. Amount: $${(s.recurring_pre_tax_amount / 100).toFixed(2)}/${s.payment_frequency_interval}`
    };
  }
  return webhook;
}

Notification d’échec de paiement

payment_failure.js
function handler(webhook) {
  if (webhook.eventType === "payment.failed") {
    const p = webhook.payload.data;
    webhook.url = "https://api.resend.com/emails";
    webhook.payload = {
      from: "[email protected]",
      to: [p.customer.email],
      subject: "Payment Failed - Action Required",
      html: `
        <h2>Payment Failed</h2>
        <p>Hi ${p.customer.name},</p>
        <p>We were unable to process your payment of $${(p.total_amount / 100).toFixed(2)}.</p>
        <ul>
          <li><strong>Payment ID:</strong> ${p.payment_id}</li>
          <li><strong>Amount:</strong> $${(p.total_amount / 100).toFixed(2)}</li>
          <li><strong>Error:</strong> ${p.error_message || "Payment processing failed"}</li>
        </ul>
        <p>Please update your payment method or contact support for assistance.</p>
        <a href="https://yourdomain.com/update-payment">Update Payment Method</a>
      `,
      text: `Payment Failed: We couldn't process your $${(p.total_amount / 100).toFixed(2)} payment. Please update your payment method.`
    };
  }
  return webhook;
}

Conseils

  • Utilisez des domaines d’expéditeur vérifiés pour une meilleure délivrabilité
  • Incluez à la fois des versions HTML et texte des e-mails
  • Personnalisez le contenu avec les données des clients
  • Utilisez des lignes de sujet claires et orientées vers l’action
  • Incluez des liens de désinscription pour la conformité
  • Testez les modèles d’e-mails avant de les mettre en ligne

Dépannage

  • Vérifiez que la clé API est correcte et active
  • Assurez-vous que le domaine de l’expéditeur est vérifié dans Resend
  • Vérifiez que les adresses e-mail des destinataires sont valides
  • Examinez les limites et quotas d’envoi de Resend
  • Validez que la structure JSON correspond au format de l’API Resend
  • Vérifiez que tous les champs requis sont présents
  • Assurez-vous que le contenu HTML est correctement formaté
  • Vérifiez que l’adresse e-mail de l’expéditeur est vérifiée