hl-read
A read-only MCP server for Hyperliquid that provides public market data (prices, order books, funding) and any wallet's positions, orders, and fills via MCP tools, without requiring a private key.
README
hl-read
A key-free, read-only toolkit for Hyperliquid. Use it as a Python library, a CLI, or an MCP server that lets an LLM agent (Claude, n8n, …) observe Hyperliquid markets and any wallet's public state.
Why "read-only" is the feature.
hl-readimports only the read side of the Hyperliquid SDK (Info) — neverExchange. There is no code path that can sign a transaction, place an order, or move funds. You never hand it a private key, so there is no key to leak. Most Hyperliquid MCP servers ask for your key so the model can trade; this one is safe to point an autonomous agent at by construction.
Everything it reads is public on-chain / exchange data: prices, order books, funding, and any address's positions, orders and fills.
Install
pip install hl-read # library + CLI
pip install "hl-read[mcp]" # also installs the MCP server deps
CLI
hl-read mids # all mid prices
hl-read mids BTC ETH # just these
hl-read book ETH --depth 5 # order book snapshot
hl-read funding --top 10 # markets with the most extreme funding
hl-read markets # every perp + max leverage
hl-read spot # every spot pair + mid price
hl-read spot PURR # filter by base coin / pair
hl-read positions 0xYourAddr... # anyone's positions (public data)
hl-read positions 0xYourAddr... --watch # live, re-polled every few seconds
hl-read balances 0xYourAddr... # spot token balances
hl-read orders 0xYourAddr... # resting orders
hl-read fills 0xYourAddr... --limit 20
hl-read watch ETH # live order book over websocket
Global flags: --testnet (use the testnet API), --json (raw JSON, great for piping to jq), --retries N (retry transient failures), --rate-limit N (cap HTTP calls/min), --no-cache (always fetch fresh).
hl-read --json funding | jq '.[] | select(.funding > 0.0001)'
Library
from hl_read import HLRead
hl = HLRead() # mainnet; HLRead(testnet=True) for testnet
hl.mids()["BTC"] # current mid price
hl.book("ETH", depth=5) # {"bids": [...], "asks": [...], "mid": ..., "spread": ...}
hl.positions("0xabc...") # account value + open positions for any address
hl.funding() # funding / mark / oracle / OI per market
hl.fills("0xabc...", limit=20) # recent fills
hl.spot_markets() # spot pairs: name, base/quote token, mid
hl.spot_balances("0xabc...") # spot token balances for any address
# live streams (open their own websocket — keep the returned Info alive)
hl.stream_book("ETH", lambda msg: print(msg["data"]["levels"][0][0]))
hl.stream_user_events("0xabc...", print) # live fills / funding / liquidations
Resilience (built in, configurable)
Every HTTP read goes through a default timeout, exponential backoff with jitter on
transient failures (network errors, HTTP 429/5xx → HLReadError once exhausted), an
optional client-side rate limit, and short-lived caching of the high-frequency market
endpoints (so e.g. mid() in a loop costs one fetch per cache window, not one per call).
hl = HLRead(
max_retries=4, # retry transient failures
rate_limit_per_min=600, # cap HTTP calls/min (None = off)
cache_ttl=1.0, # seconds to cache mids / funding ctxs (0 = always fresh)
meta_ttl=300.0, # seconds to cache the market/token tables
http_timeout=10.0, # per-request timeout
)
hl.clear_cache() # drop cached data on demand
MCP server (the differentiator)
Expose read-only Hyperliquid data to any MCP client over stdio.
hl-read-mcp # mainnet
HL_READ_TESTNET=1 hl-read-mcp # testnet
Claude Desktop — add to claude_desktop_config.json:
{
"mcpServers": {
"hl-read": { "command": "hl-read-mcp" }
}
}
Claude Code:
claude mcp add hl-read -- hl-read-mcp
Tools exposed to the model (11): list_markets, get_mids, get_book, get_funding, get_funding_history, get_positions, get_open_orders, get_fills, get_candles, get_spot_markets, get_spot_balances. None of them can place an order.
Ask Claude: "What's the funding on the top 5 Hyperliquid perps right now, and what's 0xabc…'s open position on the highest one?" — it answers using only public reads.
Safety model
- No key, ever. The library has no parameter, env var, or file from which it reads a private key.
- No trading code in the import graph.
hyperliquid.exchange.Exchangeis never imported, so signing/order/cancel functions are not reachable. - Read-only network calls. Only Hyperliquid's public
infoendpoint and public websocket subscriptions are used.
This makes hl-read a sound base for monitoring bots, dashboards, and autonomous agents where you want market awareness without ceding the ability to spend.
Development
pip install -e ".[dev]"
python -m unittest discover -s tests # or: pytest
The test suite is fully offline — the SDK is mocked, so it exercises the retry/backoff, cache, and parsing logic deterministically without touching the network.
License
MIT © Koki Yonai. Not affiliated with Hyperliquid. Public market data only; nothing here is financial advice.
Recommended Servers
playwright-mcp
A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.
Magic Component Platform (MCP)
An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.
Audiense Insights MCP Server
Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
graphlit-mcp-server
The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.
Kagi MCP Server
An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.
Exa Search
A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.