mirror of
https://github.com/JKorf/CryptoExchange.Net
synced 2025-12-18 04:37:01 +00:00
Performance update: Authentication Added Ed25519 signing support for NET8.0 and newer Added static methods on ApiCredentials to create credentials of a specific type Added static ApiCredentials.ReadFromFile method to read a key from file Added required abstract SupportedCredentialTypes property on AuthenticationProvider base class General Performance Added checks before logging statements to prevent overhead of building the log string if logging is not needed Added ExchangeHelpers.ProcessQueuedAsync method to process updates async Replaced locking object types from object to Lock in NET9.0 and newer Replaced some Task response types with ValueTask to prevent allocation overhead on hot paths Updated Json ArrayConverter to reduce some allocation overhead Updated Json BoolConverter to prevent boxing Updated Json DateTimeConverter to prevent boxing Updated Json EnumConverter caching to reduce lookup overhead Updated ExtensionMethods.CreateParamString to reduce allocations Updated ExtensionMethods.AppendPath to reduce overhead REST Refactored REST message processing to separate IRestMessageHandler instance Split RestApiClient.PrepareAsync into CheckTimeSync and RateLimitAsync Updated IRequest.Accept type from string to MediaTypeWithQualityHeaderValue to prevent creation on each request Updated IRequest.GetHeaders response type from KeyValuePair<string, string[]>[] to HttpRequestHeaders to prevent additional mapping Updated IResponse.ResponseHeaders type from KeyValuePair<string, string[]>[] to HttpResponseHeaders to prevent additional mapping Updated WebCallResult RequestHeaders and ResponseHeaders types to HttpRequestHeaders and HttpResponseHeaders Removed unnecessary empty dictionary initializations for each request Removed CallResult creation in internal methods to prevent having to create multiple versions for different result types Socket Added HighPerformance websocket client implementation which significantly reduces memory overhead and improves speed but with certain limitations Added MaxIndividualSubscriptionsPerConnection setting in SocketApiClient to limit the number of individual stream subscriptions on a connection Added SocketIndividualSubscriptionCombineTarget option to set the target number of individual stream subscriptions per connection Added new websocket message handling logic which is faster and reduces memory allocation Added UseUpdatedDeserialization option to toggle between updated deserialization and old deserialization Added Exchange property to DataEvent to prevent additional mapping overhead for Shared apis Refactored message callback to be sync instead of async to prevent async overhead Refactored CryptoExchangeWebSocketClient.IncomingKbps calculation to significantly reduce overhead Moved websocket client creation from SocketApiClient to SocketConnection Removed DataEvent.As and DataEvent.ToCallResult methods in favor of single ToType method Removed DataEvent creation on lower levels to prevent having to create multiple versions for different result types Removed Subscription<TSubResponse, TUnsubResponse> as its no longer used Other Added null check to ParameterCollection for required parameters Added Net10.0 target framework Updated dependency versions Updated Shared asset aliases check to be culture invariant Updated Error string representation Updated some namespaces Updated SymbolOrderBook processing of buffered updates to prevent additional allocation Removed ExchangeEvent type which is no longer needed Removed unused usings
131 lines
4.7 KiB
C#
131 lines
4.7 KiB
C#
using System;
|
|
using System.Threading;
|
|
using System.Threading.Tasks;
|
|
using CryptoExchange.Net.Objects;
|
|
|
|
namespace CryptoExchange.Net.Interfaces
|
|
{
|
|
/// <summary>
|
|
/// Interface for order book
|
|
/// </summary>
|
|
public interface ISymbolOrderBook
|
|
{
|
|
/// <summary>
|
|
/// The exchange the book is for
|
|
/// </summary>
|
|
string Exchange { get; }
|
|
|
|
/// <summary>
|
|
/// The Api the book is for
|
|
/// </summary>
|
|
string Api { get; }
|
|
|
|
/// <summary>
|
|
/// The status of the order book. Order book is up to date when the status is `Synced`
|
|
/// </summary>
|
|
OrderBookStatus Status { get; set; }
|
|
|
|
/// <summary>
|
|
/// Last update identifier
|
|
/// </summary>
|
|
long LastSequenceNumber { get; }
|
|
/// <summary>
|
|
/// The symbol of the order book
|
|
/// </summary>
|
|
string Symbol { get; }
|
|
|
|
/// <summary>
|
|
/// Event when the state changes
|
|
/// </summary>
|
|
event Action<OrderBookStatus, OrderBookStatus> OnStatusChange;
|
|
/// <summary>
|
|
/// Event when order book was updated. Be careful! It can generate a lot of events at high-liquidity markets
|
|
/// </summary>
|
|
event Action<(ISymbolOrderBookEntry[] Bids, ISymbolOrderBookEntry[] Asks)> OnOrderBookUpdate;
|
|
/// <summary>
|
|
/// Event when the BestBid or BestAsk changes ie a Pricing Tick
|
|
/// </summary>
|
|
event Action<(ISymbolOrderBookEntry BestBid, ISymbolOrderBookEntry BestAsk)> OnBestOffersChanged;
|
|
/// <summary>
|
|
/// Timestamp of the last update
|
|
/// </summary>
|
|
DateTime UpdateTime { get; }
|
|
|
|
/// <summary>
|
|
/// The number of asks in the book
|
|
/// </summary>
|
|
int AskCount { get; }
|
|
/// <summary>
|
|
/// The number of bids in the book
|
|
/// </summary>
|
|
int BidCount { get; }
|
|
|
|
/// <summary>
|
|
/// Get a snapshot of the book at this moment
|
|
/// </summary>
|
|
(ISymbolOrderBookEntry[] bids, ISymbolOrderBookEntry[] asks) Book { get; }
|
|
|
|
/// <summary>
|
|
/// The list of asks
|
|
/// </summary>
|
|
ISymbolOrderBookEntry[] Asks { get; }
|
|
|
|
/// <summary>
|
|
/// The list of bids
|
|
/// </summary>
|
|
ISymbolOrderBookEntry[] Bids { get; }
|
|
|
|
/// <summary>
|
|
/// The best bid currently in the order book
|
|
/// </summary>
|
|
ISymbolOrderBookEntry BestBid { get; }
|
|
|
|
/// <summary>
|
|
/// The best ask currently in the order book
|
|
/// </summary>
|
|
ISymbolOrderBookEntry BestAsk { get; }
|
|
|
|
/// <summary>
|
|
/// BestBid/BesAsk returned as a pair
|
|
/// </summary>
|
|
(ISymbolOrderBookEntry Bid, ISymbolOrderBookEntry Ask) BestOffers { get; }
|
|
|
|
/// <summary>
|
|
/// Start connecting and synchronizing the order book
|
|
/// </summary>
|
|
/// <param name="ct">A cancellation token to stop the order book when canceled</param>
|
|
/// <returns></returns>
|
|
Task<CallResult<bool>> StartAsync(CancellationToken? ct = null);
|
|
|
|
/// <summary>
|
|
/// Stop syncing the order book
|
|
/// </summary>
|
|
/// <returns></returns>
|
|
Task StopAsync();
|
|
|
|
/// <summary>
|
|
/// Get the average price that a market order would fill at at the current order book state. This is no guarantee that an order of that quantity would actually be filled
|
|
/// at that price since between this calculation and the order placement the book might have changed.
|
|
/// </summary>
|
|
/// <param name="quantity">The quantity in base asset to fill</param>
|
|
/// <param name="type">The type</param>
|
|
/// <returns>Average fill price</returns>
|
|
CallResult<decimal> CalculateAverageFillPrice(decimal quantity, OrderBookEntryType type);
|
|
|
|
/// <summary>
|
|
/// Get the amount of base asset which can be traded with the quote quantity when placing a market order at at the current order book state.
|
|
/// This is no guarantee that an order of that quantity would actually be fill the quantity returned by this since between this calculation and the order placement the book might have changed.
|
|
/// </summary>
|
|
/// <param name="quoteQuantity">The quantity in quote asset looking to trade</param>
|
|
/// <param name="type">The type</param>
|
|
/// <returns>Amount of base asset tradable with the specified amount of quote asset</returns>
|
|
CallResult<decimal> CalculateTradableAmount(decimal quoteQuantity, OrderBookEntryType type);
|
|
|
|
/// <summary>
|
|
/// String representation of the top x entries
|
|
/// </summary>
|
|
/// <returns></returns>
|
|
string ToString(int rows);
|
|
}
|
|
}
|