Pular para o conteúdo principal
Subscriptions let you sell ongoing access with automated renewals. Use flexible billing cycles, free trials, plan changes, and add‑ons to tailor pricing for each customer.

Upgrade & Downgrade

Control plan changes with proration and quantity updates.

On‑Demand Subscriptions

Authorize a mandate now and charge later with custom amounts.

Customer Portal

Let customers manage plans, billing, and cancellations.

Subscription Webhooks

React to lifecycle events like created, renewed, and canceled.

What Are Subscriptions?

Subscriptions are recurring products customers purchase on a schedule. They’re ideal for:
  • SaaS licenses: Apps, APIs, or platform access
  • Memberships: Communities, programs, or clubs
  • Digital content: Courses, media, or premium content
  • Support plans: SLAs, success packages, or maintenance

Key Benefits

  • Predictable revenue: Recurring billing with automated renewals
  • Flexible cycles: Monthly, annual, custom intervals, and trials
  • Plan agility: Proration for upgrades and downgrades
  • Add‑ons and seats: Attach optional, quantifiable upgrades
  • Seamless checkout: Hosted checkout and customer portal
  • Developer-first: Clear APIs for creation, changes, and usage tracking

Creating Subscriptions

Create subscription products in your Dodo Payments dashboard, then sell them through checkout or your API. Separating products from active subscriptions lets you version pricing, attach add‑ons, and track performance independently.

Subscription product creation

Configure the fields in the dashboard to define how your subscription sells, renews, and bills. The sections below map directly to what you see in the creation form.

Product details

  • Product Name (required): The display name shown in checkout, customer portal, and invoices.
  • Product Description (required): A clear value statement that appears in checkout and invoices.
  • Product Image (required): PNG/JPG/WebP up to 3 MB. Used on checkout and invoices.
  • Brand: Associate the product with a specific brand for theming and emails.
  • Tax Category (required): Choose the category (for example, SaaS) to determine tax rules.
Pick the most accurate tax category to ensure correct tax collection per region.

Pricing

  • Pricing Type: Choose Subscription (this guide). Alternatives are Single Payment and Usage Based Billing.
  • Price (required): Base recurring price with currency.
  • Discount Applicable (%): Optional percentage discount applied to the base price; reflected in checkout and invoices.
  • Repeat payment every (required): Interval for renewals, e.g., every 1 Month. Select the cadence (months or years) and quantity.
  • Subscription Period (required): Total term for which the subscription remains active (e.g., 10 Years). After this period ends, renewals stop unless extended.
  • Trial Period Days (required): Set trial length in days. Use 0 to disable trials. The first charge occurs automatically when the trial ends.
  • Select add‑on: Attach up to 10 add‑ons that customers can purchase alongside the base plan.
Changing pricing on an active product affects new purchases. Existing subscriptions follow your plan‑change and proration settings.
Add‑ons are ideal for quantifiable extras such as seats or storage. You can control allowed quantities and proration behavior when customers change them.

Advanced settings

  • Tax Inclusive Pricing: Display prices inclusive of applicable taxes. Final tax calculation still varies by customer location.
  • Generate license keys: Issue a unique key to each customer after purchase. See the License Keys guide.
  • Digital Product Delivery: Deliver files or content automatically after purchase. Learn more in Digital Product Delivery.
  • Metadata: Attach custom key–value pairs for internal tagging or client integrations. See Metadata.
Use metadata to store identifiers from your system (e.g., accountId) so you can reconcile events and invoices later.

Subscription Trials

Trials let customers access subscriptions without immediate payment. The first charge occurs automatically when the trial ends.

Configuring Trials

Set Trial Period Days in the product pricing section (use 0 to disable). You can override this when creating subscriptions:
// Via subscription creation
const subscription = await client.subscriptions.create({
  customer_id: 'cus_123',
  product_id: 'prod_monthly',
  trial_period_days: 14  // Overrides product's trial period
});

// Via checkout session
const session = await client.checkoutSessions.create({
  product_cart: [{ product_id: 'prod_monthly', quantity: 1 }],
  subscription_data: { trial_period_days: 14 }
});
The trial_period_days value must be between 0 and 10,000 days.

Detecting Trial Status

