Menos de 10 minutos
Primeiro pagamento de agente
no Ergo testnet.
Sem teoria. Sem cerimônia de configuração. Um pacote npm, 30 linhas, um comando — e você vê uma transação real no explorador Ergo testnet.
bash
npm install @fleet-sdk/core
Pré-requisitos
- Node.js 18+ instalado
- Um endereço testnet (crie em Nautilus wallet → Configurações → Modo testnet)
- testnet ERG do faucet em testnet.ergofaucet.org
- 5 minutos de foco ininterrupto
01
Instalar Fleet SDK
~30 segundosbash
mkdir my-agent && cd my-agent npm init -y npm install @fleet-sdk/core node-fetch
Fleet SDK é o SDK oficial TypeScript/JS para Ergo. Funciona em Node.js e navegadores.
02
Criar agent-pay.js
~2 minutosjavascript
// agent-pay.js
import { TransactionBuilder, OutputBuilder, SAFE_MIN_BOX_VALUE } from "@fleet-sdk/core";
// ── Config ───────────────────────────────────────────────────────────────────
const TESTNET_API = "https://api-testnet.ergoplatform.com";
const YOUR_ADDRESS = "YOUR_TESTNET_ADDRESS"; // paste your testnet address
const RECEIVER_ADDRESS = "3WwbzW6u8hKWBcL1W7kNVMr25s2UHfSBnYtwSHvrRQt7DdPuoXrt"; // testnet receiver
// ── 1. Fetch unspent boxes ────────────────────────────────────────────────────
const res = await fetch(
`${TESTNET_API}/api/v1/boxes/unspent/byAddress/${YOUR_ADDRESS}`
);
const { items: inputs } = await res.json();
// ── 2. Build transaction ──────────────────────────────────────────────────────
const unsignedTx = new TransactionBuilder(await getCurrentHeight())
.from(inputs)
.to(
new OutputBuilder("1000000", RECEIVER_ADDRESS) // 0.001 ERG
)
.sendChangeTo(YOUR_ADDRESS)
.payMinFee()
.build()
.toEIP12Object();
console.log("Unsigned TX:", JSON.stringify(unsignedTx, null, 2));
// → Sign with Nautilus wallet or server-side key, then submit
async function getCurrentHeight() {
const r = await fetch(`${TESTNET_API}/api/v1/info`);
const info = await r.json();
return info.fullHeight;
}Este script busca seus UTxO testnet, constrói uma transação e produz o objeto TX não assinado.
03
Executar o script
~10 segundosbash
node agent-pay.js
Você verá o JSON da transação não assinada. Assine com Nautilus (navegador) ou uma chave do lado do servidor, depois POST para /api/v1/transactions.
04
Adicionar um Note (pagamento de agente)
~5 minutosjavascript
// Note payment — agent pays for an API call
import { TransactionBuilder, OutputBuilder, SByte, SColl } from "@fleet-sdk/core";
const TASK_HASH = "a1b2c3d4..."; // blake2b256 of task output
const noteOutput = new OutputBuilder("5000000", RECEIVER_ADDRESS) // 0.005 ERG
.setAdditionalRegisters({
R4: SColl(SByte, Buffer.from(TASK_HASH, "hex")), // task hash
R5: SByte(await getCurrentHeight() + 100), // expiry: +100 blocks
});
const tx = new TransactionBuilder(await getCurrentHeight())
.from(inputs)
.to(noteOutput)
.sendChangeTo(YOUR_ADDRESS)
.payMinFee()
.build();Isso estende a TX básica para criar um Note — um instrumento ao portador com um registro de hash de tarefa. O receptor o resgata contra uma Reserve.
Veja sua TX no explorador
Após enviar, sua transação aparece no explorador Ergo testnet. Cole seu TX ID em:
https://testnet.ergoplatform.com/transactions/{TX_ID}