![]() |
VOOZH | about |
dotnet add package Polymarket.Net --version 3.5.0
NuGet\Install-Package Polymarket.Net -Version 3.5.0
<PackageReference Include="Polymarket.Net" Version="3.5.0" />
<PackageVersion Include="Polymarket.Net" Version="3.5.0" />Directory.Packages.props
<PackageReference Include="Polymarket.Net" />Project file
paket add Polymarket.Net --version 3.5.0
#r "nuget: Polymarket.Net, 3.5.0"
#:package Polymarket.Net@3.5.0
#addin nuget:?package=Polymarket.Net&version=3.5.0Install as a Cake Addin
#tool nuget:?package=Polymarket.Net&version=3.5.0Install as a Cake Tool
Polymarket.Net is a client library for accessing the Polymarket REST and Websocket API.
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 |
👁 NuGet version
👁 Nuget downloads
dotnet add package Polymarket.Net
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.
The NuGet package files are added along side the source with the latest GitHub release which can found here.
Basic request:
// 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!);
Place order:
var restClient = new PolymarketRestClient(opts => {
opts.ApiCredentials = new PolymarketCredentials(new PolymarketL1Credential(
SignType.Poly1271,
"PRIVATEKEY",
"DEPOSITADDRESS"
));
});
// Update the client with layer 2 credentials
var credentials = await polymarketRestClient.ClobApi.Account.GetOrCreateApiCredentialsAsync();
polymarketRestClient.UpdateL2Credentials(credentials.Data);
// Place Limit order to buy 50 shares at 0.1 ($10)
var tokenIdTest = "67565972075898091709163371829761231762318232475740950317083391526954889294846";
var result = await polymarketRestClient.ClobApi.Trading.PlaceOrderAsync(
tokenIdTest,
OrderSide.Buy,
OrderType.Limit,
50,
price: 0.1m);
WebSocket subscription:
// 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
});
Authenticate using Poly1271 signing and a deposit address, providing the private key and the deposit address. This should be used for Polymarket accounts created after 04 May 2026. This will require you to request the layer 2 credentials before orders can be placed:
var credsPoly1271Layer1 = new PolymarketCredentials(
new PolymarketL1Credential(
SignType.Poly1271, // Poly1271 signing, for accounts created after 4 May 2026
"0x00..", // The private key for the wallet
"0x00..")); // The polymarket deposit address, can be found in the web interface under `Profile -> Copy Address`
Authenticate using Poly1271 signing and a deposit address, providing the private key and the deposit address, while also providing previously requested layer 2 credentials. Can be used to place orders directly:
var credsPoly1271WithLayer2 = new PolymarketCredentials(
new PolymarketL1Credential(
SignType.Poly1271, // Poly1271 signing, for accounts created after 4 May 2026
"0x00..", // The private key for the wallet
"0x00..")); // The polymarket deposit address, can be found in the web interface under `Profile -> Copy Address`
new HMACPassCredential(
"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()`
));
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(
new PolymarketL1Credential(
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(
new PolymarketL1Credential(
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`
new HMACPassCredential(
"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()`
));
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(
new PolymarketL1Credential(
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(
new PolymarketL1Credential(
SignType.EOA, // Externally Owned Account wallet, when using an existing wallet to connect to polymarket
"0x00.." // The private key for the wallet
),
new HMACPassCredential(
"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.
Polymarket.Net includes AI-oriented documentation and examples for code generation tools:
| File | Purpose |
|---|---|
| Assistant skill with core Polymarket.Net patterns, pitfalls, and examples | |
| Claude-oriented guide with authentication rules and source-of-truth files | |
| Short LLM index with links to docs, examples, and critical usage rules | |
| Detailed LLM context with endpoint routing, authentication levels, code patterns, and anti-hallucination checks | |
| Table-style intent-to-method map for CLOB, Gamma, Data, WebSocket, authentication, DI, and local order book workflows | |
| Compilable single-file examples for common REST, authentication/trading, WebSocket, DI/order book, and error handling workflows |
GitHub Copilot and Cursor instructions are also provided in .github/copilot-instructions.md and .cursor/rules/polymarket-net.mdc; both point back to the root AI context files.
NOTE
Polymarket.Net uses the Builder Code mechanism for Polymarket, which means that an additional 1bps / 0.01% fee is charged on top of orders placed with the library to fund development. This is entirely optional and can be disabled in the client options by setting BuilderCode to null in the REST client options.
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.
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.
👁 Nuget version
A Discord server is available here. For discussion and/or questions around the CryptoExchange.Net and implementation libraries, feel free to join.
| API | Supported | Location |
|---|---|---|
| Events | ✓ | restClient.ClobApi.ExchangeData |
| Markets | ✓ | restClient.ClobApi.ExchangeData |
| Orderbook & Pricing | ✓ | restClient.ClobApi.ExchangeData |
| Orders | ✓ | restClient.ClobApi.Trading / restClient.ClobApi.Account |
| Trades | ✓ | restClient.ClobApi.Trading / restClient.ClobApi.Account |
| CLOB Markets | ✓ | restClient.ClobApi.ExchangeData |
| Rebates | X | |
| Rewards | X | |
| Profile | partial | restClient.DataApi |
| Leaderboard | X | |
| Builders | X | |
| Search | ✓ | restClient.GammaApi |
| Tags | ✓ | restClient.GammaApi |
| Series | ✓ | restClient.GammaApi |
| Comments | X | |
| Sports | ✓ | restClient.GammaApi |
| Bridge | X | |
| Relayer | X |
| API | Supported | Location |
|---|---|---|
| Market Channel | ✓ | socketClient.ClobApi |
| User Channel | ✓ | socketClient.ClobApi |
| Sport Channel | ✓ | socketClient.ClobApi |
Any support is greatly appreciated.
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.
Version 3.5.0 - 08 Jun 2026
Version 3.4.0 - 29 May 2026
Version 3.3.1 - 28 May 2026
Version 3.3.0 - 26 May 2026
Version 3.2.0 - 22 May 2026
Version 3.1.0 - 09 May 2026
Version 3.0.3 - 01 May 2026
Version 3.0.2 - 01 May 2026
Version 3.0.1 - 29 Apr 2026
Version 3.0.0 - 28 Apr 2026
Updated library to use V2 Clob API
Updated CryptoExchange.Net to version 11.1.1
Added restClient.ClobApi.ExchangeData.GetMarketInfoAsync endpoint
Added tokenId parameter to GetUserTradesAsync endpoint
Added BuilderCode to REST client options
Updated GetUserTradesAsync endpoint from /data/trades to /trades
Updated PostOrderHeartbeatAsync endpoint from /v1/heartbeats to /heartbeats
Updated documentation references
Renamed all ConditionId parameters/properties to MarketId for consistency
Renamed all AssetId parameters/properties to TokenId for consistency
Removed deprecated takerAddress, nonce and feeRateBps from PlaceOrder endpoints
Removed takerAddress parameter from GetUserTradesAsync endpoint
Removed BuilderApiKey, BuilderSecret, BuilderPass from REST client options
Notes for updating:
https://clob-v2.polymarket.com in the client options Environment settingVersion 2.2.0 - 24 Apr 2026
Version 2.1.1 - 13 Apr 2026
Version 2.1.0 - 09 Apr 2026
Version 2.0.0 - 24 Mar 2026
Updated CryptoExchange.Net to version 11.0.1, see https://github.com/JKorf/CryptoExchange.Net/releases/ for full release notes
Updated class for supplying API credentials from ApiCredentials to PolymarketCredentials
Updated Shared order status parsing to default to Unknown value if not parsable
Updated signing logic to unified logic in the CryptoExchange.Net library
Added cursor parameter to restClient.ClobApi.Trading.GetOpenOrdersAsync endpoint
Updated PolymarketEvent ParentEvent to ParentEventId and changed type to long?
Fixed SubscribeToPlatformUpdatesAsync onMarketResolved handling
Fixed exception in PolymarketSocketClient.UpdateL2Credentials
Fixed parameter serialization restClient.ClobApi.Account.GetBuilderTradesAsync endpoint
Fixed parameter serialization restClient.ClobApi.Trading.GetOpenOrdersAsync endpoint
Notes for updating:
ApiCredentials = new ApiCredentials(signType, l1key, l1fundkey, l2key, l2sec, l2pass) ⇒ ApiCredentials = new PolymarketCredentials(new PolymarketL1Credential(signType, l1key, l1fundkey), new HMACPassCredential(l2key, l2sec, l2pass))Version 1.5.2 - 10 Mar 2026
Version 1.5.1 - 06 Mar 2026
Version 1.5.0 - 06 Mar 2026
Version 1.4.1 - 26 Feb 2026
Version 1.4.0 - 24 Feb 2026
Version 1.3.1 - 17 Feb 2026
Version 1.3.0 - 16 Feb 2026
Version 1.2.0 - 10 Feb 2026
Version 1.1.0 - 06 Feb 2026
Version 1.0.1 - 27 Jan 2026
Version 1.0.0 - 22 Jan 2026
| Product | Versions Compatible and additional computed target framework versions. |
|---|---|
| .NET | net5.0 net5.0 was computed. net5.0-windows net5.0-windows was computed. net6.0 net6.0 was computed. net6.0-android net6.0-android was computed. net6.0-ios net6.0-ios was computed. net6.0-maccatalyst net6.0-maccatalyst was computed. net6.0-macos net6.0-macos was computed. net6.0-tvos net6.0-tvos was computed. net6.0-windows net6.0-windows was computed. net7.0 net7.0 was computed. net7.0-android net7.0-android was computed. net7.0-ios net7.0-ios was computed. net7.0-maccatalyst net7.0-maccatalyst was computed. net7.0-macos net7.0-macos was computed. net7.0-tvos net7.0-tvos was computed. net7.0-windows net7.0-windows was computed. net8.0 net8.0 is compatible. net8.0-android net8.0-android was computed. net8.0-browser net8.0-browser was computed. net8.0-ios net8.0-ios was computed. net8.0-maccatalyst net8.0-maccatalyst was computed. net8.0-macos net8.0-macos was computed. net8.0-tvos net8.0-tvos was computed. net8.0-windows net8.0-windows was computed. net9.0 net9.0 is compatible. net9.0-android net9.0-android was computed. net9.0-browser net9.0-browser was computed. net9.0-ios net9.0-ios was computed. net9.0-maccatalyst net9.0-maccatalyst was computed. net9.0-macos net9.0-macos was computed. net9.0-tvos net9.0-tvos was computed. net9.0-windows net9.0-windows was computed. net10.0 net10.0 is compatible. net10.0-android net10.0-android was computed. net10.0-browser net10.0-browser was computed. net10.0-ios net10.0-ios was computed. net10.0-maccatalyst net10.0-maccatalyst was computed. net10.0-macos net10.0-macos was computed. net10.0-tvos net10.0-tvos was computed. net10.0-windows net10.0-windows was computed. |
| .NET Core | netcoreapp2.0 netcoreapp2.0 was computed. netcoreapp2.1 netcoreapp2.1 was computed. netcoreapp2.2 netcoreapp2.2 was computed. netcoreapp3.0 netcoreapp3.0 was computed. netcoreapp3.1 netcoreapp3.1 was computed. |
| .NET Standard | netstandard2.0 netstandard2.0 is compatible. netstandard2.1 netstandard2.1 is compatible. |
| .NET Framework | net461 net461 was computed. net462 net462 was computed. net463 net463 was computed. net47 net47 was computed. net471 net471 was computed. net472 net472 was computed. net48 net48 was computed. net481 net481 was computed. |
| MonoAndroid | monoandroid monoandroid was computed. |
| MonoMac | monomac monomac was computed. |
| MonoTouch | monotouch monotouch was computed. |
| Tizen | tizen40 tizen40 was computed. tizen60 tizen60 was computed. |
| Xamarin.iOS | xamarinios xamarinios was computed. |
| Xamarin.Mac | xamarinmac xamarinmac was computed. |
| Xamarin.TVOS | xamarintvos xamarintvos was computed. |
| Xamarin.WatchOS | xamarinwatchos xamarinwatchos was computed. |
Showing the top 1 NuGet packages that depend on Polymarket.Net:
| Package | Downloads |
|---|---|
|
CryptoClients.Net
CryptoClients.Net offers full easy access to 27 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. |
This package is not used by any popular GitHub repositories.
| Version | Downloads | Last Updated |
|---|---|---|
| 3.5.0 | 390 | 6/8/2026 |
| 3.4.0 | 521 | 5/29/2026 |
| 3.3.1 | 195 | 5/28/2026 |
| 3.3.0 | 225 | 5/26/2026 |
| 3.2.0 | 143 | 5/22/2026 |
| 3.1.0 | 681 | 5/9/2026 |
| 3.0.3 | 773 | 5/1/2026 |
| 3.0.2 | 121 | 5/1/2026 |
| 3.0.1 | 270 | 4/29/2026 |
| 3.0.0 | 184 | 4/28/2026 |
| 2.2.0 | 411 | 4/24/2026 |
| 2.1.1 | 341 | 4/13/2026 |
| 2.1.0 | 448 | 4/9/2026 |
| 2.0.0 | 1,420 | 3/24/2026 |
| 1.5.2 | 944 | 3/10/2026 |
| 1.5.1 | 226 | 3/6/2026 |
| 1.5.0 | 340 | 3/6/2026 |
| 1.4.1 | 313 | 2/26/2026 |
| 1.4.0 | 255 | 2/24/2026 |
| 1.3.1 | 477 | 2/17/2026 |