Perpetuals data and signed order relay flow via LiberFi OpenAPI (/v1/perpetuals/… → perpetuals-server).
See bootstrap.md for CLI install and lfi ping.
positions, orders, fills): pass the wallet address (0x) as the positional argument. For first-person queries
("我的持仓", "my positions", etc.), the skill MUST auto-resolve the user's
TEE EVM address via lfi status → lfi login key (if needed) →
lfi whoami → use the returned evmAddress. NEVER ask the user for an
address — the TEE wallet is server-managed and the user does not know it.
order-prepare / order-submit, cancel variants): require a user wallet to sign typed data; agents must not fabricate signatures.deposit-place): requires authentication (lfi status then lfi login key) — the server's TEE wallet signs and broadcasts on the user's behalf. The atomic deposit-quote / deposit-submit escape hatches do not require auth but the caller is then responsible for signing the SOL tx and broadcasting it themselves.| User intent | Skill |
|---|---|
| ------------- | -------- |
| Spot swap, bridge, gas send | liberfi-swap |
| Trending spot tokens, new listings | liberfi-market |
| Polymarket / Kalshi | liberfi-predict |
| Spot token audit, DEX pools for a token | liberfi-token |
| Perp markets, HL-style orderbook, perp positions | liberfi-perpetuals |
| Funding the perp account (Solana → Hyperliquid via Relay), checking deposit lifecycle | liberfi-perpetuals |
| Spot wallet holdings on a chain (not perp account) | liberfi-portfolio |
| Command | Description |
|---|---|
| --------- | ------------- |
lfi perpetuals coins | List tradable perp coins |
lfi perpetuals markets | Market snapshots (--symbols optional) |
lfi perpetuals market | Single market |
lfi perpetuals orderbook | L2 book (--max-level) |
lfi perpetuals trades | Recent trades (--limit) |
lfi perpetuals klines | Candles (--interval required) |
lfi perpetuals positions | Positions + margin summary |
lfi perpetuals orders | Open orders |
lfi perpetuals fills | Fill history |
lfi perpetuals order-prepare | Build typed data for place order |
lfi perpetuals order-submit --body ' | Submit signed place order |
lfi perpetuals cancel-prepare | Build typed data for cancel |
lfi perpetuals cancel-submit --body ' | Submit signed cancel |
lfi perpetuals deposit-place --gross-lamports | Recommended: TEE one-click Solana → Hyperliquid deposit (server quotes, signs, broadcasts, submits). Auth required. |
lfi perpetuals deposit-quote --user-solana-address --hyperliquid-recipient --gross-lamports | Escape hatch step 1: returns unsigned SOL tx + breakdown. Caller signs + broadcasts within ~30s, then calls deposit-submit. |
lfi perpetuals deposit-submit --body ' | Escape hatch step 2: record the broadcasted SOL tx hash. Idempotent on solanaTxHash. |
lfi perpetuals deposit-status | Read deposit lifecycle. --refresh bypasses any server-side cache (server-reserved knob; today both endpoints behave identically). |
Common flags: --provider (e.g. hyperliquid), global --json.
The deposit pipeline moves SOL from the user's Solana wallet to the user's
Hyperliquid perp account via the Relay bridge service. The recommended path
is the one-click TEE auto-flow:
lfi status --json; if not logged in, lfi login key --role AGENT --name ".
lfi perpetuals deposit-place --gross-lamports --json lamports = SOL × 1_000_000_000 (1 SOL = 1e9 lamports).--hyperliquid-recipient is optional — defaults to the user's TEE EVM address (lfi whoami evmAddress), which is what 99% of users want.
intentId and solanaTxHash.lfi perpetuals deposit-status --json until status is settled (typical: 30–120 s).
Server returns status: "broadcasted" immediately after step 3; the
reconciliation loop progresses through `relay_waiting → relay_pending →
settled (or failed_*` states). On failure consult the
statusHistory[] and lastError fields for the recoverable / non-
recoverable distinction.
For the atomic escape-hatch flow (when the user controls their own SOL
private key outside the TEE, or recovering from a partial failure where
the SOL tx has been broadcasted but submit did not succeed), see
lfi perpetuals markets --jsonlfi perpetuals orderbook BTC --jsonlfi perpetuals trades BTC --limit 20 --jsonlfi perpetuals positions 0xYourAddr --json**If the user says "我有什么永续持仓", "我的合约持仓", "my perp positions",
"我在 Hyperliquid 上挂了哪些单", "我永续盈亏", "show my fills" or any
first-person variant — DO NOT ask for a wallet address. Run this exact
sequence:**
lfi status --jsonlfi login key --role AGENT --name "OpenClawAgent" --jsonlfi whoami --json → returns evmAddress(the user's TEE EVM address managed by the LiberFi server).
lfi perpetuals positions --json lfi perpetuals orders --json lfi perpetuals fills --limit 20 --json directly — do not retry with a different address; an empty result is the
correct answer for a fresh TEE wallet.
The user does not know their EVM address — the LiberFi server holds the TEE
wallet. The skill must resolve "我" → TEE wallet via whoami, transparently.
lfi perpetuals order-prepare --user-address 0x… --symbol BTC --side long --order-type limit --amount 0.01 --price 95000 --jsontypedData with their wallet (e.g. MetaMask eth_signTypedData_v4).SignedAction: action, nonce, signature (0x), optional vaultAddress from prepare response.lfi perpetuals order-submit --body '{"action":…,"nonce":…,"signature":"0x…"}' --jsonAll CLI calls hit OpenAPI paths under /v1/perpetuals/…, which the gateway proxies to perpetuals-server /v1/…. Configure the gateway with UPSTREAM_PERPETUALS_SERVICE_BASE_URL (default local example: http://localhost:8083 — avoid colliding with openapi :8080 and prediction :8082; run perpetuals-server with SERVER_PORT=8083 when colocated).
共 1 个版本