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
| Campo | Tipo | Obrigatório | Notas |
|---|---|---|---|
amount | int | sim | Centavos (> 0). |
currency | string | não | Padrão BRL. Aceita fiat (BRL/EUR/USD) e cripto (USDT/USDC). |
paymentMethods | string[] | sim | PIX, CREDIT_CARD, BOLETO, MBWAY, MULTIBANCO, CRYPTO, SWAP_NOW. |
idempotencyKey | string | sim | Reenvio retorna a cobrança original. |
customerName/Document/Email/Phone | string | não | Dados do pagador. |
items | array | não | { name, quantity, unitPrice, totalPrice }. |
webhookUrl | string | não | Recebe o POST de mudança de status. |