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âmetro | Tipo | Obrigatório | Descrição |
|---|---|---|---|
transaction_id | string | Sim | Identificador único da transação na sua plataforma (UUID v4 recomendado) |
currency | string | Sim | Moeda da transação (apenas "BRL" é suportado) |
amount | number | Sim | Valor da cobrança em reais (ex: 150.75) |
due | string (ISO 8601) | Sim | Data e hora de expiração da cobrança (ex: "2024-12-31T23:59:59") enviar sempre no timezone UTC-0 |
name | string | Sim | Nome completo do pagador |
document_type | string | Sim | Tipo de documento do pagador ("CPF" ou "CNPJ") |
document_number | string | Sim | Número do documento do pagador (apenas números) |
webhook | string | Sim | URL para receber notificações de status da cobrança via webhook |
phone_number | string | Não | Número de telefone do pagador no formato internacional (ex: "5547999999999") |
email | string | Não | Endereço de email do pagador |
external_id | string | Não | Identificador 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âmetro | Tipo | Descrição |
|---|---|---|
id | integer | Identificador único da cobrança PIX gerada |
transaction_id | string | Identificador único da transação na sua plataforma |
status | integer | Status atual da cobrança PIX (ver tabela de status abaixo) |
currency | string | Moeda da transação (sempre "BRL") |
amount | number | Valor da cobrança em reais |
due | string (ISO 8601) | Data e hora de expiração da cobrança |
qrcode | string | Código QR da cobrança PIX para pagamento |
qrcode_image | string | (Opcional) Imagem do código QR em formato base64 (presente apenas se base64image for true no body) |
Modelo de respostas [4xx]
| Parâmetro | Tipo | Descrição |
|---|---|---|
type | string | Tipo do erro ocorrido |
message | string | Mensagem detalhando o erro ocorrido |
Modelos de respostas [5xx]
| Parâmetro | Tipo | Descrição |
|---|---|---|
message | string | Mensagem 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:
| Status | Descrição |
|---|---|
0 | Cobrança criada, aguardando pagamento |
1 | Cobrança paga |
2 | Cobrança cancelada |
3 | Cobrança expirada |
4 | Cobranç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).