Saltar al contenido principal

Introducción

Envía automáticamente correos electrónicos transaccionales para confirmaciones de pago, actualizaciones de suscripción y notificaciones importantes utilizando SendGrid. Activa correos electrónicos personalizados basados en eventos de pago con contenido dinámico y plantillas profesionales.
Esta integración requiere una clave de API de SendGrid con permisos de Mail Send.

Comenzando

1

Open the Webhook Section

En tu panel de control de Dodo Payments, dirígete a Webhooks → + Add Endpoint y despliega el menú desplegable de integraciones.
Add Endpoint and integrations dropdown
2

Select SendGrid

Elige la tarjeta de integración SendGrid.
3

Enter API Key

Proporciona tu clave de API de SendGrid en la configuración.
4

Configure Transformation

Edita el código de transformación para formatear los correos electrónicos para la API Mail Send de SendGrid.
5

Test & Create

Prueba con payloads de muestra y haz clic en Create para activar el envío de correos electrónicos.
6

Done!

🎉 Ahora los eventos de pago activarán automáticamente correos transaccionales a través de SendGrid.

Ejemplos de código de transformación

Correo electrónico de confirmación de pago

payment_confirmation.js
function handler(webhook) {
  if (webhook.eventType === "payment.succeeded") {
    const p = webhook.payload.data;
    webhook.url = "https://api.sendgrid.com/v3/mail/send";
    webhook.payload = {
      personalizations: [
        {
          to: [{ email: p.customer.email }],
          dynamic_template_data: {
            customer_name: p.customer.name,
            payment_amount: (p.total_amount / 100).toFixed(2),
            payment_id: p.payment_id,
            payment_date: new Date(webhook.payload.timestamp).toLocaleDateString(),
            currency: p.currency || "USD"
          }
        }
      ],
      from: {
        email: "payments@yourdomain.com",
        name: "Your Company"
      },
      template_id: "d-xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx"
    };
  }
  return webhook;
}

Correo electrónico de bienvenida de suscripción

subscription_welcome.js
function handler(webhook) {
  if (webhook.eventType === "subscription.active") {
    const s = webhook.payload.data;
    webhook.url = "https://api.sendgrid.com/v3/mail/send";
    webhook.payload = {
      personalizations: [
        {
          to: [{ email: s.customer.email }],
          dynamic_template_data: {
            customer_name: s.customer.name,
            subscription_id: s.subscription_id,
            product_name: s.product_id,
            amount: (s.recurring_pre_tax_amount / 100).toFixed(2),
            frequency: s.payment_frequency_interval,
            next_billing: new Date(s.next_billing_date).toLocaleDateString()
          }
        }
      ],
      from: {
        email: "welcome@yourdomain.com",
        name: "Your Company"
      },
      template_id: "d-xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx"
    };
  }
  return webhook;
}

Notificación de fallo de pago

payment_failure.js
function handler(webhook) {
  if (webhook.eventType === "payment.failed") {
    const p = webhook.payload.data;
    webhook.url = "https://api.sendgrid.com/v3/mail/send";
    webhook.payload = {
      personalizations: [
        {
          to: [{ email: p.customer.email }],
          dynamic_template_data: {
            customer_name: p.customer.name,
            payment_amount: (p.total_amount / 100).toFixed(2),
            error_message: p.error_message || "Payment processing failed",
            payment_id: p.payment_id,
            retry_link: `https://yourdomain.com/retry-payment/${p.payment_id}`
          }
        }
      ],
      from: {
        email: "support@yourdomain.com",
        name: "Your Company Support"
      },
      template_id: "d-xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx"
    };
  }
  return webhook;
}

Consejos

  • Utiliza plantillas dinámicas de SendGrid para contenido personalizado
  • Incluye datos de pago relevantes en las variables de plantilla
  • Establece direcciones de envío y nombres de remitente adecuados
  • Usa IDs de plantilla para un formato de correo electrónico consistente
  • Incluye enlaces de cancelación de suscripción para cumplir con la normativa

Solución de problemas

  • Verifica que la clave de API tenga permisos de Mail Send
  • Comprueba que las IDs de plantilla sean válidas y estén activas
  • Asegúrate de que las direcciones de correo electrónico de los destinatarios sean válidas
  • Revisa los límites y cuotas de envío de SendGrid
  • Valida que la estructura JSON coincida con el formato de la API de SendGrid
  • Comprueba que todos los campos obligatorios estén presentes
  • Asegúrate de que las variables de datos de plantilla estén correctamente formateadas
  • Verifica que las direcciones de correo electrónico del remitente estén verificadas en SendGrid