0xarchive

install
source · Clone the upstream repo
git clone https://github.com/0xArchiveIO/0xarchive-skill
Claude Code · Install into ~/.claude/skills/
T=$(mktemp -d) && git clone --depth=1 https://github.com/0xArchiveIO/0xarchive-skill "$T" && mkdir -p ~/.claude/skills && cp -r "$T/skills/query" ~/.claude/skills/0xarchiveio-0xarchive-skill-0xarchive && rm -rf "$T"
manifest: skills/query/SKILL.md
source content

0xArchive API Skill

Query historical and real-time crypto market data from 0xArchive using

curl
. Three exchanges are supported: Hyperliquid (perps DEX), Lighter.xyz (order-book DEX), and HIP-3 (Hyperliquid builder perps). Data types: orderbooks, trades, candles, funding rates, open interest, liquidations, and data quality metrics.

Authentication

All endpoints require the

x-api-key
header. The key is read from
$OXARCHIVE_API_KEY
.

curl -s -H "x-api-key: $OXARCHIVE_API_KEY" "https://api.0xarchive.io/v1/..."

Exchanges & Coin Naming

ExchangePath prefixCoin formatExamples
Hyperliquid
/v1/hyperliquid
UPPERCASE
BTC
,
ETH
,
SOL
HIP-3
/v1/hyperliquid/hip3
Case-sensitive,
builder:NAME
km:US500
,
xyz:GOLD
,
hyna:BTC
,
vntl:SPACEX
,
flx:TSLA
,
cash:NVDA
Lighter
/v1/lighter
UPPERCASE
BTC
,
ETH

Hyperliquid and Lighter auto-uppercase the symbol server-side. HIP-3 coin names are passed through as-is.

Timestamps

All timestamps are Unix milliseconds. Use these shell helpers:

NOW=$(( $(date +%s) * 1000 ))
HOUR_AGO=$(( NOW - 3600000 ))
DAY_AGO=$(( NOW - 86400000 ))
WEEK_AGO=$(( NOW - 604800000 ))

Response Format

Every response follows this shape:

{
  "success": true,
  "data": [ ... ],
  "meta": {
    "count": 100,
    "request_id": "uuid",
    "next_cursor": "1706000000000"   // present when more pages exist
  }
}

Endpoint Reference

Hyperliquid (
/v1/hyperliquid
)

EndpointParamsNotes
GET /instruments
--List all instruments
GET /instruments/{symbol}
--Single instrument details
GET /orderbook/{symbol}
timestamp
,
depth
Latest or at timestamp
GET /orderbook/{symbol}/history
start
,
end
,
limit
,
cursor
,
depth
Historical snapshots
GET /trades/{symbol}
start
,
end
,
limit
,
cursor
Trade history
GET /candles/{symbol}
start
,
end
,
limit
,
cursor
,
interval
OHLCV candles
GET /funding/{symbol}/current
--Current funding rate
GET /funding/{symbol}
start
,
end
,
limit
,
cursor
,
interval
Funding rate history
GET /openinterest/{symbol}/current
--Current open interest
GET /openinterest/{symbol}
start
,
end
,
limit
,
cursor
,
interval
OI history
GET /liquidations/{symbol}
start
,
end
,
limit
,
cursor
Liquidation events
GET /liquidations/{symbol}/volume
start
,
end
,
limit
,
cursor
,
interval
Aggregated liquidation volume (USD)
GET /liquidations/user/{address}
start
,
end
,
limit
,
cursor
,
coin
Liquidations for a user
GET /freshness/{symbol}
--Data freshness per data type
GET /summary/{symbol}
--Combined market summary (price, funding, OI, volume, liquidations)
GET /prices/{symbol}
start
,
end
,
limit
,
cursor
,
interval
Mark/oracle/mid price history
GET /orders/{symbol}/history
start
,
end
,
user
,
status
,
order_type
,
limit
,
cursor
Order history with user attribution (Build+)
GET /orders/{symbol}/flow
start
,
end
,
interval
,
limit
Order flow aggregation (Build+)
GET /orders/{symbol}/tpsl
start
,
end
,
user
,
triggered
,
limit
,
cursor
TP/SL order history (Pro+)
GET /orderbook/{symbol}/l4
timestamp
,
depth
L4 orderbook reconstruction (Pro+)
GET /orderbook/{symbol}/l4/diffs
start
,
end
,
limit
,
cursor
L4 orderbook diffs (Pro+)
GET /orderbook/{symbol}/l4/history
start
,
end
,
limit
,
cursor
L4 orderbook checkpoints (Pro+)
GET /orderbook/{symbol}/l2
timestamp
,
depth
L2 full-depth orderbook derived from L4 (Build+)
GET /orderbook/{symbol}/l2/history
start
,
end
,
limit
,
cursor
,
depth
L2 full-depth checkpoints (Build+)
GET /orderbook/{symbol}/l2/diffs
start
,
end
,
limit
,
cursor
L2 tick-level diffs (Pro+)

