Hoppa till huvudinnehåll

Introduktion

Skicka professionella transaktionsmejl automatiskt när betalnings- och prenumerationshändelser inträffar. Leverera betalningsbekräftelser, uppdateringar om prenumerationer och felnotifieringar genom Keplars utan att någon mellanliggande server krävs. Dodo Payments anropar Keplars API direkt med hjälp av en JavaScript-transformationshanterare.
Denna integration kräver din Keplars API-nyckel för autentisering. Hitta den i Keplars instrumentpanel under Settings → API Keys, och verifiera en avsändardomän eller adress under Domains.

Kom igång

1

Open the Webhook Section

Navigera till Webhooks → + Lägg till slutpunkt i din Dodo Payments-instrumentpanel och expandera integrationsmenyn.
2

Select Keplars

Välj Keplars-integrationskortet.
Välj Keplars-integrationskortet
3

Enter API Key

Ange din Keplars API-nyckel. Den skickas som en Bearer-token vid varje förfrågan.
Ange Keplars API-URL, API-nyckel och prenumerera på händelser
4

Configure Transformation

Redigera transformationskoden för att formatera mejl för Keplars. Ersätt platshållaradressen och mall-ID med dina egna.
5

Test & Create

Testa med exempelbelastningar och klicka på Skapa för att aktivera e-postsändning.
6

Done!

🎉 Betalningshändelser utlöser nu automatiskt transaktionsmejl via Keplars.

Exempel på transformationskod

Varje hanterare ställer in webhook.url till Keplars högprioriterade sändslutpunkt och omskriver webhook.payload till en Keplars-förfrågan (API-nyckeln skickas automatiskt som en Bearer-token). Ersätt payments@mail.yourdomain.com med din verifierade avsändare och your-keplars-*-template-id med dina faktiska mall-ID.
to måste vara en array, även för en enskild mottagare. När du använder template_id, skicka inte också subject eller body. Mallen tillhandahåller dem.

Betalningsbekräftelsemejl

payment_succeeded.js
function handler(webhook) {
  if (webhook.eventType !== "payment.succeeded") return webhook;

  const data = webhook.payload.data || {};
  const paymentDate = new Date(webhook.payload.timestamp).toLocaleDateString("en-US", {
    year: "numeric", month: "long", day: "numeric",
  });

  webhook.url = "https://api.keplars.com/api/v1/send-email/high";
  webhook.payload = {
    to: [data.customer?.email],
    from: "payments@mail.yourdomain.com",
    template_id: "your-keplars-payment-success-template-id",
    params: {
      customer_name: data.customer?.name,
      amount: ((data.total_amount || 0) / 100).toFixed(2),
      currency: data.currency || "USD",
      payment_id: data.payment_id,
      payment_method: data.payment_method,
      payment_date: paymentDate,
    },
  };
  return webhook;
}

Notifiering om betalningsmisslyckande

payment_failed.js
function handler(webhook) {
  if (webhook.eventType !== "payment.failed") return webhook;

  const data = webhook.payload.data || {};
  const paymentDate = new Date(webhook.payload.timestamp).toLocaleDateString("en-US", {
    year: "numeric", month: "long", day: "numeric",
  });

  webhook.url = "https://api.keplars.com/api/v1/send-email/high";
  webhook.payload = {
    to: [data.customer?.email],
    from: "payments@mail.yourdomain.com",
    template_id: "your-keplars-payment-failed-template-id",
    params: {
      customer_name: data.customer?.name,
      amount: ((data.total_amount || 0) / 100).toFixed(2),
      currency: data.currency || "USD",
      payment_id: data.payment_id,
      error_message: data.error_message || "Your payment could not be processed.",
      payment_date: paymentDate,
    },
  };
  return webhook;
}

Prenumerationsvälkomstmejl

subscription_active.js
function handler(webhook) {
  if (webhook.eventType !== "subscription.active") return webhook;

  const data = webhook.payload.data || {};
  const nextBilling = data.next_billing_date
    ? new Date(data.next_billing_date).toLocaleDateString("en-US", {
        year: "numeric", month: "long", day: "numeric",
      })
    : "";

  webhook.url = "https://api.keplars.com/api/v1/send-email/high";
  webhook.payload = {
    to: [data.customer?.email],
    from: "payments@mail.yourdomain.com",
    template_id: "your-keplars-subscription-active-template-id",
    params: {
      customer_name: data.customer?.name,
      subscription_id: data.subscription_id,
      product_id: data.product_id,
      amount: ((data.recurring_pre_tax_amount || 0) / 100).toFixed(2),
      currency: data.currency || "USD",
      billing_interval: data.payment_frequency_interval || "month",
      next_billing_date: nextBilling,
    },
  };
  return webhook;
}

Prenumerationsavslutsmejl

subscription_cancelled.js
function handler(webhook) {
  if (webhook.eventType !== "subscription.cancelled") return webhook;

  const data = webhook.payload.data || {};
  const cancellationDate = new Date(webhook.payload.timestamp).toLocaleDateString("en-US", {
    year: "numeric", month: "long", day: "numeric",
  });

  webhook.url = "https://api.keplars.com/api/v1/send-email/high";
  webhook.payload = {
    to: [data.customer?.email],
    from: "payments@mail.yourdomain.com",
    template_id: "your-keplars-subscription-cancelled-template-id",
    params: {
      customer_name: data.customer?.name,
      subscription_id: data.subscription_id,
      cancellation_date: cancellationDate,
    },
  };
  return webhook;
}

Tips

  • Använd en verifierad avsändardomän eller adress för bättre leveranssäkerhet.
  • Skapa en dedikerad Keplars-mall per händelsetyp så varje mejl håller sig i enlighet med ditt varumärke och budskap.
  • Anpassa varje mejl genom att skicka kunddata som namn, belopp och betalnings-ID genom params.
  • Testa i sandlådeläge först. Sandlådssändningar fångas upp i Keplars testinkorg istället för att levereras.

Felsökning

  • Verifiera att din API-nyckel är korrekt och aktiv i Keplars under Settings → API Keys.
  • Verifiera att din avsändardomän eller adress är verifierad.
  • Dodo Payments visar det råa Keplars-felmeddelandet i webhook-leveransloggen. Kontrollera det för detaljer.
  • template_id i din hanterare måste matcha en aktiv mall i ditt Keplars-konto. Verifiera ID:t (och att det är aktivt) i instrumentpanelen.
  • Varje hanterare kontrollerar webhook.eventType och returnerar tidigt om det inte matchar. Se till att rätt händelser är prenumererade på Dodo Payments webhook-slutpunkten.
Senast ändrad 18 juni 2026