Currently, there is no direct field to detect trial status. The following is a workaround that requires querying payments, which is inefficient. We are working on a more efficient solution.
To determine if a subscription is in trial, retrieve the list of payments for the subscription. If there is exactly one payment with amount 0, the subscription is in trial period:
const subscription = await client.subscriptions.retrieve('sub_123');
const payments = await client.payments.list({
  subscription_id: subscription.subscription_id
});

// Check if subscription is in trial
const isInTrial = payments.items.length === 1 && 
                  payments.items[0].total_amount === 0;

Updating Trial Period

Extend the trial by updating next_billing_date:
await client.subscriptions.update('sub_123', {
  next_billing_date: '2025-02-15T00:00:00Z'  // New trial end date
});
You cannot set next_billing_date to a past time. The date must be in the future.

Subscription Plan Changes

Plan changes let you upgrade or downgrade subscriptions, adjust quantities, or migrate to different products. Depending on the proration mode you select, a change may trigger an immediate charge, create credit, or apply no billing adjustment.
You can change subscription plans and update the next billing date directly from the Dodo Payments dashboard. This provides a quick way to adjust subscriptions for customer support requests, promotional upgrades, or plan migrations without making API calls.
Enable self-service plan changes: Want customers to upgrade or downgrade their own subscriptions via the Customer Portal? Add your subscription products to a Product Collection and enable “Allow Subscription Updates” in your Subscription Settings.

Product Collections

Group related products into collections to enable seamless upgrade/downgrade paths in the Customer Portal.

Proration Modes

Choose how customers are billed when changing plans:
Quick comparison of the four proration modes:
prorated_immediatelydifference_immediatelyfull_immediatelydo_not_bill
UpgradeCobrança proporcional pelos dias restantesDiferença de preço total cobradaPreço total do novo plano cobradoSem cobrança — troca imediata
DowngradeCrédito proporcional pelos dias restantesDiferença de preço total como créditoSem crédito, cobrança totalSem crédito — troca imediata
Ciclo de faturamentoReinicia hojeReinicia hojeReinicia hojePermanece o mesmo
Melhor paraCobrança justa baseada no tempoMudanças simples de nívelReinicialização do ciclo de faturamentoMigrações gratuitas ou trocas de cortesia

prorated_immediately

Charges prorated amount based on remaining time in the current billing cycle. Best for fair billing that accounts for unused time.
await client.subscriptions.changePlan('sub_123', {
  product_id: 'prod_pro',
  quantity: 1,
  proration_billing_mode: 'prorated_immediately'
});

difference_immediately

Charges the price difference immediately (upgrade) or adds credit for future renewals (downgrade). Best for simple upgrade/downgrade scenarios.
// Upgrade: charges $50 (difference between $30 and $80)
// Downgrade: credits remaining value, auto-applied to renewals
await client.subscriptions.changePlan('sub_123', {
  product_id: 'prod_pro',
  quantity: 1,
  proration_billing_mode: 'difference_immediately'
});
Credits from downgrades using difference_immediately are subscription-scoped and auto-applied to future renewals. They’re distinct from Credit-Based Billing entitlements.
When a customer downgrades with difference_immediately, the unused value becomes a subscription-scoped credit that automatically offsets future renewals:

full_immediately

Charges full new plan amount immediately, ignoring remaining time. Best for resetting billing cycles.
await client.subscriptions.changePlan('sub_123', {
  product_id: 'prod_monthly',
  quantity: 1,
  proration_billing_mode: 'full_immediately'
});

do_not_bill

