diff --git a/Examples/BlazorClient/BlazorClient.csproj b/Examples/BlazorClient/BlazorClient.csproj index b5047b1..989d7a8 100644 --- a/Examples/BlazorClient/BlazorClient.csproj +++ b/Examples/BlazorClient/BlazorClient.csproj @@ -5,30 +5,31 @@ - - - - - - - - - - - - - - - - - - - - + + + + + + + + + + + + + + + + + + + + + - - - + + + diff --git a/Examples/BlazorClient/Pages/Index.razor b/Examples/BlazorClient/Pages/Index.razor index b162935..cb094b8 100644 --- a/Examples/BlazorClient/Pages/Index.razor +++ b/Examples/BlazorClient/Pages/Index.razor @@ -1,4 +1,5 @@ @page "/" +@inject IAsterRestClient asterClient @inject IBinanceRestClient binanceClient @inject IBingXRestClient bingXClient @inject IBitfinexRestClient bitfinexClient @@ -34,6 +35,7 @@ protected override async Task OnInitializedAsync() { + var asterTask = asterClient.SpotApi.ExchangeData.GetTickerAsync("BTCUSDT"); var binanceTask = binanceClient.SpotApi.ExchangeData.GetTickerAsync("BTCUSDT"); var bingXTask = bingXClient.SpotApi.ExchangeData.GetTickersAsync("BTC-USDT"); var bitfinexTask = bitfinexClient.SpotApi.ExchangeData.GetTickerAsync("tBTCUSD"); @@ -49,7 +51,7 @@ var deepCoinTask = deepCoinClient.ExchangeApi.ExchangeData.GetTickersAsync(DeepCoin.Net.Enums.SymbolType.Spot); var gateioTask = gateioClient.SpotApi.ExchangeData.GetTickersAsync("BTC_USDT"); var htxTask = htxClient.SpotApi.ExchangeData.GetTickerAsync("btcusdt"); - var hyperLiquidTask = hyperLiquidClient.FuturesApi.ExchangeData.GetExchangeInfoAndTickersAsync(); // HyperLiquid does not have BTC spot trading + var hyperLiquidTask = hyperLiquidClient.FuturesApi.ExchangeData.GetExchangeInfoAndTickersAsync(); var krakenTask = krakenClient.SpotApi.ExchangeData.GetTickerAsync("XBTUSD"); var kucoinTask = kucoinClient.SpotApi.ExchangeData.GetTickerAsync("BTC-USDT"); var mexcTask = mexcClient.SpotApi.ExchangeData.GetTickerAsync("BTCUSDT"); @@ -58,7 +60,10 @@ var whitebitTask = whitebitClient.V4Api.ExchangeData.GetTickersAsync(); var xtTask = xtClient.SpotApi.ExchangeData.GetTickersAsync("btc_usdt"); - await Task.WhenAll(binanceTask, bingXTask, bitfinexTask, bitgetTask, bitmartTask, bybitTask, coinexTask, deepCoinTask, gateioTask, htxTask, krakenTask, kucoinTask, mexcTask, okxTask); + await Task.WhenAll(asterTask, binanceTask, bingXTask, bitfinexTask, bitgetTask, bitmartTask, bloFinTask, bitmexTask, bybitTask, coinexTask, coinWTask, deepCoinTask, gateioTask, htxTask, krakenTask, kucoinTask, mexcTask, okxTask); + + if (asterTask.Result.Success) + _prices.Add("Aster", asterTask.Result.Data.LastPrice); if (binanceTask.Result.Success) _prices.Add("Binance", binanceTask.Result.Data.LastPrice); diff --git a/Examples/BlazorClient/Pages/LiveData.razor b/Examples/BlazorClient/Pages/LiveData.razor index 7edfa25..b0d477d 100644 --- a/Examples/BlazorClient/Pages/LiveData.razor +++ b/Examples/BlazorClient/Pages/LiveData.razor @@ -1,4 +1,5 @@ @page "/LiveData" +@inject IAsterSocketClient asterSocketClient @inject IBinanceSocketClient binanceSocketClient @inject IBingXSocketClient bingXSocketClient @inject IBitfinexSocketClient bitfinexSocketClient @@ -43,6 +44,8 @@ { var tasks = new Task>[] { + // Aster doesn't support the ETH/BTC pair + //asterSocketClient.SpotApi.ExchangeData.SubscribeToTickerUpdatesAsync("ETHBTC", data => UpdateData("Aster", data.Data.LastPrice)), binanceSocketClient.SpotApi.ExchangeData.SubscribeToTickerUpdatesAsync("ETHBTC", data => UpdateData("Binance", data.Data.LastPrice)), bingXSocketClient.SpotApi.SubscribeToTickerUpdatesAsync("ETH-BTC", data => UpdateData("BingX", data.Data.LastPrice)), bitfinexSocketClient.SpotApi.SubscribeToTickerUpdatesAsync("tETHBTC", data => UpdateData("Bitfinex", data.Data.LastPrice)), diff --git a/Examples/BlazorClient/Pages/OrderBooks.razor b/Examples/BlazorClient/Pages/OrderBooks.razor index 8804575..d556103 100644 --- a/Examples/BlazorClient/Pages/OrderBooks.razor +++ b/Examples/BlazorClient/Pages/OrderBooks.razor @@ -1,6 +1,7 @@ @page "/OrderBooks" @using System.Collections.Concurrent @using System.Timers +@using Aster.Net.Interfaces @using Binance.Net.Interfaces @using BingX.Net.Interfaces @using Bitfinex.Net.Interfaces @@ -27,6 +28,7 @@ @using Toobit.Net.Interfaces; @using WhiteBit.Net.Interfaces @using XT.Net.Interfaces +@inject IAsterOrderBookFactory asterFactory @inject IBinanceOrderBookFactory binanceFactory @inject IBingXOrderBookFactory bingXFactory @inject IBitfinexOrderBookFactory bitfinexFactory @@ -83,6 +85,7 @@ _books = new Dictionary { + { "Aster", binanceFactory.CreateSpot("ETHUSDT") }, { "Binance", binanceFactory.CreateSpot("ETHBTC") }, { "BingX", bingXFactory.CreateSpot("ETH-BTC") }, { "Bitfinex", bitfinexFactory.Create("tETHBTC") }, diff --git a/Examples/BlazorClient/Pages/Trackers.razor b/Examples/BlazorClient/Pages/Trackers.razor index bacfb6c..68cd088 100644 --- a/Examples/BlazorClient/Pages/Trackers.razor +++ b/Examples/BlazorClient/Pages/Trackers.razor @@ -1,6 +1,7 @@ @page "/Trackers" @using System.Collections.Concurrent @using System.Timers +@using Aster.Net.Interfaces @using Binance.Net.Interfaces @using BingX.Net.Interfaces @using Bitfinex.Net.Interfaces @@ -28,6 +29,7 @@ @using Toobit.Net.Interfaces; @using WhiteBit.Net.Interfaces @using XT.Net.Interfaces +@inject IAsterTrackerFactory asterFactory @inject IBinanceTrackerFactory binanceFactory @inject IBingXTrackerFactory bingXFactory @inject IBitfinexTrackerFactory bitfinexFactory @@ -79,6 +81,7 @@ _trackers = new List { + { asterFactory.CreateTradeTracker(usdtSpotSymbol, period: TimeSpan.FromMinutes(5)) }, { binanceFactory.CreateTradeTracker(usdtSpotSymbol, period: TimeSpan.FromMinutes(5)) }, { bingXFactory.CreateTradeTracker(usdtSpotSymbol, period: TimeSpan.FromMinutes(5)) }, { bitfinexFactory.CreateTradeTracker(usdtSpotSymbol, period: TimeSpan.FromMinutes(5)) }, diff --git a/Examples/BlazorClient/Startup.cs b/Examples/BlazorClient/Startup.cs index 415ff73..6c9bdab 100644 --- a/Examples/BlazorClient/Startup.cs +++ b/Examples/BlazorClient/Startup.cs @@ -33,6 +33,7 @@ namespace BlazorClient restOptions.ApiCredentials = new ApiCredentials("KEY", "SECRET"); }); + services.AddAster(); services.AddBingX(); services.AddBitfinex(); services.AddBitget(); diff --git a/Examples/BlazorClient/_Imports.razor b/Examples/BlazorClient/_Imports.razor index 9367f9c..17dfdf7 100644 --- a/Examples/BlazorClient/_Imports.razor +++ b/Examples/BlazorClient/_Imports.razor @@ -8,6 +8,7 @@ @using Microsoft.JSInterop @using BlazorClient @using BlazorClient.Shared +@using Aster.Net.Interfaces.Clients; @using Binance.Net.Interfaces.Clients; @using BingX.Net.Interfaces.Clients; @using Bitfinex.Net.Interfaces.Clients; diff --git a/README.md b/README.md index 9b5492e..da060f6 100644 --- a/README.md +++ b/README.md @@ -12,6 +12,7 @@ Full list of all libraries part of the CryptoExchange.Net ecosystem. Consider us ||Exchange|Type|Repository|Nuget|Referral Link|Referral Fee Discount| |--|--|--|--|--|--|--| +|![Aster](https://raw.githubusercontent.com/JKorf/Aster.Net/refs/heads/main/Aster.Net/Icon/icon.png)|Aster|DEX|[JKorf/Aster.Net](https://github.com/JKorf/Aster.Net)|[![Nuget version](https://img.shields.io/nuget/v/JKorf.Aster.net.svg?style=flat-square)](https://www.nuget.org/packages/JKorf.Aster.Net)|[Link](https://www.asterdex.com/en/referral/FD2E11)|4%| |![Binance](https://raw.githubusercontent.com/JKorf/Binance.Net/refs/heads/master/Binance.Net/Icon/icon.png)|Binance|CEX|[JKorf/Binance.Net](https://github.com/JKorf/Binance.Net)|[![Nuget version](https://img.shields.io/nuget/v/Binance.net.svg?style=flat-square)](https://www.nuget.org/packages/Binance.Net)|[Link](https://accounts.binance.com/register?ref=X5K3F2ZG)|20%| |![BingX](https://raw.githubusercontent.com/JKorf/BingX.Net/refs/heads/main/BingX.Net/Icon/BingX.png)|BingX|CEX|[JKorf/BingX.Net](https://github.com/JKorf/BingX.Net)|[![Nuget version](https://img.shields.io/nuget/v/JK.BingX.net.svg?style=flat-square)](https://www.nuget.org/packages/JK.BingX.Net)|[Link](https://bingx.com/invite/FFHRJKWG/)|20%| |![Bitfinex](https://raw.githubusercontent.com/JKorf/Bitfinex.Net/refs/heads/master/Bitfinex.Net/Icon/icon.png)|Bitfinex|CEX|[JKorf/Bitfinex.Net](https://github.com/JKorf/Bitfinex.Net)|[![Nuget version](https://img.shields.io/nuget/v/Bitfinex.net.svg?style=flat-square)](https://www.nuget.org/packages/Bitfinex.Net)|-|-|