mirror of
https://github.com/JKorf/CryptoExchange.Net
synced 2025-11-01 19:07:43 +00:00
* Added support for Native AOT compilation * Updated all IEnumerable response types to array response types * Added Pass support for ApiCredentials, removing the need for most implementations to add their own ApiCredentials type * Added KeepAliveTimeout setting setting ping frame timeouts for SocketApiClient * Added IBookTickerRestClient Shared interface for requesting book tickers * Added ISpotTriggerOrderRestClient Shared interface for managing spot trigger orders * Added ISpotOrderClientIdClient Shared interface for managing spot orders by client order id * Added IFuturesTriggerOrderRestClient Shared interface for managing futures trigger orders * Added IFuturesOrderClientIdClient Shared interface for managing futures orders by client order id * Added IFuturesTpSlRestClient Shared interface for setting TP/SL on open futures positions * Added GenerateClientOrderId to ISpotOrderRestClient and IFuturesOrderRestClient interface * Added OptionalExchangeParameters and Supported properties to EndpointOptions * Refactor Shared interfaces quantity parameters and properties to use SharedQuantity * Added SharedSymbol property to Shared interface models returning a symbol * Added TriggerPrice, IsTriggerOrder, TakeProfitPrice, StopLossPrice and IsCloseOrder to SharedFuturesOrder response model * Added MaxShortLeverage and MaxLongLeverage to SharedFuturesSymbol response model * Added StopLossPrice and TakeProfitPrice to SharedPosition response model * Added TriggerPrice and IsTriggerOrder to SharedSpotOrder response model * Added QuoteVolume property to SharedSpotTicker response model * Added AssetAlias configuration models * Added static ExchangeSymbolCache for tracking symbol information from exchanges * Added static CallResult.SuccessResult to be used instead of constructing success CallResult instance * Added static ApplyRules, RandomHexString and RandomLong helper methods to ExchangeHelpers class * Added AsErrorWithData To CallResult * Added OriginalData property to CallResult * Added support for adjusting the rate limit key per call, allowing for ratelimiting depending on request parameters * Added implementation for integration testing ISymbolOrderBook instances * Added implementation for integration testing socket subscriptions * Added implementation for testing socket queries * Updated request cancellation logging to Debug level * Updated logging SourceContext to include the client type * Updated some logging logic, errors no longer contain any data, exception are not logged as string but instead forwarded to structured logging * Fixed warning for Enum parsing throwing exception and output warnings for each object in a response to only once to prevent slowing down execution * Fixed memory leak in AsyncAutoRestEvent * Fixed logging for ping frame timeout * Fixed warning getting logged when user stops SymbolOrderBook instance * Fixed socket client `UnsubscribeAll` not unsubscribing dedicated connections * Fixed memory leak in Rest client cache * Fixed integers bigger than int16 not getting correctly parsed to enums * Fixed issue where the default options were overridden when using SetApiCredentials * Removed Newtonsoft.Json dependency * Removed legacy Rest client code * Removed legacy ISpotClient and IFuturesClient support
131 lines
4.5 KiB
C#
131 lines
4.5 KiB
C#
using CryptoExchange.Net.Authentication;
|
|
using CryptoExchange.Net.Objects.Options;
|
|
using Microsoft.Extensions.Logging;
|
|
using Microsoft.Extensions.Logging.Abstractions;
|
|
using System;
|
|
using System.Collections.Generic;
|
|
|
|
namespace CryptoExchange.Net.Clients
|
|
{
|
|
/// <summary>
|
|
/// The base for all clients, websocket client and rest client
|
|
/// </summary>
|
|
public abstract class BaseClient : IDisposable
|
|
{
|
|
/// <summary>
|
|
/// Version of the CryptoExchange.Net base library
|
|
/// </summary>
|
|
public Version CryptoExchangeLibVersion { get; } = typeof(BaseClient).Assembly.GetName().Version!;
|
|
|
|
/// <summary>
|
|
/// Version of the client implementation
|
|
/// </summary>
|
|
public Version ExchangeLibVersion
|
|
{
|
|
get
|
|
{
|
|
lock(_versionLock)
|
|
{
|
|
if (_exchangeVersion == null)
|
|
_exchangeVersion = GetType().Assembly.GetName().Version!;
|
|
|
|
return _exchangeVersion;
|
|
}
|
|
}
|
|
}
|
|
|
|
/// <summary>
|
|
/// The name of the API the client is for
|
|
/// </summary>
|
|
public string Exchange { get; }
|
|
|
|
/// <summary>
|
|
/// Api clients in this client
|
|
/// </summary>
|
|
internal List<BaseApiClient> ApiClients { get; } = new List<BaseApiClient>();
|
|
|
|
/// <summary>
|
|
/// The log object
|
|
/// </summary>
|
|
protected internal ILogger _logger;
|
|
|
|
private readonly object _versionLock = new object();
|
|
private Version _exchangeVersion;
|
|
|
|
/// <summary>
|
|
/// Provided client options
|
|
/// </summary>
|
|
public ExchangeOptions ClientOptions { get; private set; }
|
|
|
|
/// <summary>
|
|
/// ctor
|
|
/// </summary>
|
|
/// <param name="logger">Logger</param>
|
|
/// <param name="exchange">The name of the exchange this client is for</param>
|
|
#pragma warning disable CS8618 // Non-nullable field must contain a non-null value when exiting constructor. Consider declaring as nullable.
|
|
protected BaseClient(ILoggerFactory? logger, string exchange)
|
|
#pragma warning restore CS8618 // Non-nullable field must contain a non-null value when exiting constructor. Consider declaring as nullable.
|
|
{
|
|
Exchange = exchange;
|
|
}
|
|
|
|
/// <summary>
|
|
/// Initialize the client with the specified options
|
|
/// </summary>
|
|
/// <param name="options"></param>
|
|
/// <exception cref="ArgumentNullException"></exception>
|
|
protected virtual void Initialize(ExchangeOptions options)
|
|
{
|
|
if (options == null)
|
|
throw new ArgumentNullException(nameof(options));
|
|
|
|
ClientOptions = options;
|
|
_logger.Log(LogLevel.Trace, $"Client configuration: {options}, CryptoExchange.Net: v{CryptoExchangeLibVersion}, {Exchange}.Net: v{ExchangeLibVersion}");
|
|
}
|
|
|
|
/// <summary>
|
|
/// Set the API credentials for this client. All Api clients in this client will use the new credentials, regardless of earlier set options.
|
|
/// </summary>
|
|
/// <param name="credentials">The credentials to set</param>
|
|
protected virtual void SetApiCredentials<T>(T credentials) where T : ApiCredentials
|
|
{
|
|
foreach (var apiClient in ApiClients)
|
|
apiClient.SetApiCredentials(credentials);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Register an API client
|
|
/// </summary>
|
|
/// <param name="apiClient">The client</param>
|
|
protected T AddApiClient<T>(T apiClient) where T : BaseApiClient
|
|
{
|
|
if (ClientOptions == null)
|
|
throw new InvalidOperationException("Client should have called Initialize before adding API clients");
|
|
|
|
_logger.Log(LogLevel.Trace, $" {apiClient.GetType().Name}, base address: {apiClient.BaseAddress}");
|
|
ApiClients.Add(apiClient);
|
|
return apiClient;
|
|
}
|
|
|
|
/// <summary>
|
|
/// Apply the options delegate to a new options instance
|
|
/// </summary>
|
|
protected static T ApplyOptionsDelegate<T>(Action<T>? del) where T: new()
|
|
{
|
|
var opts = new T();
|
|
del?.Invoke(opts);
|
|
return opts;
|
|
}
|
|
|
|
/// <summary>
|
|
/// Dispose
|
|
/// </summary>
|
|
public virtual void Dispose()
|
|
{
|
|
_logger.Log(LogLevel.Debug, "Disposing client");
|
|
foreach (var client in ApiClients)
|
|
client.Dispose();
|
|
}
|
|
}
|
|
}
|