Documentation ¶
Index ¶
- Variables
- type Account
- type AccountEvent
- type AccountRequest
- type AggTrade
- type AggTradeEvent
- type AggTradesRequest
- type AllOrdersRequest
- type Balance
- type Binance
- type BookTicker
- type CancelOrderRequest
- type CanceledOrder
- type Deposit
- type DepthEvent
- type DepthWebsocketRequest
- type Error
- type ExchangeFilter
- type ExchangeInfo
- type ExecutedOrder
- type Fill
- type Filter
- type HistoryRequest
- type HmacSigner
- type Interval
- type Kline
- type KlineEvent
- type KlineWebsocketRequest
- type KlinesRequest
- type MyTradesRequest
- type NewOrderRequest
- type OpenOrdersRequest
- type Order
- type OrderBook
- type OrderBookRequest
- type OrderSide
- type OrderStatus
- type OrderType
- type Permission
- type PriceTicker
- type ProcessedOrder
- type QueryOrderRequest
- type RateLimit
- type Service
- type Signer
- type Stream
- type SymbolInfo
- type Ticker24
- type TickerRequest
- type TimeInForce
- type Trade
- type TradeWebsocketRequest
- type UserDataWebsocketRequest
- type WSEvent
- type WithdrawRequest
- type WithdrawResult
- type Withdrawal
Constants ¶
This section is empty.
Variables ¶
var ( Minute = Interval("1m") ThreeMinutes = Interval("3m") FiveMinutes = Interval("5m") FifteenMinutes = Interval("15m") ThirtyMinutes = Interval("30m") Hour = Interval("1h") TwoHours = Interval("2h") FourHours = Interval("4h") SixHours = Interval("6h") EightHours = Interval("8h") TwelveHours = Interval("12h") Day = Interval("1d") ThreeDays = Interval("3d") Week = Interval("1w") Month = Interval("1M") )
var ( GTC = TimeInForce("GTC") IOC = TimeInForce("IOC") )
var ( StatusNew = OrderStatus("NEW") StatusPartiallyFilled = OrderStatus("PARTIALLY_FILLED") StatusFilled = OrderStatus("FILLED") StatusCancelled = OrderStatus("CANCELED") StatusPendingCancel = OrderStatus("PENDING_CANCEL") StatusRejected = OrderStatus("REJECTED") StatusExpired = OrderStatus("EXPIRED") TypeLimit = OrderType("LIMIT") TypeMarket = OrderType("MARKET") TypeStopLoss = OrderType("STOP_LOSS") TypeStopLossLimit = OrderType("STOP_LOSS_LIMIT") TypeTakeProfit = OrderType("TAKE_PROFIT") TypeTakeProfitLimit = OrderType("TAKE_PROFIT_LIMIT") TypeLimitMaker = OrderType("LIMIT_MAKER") SideBuy = OrderSide("BUY") SideSell = OrderSide("SELL") )
OrderStatus, OrderType and OrderSide variables make sure to get the terms correct.
Functions ¶
This section is empty.
Types ¶
type Account ¶
type Account struct { MakerCommision int64 TakerCommision int64 BuyerCommision int64 SellerCommision int64 CanTrade bool CanWithdraw bool CanDeposit bool Balances []*Balance }
Account represents user's account information.
type AccountEvent ¶
type AccountRequest ¶
AccountRequest represents Account request data.
type AggTrade ¶
type AggTrade struct { ID int Price float64 Quantity float64 FirstTradeID int LastTradeID int Timestamp time.Time BuyerMaker bool BestPriceMatch bool }
AggTrade represents aggregated trade.
type AggTradeEvent ¶
type AggTradesRequest ¶
AggTradesRequest represents AggTrades request data.
type AllOrdersRequest ¶
type AllOrdersRequest struct { Symbol string OrderID int64 Limit int RecvWindow time.Duration Timestamp time.Time }
AllOrdersRequest represents AllOrders request data.
type Binance ¶
type Binance interface { // Ping tests connectivity. Ping() error // Time returns server time. Time() (time.Time, error) // OrderBook returns list of orders. OrderBook(obr OrderBookRequest) (*OrderBook, error) // AggTrades returns compressed/aggregate list of trades. AggTrades(atr AggTradesRequest) ([]*AggTrade, error) // Klines returns klines/candlestick data. Klines(kr KlinesRequest) ([]*Kline, error) // Ticker24 returns 24hr price change statistics. Ticker24(tr TickerRequest) (*Ticker24, error) // TickerAllPrices returns ticker data for symbols. TickerAllPrices() ([]*PriceTicker, error) // TickerAllBooks returns tickers for all books. TickerAllBooks() ([]*BookTicker, error) // ExchangeInfo returns a selection of the exchange information. ExchangeInfo() (*ExchangeInfo, error) // NewOrder places new order and returns ProcessedOrder. NewOrder(nor NewOrderRequest) (*ProcessedOrder, error) // NewOrder places testing order. NewOrderTest(nor NewOrderRequest) error // QueryOrder returns data about existing order. QueryOrder(qor QueryOrderRequest) (*ExecutedOrder, error) // CancelOrder cancels order. CancelOrder(cor CancelOrderRequest) (*CanceledOrder, error) // OpenOrders returns list of open orders. OpenOrders(oor OpenOrdersRequest) ([]*ExecutedOrder, error) // AllOrders returns list of all previous orders. AllOrders(aor AllOrdersRequest) ([]*ExecutedOrder, error) // Account returns account data. Account(ar AccountRequest) (*Account, error) // MyTrades list user's trades. MyTrades(mtr MyTradesRequest) ([]*Trade, error) // Withdraw executes withdrawal. Withdraw(wr WithdrawRequest) (*WithdrawResult, error) // DepositHistory lists deposit data. DepositHistory(hr HistoryRequest) ([]*Deposit, error) // WithdrawHistory lists withdraw data. WithdrawHistory(hr HistoryRequest) ([]*Withdrawal, error) // StartUserDataStream starts stream and returns Stream with ListenKey. StartUserDataStream() (*Stream, error) // KeepAliveUserDataStream prolongs stream livespan. KeepAliveUserDataStream(s *Stream) error // CloseUserDataStream closes opened stream. CloseUserDataStream(s *Stream) error DepthWebsocket(dwr DepthWebsocketRequest) (chan *DepthEvent, chan struct{}, error) KlineWebsocket(kwr KlineWebsocketRequest) (chan *KlineEvent, chan struct{}, error) TradeWebsocket(twr TradeWebsocketRequest) (chan *AggTradeEvent, chan struct{}, error) UserDataWebsocket(udwr UserDataWebsocketRequest) (chan *AccountEvent, chan struct{}, error) }
Binance is wrapper for Binance API.
Read web documentation for more endpoints descriptions and list of mandatory and optional params. Wrapper is not responsible for client-side validation and only sends requests further.
For each API-defined enum there's a special type and list of defined enum values to be used.
type BookTicker ¶
type BookTicker struct { Symbol string BidPrice float64 BidQty float64 AskPrice float64 AskQty float64 }
BookTicker represents book ticker data.
type CancelOrderRequest ¶
type CancelOrderRequest struct { Symbol string OrderID int64 OrigClientOrderID string NewClientOrderID string RecvWindow time.Duration Timestamp time.Time }
CancelOrderRequest represents CancelOrder request data.
type CanceledOrder ¶
type CanceledOrder struct { Symbol string OrigClientOrderID string OrderID int64 ClientOrderID string }
CanceledOrder represents data about canceled order.
type DepthEvent ¶
type DepthWebsocketRequest ¶
type DepthWebsocketRequest struct {
Symbol string
}
type ExchangeInfo ¶ added in v1.0.8
type ExchangeInfo struct { Timezone string // ServerTime time.Time // RateLimits []RateLimit // ExchangeFilters []ExchangeFilter Symbols []SymbolInfo }
ExchangeInfo ...
type ExecutedOrder ¶
type ExecutedOrder struct { Symbol string OrderID int ClientOrderID string Price float64 OrigQty float64 ExecutedQty float64 Status OrderStatus TimeInForce TimeInForce Type OrderType Side OrderSide StopPrice float64 IcebergQty float64 Time time.Time }
ExecutedOrder represents data about executed order.
type Fill ¶ added in v1.0.10
type Fill struct { Price float64 `json:"price"` QTY float64 `json:"qty"` Commission float64 `json:"commission"` CommissionAsset string `json:"commisionAsset"` }
Fill represents the price paid for (a part of) the trade made.
type HistoryRequest ¶
type HistoryRequest struct { Asset string Status *int StartTime time.Time EndTime time.Time RecvWindow time.Duration Timestamp time.Time }
HistoryRequest represents history-related calls request data.
type HmacSigner ¶
type HmacSigner struct {
Key []byte
}
HmacSigner uses HMAC SHA256 for signing payloads.
func (*HmacSigner) Sign ¶
func (hs *HmacSigner) Sign(payload []byte) string
Sign signs provided payload and returns encoded string sum.
type Kline ¶
type Kline struct { OpenTime time.Time Open float64 High float64 Low float64 Close float64 Volume float64 CloseTime time.Time QuoteAssetVolume float64 NumberOfTrades int TakerBuyBaseAssetVolume float64 TakerBuyQuoteAssetVolume float64 }
Kline represents single Kline information.
type KlineEvent ¶
type KlineWebsocketRequest ¶
type KlinesRequest ¶
type KlinesRequest struct { Symbol string Interval Interval Limit int StartTime int64 EndTime int64 }
KlinesRequest represents Klines request data.
type MyTradesRequest ¶
type MyTradesRequest struct { Symbol string Limit int FromID int64 RecvWindow time.Duration Timestamp time.Time }
MyTradesRequest represents MyTrades request data.
type NewOrderRequest ¶
type NewOrderRequest struct { Symbol string Side OrderSide Type OrderType TimeInForce TimeInForce Quantity float64 QuoteOrderQty float64 Price float64 NewClientOrderID string StopPrice float64 IcebergQty float64 RecvWindow time.Duration Timestamp time.Time }
NewOrderRequest represents NewOrder request data.
type OpenOrdersRequest ¶
OpenOrdersRequest represents OpenOrders request data.
type OrderBookRequest ¶
OrderBookRequest represents OrderBook request data.
type Permission ¶ added in v1.0.8
type Permission struct {
// contains filtered or unexported fields
}
Permission ...
type PriceTicker ¶
PriceTicker represents ticker data for price.
type ProcessedOrder ¶
type ProcessedOrder struct { Symbol string OrderID int64 ClientOrderID string TransactTime time.Time Fills []Fill }
ProcessedOrder represents data from processed order.
type QueryOrderRequest ¶
type QueryOrderRequest struct { Symbol string OrderID int64 OrigClientOrderID string RecvWindow time.Duration Timestamp time.Time }
QueryOrderRequest represents QueryOrder request data.
type RateLimit ¶ added in v1.0.8
type RateLimit struct { RateLimitType string // "REQUEST_WEIGHT" Interval string // "MINUTE" IntervalNum int // 1 Limit int // 1200 }
RateLimit ...
type Service ¶
type Service interface { Ping() error Time() (time.Time, error) OrderBook(obr OrderBookRequest) (*OrderBook, error) AggTrades(atr AggTradesRequest) ([]*AggTrade, error) Klines(kr KlinesRequest) ([]*Kline, error) Ticker24(tr TickerRequest) (*Ticker24, error) TickerAllPrices() ([]*PriceTicker, error) TickerAllBooks() ([]*BookTicker, error) ExchangeInfo() (*ExchangeInfo, error) NewOrder(or NewOrderRequest) (*ProcessedOrder, error) NewOrderTest(or NewOrderRequest) error QueryOrder(qor QueryOrderRequest) (*ExecutedOrder, error) CancelOrder(cor CancelOrderRequest) (*CanceledOrder, error) OpenOrders(oor OpenOrdersRequest) ([]*ExecutedOrder, error) AllOrders(aor AllOrdersRequest) ([]*ExecutedOrder, error) Account(ar AccountRequest) (*Account, error) MyTrades(mtr MyTradesRequest) ([]*Trade, error) Withdraw(wr WithdrawRequest) (*WithdrawResult, error) DepositHistory(hr HistoryRequest) ([]*Deposit, error) WithdrawHistory(hr HistoryRequest) ([]*Withdrawal, error) StartUserDataStream() (*Stream, error) KeepAliveUserDataStream(s *Stream) error CloseUserDataStream(s *Stream) error DepthWebsocket(dwr DepthWebsocketRequest) (chan *DepthEvent, chan struct{}, error) KlineWebsocket(kwr KlineWebsocketRequest) (chan *KlineEvent, chan struct{}, error) TradeWebsocket(twr TradeWebsocketRequest) (chan *AggTradeEvent, chan struct{}, error) UserDataWebsocket(udwr UserDataWebsocketRequest) (chan *AccountEvent, chan struct{}, error) }
Service represents service layer for Binance API.
The main purpose for this layer is to be replaced with dummy implementation if necessary without need to replace Binance instance.
func NewAPIService ¶
func NewAPIService(url, apiKey string, signer Signer, logger log.Logger, ctx context.Context) Service
NewAPIService creates instance of Service.
If logger or ctx are not provided, NopLogger and Background context are used as default. You can use context for one-time request cancel (e.g. when shutting down the app).
type Signer ¶
type Signer interface { // Sign signs provided payload and returns encoded string sum. Sign(payload []byte) string }
Signer signs provided payloads.
type Stream ¶
type Stream struct {
ListenKey string
}
Stream represents stream information.
Read web docs to get more information about using streams.
type SymbolInfo ¶ added in v1.0.8
type SymbolInfo struct { Symbol string // "ETHBTC" // Status string // "TRADING" // BaseAsset string // "ETH" BaseAssetPrecision int // 8 // QuoteAsset string // "BTC" // QuotePrecision int // 8 // QuoteAssetPrecision int // 8 // BaseCommissionPrecision int // 8 // QuoteCommissionPrecision int // 8 // OrderTypes []OrderType // "MARKET" // IcebergAllowed bool // true // OcoAllowed bool // true // QuoteOrderQtyMarketAllowed bool // true // IsSpotTradingAllowed bool // true // IsMarginTradingAllowed bool // true Filters []Filter }
SymbolInfo ...
type Ticker24 ¶
type Ticker24 struct { PriceChange float64 PriceChangePercent float64 WeightedAvgPrice float64 PrevClosePrice float64 LastPrice float64 BidPrice float64 AskPrice float64 OpenPrice float64 HighPrice float64 LowPrice float64 Volume float64 OpenTime time.Time CloseTime time.Time FirstID int LastID int Count int }
Ticker24 represents data for 24hr ticker.
type TickerRequest ¶
type TickerRequest struct {
Symbol string
}
TickerRequest represents Ticker request data.
type Trade ¶
type Trade struct { ID int64 Price float64 Qty float64 Commission float64 CommissionAsset string Time time.Time IsBuyer bool IsMaker bool IsBestMatch bool }
Trade represents data about trade.
type TradeWebsocketRequest ¶
type TradeWebsocketRequest struct {
Symbol string
}
type UserDataWebsocketRequest ¶
type UserDataWebsocketRequest struct {
ListenKey string
}
type WithdrawRequest ¶
type WithdrawRequest struct { Asset string Address string Amount float64 Name string RecvWindow time.Duration Timestamp time.Time }
WithdrawRequest represents Withdraw request data.
type WithdrawResult ¶
WithdrawResult represents Withdraw result.