Criar Cobrança

Cash-in routes

Nesta sessão você encontrará todos os endpoints necessários para criar, consultar, cancelar e gerenciar cobranças PIX utilizando a API PixToPay.

Endpoints Disponíveis

  • Sandbox: https://sandbox.pixtopay.com.br/v2/cashin
  • Produção: https://api.pixtopay.com.br/v2/cashin

Criar cobrança PIX com expiração

Route

POST /v2/pix

Headers

{
  "Authorization": "YOUR_API_KEY",
  "Content-Type": "application/json", // opcional, padrão é application/json
  ...
}

Body

ParâmetroTipoObrigatórioDescrição
transaction_idstringSimIdentificador único da transação na sua plataforma (UUID v4 recomendado)
currencystringSimMoeda da transação (apenas "BRL" é suportado)
amountnumberSimValor da cobrança em reais (ex: 150.75)
duestring (ISO 8601)SimData e hora de expiração da cobrança (ex: "2024-12-31T23:59:59") enviar sempre no timezone UTC-0
namestringSimNome completo do pagador
document_typestringSimTipo de documento do pagador ("CPF" ou "CNPJ")
document_numberstringSimNúmero do documento do pagador (apenas números)
webhookstringSimURL para receber notificações de status da cobrança via webhook
phone_numberstringNãoNúmero de telefone do pagador no formato internacional (ex: "5547999999999")
emailstringNãoEndereço de email do pagador
external_idstringNãoIdentificador externo para agrupar cobranças ou identificar usuário (ex: "group_1" ou "user_12345")

Exemplo de requisição:

curl --location 'https://sandbox.pixtopay.com.br/v2/pix' \
--header 'Authorization: API_KEY' \
--header 'Content-Type: application/json' \
--data-raw '{
    "transaction_id": "5fe8e512-fa13-44e4-86b4-c557dd76e68d",
    "currency": "BRL",
    "amount": 1.02,
    "due" : "2024-12-30T14:00:00",
    "name": "NOME E SOBRENOME",
    "document_type": "CPF",
    "document_number": "08965726921",
    "webhook": "https://webhook.site/1729bf83-5b8e-46fe-b125-1ef5932f4fef",
    "phone_number": "5547999999999",
    "email": "sandbox@pixtopay.com.br",
    "external_id": "group_1",
    "base64image": true
}'

Modelo de resposta [2xx]

ParâmetroTipoDescrição
idintegerIdentificador único da cobrança PIX gerada
transaction_idstringIdentificador único da transação na sua plataforma
statusintegerStatus atual da cobrança PIX (ver tabela de status abaixo)
currencystringMoeda da transação (sempre "BRL")
amountnumberValor da cobrança em reais
duestring (ISO 8601)Data e hora de expiração da cobrança
qrcodestringCódigo QR da cobrança PIX para pagamento
qrcode_imagestring(Opcional) Imagem do código QR em formato base64 (presente apenas se base64image for true no body)

Modelo de respostas [4xx]

ParâmetroTipoDescrição
typestringTipo do erro ocorrido
messagestringMensagem detalhando o erro ocorrido

Modelos de respostas [5xx]

ParâmetroTipoDescrição
messagestringMensagem detalhando o erro ocorrido

Resposta 200:

{
  "id": 59366,
  "transaction_id": "12345678942",
  "status": 0,
  "currency": "BRL",
  "amount": 145,
  "due": "2021-11-30T19:00:00.000Z",
  "qrcode": "00020101021226890014br.gov.bcb.pix2567invoice-h.sandbox.starkbank.com/v2/7998213473f84059983768a2b646ce6b5204000053039865802BR5925Pay42 Intermediacao De Ne6010Porto Belo62070503***6304F572"
}

Resposta 200 com base64image:

{
  "id": 23592,
  "transaction_id": "074b88a1-58ae-47b4-80c5-856ad88d2ac2",
  "status": 0,
  "currency": "BRL",
  "amount": 1.02,
  "due": "2024-12-30T17:00:00.000Z",
  "qrcode": "00020101021226890014br.gov.bcb.pix2567brcode-h.sandbox.starkinfra.com/v2/4e093f699bf746e3824bf61abb6a9d855204000053039865802BR5925Bpay Solucoes de Pagament6015Balneario Cambo62070503***6304A308",
  "qrcode_image": ""
}

Resposta 400 transaction_id duplicado:

{
  "type": "ValidationError",
  "message": "body.transaction_id already exists"
}

Resposta 400 expiração inválida:

{
  "type": "ValidationError",
  "message": "body.due must be greater or equal to now"
}

Resposta 5xx erro interno:

{
  "message": "Internal server error!"
}

Lista de status de cobranças PIX

Os status de cobranças PIX são representados por números inteiros. A baixo estão os possíveis status de uma cobrança PIX:

StatusDescrição
0Cobrança criada, aguardando pagamento
1Cobrança paga
2Cobrança cancelada
3Cobrança expirada
4Cobrança devolvida

Fluxo de status

O fluxo de status de uma cobrança PIX segue a sequência abaixo:

0 (Criada) → 1 (Paga)
0 (Criada) → 2 (Cancelada)
0 (Criada) → 3 (Expirada)
0 (Criada) → 4 (Devolvida)*
0 (Criada) → 1 (Paga) → 4 (Devolvida)

*Obs: no caso da troca de status 0 (criada) diretamente para 4: (devolvida), isso ocorre quando o pagador realiza o pagamento, mas o valor é devolvido por algum motivo (ex: tentativa de pagamento por terceiros, lista restritiva, etc).