HIP-3 (
/v1/hyperliquid/hip3
)

Coin names are case-sensitive (e.g.,

km:US500
). Free tier includes km:US500 for orderbook and orderbook history; Build+ unlocks all HIP-3 symbols.

EndpointParamsNotes
GET /instruments
--List HIP-3 instruments
GET /instruments/{coin}
--Single instrument
GET /orderbook/{coin}
timestamp
,
depth
Free: km:US500 only. Build+: all HIP-3 symbols.
GET /orderbook/{coin}/history
start
,
end
,
limit
,
cursor
,
depth
Free: km:US500 only. Build+: all HIP-3 symbols.
GET /trades/{coin}
start
,
end
,
limit
,
cursor
Trade history
GET /trades/{coin}/recent
limit
Recent trades (no time range needed)
GET /candles/{coin}
start
,
end
,
limit
,
cursor
,
interval
OHLCV candles
GET /funding/{coin}/current
--Current funding rate
GET /funding/{coin}
start
,
end
,
limit
,
cursor
,
interval
Funding history
GET /openinterest/{coin}/current
--Current OI
GET /openinterest/{coin}
start
,
end
,
limit
,
cursor
,
interval
OI history
GET /liquidations/{coin}
start
,
end
,
limit
,
cursor
Liquidation events
GET /liquidations/{coin}/volume
start
,
end
,
limit
,
cursor
,
interval
Aggregated liquidation volume (USD)
GET /freshness/{coin}
--Data freshness per data type
GET /summary/{coin}
--Combined market summary (price, funding, OI)
GET /prices/{coin}
start
,
end
,
limit
,
cursor
,
interval
Mark/oracle/mid price history
GET /orders/{coin}/history
start
,
end
,
user
,
status
,
order_type
,
limit
,
cursor
Order history with user attribution (Build+)
GET /orders/{coin}/flow
start
,
end
,
interval
,
limit
Order flow aggregation (Build+)
GET /orders/{coin}/tpsl
start
,
end
,
user
,
triggered
,
limit
,
cursor
TP/SL order history (Pro+)
GET /orderbook/{coin}/l4
timestamp
,
depth
L4 orderbook reconstruction (Pro+)
GET /orderbook/{coin}/l4/diffs
start
,
end
,
limit
,
cursor
L4 orderbook diffs (Pro+)
GET /orderbook/{coin}/l4/history
start
,
end
,
limit
,
cursor
L4 orderbook checkpoints (Pro+)
GET /orderbook/{coin}/l2
timestamp
,
depth
L2 full-depth orderbook derived from L4 (Build+)
GET /orderbook/{coin}/l2/history
start
,
end
,
limit
,
cursor
,
depth
L2 full-depth checkpoints (Build+)
GET /orderbook/{coin}/l2/diffs
start
,
end
,
limit
,
cursor
L2 tick-level diffs (Pro+)

Lighter (
/v1/lighter
)

Same data types as Hyperliquid except: no liquidations. Adds

granularity
on orderbook history and
/recent
trades.

EndpointParamsNotes
GET /instruments
--List Lighter instruments
GET /instruments/{symbol}
--Single instrument
GET /orderbook/{symbol}
timestamp
,
depth
Latest or at timestamp
GET /orderbook/{symbol}/history
start
,
end
,
limit
,
cursor
,
depth
,
granularity
Default granularity:
checkpoint
GET /trades/{symbol}
start
,
end
,
limit
,
cursor
Trade history
GET /trades/{symbol}/recent
limit
Recent trades (no time range needed)
GET /candles/{symbol}
start
,
end
,
limit
,
cursor
,
interval
OHLCV candles
GET /funding/{symbol}/current
--Current funding rate
GET /funding/{symbol}
start
,
end
,
limit
,
cursor
,
interval
Funding history
GET /openinterest/{symbol}/current
--Current OI
GET /openinterest/{symbol}
start
,
end
,
limit
,
cursor
,
interval
OI history
GET /freshness/{symbol}
--Data freshness per data type
GET /summary/{symbol}
--Combined market summary (price, funding, OI)
GET /prices/{symbol}
start
,
end
,
limit
,
cursor
,
interval
Mark/oracle price history
GET /l3orderbook/{symbol}
timestamp
,
depth
,
account
L3 order-level orderbook (Pro+)
GET /l3orderbook/{symbol}/history
start
,
end
,
limit
,
cursor
,
granularity
,
account
Historical L3 snapshots (Pro+)

