Documentation Index
Fetch the complete documentation index at: https://goldrush.dev/docs/llms.txt
Use this file to discover all available pages before exploring further.
Hyperliquid WebSocket API
Critical Rules
- WebSocket URL:
wss://hypercore.goldrushdata.com/ws?key=<GOLDRUSH_API_KEY>(note:hypercore, nothyperliquid; auth is a?key=query parameter, not anAuthorizationheader). - Wire-compatible with
wss://api.hyperliquid.xyz/wsfor shared subscription types (e.g.l2Book). - No 1000-subscription-per-IP cap. Multiplex many subscriptions on one connection.
l2Book- aggregated price-level snapshots{px, sz, n}.coinis optional - omit it to stream every asset over a single subscription.l4Book- GoldRush-native order-level stream withuser,oid,cloid,tif, and trigger metadata per order.coinis required. Emits a singleSnapshoton subscribe, then per-blockUpdates(order_statuses+book_diffs). Not available on the public Hyperliquid WebSocket.
Available Subscriptions
| Channel | Subscription body | Returns |
|---|---|---|
l2Book | {"type":"l2Book","coin":"BTC"} (or omit coin) | Full L2 book snapshot per tick with bids/asks aggregated by significant figures. Self-healing - every message is a complete snapshot. |
l4Book | {"type":"l4Book","coin":"BTC"} | Initial Snapshot of every resting order, then per-block Updates with order_statuses (lifecycle) and book_diffs (per-order changes). GoldRush-native, no upstream equivalent. |
Subscribe / Unsubscribe Pattern
When to use which channel
| Need | Use |
|---|---|
| Top-of-book, spread, depth-weighted mid, slippage / impact estimator | l2Book |
| Stream every asset on one subscription | l2Book (omit coin) |
| Queue position, per-user flow attribution, microstructure analytics | l4Book |
| Reconstruct an L2-style aggregated view but keep order-level detail | l4Book (aggregate client-side) |
| OHLCV candles instead of raw book state | Streaming API ohlcvCandlesForPair (see streaming.md) |
The GoldRush Hyperliquid WebSocket API is a drop-in replacement for
wss://api.hyperliquid.xyz/ws. Subscription payloads, channel names, and message shapes are byte-for-byte identical to the public Hyperliquid feed. The only difference is the connection URL - authentication is a required key query parameter, so no header changes are needed in your client.
Endpoint
Comparison with the public Hyperliquid WebSocket
| Public WebSocket | GoldRush | |
|---|---|---|
| URL | wss://api.hyperliquid.xyz/ws | wss://hypercore.goldrushdata.com/ws?key= |
| Auth | None | key query parameter (required) |
| Subscriptions per IP | 1000 | No cap |
| Wire compatibility | n/a (it’s the source) | Byte-for-byte |
| Available channels | See Hyperliquid Docs | See Available subscriptions |
Available subscriptions
| Channel | Subscription body | Returns |
|---|---|---|
l2Book | {"type": "l2Book", "coin": "BTC"} | Real-time L2 order book snapshots - bids and asks aggregated by significant figures. coin is optional - omit it to stream every asset on one subscription. |
l4Book | {"type": "l4Book", "coin": "BTC"} | GoldRush-native order-level book stream - initial Snapshot of every resting order plus per-block Updates with order_statuses and book_diffs. Exposes user, oid, cloid, tif, and trigger metadata per order. coin is required. Not available on the public Hyperliquid WebSocket. |
Limits
No 1000-subscription-per-IP cap. Onl2Book, filter parameters are optional - omit coin to stream the full L2 book across every asset on a single subscription. l4Book requires coin and is one-asset-per-subscription. See Limits & Connections for details.
For richer real-time analytics (pre-decoded HyperCore fills, liquidations, vault events, OHLCV across every HIP-3/HIP-4 market), pair the WebSocket with the GraphQL Streaming API.
Moving from the public Hyperliquid WebSocket to GoldRush is one change:
- URL - replace
wss://api.hyperliquid.xyz/wswithwss://hypercore.goldrushdata.com/ws?key=.
key query parameter, so no header swap is needed in your client.
Side-by-side
wscat
Public Hyperliquid
GoldRush
JavaScript / TypeScript
Public Hyperliquid
GoldRush
Python
Public Hyperliquid
GoldRush
Behavioral notes
Things to be aware of when you cut over.Stream payloads are byte-equal, modulo live drift
Thechannel name and data shape match Hyperliquid byte-for-byte - same keys, same nesting, same value types. Numeric fields update independently on each side, so a price level may differ by tens of milliseconds, but the schema is identical.
Auth errors close the connection
A missing or invalidkey query param returns HTTP 401 on the upgrade handshake, so the WebSocket never opens. Public Hyperliquid has no auth and never rejects the handshake.
Filter parameters are optional on GoldRush
Parameters that the public Hyperliquid WebSocket requires (e.g.coin on l2Book) are optional on GoldRush. Omit them to stream the entire channel on a single subscription instead of fanning out one subscription per asset. See Limits.
Existing SDKs work after a wsUrl override
Most popular Hyperliquid SDKs accept a WebSocket base URL override - point them at wss://hypercore.goldrushdata.com/ws?key= and the rest of the SDK works unchanged. See SDK compatibility for the override snippets.
Authentication
The WebSocket API uses your standard GoldRush API key, passed as akey query parameter at connection time. The same key works against the Foundational API, the Streaming API, the Pipeline API, and the Info API. If you don’t have one yet, sign up here.
Never hardcode keys in source. Use environment variables or a secrets manager.
What you gain
- No subscription cap. No 1000-subscription-per-IP limit; multiplex hundreds of subscriptions on a single connection.
- Wildcard subscriptions. Omit filter parameters to stream the entire channel - e.g. the full L2 order book across every asset on one subscription.
- One key for everything Hyperliquid. The same API key unlocks Streaming, Pipeline, the Info API, and HyperEVM via the Foundational API.
The most popular Hyperliquid SDKs work against the GoldRush WebSocket API after a one-line URL override. Authentication is a
key query parameter on the connection URL - no header injection is needed.
JavaScript / TypeScript: nomeida/hyperliquid
Install
npm
yarn
Configure
Note: If your SDK version doesn’t expose a wsUrl option, instantiate the WebSocket client manually and pass it to the SDK, or patch the constant the SDK uses. See the override fallback below.
Manual WebSocket fallback
When the SDK doesn’t expose awsUrl knob, bypass it and drive the raw socket yourself:
Python: hyperliquid-dex/hyperliquid-python-sdk
Install
Configure
Tip: The SDK’sInfoclass manages both REST and WebSocket. If you only need WebSocket, you can skip thesession.headers.update(...)line. If you only need REST, passskip_ws=Trueinstead.
Verification
After cutover, confirm everything is wired correctly:- Diff a known subscription - subscribe to
l2Bookfor the same coin against both endpoints; the streamedchannelanddatashape (keys, nesting, types) should match exactly. - Confirm auth - remove the
keyquery parameter and confirm the WebSocket upgrade fails with HTTP401. If the socket opens, your request isn’t reaching GoldRush. - Confirm wildcard - subscribe to
l2Bookwithout acoinand confirm you receive book snapshots for multiple assets. This call would be rejected on the public Hyperliquid WebSocket.
Other SDKs
The pattern is the same for any WebSocket client: override the connection URL towss://hypercore.goldrushdata.com/ws?key=. If you run into a specific SDK that doesn’t expose a URL override, email us - we’ll publish a recipe.
No subscription cap
The GoldRush Hyperliquid WebSocket API has no per-IP, per-key, or per-connection subscription cap. The 1000-subscription-per-IP limit on the public Hyperliquid WebSocket does not apply. You can:- Open as many concurrent subscriptions as your client supports.
- Multiplex hundreds of
l2Booksubscriptions on a single connection. - Track every active wallet, market, and asset from one process.
Wildcard subscriptions
Filter parameters that the public Hyperliquid WebSocket requires are optional on GoldRush. Omit them to stream the entire channel on one subscription instead of fanning out one subscription per asset.| Channel | Public Hyperliquid | GoldRush |
|---|---|---|
l2Book | coin required - one subscription per asset | coin optional - omit it to stream the full L2 order book across every asset on a single subscription |
How streaming works
Messages are pushed directly from a live Hyperliquid ingestion pipeline - no polling, no cache delay. Latency from upstream Hyperliquid event to your client is dominated by network round-trip from our Tokyo nodes.| Channel | Push trigger |
|---|---|
l2Book | Every L2 update on the subscribed coin (or every coin, if wildcard). |
Connection management
You’re not rate-limited, but a few client-side defaults are worth tuning.| Behavior | Recommended client setting |
|---|---|
| Reconnect | On unexpected close, reconnect with exponential backoff capped at ~30 seconds. Re-send your subscription messages after the new socket opens. |
| Heartbeat | Send an application-level ping every 30 seconds. The server replies with pong. Most WebSocket libraries handle this automatically; verify yours does. |
| Max message size | L2 book snapshots for wildcard subscriptions can exceed 1 MB. Raise your client’s maxPayload (Node ws library) or max_size (Python websockets) if you’re receiving truncated messages. |
| Backpressure | If your handler can’t keep up with incoming messages, your client buffer will fill. Drain to a queue or downstream consumer; don’t block the read loop on application work. |
Reconnect sketch
TypeScript
Python
Watch out for client-side limits
GoldRush has no caps, but the rest of your stack might:- OS file descriptor limits - if you’re opening many connections in parallel, raise
ulimit -n. - Reverse proxy idle timeouts - if you’re terminating WS through nginx, HAProxy, or a cloud load balancer, set the idle timeout above your heartbeat interval (typically 60 seconds minimum).
- Browser concurrency - browsers limit WebSocket connections per origin; one connection multiplexing many subscriptions is always preferable to many connections.
Network and TLS
- HTTP/1.1 Upgrade to WSS is supported (standard WebSocket handshake).
- TLS 1.2+ required.
- Compression (
permessage-deflate) is negotiated when offered by the client.
Need higher guarantees?
Enterprise SLA, dedicated capacity, regional pinning, and on-prem options are all available. Email sales.WebSocket API Reference
L2 Order Book
Subscribe to a continuous stream of L2 order book snapshots for any Hyperliquid perp or spot asset. The payload is wire-equal to the public Hyperliquidl2Book WebSocket subscription - same channel name, same levels shape, same aggregation parameters. Point your client at wss://hypercore.goldrushdata.com/ws?key= and the rest of your code stays the same.
Endpoint
Authorization header is used.
Subscribe
Send this JSON message after the connection is established:| Parameter | Type | Required | Description |
|---|---|---|---|
method | string | Yes | Always "subscribe". |
subscription | object | Yes | __RESPONSE_ROW__type string Always "l2Book". __RESPONSE_ROW__coin string Asset symbol - e.g. "BTC", "ETH", "@107" for spot pairs. For HIP-3 markets, include the deployer prefix. Omit to receive snapshots for all assets in the order book. __RESPONSE_ROW__nSigFigs int Significant figures used for price aggregation. One of 2, 3, 4, 5, or null for full precision. Defaults to null. __RESPONSE_ROW__mantissa int When nSigFigs is 5, controls the mantissa rounding. One of 1, 2, or 5. Not allowed for other nSigFigs values. |
Example
wscat
TypeScript
Python
Unsubscribe
Send the samesubscription body with method: "unsubscribe":
Streamed message
Each message haschannel: "l2Book" and a data payload with the current book snapshot for the subscribed coin.
| Field | Type | Description |
|---|---|---|
channel | string | Always "l2Book". |
data | object | |
data.coin | string | Asset symbol the snapshot belongs to. |
data.time | int | HyperCore block timestamp in milliseconds. |
data.block_height | int | HyperCore block height the snapshot was taken at. |
data.levels | array> | Tuple [bids, asks]. Each side is an array of price levels in best-first order. __RESPONSE_ROW__px string Price for this level (decimal string). __RESPONSE_ROW__data.sz string Aggregate size resting at this level (decimal string, base units). __RESPONSE_ROW__data.n int Number of orders aggregated into this level. |
Notes
- Wire-compatible with
wss://api.hyperliquid.xyz/wsl2Booksubscriptions - same channel name, samelevelsshape. coinis optional on GoldRush. Omit it to stream the entire L2 order book across every asset on a single subscription. The public Hyperliquid API requirescoinand locks each subscription to one asset at a time.- No 1000-subscription-per-IP cap - multiplex hundreds of
l2Booksubscriptions on a single connection. - For OHLCV candles instead of raw book state, use the Streaming API OHLCV streams.
L4 Order Book Diff
Subscribe to a GoldRush-native order-level view of the Hyperliquid book. Unlikel2Book, which emits a full aggregated snapshot every tick, l4Book emits a single Snapshot of every resting order on subscribe and then per-block Updates carrying individual order_statuses and book_diffs. Each order in the stream includes its user, oid, cloid, orderType, tif, and trigger metadata - enough to reconstruct queue position, per-trader flow, and microstructure. This channel is not available on wss://api.hyperliquid.xyz/ws - it is exclusive to wss://hypercore.goldrushdata.com/ws.
Endpoint
Authorization header is used.
Subscribe
Send this JSON message after the connection is established:| Parameter | Type | Required | Description |
|---|---|---|---|
method | string | Yes | Always "subscribe". |
subscription | object | Yes | __RESPONSE_ROW__type string Always "l4Book". __RESPONSE_ROW__coin string Asset symbol - e.g. "BTC", "ETH", "@107" for spot pairs. For HIP-3 markets, include the deployer prefix. Required - unlike l2Book, l4Book does not support wildcard subscriptions; each subscription is locked to a single asset. |
Example
wscat
TypeScript
Python
Unsubscribe
Send the samesubscription body with method: "unsubscribe":
Streamed messages
Every message haschannel: "l4Book". The data payload contains exactly one of two variants: a Snapshot (emitted once, immediately after subscribe) or an Updates (emitted on each subsequent HyperCore block where the book for coin changed).
Initial snapshot
The first message after subscribe carries the full resting book at the current block. Each entry inlevels[0] (bids) and levels[1] (asks) is an individual order - not an aggregated price level.
Incremental updates
Subsequent messages carry only what changed since the previous block.order_statuses describes order lifecycle events (open, etc.); book_diffs carries the corresponding price-level changes.
Response fields
| Field | Type | Description |
|---|---|---|
channel | string | Always "l4Book". |
data | object | Contains exactly one of Snapshot or Updates. |
data.coin | string | Asset symbol the snapshot belongs to. |
data.time | int | HyperCore block timestamp in milliseconds. |
data.block_height | int | HyperCore block height the snapshot was taken at. |
data.levels | array> | Tuple [bids, asks]. Each side is an array of individual Order objects (see below), in queue order at their respective price. |
data.time | int | HyperCore block timestamp in milliseconds. |
data.block_height | int | HyperCore block height. |
data.order_statuses | array | Order lifecycle events at this block. __RESPONSE_ROW__time string ISO-8601 timestamp with nanosecond precision. __RESPONSE_ROW__data.user string Wallet address that owns the order. __RESPONSE_ROW__data.status string Lifecycle status (e.g. "open"). __RESPONSE_ROW__data.order Order The order, in the same shape as a snapshot entry. user inside this nested object is null because it duplicates the parent user. __RESPONSE_ROW__book_diffs array Per-order book changes at this block. __RESPONSE_ROW__book_diffs.user string Wallet address that owns the order. __RESPONSE_ROW__book_diffs.oid int Order id the diff applies to. __RESPONSE_ROW__book_diffs.px string Price level the diff applies to (decimal string). __RESPONSE_ROW__book_diffs.coin string Asset symbol. __RESPONSE_ROW__book_diffs.raw_book_diff object The change descriptor. Observed shape: { "new": { "sz": "" } } for a newly resting order. Other shapes may carry size deltas or cancellations - inspect the keys to discriminate. |
Order object
The Order type appears insideSnapshot.levels[*][*] and Updates.order_statuses[*].order.
| Field | Type | Description | |
|---|---|---|---|
user | `string | null` | Wallet address that owns the order. null when the order is nested inside an order_status (the parent already carries it). |
coin | string | Asset symbol. | |
side | string | "B" for bid, "A" for ask. | |
limitPx | string | Limit price (decimal string). | |
sz | string | Resting size (decimal string, base units). | |
oid | int | Hyperliquid order id - stable for the lifetime of the order. | |
timestamp | int | Order-placement timestamp in HyperCore milliseconds. | |
triggerCondition | string | Trigger condition string (e.g. "N/A" for plain limit orders). | |
isTrigger | boolean | True if this is a stop / take-profit trigger order. | |
triggerPx | string | Trigger price (decimal string, "0.0" for non-trigger orders). | |
isPositionTpsl | boolean | True if this is a position-level TP/SL. | |
reduceOnly | boolean | True if the order is flagged reduce-only. | |
orderType | string | Hyperliquid order type (e.g. "Limit"). | |
tif | string | Time-in-force (e.g. "Alo", "Gtc", "Ioc"). | |
cloid | `string | null` | Client-supplied order id (hex string), or null if none was provided. |
Notes
- GoldRush-native.
l4Bookis not exposed onwss://api.hyperliquid.xyz/ws. Pointing a client at the public endpoint with this subscription type will fail. coinis required. Unlikel2Book, you cannot omitcointo stream every asset. Open one subscription per asset.- Snapshot, then diffs. The first message is always a
Snapshot; every message thereafter is anUpdates. Clients must seed local book state from the snapshot and apply diffs from there. On reconnect, drop local state and re-seed from the next snapshot. - Per-order detail. Each entry exposes
user,oid,cloid,tif, and trigger metadata - enabling queue-position reconstruction, per-trader flow attribution, and microstructure analytics that are not possible withl2Book. - See the L4 Order Book recipe for patterns to maintain book state, attribute flow by
user, or reconstruct aggregated price levels. For aggregated{px, sz, n}snapshots without per-order detail, usel2Book.
Recipes
Thel2Book channel on wss://hypercore.goldrushdata.com/ws?key= is wire-equal to the public Hyperliquid feed but with coin made optional and the per-IP subscription cap removed. This recipe shows how to turn that stream into common trading and analytics building blocks. For the raw subscription shape see the l2Book reference; for the connection model see the WebSocket API overview.
What you get
- Complete snapshots, not diffs. Every
l2Bookmessage contains the currenttime,coin, and a full[bids, asks]tuple in best-first order, withpx/sz/nper level. Consume each message in isolation - no sequence numbers to track, no diff replay buffer, no REST snapshot to bootstrap. - Self-healing on packet loss. Drop a message, reconnect mid-session, or restart your process - the next message arrives with the full book state, so your in-memory view is correct on the very next tick.
- Upstream-compatible aggregation knobs.
nSigFigsaccepts2,3,4,5, ornull(full precision).mantissaaccepts1,2, or5, and is only valid whennSigFigsis5. - Wildcard coverage. Omit
cointo stream every asset’s book over a single subscription, instead of fanning out one subscription per asset.
Subscribe and hold book state
The pattern below keeps aMap in memory. Each incoming message replaces the entry for its coin, so the map is always current and never needs reconciliation.
TypeScript
Python
Patterns
Top-of-book tracker
Readbids[0] and asks[0] directly from each message. The spread is Number(asks[0].px) - Number(bids[0].px). No state required - every message is self-contained, so a single-line transformation gives you a live ticker.
Depth-weighted mid quote
Sumpx * sz across the first K levels on each side, then average. This produces a fair-value mid that’s robust to thin top-of-book liquidity, and is useful as a hedging or pricing reference.
TypeScript
Slippage / impact estimator
Walk levels on the relevant side until cumulativesz covers the requested notional. Return the size-weighted average fill price - the difference vs the top-of-book is your expected slippage.
TypeScript
Liquidity heatmap
On each message, append[time, coin, side, px, sz] rows to your time-series store (Clickhouse, TimescaleDB, Parquet). Because every message is a complete snapshot of the top levels, the heatmap rebuilds correctly from any contiguous slice of history - you don’t need a separate “initial book” record to seed the visualisation.
Handling reconnects
Reconnect logic is a one-liner: open a new socket and resend the samesubscribe payload. The first message after subscribe is a full book snapshot, so your books map is correct on the next tick - there’s nothing to replay, nothing to buffer, and no sequence numbers to reconcile against a separately-fetched REST snapshot.
TypeScript
Related
l2BookAPI reference - full subscription and message schema.- WebSocket API overview - endpoint URL, auth, and limits.
clearinghouseState- pair the live book with per-account position and margin state.- OHLCV pairs stream - candles instead of raw book state.
The
l4Book channel on wss://hypercore.goldrushdata.com/ws?key= is a GoldRush-exclusive stream - it has no equivalent on wss://api.hyperliquid.xyz/ws. After subscribing, the server sends a single Snapshot of every resting order, then per-block Updates carrying lifecycle events and per-order book changes. Each order arrives with its user, oid, cloid, tif, and trigger metadata, so you can reconstruct queue position, attribute flow to specific wallets, and run microstructure analytics that l2Book’s aggregated {px, sz, n} view hides. For the raw subscription shape see the l4Book reference; for the connection model see the WebSocket API overview.
What you get
- Per-order visibility. Every level in the snapshot is an individual order keyed by
oid, withuser,cloid,tif,orderType, and trigger metadata attached.l2Bookonly exposes{px, sz, n}per price level. - Snapshot + diff transport. One full
Snapshoton subscribe, then per-blockUpdatescontainingorder_statuses(lifecycle events) andbook_diffs(per-order changes). Apply diffs to local state. - Per-block cadence. Updates fire on each HyperCore block where the book for the subscribed
coinchanged. Thetimeandblock_heightfields anchor each message to a specific block. - GoldRush-exclusive. Not available on the public Hyperliquid WebSocket - this stream surfaces user attribution and per-order metadata the public feed never exposes.
- One coin per subscription. Unlike
l2Book,coinis required. To cover multiple assets, open onel4Booksubscription per asset on the same connection.
Subscribe and maintain book state
The pattern below keeps aMap per coin. The snapshot seeds the map; each Updates message applies book_diffs against it. Reconnects drop the map and re-seed from the next snapshot.
TypeScript
Python
Patterns
Track individual orders by oid
oid is the Hyperliquid order id, stable for the lifetime of the order - use it as the primary key in your local map. cloid is the client-supplied id (may be null); index on it when you need to correlate fills back to a specific trading bot’s instructions.
Per-user flow attribution
Every order entry carriesuser. Group orders by wallet to surface market-maker behavior, identify spoofing patterns, or build a per-trader heatmap of resting size. Pair this with clearinghouseState for per-user position and margin context.
TypeScript
Reconstruct aggregated price levels
If a downstream consumer expects anl2Book-style aggregated view, sum sz across all orders sharing a limitPx on the same side. Going the other way isn’t possible - l2Book collapses the per-order detail you’d lose.
TypeScript
Handling reconnects
On reconnect, resend the samesubscribe payload. The first message back is always a fresh Snapshot - drop your local orders map and re-seed from it. Do not attempt to replay missed Updates - the snapshot is authoritative and supersedes anything you held before the disconnect.
TypeScript
Related
l4BookAPI reference - full subscription, snapshot, and update schema.l2Bookreference - aggregated price-level snapshots when per-order detail isn’t needed.- WebSocket API overview - endpoint URL, auth, and limits.
clearinghouseState- pair per-user resting orders with position and margin state.