Pular para o conteúdo principal

Introdução

Execute fluxos de trabalho e scripts personalizados no Windmill quando eventos de pagamento ocorrerem. Realize operações de banco de dados, envie notificações, processe dados e automatize lógica de negócios complexa com o poderoso mecanismo de fluxo de trabalho do Windmill.
Esta integração requer a URL do webhook do Windmill da sua configuração de fluxo de trabalho.

Começando

1

Abra a Seção de Webhook

No seu painel do Dodo Payments, navegue até Webhooks → + Adicionar Endpoint e expanda o dropdown de integrações.
Adicionar Endpoint e dropdown de integrações
2

Selecione Windmill

Escolha o cartão de integração Windmill.
3

Crie o Fluxo de Trabalho do Windmill

No Windmill, crie um novo fluxo de trabalho e copie a URL do webhook da configuração do gatilho.
4

Cole a URL do Webhook

Cole a URL do webhook do Windmill na configuração do endpoint.
5

Configure a Transformação

Edite o código de transformação para formatar eventos para o seu fluxo de trabalho do Windmill.
6

Teste e Crie

Teste com cargas úteis de exemplo e clique em Criar para ativar a integração.
7

Pronto!

🎉 Eventos de pagamento agora acionarão seus fluxos de trabalho do Windmill automaticamente.

Exemplos de Código de Transformação

Carga Útil de Fluxo de Trabalho Básico

basic_workflow.js
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,
      metadata: {
        business_id: p.business_id,
        product_id: p.product_id
      }
    };
  }
  return webhook;
}

Manipulador de Fluxo de Trabalho de Assinatura

subscription_workflow.js
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,
        customer_id: s.customer.customer_id,
        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,
        customer_id: s.customer.customer_id,
        timestamp: webhook.payload.timestamp
      };
      break;
  }
  return webhook;
}

Manipulador de Fluxo de Trabalho de Disputa

dispute_workflow.js
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",
      business_id: d.business_id,
      timestamp: webhook.payload.timestamp
    };
  }
  return webhook;
}

Casos de Uso Comuns do Windmill

  • Atualizar registros de clientes no PostgreSQL/MySQL
  • Registrar eventos de pagamento em data warehouses
  • Sincronizar dados com sistemas externos
  • Atualizar níveis de inventário
  • Rastrear métricas analíticas
  • Calcular métricas de receita
  • Processar reembolsos e ajustes
  • Gerenciar o ciclo de vida da assinatura
  • Gerar relatórios e exportações
  • Validar dados de pagamento
  • Enviar dados para plataformas de análise
  • Atualizar sistemas de CRM
  • Acionar campanhas de e-mail
  • Criar eventos de calendário
  • Enviar notificações por SMS

Dicas

  • Estruture os dados da carga útil para fácil processamento do fluxo de trabalho
  • Inclua todos os metadados relevantes para a lógica de negócios
  • Use nomes de campo consistentes entre eventos
  • Inclua timestamps para o tempo de fluxo de trabalho
  • Aproveite o tratamento de erros embutido do Windmill

Solução de Problemas

  • Verifique se a URL do webhook está correta e ativa
  • Confira se o fluxo de trabalho do Windmill está publicado e ativo
  • Assegure-se de que a estrutura da carga útil corresponda às expectativas do fluxo de trabalho
  • Revise os logs de execução do Windmill em busca de erros
  • Verifique o mapeamento de parâmetros de entrada do fluxo de trabalho
  • Verifique se os tipos de dados correspondem aos formatos esperados
  • Teste o fluxo de trabalho com dados de exemplo
  • Revise os logs de execução do script do Windmill