HyperLiquid.Net 2.3.0

There is a newer version of this package available.
See the version list below for details.
dotnet add package HyperLiquid.Net --version 2.3.0
                    
NuGet\Install-Package HyperLiquid.Net -Version 2.3.0
                    
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="HyperLiquid.Net" Version="2.3.0" />
                    
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="HyperLiquid.Net" Version="2.3.0" />
                    
Directory.Packages.props
<PackageReference Include="HyperLiquid.Net" />
                    
Project file
For projects that support Central Package Management (CPM), copy this XML node into the solution Directory.Packages.props file to version the package.
paket add HyperLiquid.Net --version 2.3.0
                    
#r "nuget: HyperLiquid.Net, 2.3.0"
                    
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
#:package HyperLiquid.Net@2.3.0
                    
#:package directive can be used in C# file-based apps starting in .NET 10 preview 4. Copy this into a .cs file before any lines of code to reference the package.
#addin nuget:?package=HyperLiquid.Net&version=2.3.0
                    
Install as a Cake Addin
#tool nuget:?package=HyperLiquid.Net&version=2.3.0
                    
Install as a Cake Tool

HyperLiquid.Net HyperLiquid.Net

.NET License

HyperLiquid.Net is a client library for accessing the HyperLiquid DEX REST and Websocket API.

Features

  • Response data is mapped to descriptive models
  • Input parameters and response values are mapped to discriptive enum values where possible
  • Automatic websocket (re)connection management
  • Client side rate limiting
  • Client side order book implementation
  • Support for managing different accounts
  • Extensive logging
  • Support for different environments
  • Easy integration with other exchange client based on the CryptoExchange.Net base library
  • Native AOT support

Supported Frameworks

The library is targeting both .NET Standard 2.0 and .NET Standard 2.1 for optimal compatibility, as well as dotnet 8.0 and 9.0 to use the latest framework features.

.NET implementation Version Support
.NET Core 2.0 and higher
.NET Framework 4.6.1 and higher
Mono 5.4 and higher
Xamarin.iOS 10.14 and higher
Xamarin.Android 8.0 and higher
UWP 10.0.16299 and higher
Unity 2018.1 and higher

Install the library

NuGet

NuGet version Nuget downloads

dotnet add package HyperLiquid.Net

GitHub packages

HyperLiquid.Net is available on GitHub packages. You'll need to add https://nuget.pkg.github.com/JKorf/index.json as a NuGet package source.

Download release

GitHub Release

The NuGet package files are added along side the source with the latest GitHub release which can found here.

How to use

The library uses [BaseAsset]/[QuoteAsset] notation for Spot symbols and [BaseAsset] for futures symbols. Futures symbols inherently have USDC as quote symbol.
Spot symbol: HYPE/USDC
Futures symbol: HYPE

  • REST Endpoints
      var restClient = new HyperLiquidRestClient();
    
      // Spot HYPE/USDC info
      var spotTickerResult = await restClient.SpotApi.ExchangeData.GetExchangeInfoAndTickersAsync();
      var hypeInfo = spotTickerResult.Data.Tickers.Single(x => x.Symbol == "HYPE/USDC");
      var currentHypePrice = hypeInfo.MidPrice;
    
      // Futures ETH perpetual contract info
      var futuresTickerResult = await restClient.FuturesApi.ExchangeData.GetExchangeInfoAndTickersAsync();
      var ethInfo = futuresTickerResult.Data.Tickers.Single(x => x.Symbol == "ETH");
      var currentEthPrice = ethInfo.MidPrice;
    
  • Websocket streams
      // Subscribe to HYPE/USDC Spot ticker updates via the websocket API
      var socketClient = new HyperLiquidSocketClient();
      var tickerSubscriptionResult = await hyperLiquidSocketClient.SpotApi.SubscribeToSymbolUpdatesAsync("HYPE/USDC", (update) =>
      {
      	var lastPrice = update.Data.MidPrice;
      });
    

For information on the clients, dependency injection, response processing and more see the documentation, or have a look at the examples here or here.

CryptoExchange.Net

HyperLiquid.Net is based on the CryptoExchange.Net base library. Other exchange API implementations based on the CryptoExchange.Net base library are available and follow the same logic.

CryptoExchange.Net also allows for easy access to different exchange API's.

