Polymarket.Net
1.0.0
dotnet add package Polymarket.Net --version 1.0.0
NuGet\Install-Package Polymarket.Net -Version 1.0.0
<PackageReference Include="Polymarket.Net" Version="1.0.0" />
<PackageVersion Include="Polymarket.Net" Version="1.0.0" />
<PackageReference Include="Polymarket.Net" />
paket add Polymarket.Net --version 1.0.0
#r "nuget: Polymarket.Net, 1.0.0"
#:package Polymarket.Net@1.0.0
#addin nuget:?package=Polymarket.Net&version=1.0.0
#tool nuget:?package=Polymarket.Net&version=1.0.0
Polymarket.Net
Polymarket.Net is a client library for accessing the Polymarket 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
- High performance
- 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 clients 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 the latest dotnet versions 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
dotnet add package Polymarket.Net
GitHub packages
Polymarket.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
The NuGet package files are added along side the source with the latest GitHub release which can found here.
How to use
- REST Endpoints
// Get the order book info for the outcomes of the first market via rest request var markets = await polymarketRestClient.GammaApi.GetMarketsAsync(closed: false); if (!markets.Success) { Console.WriteLine("Failed: " + markets.Error); return; } var firstMarket = markets.Data[0]; var bookInfo = await polymarketRestClient.ClobApi.ExchangeData.GetOrderBooksAsync(firstMarket.ClobTokenIds!); - Websocket streams
// Subscribe to updates for a specific token/asset via the websocket API var socketClient = new PolymarketSocketClient(); var tokenId = "11862165566757345985240476164489718219056735011698825377388402888080786399275"; var subscriptionResult = await polymarketSocketClient.ClobApi.SubscribeToTokenUpdatesAsync([tokenId2], priceUpdate => { // Handle price change update }, bookUpdate => { // Handle order book update }, lastTradePriceUpdate => { // Handle last trade price update }, tickSizeUpdate => { // Handle tick size update }, bestBidAskUpdate => { // Handle best bid/ask change update });
Authentication
Authenticate using an email account and providing the exported private key and the funding address. This will require you to request the layer 2 credentials before orders can be placed:
var credsEmailLayer1 = new PolymarketCredentials(
SignType.Email, // Email wallet, when creating a new wallet via the web interface
"0x00..", // The private key, can be exported from the web interface
"0x00.."); // The polymarket funding address, can be found in the web interface under `Profile -> Your Polymarket Wallet Address`
Authenticate using an email account and providing the exported private key and the funding address, while also providing previously requested layer 2 credentials. Can be used to place orders directly:
var credsEmailWithLayer2 = new PolymarketCredentials(
SignType.Email,// Email wallet, when creating a new wallet via the web interface
"0x00..", // The private key, can be exported from the web interface
"KEY",// The L2 API key as previously retrieved with `polymarketRestClient.ClobApi.Account.GetOrCreateApiCredentialsAsync()`
"SEC", // The L2 API secret as previously retrieved with `polymarketRestClient.ClobApi.Account.GetOrCreateApiCredentialsAsync()`
"PASS", // The L2 API passphrase as previously retrieved with `polymarketRestClient.ClobApi.Account.GetOrCreateApiCredentialsAsync()`
"0x00.."); // The polymarket funding address, can be found in the web interface under `Profile -> Your Polymarket Wallet Address`
Authenticate using an external account, for example MetaMask, and providing the private key. This will require you to request the layer 2 credentials before orders can be placed:
var credsEoaLayer1 = new PolymarketCredentials(
SignType.EOA, // Externally Owned Account wallet, when using an existing wallet to connect to polymarket
"0x00.." // The private key for the wallet
);
Authenticate using an external account, for example MetaMask, and providing the private key, while also providing previously requested layer 2 credentials. Can be used to place orders directly:
var credsEoaWithLayer2 = new PolymarketCredentials(
SignType.EOA, // Externally Owned Account wallet, when using an existing wallet to connect to polymarket
"0x00..", // The private key for the wallet
"KEY", // The L2 API key as previously retrieved with `polymarketRestClient.ClobApi.Account.GetOrCreateApiCredentialsAsync()`
"SEC", // The L2 API secret as previously retrieved with `polymarketRestClient.ClobApi.Account.GetOrCreateApiCredentialsAsync()`
"PASS" // The L2 API passphrase as previously retrieved with `polymarketRestClient.ClobApi.Account.GetOrCreateApiCredentialsAsync()`
);
Retrieve and set layer 2 credentials need for placing orders (required when L2 credentials not provided in the credentials):
var credentialResult = await polymarketRestClient.ClobApi.Account.GetOrCreateApiCredentialsAsync();
if (credentialResult.Success)
polymarketRestClient.UpdateL2Credentials(credentialResult.Data);
Set the previously created credentials:
// Via constructor
var client = new PolymarketRestClient(options =>
{
options.ApiCredentials = credentials;
});
// Via dependency injection
services.AddPolymarket(options =>
{
options.ApiCredentials = credentials
});
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
Polymarket.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 |
|---|---|---|
| Aster | JKorf/Aster.Net | |
| Binance | JKorf/Binance.Net | |
| BingX | JKorf/BingX.Net | |
| Bitfinex | JKorf/Bitfinex.Net | |
| Bitget | JKorf/Bitget.Net | |
| BitMart | JKorf/BitMart.Net | |
| BitMEX | JKorf/BitMEX.Net | |
| BloFin | JKorf/BloFin.Net | |
| Bybit | JKorf/Bybit.Net | |
| Coinbase | JKorf/Coinbase.Net | |
| CoinEx | JKorf/CoinEx.Net | |
| CoinGecko | JKorf/CoinGecko.Net | |
| CoinW | JKorf/CoinW.Net | |
| Crypto.com | JKorf/CryptoCom.Net | |
| DeepCoin | JKorf/DeepCoin.Net | |
| Gate.io | JKorf/GateIo.Net | |
| HTX | JKorf/HTX.Net | |
| HyperLiquid | JKorf/HyperLiquid.Net | |
| Kraken | JKorf/Kraken.Net | |
| Kucoin | JKorf/Kucoin.Net | |
| Mexc | JKorf/Mexc.Net | |
| OKX | JKorf/OKX.Net | |
| Toobit | JKorf/Toobit.Net | |
| Upbit | JKorf/Upbit.Net | |
| WhiteBit | JKorf/WhiteBit.Net | |
| XT | JKorf/XT.Net |
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
A Discord server is available here. For discussion and/or questions around the CryptoExchange.Net and implementation libraries, feel free to join.
Supported functionality
REST Central Limit Order Book (CLOB) API
| API | Supported | Location |
|---|---|---|
| Orderbook | ✓ | restClient.ClobApi.ExchangeData |
| Pricing | ✓ | restClient.ClobApi.ExchangeData |
| Spreads | ✓ | restClient.ClobApi.ExchangeData |
| Historical Timeseries Data | ✓ | restClient.ClobApi.ExchangeData |
| Order Management | ✓ | restClient.ClobApi.Trading |
| Trades | ✓ | restClient.ClobApi.Trading |
REST Gamma API
| API | Supported | Location |
|---|---|---|
| Sports | ✓ | restClient.GammaApi |
| Tags | ✓ | restClient.GammaApi |
| Events | ✓ | restClient.GammaApi |
| Markets | ✓ | restClient.GammaApi |
| Series | ✓ | restClient.GammaApi |
| Comments | X | |
| Profiles | X | |
| Search | ✓ | restClient.GammaApi |
Websocket API
| API | Supported | Location |
|---|---|---|
| User Channel | ✓ | socketClient.ClobApi |
| Market Channel | ✓ | socketClient.ClobApi |
| Sports websocket | ✓ | socketClient.ClobApi |
Support the project
Any support is greatly appreciated.
Donate
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
Sponsor
Alternatively, sponsor me on Github using Github Sponsors.
Release notes
- Version 1.0.0 - 22 Jan 2026
- Initial release
| Product | Versions 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 is compatible. 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. |
-
.NETStandard 2.0
- CryptoExchange.Net (>= 10.3.0)
- Secp256k1.Net (>= 2.0.0)
-
.NETStandard 2.1
- CryptoExchange.Net (>= 10.3.0)
- Secp256k1.Net (>= 2.0.0)
-
net10.0
- CryptoExchange.Net (>= 10.3.0)
- Secp256k1.Net (>= 2.0.0)
-
net8.0
- CryptoExchange.Net (>= 10.3.0)
- Secp256k1.Net (>= 2.0.0)
-
net9.0
- CryptoExchange.Net (>= 10.3.0)
- Secp256k1.Net (>= 2.0.0)
NuGet packages (1)
Showing the top 1 NuGet packages that depend on Polymarket.Net:
| Package | Downloads |
|---|---|
|
CryptoClients.Net
CryptoClients.Net offers full easy access to 25 different cryptocurrency exchange API's, such as Binance, Bybit, HyperLiquid and many more. It offers a unified way to access the API's and tools to dynamically call endpoints on different exchanges. |
GitHub repositories
This package is not used by any popular GitHub repositories.
| Version | Downloads | Last Updated |
|---|---|---|
| 1.0.0 | 104 | 1/22/2026 |