A community-supported Hyperliquid API SDK for all major JS runtimes, written in TypeScript.
- ποΈ Typed: Source code is 100% TypeScript.
- π§ͺ Tested: Good code coverage and type relevance.
- π¦ Minimal dependencies: A few small trusted dependencies.
- π Cross-Environment Support: Compatible with all major JS runtimes.
- π§ Integratable: Easy to use with wallet providers (viem or ethers).
npm i @nktkas/hyperliquid # npm / pnpm / yarn
deno add jsr:@nktkas/hyperliquid # Deno
bun add @nktkas/hyperliquid # Bun
// 1. Import module
import { HttpTransport, InfoClient } from "@nktkas/hyperliquid";
// 2. Set up client with transport
const transport = new HttpTransport();
const info = new InfoClient({ transport });
// 3. Query data
// Retrieve mids for all coins
const mids = await info.allMids();
// Retrieve a user's open orders
const openOrders = await info.openOrders({ user: "0x..." });
// L2 book snapshot
const book = await info.l2Book({ coin: "BTC" });// 1. Import modules
import { ExchangeClient, HttpTransport } from "@nktkas/hyperliquid";
import { privateKeyToAccount } from "viem/accounts";
// 2. Set up client with wallet and transport
const wallet = privateKeyToAccount("0x...");
const transport = new HttpTransport();
const exchange = new ExchangeClient({ transport, wallet });
// 3. Execute an action
// Place an order
const result = await exchange.order({
orders: [{
a: 0,
b: true,
p: "95000",
s: "0.01",
r: false,
t: { limit: { tif: "Gtc" } },
}],
grouping: "na",
});
// Update leverage
await exchange.updateLeverage({ asset: 0, isCross: true, leverage: 5 });
// Initiate a withdrawal request
await exchange.withdraw3({ destination: "0x...", amount: "1" });// 1. Import module
import { SubscriptionClient, WebSocketTransport } from "@nktkas/hyperliquid";
// 2. Set up client with transport
const transport = new WebSocketTransport();
const subs = new SubscriptionClient({ transport });
// 3. Subscribe to events
// Subscribe to mids for all coins
await subs.allMids((data) => {
console.log(data);
});
// Subscribe to user's open orders
await subs.openOrders({ user: "0x..." }, (data) => {
console.log(data);
});
// Subscribe to L2 book snapshot
await subs.l2Book({ coin: "ETH" }, (data) => {
console.log(data);
});Full guides, examples, and API reference: nktkas.gitbook.io/hyperliquid
This SDK follows Semantic Versioning. While it is on 0.x.y, a breaking change bumps the minor
version and every other change bumps the patch version.
The exception is the request, response, and event types that mirror the Hyperliquid API. The API is unversioned and always serves its latest shape, so changes to these types ship in patch releases even when breaking β the break comes from Hyperliquid, not the SDK.
@nktkas/hyperliquid is licensed under the MIT License.
Copyright Β© 2024-present nktkas and contributors.