Exchange Repository Nuget
Binance JKorf/Binance.Net Nuget version
BingX JKorf/BingX.Net Nuget version
Bitfinex JKorf/Bitfinex.Net Nuget version
Bitget JKorf/Bitget.Net Nuget version
BitMart JKorf/BitMart.Net Nuget version
BitMEX JKorf/BitMEX.Net Nuget version
Bybit JKorf/Bybit.Net Nuget version
Coinbase JKorf/Coinbase.Net Nuget version
CoinEx JKorf/CoinEx.Net Nuget version
CoinGecko JKorf/CoinGecko.Net Nuget version
Crypto.com JKorf/CryptoCom.Net Nuget version
DeepCoin JKorf/DeepCoin.Net Nuget version
Gate.io JKorf/GateIo.Net Nuget version
HTX JKorf/HTX.Net Nuget version
Kraken JKorf/Kraken.Net Nuget version
Kucoin JKorf/Kucoin.Net Nuget version
Mexc JKorf/Mexc.Net Nuget version
OKX JKorf/OKX.Net Nuget version
Toobit JKorf/Toobit.Net Nuget version
WhiteBit JKorf/WhiteBit.Net Nuget version
XT JKorf/XT.Net Nuget version

When using multiple of these API's the CryptoClients.Net package can be used which combines this and the other packages and allows easy access to all exchange API's.

Discord

Nuget version
A Discord server is available here. For discussion and/or questions around the CryptoExchange.Net and implementation libraries, feel free to join.

OSX Support

The signing method used in the library is not natively supported on OSX. Because of this a custom signing method has to be provided or a PlatformNotSupported exception will be thrown while trying to sign a request.

A custom signing method can be provided using HyperLiquidExchange.SignRequestDelegate = CustomSigningMethod;.
To run on OSX the Nethereum.Signer.EIP712 package can be installed with the following custom signing method:

Dictionary<string, object> Sign(string request, string secret)
{
    var messageBytes = Convert.FromHexString(request);
    var sign = new MessageSigner().SignAndCalculateV(messageBytes, new EthECKey(secret));
    return new Dictionary<string, object>()
            {
                { "r", "0x" + Convert.ToHexString(sign.R).ToLowerInvariant() },
                { "s", "0x" + Convert.ToHexString(sign.S).ToLowerInvariant() },
                { "v", (int)sign.V[0] }
            };
}

Supported functionality

Rest

API Supported Location
Info restClient.SpotApi.Account / restClient.SpotApi.ExchangeData / restClient.SpotApi.Trading restClient.FuturesApi.Account / restClient.FuturesApi.ExchangeData / restClient.FuturesApi.Trading
Info Perpetuals restClient.FuturesApi.Account / restClient.FuturesApi.ExchangeData
Info Spot restClient.SpotApi.Account / restClient.SpotApi.ExchangeData
Exchange restClient.SpotApi.Account / restClient.SpotApi.Trading restClient.FuturesApi.Account / restClient.FuturesApi.Trading

Websocket

API Supported Location
* socketClient.SpotApi / socketClient.FuturesApi

Support the project

Any support is greatly appreciated.

Referral

If you do not yet have an account please consider using this referal link to sign up: Link
Not only will you support development at no cost, you also get a 4% discount in fees.

Make a one time donation in a crypto currency of your choice. If you prefer to donate a currency not listed here please contact me.

Btc: bc1q277a5n54s2l2mzlu778ef7lpkwhjhyvghuv8qf
Eth: 0xcb1b63aCF9fef2755eBf4a0506250074496Ad5b7
USDT (TRX) TKigKeJPXZYyMVDgMyXxMf17MWYia92Rjd

Alternatively, sponsor me on Github using Github Sponsors.

