Pular para o conteúdo principal
Esta página é o caminho mais curto no back-end entre credenciais e um pagamento Pix funcional em sandbox.

Pré-requisitos

  • Um token de sandbox
  • Acesso a https://api-sandbox.pagou.ai
  • Um identificador estável de pedido para reutilizar como external_ref
  • Um endpoint HTTPS de webhook ou um plano temporário de reconciliação

Etapa 1: valide a autenticação

curl --request GET \
  --url https://api-sandbox.pagou.ai/v2/transactions \
  --header "Authorization: Bearer SEU_TOKEN_SANDBOX"
Se isso retornar 200, sua autenticação e o caminho de rede estão prontos.

Etapa 2: crie uma transação Pix

curl --request POST \
  --url https://api-sandbox.pagou.ai/v2/transactions \
  --header "Authorization: Bearer SEU_TOKEN_SANDBOX" \
  --header "Content-Type: application/json" \
  --data '{
    "external_ref": "order_1001",
    "amount": 1500,
    "currency": "BRL",
    "method": "pix",
    "notify_url": "https://merchant.example/webhooks/pagou",
    "buyer": {
      "name": "Ada Lovelace",
      "email": "ada@example.com",
      "document": {
        "type": "CPF",
        "number": "12345678901"
      }
    },
    "products": [
      {
        "name": "Starter order",
        "price": 1500,
        "quantity": 1
      }
    ]
  }'

Exemplo de resposta

{
  "success": true,
  "requestId": "req_1001",
  "data": {
    "id": "tr_1001",
    "status": "pending",
    "method": "pix",
    "amount": 1500,
    "base_price": 1500,
    "currency": "BRL",
    "pix": {
      "qr_code": "000201010212...",
      "expiration_date": "2026-03-16T14:15:00.000Z",
      "receipt_url": null
    },
    "created_at": "2026-03-16T14:00:00.000Z",
    "updated_at": "2026-03-16T14:00:00.000Z",
    "paid_at": null
  }
}

Etapa 3: persista os identificadores

Armazene no mínimo:
  • o seu external_ref
  • o id da transação na Pagou
  • o status atual
  • o requestId

Etapa 4: use webhooks para o estado final

Responda 200 OK rapidamente e processe de forma assíncrona.
app.post("/webhooks/pagou", async (req, reply) => {
  const payload = req.body as { id?: string };

  if (!payload.id) {
    return reply.code(400).send({ error: "missing_event_id" });
  }

  reply.code(200).send({ received: true });
  await queue.enqueue(payload);
});

Etapa 5: reconcilie quando houver dúvida

curl --request GET \
  --url https://api-sandbox.pagou.ai/v2/transactions/tr_1001 \
  --header "Authorization: Bearer SEU_TOKEN_SANDBOX"

Erro comum

Status 409
{
  "type": "https://api.pagou.ai/problems/conflict",
  "title": "Conflict",
  "status": 409,
  "detail": "A transaction with external_ref order_1001 already exists."
}
Como corrigir: reutilize o mesmo external_ref apenas para a mesma tentativa lógica de pagamento. Se o resultado da rede estiver incerto, reconcilie antes de criar uma nova transação.

Equivalente com o SDK TypeScript

import { Client } from "@pagouai/api-sdk";

const client = new Client({
  apiKey: process.env.PAGOU_API_KEY!,
  environment: "sandbox",
});

const created = await client.transactions.create({
  external_ref: "order_1001",
  amount: 1500,
  currency: "BRL",
  method: "pix",
  notify_url: "https://merchant.example/webhooks/pagou",
  buyer: {
    name: "Ada Lovelace",
    email: "ada@example.com",
    document: { type: "CPF", number: "12345678901" },
  },
  products: [{ name: "Starter order", price: 1500, quantity: 1 }],
});

Próximos passos