Switches to the new plan without any billing adjustment. No proration charges, no credits — the customer simply moves to the new plan. Best for courtesy migrations, free plan switches, or scenarios where you want to absorb the cost difference.
await client.subscriptions.changePlan('sub_123', {
  product_id: 'prod_new_plan',
  quantity: 1,
  proration_billing_mode: 'do_not_bill'
});
Scenario: Customer on Basic (30/month)upgradestoPro(30/month) upgrades to Pro (80/month) on day 16 of a 30-day cycle using prorated_immediately.
Unused credit from Basic = $30 × (15 remaining / 30 total) = $15.00
Prorated cost of Pro     = $80 × (15 remaining / 30 total) = $40.00
────────────────────────────────────────────────────────────────────
Immediate charge         = $40.00 − $15.00 = $25.00
Próxima renovação em 15 de fevereiro (16 de janeiro + 30 dias): $80.00/mês.
For more detailed calculation examples and edge cases, see our full Upgrade & Downgrade Guide.
Scenario: Customer on Pro (80/month)downgradestoStarter(80/month) downgrades to Starter (20/month) using difference_immediately.
Credit = Old plan − New plan = $80 − $20 = $60.00
The $60 credit auto-applies to future renewals:
  • Renewal 1: 2020 − 20 (credit) = **0.00(0.00** (40 credit remaining)
  • Renewal 2: 2020 − 20 (credit) = **0.00(0.00** (20 credit remaining)
  • Renewal 3: 2020 − 20 (credit) = $0.00 (credit exhausted)
  • Renewal 4: $20.00 (full price)
Learn more about how credits are managed in the Upgrade & Downgrade Guide.

Changing Plans with Add-ons

Modify add-ons when changing plans. Add-ons are included in proration calculations:
await client.subscriptions.changePlan('sub_123', {
  product_id: 'prod_pro',
  quantity: 1,
  proration_billing_mode: 'difference_immediately',
  addons: [{ addon_id: 'addon_extra_seats', quantity: 2 }]  // Add add-ons
  // addons: []  // Empty array removes all existing add-ons
});
Plan changes trigger immediate charges. Failed charges may move the subscription to on_hold status. Track changes via subscription.plan_changed webhook events.

Previewing Plan Changes

Before committing to a plan change, preview the exact charge and resulting subscription:
const preview = await client.subscriptions.previewChangePlan('sub_123', {
  product_id: 'prod_pro',
  quantity: 1,
  proration_billing_mode: 'prorated_immediately'
});

// Show customer the charge before confirming
console.log('You will be charged:', preview.immediate_charge.summary);

Preview Change Plan API

Preview plan changes before committing to them.

Subscription States

Uma assinatura passa por um conjunto definido de status ao longo de seu ciclo de vida. Esta tabela é a referência para cada status, o que o causa e como (ou se) você pode recuperá-lo.
StatusO que significaRecuperável?Caminho de recuperação / próximo passo
pendingA assinatura está sendo criada ou processadaAguardar subscription.active (ou subscription.failed)
activeA assinatura está ativa e será renovada automaticamenteNenhuma ação necessária
on_holdUm pagamento de renovação (ou cobrança por alteração de plano) falhou; a assinatura está em pausaSimAtualizar o método de pagamento para reativar — automaticamente via Repetições de Pagamento e Cobrança, ou manualmente via a API de Atualização de Método de Pagamento
cancelledA assinatura foi cancelada e não será renovadaSomente nova compraO cliente deve iniciar uma nova assinatura; Cobrança pode solicitar uma nova compra
failedA criação da assinatura falhou (o mandato inicial ou pagamento não obteve sucesso)Não — terminalO cliente deve criar uma nova assinatura com um método de pagamento funcional
expiredA assinatura atingiu o fim do seu termoO cliente deve começar uma nova assinatura, se desejar
on_hold e failed são frequentemente confundidos. on_hold é um estado recuperável para uma assinatura já ativa cuja renovação falhou. failed é um estado terminal que ocorre apenas quando a criação inicial da assinatura falha — não pode ser reativado.

Máquina de Estados

Estado Em Espera

Uma assinatura entra no estado on_hold quando:
  • Um pagamento de renovação falha (fundos insuficientes, cartão expirado, etc.)
  • Uma cobrança para alteração de plano falha
  • A autorização do método de pagamento falha
Quando uma assinatura está no estado on_hold, ela não se renovará automaticamente. Você deve atualizar o método de pagamento para reativar a assinatura.

Reativando do Estado Em Espera

Para reativar uma assinatura do estado on_hold, atualize o método de pagamento. Isso automaticamente:
  1. Cria uma cobrança para as dívidas restantes
  2. Gera uma fatura
  3. Processa o pagamento usando o novo método de pagamento
  4. Reativa a assinatura para o estado active após o pagamento bem-sucedido
// Reactivate subscription from on_hold
const response = await client.subscriptions.updatePaymentMethod('sub_123', {
  type: 'new',
  return_url: 'https://example.com/return'
});

// For on_hold subscriptions, a charge is automatically created
if (response.payment_id) {
  console.log('Charge created:', response.payment_id);
  // Redirect customer to response.payment_link to complete payment
  // Monitor webhooks for payment.succeeded and subscription.active
}
Após atualizar com sucesso o método de pagamento para uma assinatura on_hold, você receberá eventos de webhook payment.succeeded seguidos por subscription.active.

Eventos Webhook por Transição

Cada transição emite um webhook para que você possa gerenciar a lógica de direito sem polling:
TransiçãoEvento
Assinatura ativadasubscription.active
Renovação bem-sucedidasubscription.renewed
Renovação falha → pausadosubscription.on_hold
Criação falhasubscription.failed
Plano atualizado/degradadosubscription.plan_changed
Canceladosubscription.cancelled
Termo encerradosubscription.expired
Quaisquer alterações de camposubscription.updated

Subscription Webhook Payloads

Veja o esquema completo de payload para eventos do ciclo de vida de assinaturas.

Gerenciamento de API

Use POST /subscriptions para criar assinaturas programaticamente a partir de produtos, com testes opcionais e complementos.

API Reference

Veja a API de criação de assinatura.
Use PATCH /subscriptions/{id} para atualizar quantidades, cancelar na próxima data de cobrança ou modificar metadados.

API Reference

Saiba como atualizar os detalhes da assinatura.
Altere o produto ativo e as quantidades com controles de rateio.

API Reference

Revise as opções de alteração de plano.
Para assinaturas sob demanda, cobre valores específicos sob demanda.

API Reference

Cobre uma assinatura sob demanda.
Use GET /subscriptions para listar todas as assinaturas e GET /subscriptions/{id} para recuperar uma.

API Reference

Veja as APIs de listagem e recuperação.
Busque o uso registrado para modelos de preços medidos ou híbridos.

API Reference

Veja a API de histórico de uso.
Atualize o método de pagamento para uma assinatura. Para assinaturas ativas, isso atualiza o método de pagamento para renovações futuras. Para assinaturas no estado on_hold, isso reativa a assinatura ao criar uma cobrança para as dívidas restantes.Ao gerar um novo link de método de pagamento (o tipo de solicitação New), você pode passar allowed_payment_method_types para restringir quais métodos de pagamento o cliente vê nessa página. Os clientes nunca verão um método que não esteja na lista, embora incluir um método não garanta que ele apareça (a disponibilidade ainda depende de fatores como localização do cliente e configurações da sua empresa).

API Reference

Saiba como atualizar os métodos de pagamento e reativar assinaturas.

Casos de Uso Comuns

  • SaaS e APIs: Acesso em níveis com complementos para assentos ou uso
  • Conteúdo e mídia: Acesso mensal com testes introdutórios
  • Planos de suporte B2B: Contratos anuais com complementos de suporte premium
  • Ferramentas e plugins: Chaves de licença e lançamentos versionados

Exemplos de Integração

Sessões de Checkout (assinaturas)

Ao criar sessões de checkout, inclua seu produto de assinatura e complementos opcionais:
const session = await client.checkoutSessions.create({
  product_cart: [
    {
      product_id: 'prod_subscription',
      quantity: 1
    }
  ]
});

Alterações de plano com prorrateio

Faça upgrade ou downgrade de uma assinatura e controle o comportamento de prorrateio:
await client.subscriptions.changePlan('sub_123', {
  product_id: 'prod_new',
  quantity: 1,
  proration_billing_mode: 'difference_immediately'
});

Cancelar na próxima data de cobrança

Agende um cancelamento que entre em vigor no final do período de cobrança atual:
await client.subscriptions.update('sub_123', {
  cancel_at_next_billing_date: true
});

Assinaturas sob demanda

Crie uma assinatura sob demanda e cobre mais tarde conforme necessário:
const onDemand = await client.subscriptions.create({
  customer_id: 'cus_123',
  product_id: 'prod_on_demand',
  on_demand: true
});

await client.subscriptions.charge(onDemand.id, {
  amount: 4900,
  currency: 'USD',
  description: 'Extra usage for September'
});

Atualizar método de pagamento para assinatura ativa

Atualize o método de pagamento para uma assinatura ativa:
// Update with new payment method
const response = await client.subscriptions.updatePaymentMethod('sub_123', {
  type: 'new',
  return_url: 'https://example.com/return'
});

// Or use existing payment method
await client.subscriptions.updatePaymentMethod('sub_123', {
  type: 'existing',
  payment_method_id: 'pm_abc123'
});

Reativar assinatura de on_hold

Reative uma assinatura que ficou em espera devido a falha no pagamento:
// Update payment method - automatically creates charge for remaining dues
const response = await client.subscriptions.updatePaymentMethod('sub_123', {
  type: 'new',
  return_url: 'https://example.com/return'
});

if (response.payment_id) {
  // Charge created for remaining dues
  // Redirect customer to response.payment_link
  // Monitor webhooks: payment.succeeded → subscription.active
}

Assinaturas com Mandatos Compatíveis com RBI

UPI e assinaturas de cartão indiano operam sob regulamentos do RBI (Reserve Bank of India) com requisitos específicos de mandato:

Limites de Mandato

O tipo e o valor do mandato dependem da cobrança recorrente da sua assinatura:
  • Cobranças abaixo do piso do mandato (padrão ₹15.000): Criamos um mandato sob demanda para o valor do piso. O valor da assinatura é cobrado periodicamente de acordo com a frequência da sua assinatura, até o limite do mandato.
  • Cobranças no piso do mandato ou acima dele: Criamos um mandato de assinatura (ou mandato sob demanda) para o valor exato da assinatura.
O piso do mandato é configurável por comerciante ou por solicitação via mandate_min_amount_inr_paise (INR paise). O valor registrado junto ao banco é max(mandate_floor, billing_amount) — assim, o piso efetivamente se torna o teto de autorização visível para o cliente sempre que a cobrança for menor. Para informações detalhadas sobre mandatos compatíveis com RBI e o piso de mandato configurável para métodos de pagamento indianos, veja a página Métodos de Pagamento na Índia.

Considerações sobre Upgrade e Downgrade

Importante: Ao fazer upgrade ou downgrade de assinaturas, considere cuidadosamente os limites de mandato:
  • Se um upgrade/downgrade resultar em um valor de cobrança que excede Rs 15.000 e ultrapassa o limite de pagamento sob demanda existente, a cobrança da transação pode falhar.
  • Nesses casos, o cliente pode precisar atualizar seu método de pagamento ou alterar a assinatura novamente para estabelecer um novo mandato com o limite correto.

Autorização para Cobranças de Alto Valor

Para cobranças de assinatura de Rs 15.000 ou mais:
  • O cliente será solicitado por seu banco a autorizar a transação.
  • Se o cliente não autorizar a transação, a transação falhará e a assinatura será colocada em espera.

Atraso de Processamento de 48 Horas

Cronograma de Processamento: Cobranças recorrentes em cartões indianos e assinaturas UPI seguem um padrão de processamento único:
  • Cobranças são iniciadas na data programada de acordo com a frequência da sua assinatura.
  • A dedução real da conta do cliente ocorre apenas após 48 horas da iniciação do pagamento.
  • Esta janela de 48 horas pode se estender até 2-3 horas adicionais dependendo das respostas da API bancária.

Janela de Cancelamento de Mandato

Durante a janela de processamento de 48 horas:
  • Os clientes podem cancelar o mandato através de seus aplicativos bancários.
  • Se um cliente cancelar o mandato durante esse período, a assinatura permanecerá ativa (este é um caso específico para assinaturas AutoPay de cartões indianos e UPI).
  • No entanto, a dedução real pode falhar e, nesse caso, colocaremos a assinatura em espera.
Tratamento de Casos Extremos: Se você oferecer benefícios, créditos ou uso de assinatura aos clientes imediatamente após a iniciação da cobrança, você precisará lidar com essa janela de 48 horas adequadamente em seu aplicativo. Considere:
  • Atrasar a ativação dos benefícios até confirmação do pagamento
  • Implementar períodos de carência ou acesso temporário
  • Monitorar o status da assinatura para cancelamentos de mandato
  • Lidar com estados de espera de assinatura na lógica do seu aplicativo
Monitore webhooks de assinatura para rastrear alterações no status de pagamento e lidar com casos extremos onde mandatos são cancelados durante a janela de 48 horas.

Melhores Práticas

  • Comece com níveis claros: 2–3 planos com diferenças óbvias
  • Comunique preços: Mostre totais, prorrateio e próxima renovação
  • Use testes com cautela: Converta com integração, não apenas tempo
  • Aproveite os complementos: Mantenha os planos base simples e ofereça extras
  • Teste alterações: Valide alterações de plano e prorrateio no modo de teste
Assinaturas são uma base flexível para receita recorrente. Comece simples, teste minuciosamente e itere com base em adoção, churn e métricas de expansão.
Última modificação em 18 de junho de 2026