Release notes

  • Version 2.3.0 - 16 Jul 2025

    • Added support for providing custom signing method
    • Updated error response parsing for single failed orders
    • Fixed incorrect signatureChainId for mainnet
  • Version 2.2.0 - 15 Jul 2025

    • Updated CryptoExchange.Net to version 9.2.0, see https://github.com/JKorf/CryptoExchange.Net/releases/
    • Added OpenOrders to socketClient.FuturesApi.SubscribeToUserUpdatesAsync update model
    • Fixed caching issue when using multiple environment in a single application
  • Version 2.1.1 - 10 Jun 2025

    • Fixed HyperLiquidSymbolOrderBook Synced status being set before the book was actually synced
    • Fixed signing issue placing orders with trailing zero's in the quantity
  • Version 2.1.0 - 02 Jun 2025

  • Version 2.0.0 - 13 May 2025

    • Updated CryptoExchange.Net to version 9.0.0, see https://github.com/JKorf/CryptoExchange.Net/releases/
    • Added support for Native AOT compilation
    • Added RateLimitUpdated event
    • Added SharedSymbol response property to all Shared interfaces response models returning a symbol name
    • Added GenerateClientOrderId method to FuturesApi and Spot Shared clients
    • Added IBookTickerRestClient implementation to SpotApi and FuturesApi Shared clients
    • Added IFuturesOrderClientIdClient implementation to FuturesApi Shared client
    • Added IFuturesTpSlRestClient implementation to FuturesApi Shared client
    • Added ISpotOrderClientIdClient implementation to FuturesApi Shared client
    • Added TriggerPrice, IsTriggerOrder properties to SharedSpotOrder model
    • Added TriggerPrice, IsTriggerOrder properties to SharedFuturesOrder model
    • Added MaxLongLeverage, MaxShortLeverage to SharedFuturesSymbol model
    • Added QuoteVolume property mapping to SharedSpotTicker model
    • Added OptionalExchangeParameters and Supported properties to EndpointOptions
    • Added better error handling for unknown symbols
    • Added vaultAddress parameter to various endpoints
    • Added All property to retrieve all available environment on HyperLiquidEnvironment
    • Added automatic mapping between UETH and ETH and UBTC and BTC spot asset and symbol names when using the Shared implementations
    • Combined rest PlaceOrderAsync and PlaceTriggerOrderAsync methods for more flexibility
    • Refactored Shared clients quantity parameters and responses to use SharedQuantity
    • Updated all IEnumerable response and model types to array response types
    • Removed Newtonsoft.Json dependency
    • Removed Nethereum dependency
    • Removed legacy AddHyperLiquid(restOptions, socketOptions) DI overload
    • Fixed some typos
    • Fixed missing Enum values for OrderType, Direction and TimeInForce enums
    • Fixed market order price calculation
    • Fixed incorrect DataTradeMode on certain Shared interface responses
    • Fixed symbol name conversion not respecting environment setting
    • Fixed DivideByZero exception in Shared ticker requests if PreviousDayPrice is 0
    • Fixed various signing issues and response parsing issues
  • Version 2.0.0-beta3 - 01 May 2025

    • Updated CryptoExchange.Net version to 9.0.0-beta5
    • Added property to retrieve all available API environments
  • Version 2.0.0-beta2 - 23 Apr 2025

    • Updated CryptoExchange.Net to version 9.0.0-beta2
    • Added Shared spot ticker QuoteVolume mapping
    • Fixed incorrect DataTradeMode on responses
  • Version 2.0.0-beta1 - 22 Apr 2025

    • Updated CryptoExchange.Net to version 9.0.0-beta1, see https://github.com/JKorf/CryptoExchange.Net/releases/
    • Added support for Native AOT compilation
    • Added RateLimitUpdated event
    • Added SharedSymbol response property to all Shared interfaces response models returning a symbol name
    • Added GenerateClientOrderId method to FuturesApi and Spot Shared clients
    • Added IBookTickerRestClient implementation to SpotApi and FuturesApi Shared clients
    • Added IFuturesOrderClientIdClient implementation to FuturesApi Shared client
    • Added IFuturesTpSlRestClient implementation to FuturesApi Shared client
    • Added ISpotOrderClientIdClient implementation to FuturesApi Shared client
    • Added TriggerPrice, IsTriggerOrder properties to SharedSpotOrder model
    • Added TriggerPrice, IsTriggerOrder properties to SharedFuturesOrder model
    • Added MaxLongLeverage, MaxShortLeverage to SharedFuturesSymbol model
    • Added OptionalExchangeParameters and Supported properties to EndpointOptions
    • Added better error handling for unknown symbols
    • Added vaultAddress parameter to various endpoints
    • Combined rest PlaceOrderAsync and PlaceTriggerOrderAsync methods for more flexibility
    • Refactored Shared clients quantity parameters and responses to use SharedQuantity
    • Updated all IEnumerable response and model types to array response types
    • Removed Newtonsoft.Json dependency
    • Removed Nethereum dependency
    • Removed legacy AddHyperLiquid(restOptions, socketOptions) DI overload
    • Fixed some typos
    • Fixed symbol name conversion not respecting environment setting
    • Fixed DivideByZero exception in Shared ticker requests if PreviousDayPrice is 0
    • Fixed various signing issues and response parsing issues
  • Version 1.1.2 - 28 Mar 2025

    • Fix testnet support
  • Version 1.1.1 - 22 Mar 2025

    • Fixed deserialization of spot exchange info
  • Version 1.1.0 - 11 Feb 2025

    • Updated CryptoExchange.Net to version 8.8.0, see https://github.com/JKorf/CryptoExchange.Net/releases/
    • Added support for more SharedKlineInterval values
    • Added setting of DataTime value on websocket DataEvent updates
    • Fix Mono runtime exception on rest client construction using DI
  • Version 1.0.1 - 22 Jan 2025

    • Added DisplayName and ImageUrl to HyperLiquidExchange class
    • Update HyperLiquidOptions object to make use of LibraryOptions base class
  • Version 1.0.0 - 21 Jan 2025

    • Initial release
