Visão Geral
O boilerplate mínimo Astro fornece um ponto de partida pronto para uso para integrar os Pagamentos Dodo com sua aplicação Astro. Este template inclui sessões de checkout, manipulação de webhook, portal do cliente e componentes de UI modernos para ajudá-lo a começar a aceitar pagamentos rapidamente.Este boilerplate usa Astro 5 com TypeScript, Tailwind CSS 4 e o adaptador
@dodopayments/astro.Recursos
- Quick Setup - Comece em menos de 5 minutos
- Payment Integration - Fluxo de checkout pré-configurado usando
@dodopayments/astro - Modern UI - Página de preços limpa, com tema escuro, usando Tailwind CSS
- Webhook Handler - Endpoint pronto para uso para eventos de pagamento
- Customer Portal - Gerenciamento de assinaturas com um clique
- TypeScript - Totalmente tipado com tipos mínimos e direcionados
- Pre-filled Checkout - Demonstra como passar dados do cliente para melhorar a experiência
Pré-requisitos
Antes de começar, certifique-se de que você tem:- Node.js versão LTS (necessário para Astro 5)
- Conta Dodo Payments (para acessar as chaves da API e do Webhook no painel)
Início Rápido
Get API Credentials
Inscreva-se em Dodo Payments e obtenha suas credenciais no painel:
- Chave da API: Painel → Desenvolvedor → Chaves da API
- Chave do Webhook: Painel → Desenvolvedor → Webhooks
Configure Environment Variables
Crie um arquivo Atualize os valores com suas credenciais do Dodo Payments:
.env no diretório raiz:Run the Development Server
Estrutura do Projeto
Personalização
Atualizar Informações do Produto
Editesrc/lib/products.ts para alterar:
- IDs de produto (do seu painel Dodo)
- Preços
- Funcionalidades
- Descrições
Pré-preencher Dados do Cliente
Nosrc/components/ProductCard.astro, substitua os valores codificados pelos seus dados reais de usuário:
Atualizar Portal do Cliente
Emsrc/components/Header.astro, substitua o ID de cliente codificado pelo ID real do cliente do seu sistema de autenticação ou banco de dados:
Eventos de Webhook
O boilerplate demonstra o tratamento de eventos de webhook emsrc/pages/api/webhook.ts:
onSubscriptionActive- Disparado quando uma assinatura se torna ativaonSubscriptionCancelled- Disparado quando uma assinatura é cancelada
Implantação
Este boilerplate usa saída estática com renderização sob demanda para rotas de API. Você precisará instalar um adapter para sua plataforma de implantação:| Plataforma | Guia |
|---|---|
| Vercel | Implantar no Vercel |
| Netlify | Implantar no Netlify |
| Cloudflare | Implantar no Cloudflare |
Atualizar URL do Webhook
Após a implantação, atualize sua URL de webhook no Painel Dodo Payments:DODO_PAYMENTS_WEBHOOK_KEY em seu ambiente de produção para corresponder à chave de assinatura do webhook para o seu domínio implantado.
Solução de Problemas
Module not found or build errors
Module not found or build errors
Exclua
node_modules e reinstale as dependências:Checkout redirect fails
Checkout redirect fails
Causas comuns:
- ID do produto inválido - verifique se existe no seu painel Dodo
- Chave de API ou configuração de ambiente incorreta em
.env - Verifique o console do navegador e o terminal em busca de erros
Webhooks not receiving events
Webhooks not receiving events
Para testes locais, use ngrok para expor seu servidor:Atualize a URL do webhook no seu painel Dodo para a URL do ngrok. Lembre-se de atualizar seu arquivo .env com a chave de verificação do webhook correta.
Customer portal link doesn't work
Customer portal link doesn't work
Substitua o
CUSTOMER_ID codificado em src/components/Header.astro por um ID de cliente real do seu painel Dodo.Ou integre seu sistema de autenticação e banco de dados para buscar o ID do cliente dinamicamente.Build fails with adapter error
Build fails with adapter error
Este boilerplate usa saída estática com rotas de API sob demanda. Você precisa instalar um adaptador para implantação:Consulte os guias de implantação do Astro para mais detalhes.
Saiba Mais
Suporte
Precisa de ajuda com o boilerplate?- Junte-se à nossa comunidade no Discord para perguntas e discussões
- Verifique o repositório do GitHub para problemas e atualizações
- Entre em contato com nossa equipe de suporte para assistência