Pular para o conteúdo principal

Criar cobrança PIX

POST /v1/payments — valores em centavos. idempotencyKey evita cobrança duplicada (reenviar a mesma chave retorna a cobrança original).

cURL

curl -X POST 'https://v2.pagnow.com/v1/payments' \
-H 'apikey: pnk_sua_chave_aqui' \
-H 'content-type: application/json' \
-d '{
"amount": 1990,
"currency": "BRL",
"paymentMethods": ["PIX"],
"idempotencyKey": "pedido-123",
"customerName": "João Silva",
"customerDocument": "52998224725",
"customerEmail": "joao@exemplo.com",
"items": [
{ "name": "Plano Pro", "quantity": 1, "unitPrice": 1990, "totalPrice": 1990 }
],
"webhookUrl": "https://sua-loja.com/webhooks/pagnow"
}'

Python

import requests

resp = requests.post(
"https://v2.pagnow.com/v1/payments",
headers={"apikey": "pnk_sua_chave_aqui"},
json={
"amount": 1990,
"currency": "BRL",
"paymentMethods": ["PIX"],
"idempotencyKey": "pedido-123",
"customerName": "João Silva",
"customerDocument": "52998224725",
"customerEmail": "joao@exemplo.com",
"webhookUrl": "https://sua-loja.com/webhooks/pagnow",
},
timeout=30,
)
resp.raise_for_status()
charge = resp.json()
print(charge["pixCopyPaste"])

PHP

<?php
$ch = curl_init("https://v2.pagnow.com/v1/payments");
curl_setopt_array($ch, [
CURLOPT_POST => true,
CURLOPT_RETURNTRANSFER => true,
CURLOPT_HTTPHEADER => ["apikey: pnk_sua_chave_aqui", "Content-Type: application/json"],
CURLOPT_POSTFIELDS => json_encode([
"amount" => 1990,
"currency" => "BRL",
"paymentMethods" => ["PIX"],
"idempotencyKey" => "pedido-123",
"customerName" => "João Silva",
"customerDocument" => "52998224725",
"customerEmail" => "joao@exemplo.com",
"webhookUrl" => "https://sua-loja.com/webhooks/pagnow",
]),
]);
$charge = json_decode(curl_exec($ch), true);
echo $charge["pixCopyPaste"];

Resposta (201)

{
"id": "a99e3d82-352b-49b2-b10e-4551ca69446e",
"status": "WAITING_PAYMENT",
"amount": 1990,
"currency": "BRL",
"provider": "BRASILCASH",
"pixCopyPaste": "00020101021226...br.gov.bcb.pix...",
"pixQrCode": "data:image/png;base64,iVBOR...",
"pixExpiresAt": "2026-05-27T13:00:00.000Z"
}

O cliente paga com o pixQrCode (imagem) ou o pixCopyPaste. Você também pode enviá-lo para a página de checkout hospedada: https://checkout.v2.pagnow.com/{id}.

Campos principais

CampoTipoObrigatórioNotas
amountintsimCentavos (> 0).
currencystringnãoPadrão BRL. Aceita fiat (BRL/EUR/USD) e cripto (USDT/USDC).
paymentMethodsstring[]simPIX, CREDIT_CARD, BOLETO, MBWAY, MULTIBANCO, CRYPTO, SWAP_NOW.
idempotencyKeystringsimReenvio retorna a cobrança original.
customerName/Document/Email/PhonestringnãoDados do pagador.
itemsarraynão{ name, quantity, unitPrice, totalPrice }.
webhookUrlstringnãoRecebe o POST de mudança de status.