Guias de Integração
Quickstart
Pré-requisitos
Antes de começar, você precisa ter:
✓Certificado X.509 (arquivo
.pem) vinculado à sua conta✓Credenciais OAuth (
clientId e clientSecret)Solicite suas credenciais e certificado através do Painel Fire Banking.
1. Configurar Ambiente
Crie um arquivo .env com suas credenciais:
FIREBANKING_CLIENT_ID=account-93-seu-id
FIREBANKING_CLIENT_SECRET=sua-senha-secreta
FIREBANKING_API_URL=https://api.public.firebanking.com.brSalve seu certificado como client-cert.pem no diretório do projeto.
2. Instalar Dependências
npm install axios dotenvpip install requests python-dotenv3. Código Completo
O exemplo abaixo autentica, consulta saldo e cria uma cobrança PIX:
require('dotenv').config();
const axios = require('axios');
const fs = require('fs');
const API_URL = process.env.FIREBANKING_API_URL;
const certificate = fs.readFileSync('./client-cert.pem', 'utf8');
const encodedCert = encodeURIComponent(certificate);
// 1. Obter token
async function getToken() {
const response = await axios.post(`${API_URL}/api/auth/token`, {
clientId: process.env.FIREBANKING_CLIENT_ID,
clientSecret: process.env.FIREBANKING_CLIENT_SECRET
}, {
headers: {
'Content-Type': 'application/json',
'X-SSL-Client-Cert': encodedCert
}
});
return response.data.access_token;
}
// 2. Consultar saldo
async function getBalance(token) {
const response = await axios.get(`${API_URL}/api/balance`, {
headers: { 'Authorization': `Bearer ${token}` }
});
return response.data;
}
// 3. Criar cobrança PIX
async function createPixCharge(token, value, description, externalId, payer) {
const response = await axios.post(`${API_URL}/api/pix/cash-in`, {
transaction: {
value,
description,
externalId,
expirationTime: 3600, // 1 hora
generateQrCode: true
},
payer: {
fullName: payer.name,
document: payer.document
}
}, {
headers: {
'Authorization': `Bearer ${token}`,
'Content-Type': 'application/json'
}
});
return response.data;
}
// Executar
async function main() {
try {
// Autenticar
console.log('Autenticando...');
const token = await getToken();
console.log('Token obtido com sucesso!');
// Consultar saldo
console.log('\nConsultando saldo...');
const balance = await getBalance(token);
console.log(`Saldo disponível: R$ ${balance.netBalance.toFixed(2)}`);
// Criar cobrança
console.log('\nCriando cobrança PIX...');
const charge = await createPixCharge(token, 100.00, 'Teste de integração', 'ORDER-001', {
name: 'João da Silva',
document: '12345678901'
});
console.log(`\nCobrança criada!`);
console.log(`ID: ${charge.transactionId}`);
console.log(`Status: ${charge.status}`);
console.log(`PIX Copia e Cola: ${charge.pixCode}`);
console.log(`Expira em: ${charge.expirationDate}`);
} catch (error) {
console.error('Erro:', error.response?.data || error.message);
}
}
main();import os
import urllib.parse
import requests
from dotenv import load_dotenv
load_dotenv()
API_URL = os.getenv('FIREBANKING_API_URL')
# Carregar certificado
with open('client-cert.pem', 'r') as f:
certificate = f.read()
encoded_cert = urllib.parse.quote(certificate)
# 1. Obter token
def get_token():
response = requests.post(f'{API_URL}/api/auth/token',
json={
'clientId': os.getenv('FIREBANKING_CLIENT_ID'),
'clientSecret': os.getenv('FIREBANKING_CLIENT_SECRET')
},
headers={
'Content-Type': 'application/json',
'X-SSL-Client-Cert': encoded_cert
}
)
response.raise_for_status()
return response.json()['access_token']
# 2. Consultar saldo
def get_balance(token):
response = requests.get(f'{API_URL}/api/balance',
headers={'Authorization': f'Bearer {token}'}
)
response.raise_for_status()
return response.json()
# 3. Criar cobrança PIX
def create_pix_charge(token, value, description, external_id, payer_name, payer_document):
response = requests.post(f'{API_URL}/api/pix/cash-in',
json={
'transaction': {
'value': value,
'description': description,
'externalId': external_id,
'expirationTime': 3600,
'generateQrCode': True
},
'payer': {
'fullName': payer_name,
'document': payer_document
}
},
headers={
'Authorization': f'Bearer {token}',
'Content-Type': 'application/json'
}
)
response.raise_for_status()
return response.json()
# Executar
def main():
try:
# Autenticar
print('Autenticando...')
token = get_token()
print('Token obtido com sucesso!')
# Consultar saldo
print('\nConsultando saldo...')
balance = get_balance(token)
print(f"Saldo disponível: R$ {balance['netBalance']:.2f}")
# Criar cobrança
print('\nCriando cobrança PIX...')
charge = create_pix_charge(
token,
100.00,
'Teste de integração',
'ORDER-001',
'João da Silva',
'12345678901'
)
print(f"\nCobrança criada!")
print(f"ID: {charge['transactionId']}")
print(f"Status: {charge['status']}")
print(f"PIX Copia e Cola: {charge['pixCode']}")
print(f"Expira em: {charge['expirationDate']}")
except requests.exceptions.RequestException as e:
print(f'Erro: {e.response.json() if e.response else e}')
if __name__ == '__main__':
main()4. Executar
node quickstart.jspython quickstart.pySaída esperada:
Autenticando...
Token obtido com sucesso!
Consultando saldo...
Saldo disponível: R$ 48734.90
Criando cobrança PIX...
Cobrança criada!
ID: 7845
Status: PENDING
PIX Copia e Cola: 00020126580014br.gov.bcb.pix...
Expira em: 2024-01-20T14:30:00.000Z5. Receber Notificações (Webhook)
Configure um endpoint para receber notificações quando o pagamento for confirmado:
// Express.js
app.post('/webhook/firebanking', (req, res) => {
const { event, transactionId, status, finalAmount } = req.body;
if (event === 'CashIn' && status === 'CONFIRMED') {
console.log(`Pagamento ${transactionId} confirmado: R$ ${finalAmount}`);
// Atualizar pedido no seu sistema
}
res.status(200).send('OK');
});Configure a URL do webhook no Painel Fire Banking. Veja o Guia de Webhooks para mais detalhes.
Próximos Passos
Autenticação
Entenda o fluxo de autenticação em detalhes
PIX Cash-In
Explore todas as opções de cobrança PIX
PIX Cash-Out
Envie pagamentos PIX
Cash-Out via QR Code
Pague via QR Code PIX
Webhooks
Configure notificações em tempo real