ERGO
不到10分鐘

第一筆代理支付
在Ergo testnet上。

沒有理論。沒有設定儀式。一個npm套件,30行程式碼,一個命令——您就能在Ergo testnet瀏覽器上看到真實交易。

bash
npm install @fleet-sdk/core

先決條件

  • 已安裝Node.js 18+
  • 一個testnet地址(在Nautilus錢包→設定→testnet模式中建立)
  • 從testnet.ergofaucet.org獲取testnet ERG
  • 5分鐘不間斷的專注時間
01

安裝Fleet SDK

~30秒
bash
mkdir my-agent && cd my-agent
npm init -y
npm install @fleet-sdk/core node-fetch

Fleet SDK是Ergo的官方TypeScript/JS SDK。可在Node.js和瀏覽器中使用。

02

建立agent-pay.js

~2分鐘
javascript
// 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;
}

此腳本獲取您的testnet UTxO,建構交易,並輸出未簽名的TX物件。

03

執行腳本

~10秒
bash
node agent-pay.js

您將看到未簽名的交易JSON。使用Nautilus(瀏覽器)或伺服器端金鑰簽名,然後POST到/api/v1/transactions。

04

新增Note(代理支付)

~5分鐘
javascript
// 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();

這擴展了基本TX以建立Note——一個帶有任務雜湊暫存器的不記名工具。接收者對Reserve贖回。

在瀏覽器中查看您的TX

提交後,您的交易會出現在Ergo testnet瀏覽器上。將您的TX ID貼到:

https://testnet.ergoplatform.com/transactions/{TX_ID}

準備深入了解?

快速開始讓您動起來。完整的架構參考和7步驟Playbook正等著您。

Follow for daily updates