Data Quality (
/v1/data-quality
)

EndpointParamsNotes
GET /status
--System health status
GET /coverage
--Coverage summary, all exchanges
GET /coverage/{exchange}
--Coverage for one exchange
GET /coverage/{exchange}/{symbol}
from
,
to
Symbol-level coverage + gaps
GET /incidents
status
,
exchange
,
since
,
limit
,
offset
List incidents
GET /incidents/{id}
--Single incident
GET /latency
--Ingestion latency metrics
GET /sla
year
,
month
SLA compliance report

WebSocket Channels

Additional real-time channels available via WebSocket (

wss://api.0xarchive.io/ws?apiKey=KEY
):

ChannelNotes
l4_diffs
L4 orderbook diffs with user attribution (Pro+, real-time only)
l4_orders
Order lifecycle events with user attribution (Pro+, real-time only)
lighter_l3_orderbook
Lighter L3 order-level orderbook snapshots (Pro+, historical only)
hip3_liquidations
HIP-3 liquidation events with long/short direction (Build+, historical only)
hip3_l4_diffs
HIP-3 L4 orderbook diffs (Pro+, real-time only)
hip3_l4_orders
HIP-3 order lifecycle events (Pro+, real-time only)

Web3 Authentication (
/v1
)

Get API keys programmatically using an Ethereum wallet (SIWE). No API key required for these endpoints.

EndpointParamsNotes
POST /auth/web3/challenge
address
(wallet address)
Returns SIWE message to sign
POST /web3/signup
message
,
signature
Returns free-tier API key
POST /web3/keys
message
,
signature
List all keys for wallet
POST /web3/keys/revoke
message
,
signature
,
key_id
Revoke a key
POST /web3/subscribe
tier
(
build
or
pro
),
payment-signature
header
x402 USDC subscription (see flow below)

Free-tier flow: Call

/auth/web3/challenge
with wallet address → sign the returned message with
personal_sign
(EIP-191) → submit to
/web3/signup
with the message and signature → receive API key.

Paid-tier flow (x402):

  1. POST /web3/subscribe
    with
    { "tier": "build" }
    → server returns 402 with
    payment.amount
    (micro-USDC),
    payment.pay_to
    (treasury address),
    payment.network
    .
  2. Sign an EIP-712
    TransferWithAuthorization
    (EIP-3009) on USDC Base:
    • Domain:
      { name: "USD Coin", version: "2", chainId: 8453, verifyingContract: "0x833589fCD6eDb6E08f4c7C32D4f71b54bdA02913" }
    • Type:
      TransferWithAuthorization(address from, address to, uint256 value, uint256 validAfter, uint256 validBefore, bytes32 nonce)
    • Message:
      { from: <wallet>, to: <pay_to>, value: <amount>, validAfter: 0, validBefore: <now+3600>, nonce: <32 random bytes hex> }
  3. Build x402 v2 payment payload:
    {
      "x402Version": 2,
      "payload": {
        "signature": "0x<EIP-712 signature hex>",
        "authorization": {
          "from": "0x<wallet>",
          "to": "0x<pay_to from step 1>",
          "value": "<amount as string>",
          "validAfter": "0",
          "validBefore": "<unix timestamp as string>",
          "nonce": "0x<64 hex chars>"
        }
      }
    }
    
  4. Base64-encode the JSON and retry:
    POST /web3/subscribe
    with
    { "tier": "build" }
    and header
    payment-signature: <base64 payload>
    → receive API key + subscription.

Important: All

authorization
values (
value
,
validAfter
,
validBefore
) must be strings, not numbers. See
scripts/web3_subscribe.py
for a complete working Python implementation.

Common Parameters

ParamTypeDescription
start
intStart timestamp (Unix ms). Defaults to 24h ago.
end
intEnd timestamp (Unix ms). Defaults to now.
limit
intMax records. Default 100, max 1000 (max 10000 for candles).
cursor
stringPagination cursor from
meta.next_cursor
.
interval
stringCandle interval:
1m
,
5m
,
15m
,
30m
,
1h
,
4h
,
1d
,
1w
. Default:
1h
. For OI/funding:
5m
,
15m
,
30m
,
1h
,
4h
,
1d
. Omit for raw data.
depth
intOrderbook depth (number of price levels per side).
granularity
stringLighter orderbook resolution:
checkpoint
(default),
30s
,
10s
,
1s
,
tick
.
account
intLighter L3 orderbook: filter by account index (e.g.,
281474976710654
for LLP vault).

