Skip to main content

Criar Transação

Crie uma nova transação (venda) na plataforma. Você pode processar pagamentos via PIX, Cartão de Crédito, Cartão de Débito ou Boleto.

Autenticação

Este endpoint requer autenticação via API Keys:
X-Api-Public-Key
string
required
Sua chave pública da API
X-Api-Private-Key
string
required
Sua chave privada da API

Parâmetros do Body

amount
integer
required
Valor da transação em centavos (ex: 10000 = R$ 100,00)
paymentMethod
string
required
Método de pagamento. Valores possíveis: CREDIT_CARD, DEBIT_CARD, BOLETO, PIX, TRANSFER
customer
object
required
Dados do cliente
customer.name
string
required
Nome completo do cliente
customer.email
string
required
Email do cliente
customer.document
object
Documento do cliente (CPF ou CNPJ)
customer.document.type
string
Tipo do documento: cpf ou cnpj
customer.document.number
string
Número do documento
customer.phone
string
Telefone do cliente no formato 11999999999 (sem caracteres especiais)
card
object
Informações do cartão (obrigatório para CREDIT_CARD ou DEBIT_CARD)
card.number
string
Número do cartão (será tokenizado - apenas últimos 4 dígitos são armazenados)
card.holderName
string
Nome do portador do cartão (será tokenizado)
card.expirationMonth
string
Mês de expiração no formato MM
card.expirationYear
string
Ano de expiração no formato YYYY
card.cvv
string
CVV do cartão (não é armazenado conforme PCI DSS)
card.installments
integer
Número de parcelas (apenas para cartão de crédito)
pix
object
Informações do PIX (obrigatório para PIX)
pix.key
string
Chave PIX do recebedor
pix.expiresInDays
integer
Número de dias para expiração do PIX
boleto
object
Informações do boleto (obrigatório para BOLETO)
boleto.expiresInDays
integer
Número de dias para expiração do boleto
items
array
required
Lista de itens da transação
items[].title
string
required
Nome do produto
items[].unitPrice
integer
required
Preço unitário em centavos
items[].quantity
integer
required
Quantidade do item
items[].tangible
boolean
required
Se o item é físico (true) ou digital (false)
items[].productId
integer
ID do produto (opcional)
items[].planId
string
ID do plano (opcional)
items[].planName
string
Nome do plano (opcional)
items[].id
string
ID customizado do item (opcional)
shipping
object
Informações de entrega (obrigatório quando há itens físicos com tangible: true)
shipping.street
string
Rua
shipping.streetNumber
string
Número
shipping.complement
string
Complemento
shipping.zipCode
string
CEP
shipping.neighborhood
string
Bairro
shipping.city
string
Cidade
shipping.state
string
Estado (2 dígitos em maiúscula, ex: SP)
shipping.country
string
País (2 dígitos, ex: br)
installments
object
Configuração de parcelas (apenas para cartão de crédito)
installments.number
integer
Número de parcelas (1 a 12)
postbackUrl
string
URL para receber notificações de mudança de status da venda
utmSource
string
Origem da campanha (UTM Source)
utmMedium
string
Meio da campanha (UTM Medium)
utmCampaign
string
Nome da campanha (UTM Campaign)
utmContent
string
Conteúdo da campanha (UTM Content)
utmTerm
string
Termo da campanha (UTM Term)
src
string
Fonte personalizada
sck
string
Código de campanha personalizado
metadata
object
Dados adicionais da venda (objeto JSON livre)

Exemplos de Requisição

Nota sobre os exemplos: Os dados apresentados são apenas exemplos didáticos. Substitua:
  • sua_chave_publica_aqui e sua_chave_privada_aqui pelas suas chaves de API reais
  • seupostbackurl.com.br pela URL do seu servidor que receberá as notificações
  • Os dados do cliente, cartão e produtos pelos dados reais da sua aplicação
curl -X POST https://api.nextpagamentos.io/api/sales \
  -H "X-Api-Public-Key: sua_chave_publica_aqui" \
  -H "X-Api-Private-Key: sua_chave_privada_aqui" \
  -H "Content-Type: application/json" \
  -d '{
    "amount": 5000,
    "paymentMethod": "PIX",
    "customer": {
      "name": "João Silva Santos",
      "email": "[email protected]",
      "document": {
        "type": "cpf",
        "number": "12345678900"
      },
      "phone": "11999999999"
    },
    "items": [
      {
        "title": "Produto Digital - Assinatura Premium",
        "unitPrice": 5000,
        "quantity": 1,
        "tangible": false
      }
    ],
    "postbackUrl": "https://seupostbackurl.com.br/webhook/transacao",
    "metadata": {
      "source": "website",
      "campaign": "promocao-verao-2025"
    }
  }'

Resposta de Sucesso

message
string
Mensagem de sucesso
sale
object
Dados da venda criada

Exemplo de Resposta

{
  "message": "Venda criada com sucesso",
  "sale": {
    "id": 2486,
    "amount": "5000",
    "status": "PENDENTE",
    "paymentMethod": "PIX",
    "customer": {
      "name": "João Silva Santos",
      "email": "[email protected]",
      "document": "14793766633",
      "phone": "5511943034718"
    },
    "payment": {
      "method": "PIX",
      "installments": null,
      "pix": {
        "key": "00020101021226830014BR.GOV.BCB.PIX2561qrcodespix.sejaefi.com.br/v2/e3c7c60f73e44469a1c7a628970b1bd45204000053039865802BR5905EFISA6008SAOPAULO62070503***6304481B",
        "qrCodeBase64": "",
        "expiresAt": null
      }
    },
    "shipping": null,
    "createdAt": "2025-12-20T05:55:39.372Z"
  }
}

Códigos de Erro

{
  "message": "Campos obrigatórios faltando",
  "error": "Dados inválidos",
  "details": {
    "missingFields": ["customer.email", "items"]
  }
}
{
  "message": "Combinação de chaves de API inválida",
  "details": "Verifique se ambas as chaves pertencem ao mesmo usuário e estão corretas"
}
{
  "message": "Erro ao criar venda",
  "error": "Falha ao processar pagamento no momento. Tente novamente mais tarde."
}

Status HTTP

CódigoDescrição
201Venda criada com sucesso
400Dados inválidos ou campos obrigatórios faltando
401Não autorizado - Chaves de API inválidas ou ausentes
422Erro de validação (ex: valor mínimo não atingido)
500Erro interno do servidor