Product Compatible and additional computed target framework versions.
.NET net5.0 was computed.  net5.0-windows was computed.  net6.0 was computed.  net6.0-android was computed.  net6.0-ios was computed.  net6.0-maccatalyst was computed.  net6.0-macos was computed.  net6.0-tvos was computed.  net6.0-windows was computed.  net7.0 was computed.  net7.0-android was computed.  net7.0-ios was computed.  net7.0-maccatalyst was computed.  net7.0-macos was computed.  net7.0-tvos was computed.  net7.0-windows was computed.  net8.0 is compatible.  net8.0-android was computed.  net8.0-browser was computed.  net8.0-ios was computed.  net8.0-maccatalyst was computed.  net8.0-macos was computed.  net8.0-tvos was computed.  net8.0-windows was computed.  net9.0 is compatible.  net9.0-android was computed.  net9.0-browser was computed.  net9.0-ios was computed.  net9.0-maccatalyst was computed.  net9.0-macos was computed.  net9.0-tvos was computed.  net9.0-windows was computed.  net10.0 was computed.  net10.0-android was computed.  net10.0-browser was computed.  net10.0-ios was computed.  net10.0-maccatalyst was computed.  net10.0-macos was computed.  net10.0-tvos was computed.  net10.0-windows was computed. 
.NET Core netcoreapp2.0 was computed.  netcoreapp2.1 was computed.  netcoreapp2.2 was computed.  netcoreapp3.0 was computed.  netcoreapp3.1 was computed. 
.NET Standard netstandard2.0 is compatible.  netstandard2.1 is compatible. 
.NET Framework net461 was computed.  net462 was computed.  net463 was computed.  net47 was computed.  net471 was computed.  net472 was computed.  net48 was computed.  net481 was computed. 
MonoAndroid monoandroid was computed. 
MonoMac monomac was computed. 
MonoTouch monotouch was computed. 
Tizen tizen40 was computed.  tizen60 was computed. 
Xamarin.iOS xamarinios was computed. 
Xamarin.Mac xamarinmac was computed. 
Xamarin.TVOS xamarintvos was computed. 
Xamarin.WatchOS xamarinwatchos was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages (2)

Showing the top 2 NuGet packages that depend on HyperLiquid.Net:

Package Downloads
CryptoClients.Net

CryptoClients.Net is a collection of multiple cryptocurrency exchange API clients for accessing both the REST API's and WebSocket API's. Supports order and account management and requesting and streaming both public and private data.

Le.CryptoClients.Net

CryptoClients.Net is a collection of multiple cryptocurrency exchange API clients for accessing both the REST API's and WebSocket API's. Supports order and account management and requesting and streaming both public and private data.

GitHub repositories (1)

Showing the top 1 popular GitHub repositories that depend on HyperLiquid.Net:

Repository Stars
JKorf/CryptoExchange.Net
A C# .netstandard base library used for implementing cryptocurrency exchange API's.
Version Downloads Last Updated
2.4.0 494 7/23/2025
2.3.0 152 7/16/2025
2.2.0 133 7/15/2025
2.1.1 807 6/10/2025
2.1.0 411 6/2/2025
2.0.0 501 5/13/2025
2.0.0-beta3 154 5/1/2025
2.0.0-beta2 163 4/23/2025
2.0.0-beta1 163 4/22/2025
1.1.2 724 3/28/2025
1.1.1 99 3/22/2025
1.1.0 1,202 2/11/2025
1.0.1 639 1/22/2025
1.0.0 225 1/21/2025