Smart Defaults

When the user does not specify a time range, default to the last 24 hours:

NOW=$(( $(date +%s) * 1000 ))
DAY_AGO=$(( NOW - 86400000 ))

For candles with no explicit range, default to a range that makes sense for the interval (e.g., last 7 days for 4h candles, last 30 days for 1d candles).

Trade Response Fields

Each trade/fill record includes:

FieldTypeDescription
coin
/
symbol
stringTrading pair symbol
side
string
B
(buy) or
A
/
S
(sell)
price
stringExecution price
size
stringTrade size
timestamp
stringISO 8601 timestamp
trade_id
integerUnique trade ID
order_id
integerAssociated order ID
crossed
boolean
true
= taker,
false
= maker
fee
stringBase trading fee
fee_token
stringFee denomination (e.g., USDC)
closed_pnl
stringRealized PnL if closing position
direction
string
Open Long
,
Close Short
,
Long > Short
, etc.
start_position
stringPosition size before trade
user_address
stringUser's wallet address
builder_address
stringBuilder address that routed this order. Only present when the order was placed through a builder.
builder_fee
stringBuilder fee charged on this fill, paid to the builder (quote currency, typically USDC). Only present when
builder_address
is set.
deployer_fee
stringHIP-3 deployer fee share (quote currency). Negative for the maker side (rebate), positive for the taker side. HIP-3 only.
priority_gas
numberPriority fee burned in HYPE (not USDC) for write priority on the Hyperliquid validator queue. Independent of
builder_fee
and
deployer_fee
— paid to the network, not to a builder or deployer. Only present when the order paid for priority.
cloid
stringClient order ID
twap_id
integerTWAP execution ID

builder_address
,
builder_fee
,
deployer_fee
,
priority_gas
,
cloid
, and
twap_id
are optional — only present when non-zero/non-empty.
deployer_fee
is specific to HIP-3.
priority_gas
appears on any order that paid for write priority (most common on HIP-3 IOC orders).

Pagination

When

meta.next_cursor
is present in the response, more data is available. Append
&cursor=VALUE
to fetch the next page:

# First page
curl -s -H "x-api-key: $OXARCHIVE_API_KEY" \
  "https://api.0xarchive.io/v1/hyperliquid/trades/BTC?start=$START&end=$END&limit=1000"

# Next page (use next_cursor from previous response)
curl -s -H "x-api-key: $OXARCHIVE_API_KEY" \
  "https://api.0xarchive.io/v1/hyperliquid/trades/BTC?start=$START&end=$END&limit=1000&cursor=1706000000000_12345"

Tier Limits

TierPriceCoinsOrderbook DepthLighter GranularityHistorical DepthRate Limit
Free$0BTC only (HIP-3: km:US500 only)20 levels--30 days15 RPS
Build$49/moAll200 levelscheckpoint, 30s, 10s1 year50 RPS
Pro$199/moAllFull depth+ 1sFull history150 RPS
EnterpriseCustomAllFull depth+ tickFull historyCustom

Error Handling

HTTP StatusMeaningAction
400Bad request / validation errorCheck params (missing start/end, invalid interval)
401Missing or invalid API keySet
$OXARCHIVE_API_KEY
403Tier restrictionUpgrade plan (e.g., non-BTC coin on Free tier)
404Symbol not foundCheck coin name spelling and exchange
429Rate limitedBack off and retry

Error responses return

{ "code": 400, "error": "description" }
.

Example Queries

# List Hyperliquid instruments
curl -s -H "x-api-key: $OXARCHIVE_API_KEY" \
  "https://api.0xarchive.io/v1/hyperliquid/instruments" | jq '.data | length'

# Current BTC orderbook (top 10 levels)
curl -s -H "x-api-key: $OXARCHIVE_API_KEY" \
  "https://api.0xarchive.io/v1/hyperliquid/orderbook/BTC?depth=10" | jq '.data'

# ETH trades from the last hour
NOW=$(( $(date +%s) * 1000 )); HOUR_AGO=$(( NOW - 3600000 ))
curl -s -H "x-api-key: $OXARCHIVE_API_KEY" \
  "https://api.0xarchive.io/v1/hyperliquid/trades/ETH?start=$HOUR_AGO&end=$NOW&limit=100" | jq '.data'

# SOL 4h candles for the last week
NOW=$(( $(date +%s) * 1000 )); WEEK_AGO=$(( NOW - 604800000 ))
curl -s -H "x-api-key: $OXARCHIVE_API_KEY" \
  "https://api.0xarchive.io/v1/hyperliquid/candles/SOL?start=$WEEK_AGO&end=$NOW&interval=4h" | jq '.data'

# Current BTC funding rate
curl -s -H "x-api-key: $OXARCHIVE_API_KEY" \
  "https://api.0xarchive.io/v1/hyperliquid/funding/BTC/current" | jq '.data'

# BTC open interest aggregated to 1h intervals (last week)
NOW=$(( $(date +%s) * 1000 )); WEEK_AGO=$(( NOW - 604800000 ))
curl -s -H "x-api-key: $OXARCHIVE_API_KEY" \
  "https://api.0xarchive.io/v1/hyperliquid/openinterest/BTC?start=$WEEK_AGO&end=$NOW&interval=1h" | jq '.data'

# ETH funding rates aggregated to 4h intervals (last 30 days)
NOW=$(( $(date +%s) * 1000 )); MONTH_AGO=$(( NOW - 2592000000 ))
curl -s -H "x-api-key: $OXARCHIVE_API_KEY" \
  "https://api.0xarchive.io/v1/hyperliquid/funding/ETH?start=$MONTH_AGO&end=$NOW&interval=4h" | jq '.data'

# HIP-3 km:US500 current orderbook (Free tier safe)
curl -s -H "x-api-key: $OXARCHIVE_API_KEY" \
  "https://api.0xarchive.io/v1/hyperliquid/hip3/orderbook/km:US500" | jq '.data'

# HIP-3 km:US500 orderbook history (Free tier safe)
NOW=$(( $(date +%s) * 1000 )); HOUR_AGO=$(( NOW - 3600000 ))
curl -s -H "x-api-key: $OXARCHIVE_API_KEY" \
  "https://api.0xarchive.io/v1/hyperliquid/hip3/orderbook/km:US500/history?start=$HOUR_AGO&end=$NOW&limit=10" | jq '.data'

# HIP-3 km:US500 candles (last 24h, 1h interval)
NOW=$(( $(date +%s) * 1000 )); DAY_AGO=$(( NOW - 86400000 ))
curl -s -H "x-api-key: $OXARCHIVE_API_KEY" \
  "https://api.0xarchive.io/v1/hyperliquid/hip3/candles/km:US500?start=$DAY_AGO&end=$NOW&interval=1h" | jq '.data'

# Lighter BTC orderbook history (30s granularity, last hour)
NOW=$(( $(date +%s) * 1000 )); HOUR_AGO=$(( NOW - 3600000 ))
curl -s -H "x-api-key: $OXARCHIVE_API_KEY" \
  "https://api.0xarchive.io/v1/lighter/orderbook/BTC/history?start=$HOUR_AGO&end=$NOW&granularity=30s&limit=100" | jq '.data'

# System health status
curl -s -H "x-api-key: $OXARCHIVE_API_KEY" \
  "https://api.0xarchive.io/v1/data-quality/status" | jq '.'

# SLA report for current month
curl -s -H "x-api-key: $OXARCHIVE_API_KEY" \
  "https://api.0xarchive.io/v1/data-quality/sla" | jq '.'

# BTC market summary (price, funding, OI, volume, liquidations in one call)
curl -s -H "x-api-key: $OXARCHIVE_API_KEY" \
  "https://api.0xarchive.io/v1/hyperliquid/summary/BTC" | jq '.data'

# BTC data freshness (lag per data type)
curl -s -H "x-api-key: $OXARCHIVE_API_KEY" \
  "https://api.0xarchive.io/v1/hyperliquid/freshness/BTC" | jq '.data'

# BTC price history (mark/oracle/mid) aggregated to 1h
NOW=$(( $(date +%s) * 1000 )); DAY_AGO=$(( NOW - 86400000 ))
curl -s -H "x-api-key: $OXARCHIVE_API_KEY" \
  "https://api.0xarchive.io/v1/hyperliquid/prices/BTC?start=$DAY_AGO&end=$NOW&interval=1h" | jq '.data'

# BTC liquidation volume aggregated to 4h buckets
NOW=$(( $(date +%s) * 1000 )); WEEK_AGO=$(( NOW - 604800000 ))
curl -s -H "x-api-key: $OXARCHIVE_API_KEY" \
  "https://api.0xarchive.io/v1/hyperliquid/liquidations/BTC/volume?start=$WEEK_AGO&end=$NOW&interval=4h" | jq '.data'

# Data coverage for Hyperliquid BTC
curl -s -H "x-api-key: $OXARCHIVE_API_KEY" \
  "https://api.0xarchive.io/v1/data-quality/coverage/hyperliquid/BTC" | jq '.'