Documentation ¶
Index ¶
- Variables
- type BalancesResponse
- type Gateio
- func (g *Gateio) AuthenticateWebsocket() error
- func (g *Gateio) CancelAllExistingOrders(orderType int64, symbol string) error
- func (g *Gateio) CancelAllOrders(_ *order.Cancel) (order.CancelAllResponse, error)
- func (g *Gateio) CancelExistingOrder(orderID int64, symbol string) (bool, error)
- func (g *Gateio) CancelOrder(order *order.Cancel) error
- func (g *Gateio) FetchAccountInfo() (account.Holdings, error)
- func (g *Gateio) FetchOrderbook(p currency.Pair, assetType asset.Item) (*orderbook.Base, error)
- func (g *Gateio) FetchTicker(p currency.Pair, assetType asset.Item) (*ticker.Price, error)
- func (g *Gateio) FetchTradablePairs(asset asset.Item) ([]string, error)
- func (g *Gateio) GenerateAuthenticatedSubscriptions()
- func (g *Gateio) GenerateDefaultSubscriptions()
- func (g *Gateio) GenerateSignature(message string) []byte
- func (g *Gateio) GetActiveOrders(req *order.GetOrdersRequest) ([]order.Detail, error)
- func (g *Gateio) GetBalances() (BalancesResponse, error)
- func (g *Gateio) GetCryptoDepositAddress(currency string) (string, error)
- func (g *Gateio) GetDefaultConfig() (*config.ExchangeConfig, error)
- func (g *Gateio) GetDepositAddress(cryptocurrency currency.Code, _ string) (string, error)
- func (g *Gateio) GetExchangeHistory(p currency.Pair, assetType asset.Item) ([]exchange.TradeHistory, error)
- func (g *Gateio) GetFee(feeBuilder *exchange.FeeBuilder) (fee float64, err error)
- func (g *Gateio) GetFeeByType(feeBuilder *exchange.FeeBuilder) (float64, error)
- func (g *Gateio) GetFundingHistory() ([]exchange.FundHistory, error)
- func (g *Gateio) GetHistoricCandles(pair currency.Pair, a asset.Item, start, end time.Time, interval time.Duration) (kline.Item, error)
- func (g *Gateio) GetLatestSpotPrice(symbol string) (float64, error)
- func (g *Gateio) GetMarketInfo() (MarketInfoResponse, error)
- func (g *Gateio) GetOpenOrders(symbol string) (OpenOrdersResponse, error)
- func (g *Gateio) GetOrderHistory(req *order.GetOrdersRequest) ([]order.Detail, error)
- func (g *Gateio) GetOrderInfo(orderID string) (order.Detail, error)
- func (g *Gateio) GetOrderbook(symbol string) (Orderbook, error)
- func (g *Gateio) GetSpotKline(arg KlinesRequestParams) ([]*KLineResponse, error)
- func (g *Gateio) GetSubscriptions() ([]wshandler.WebsocketChannelSubscription, error)
- func (g *Gateio) GetSymbols() ([]string, error)
- func (g *Gateio) GetTicker(symbol string) (TickerResponse, error)
- func (g *Gateio) GetTickers() (map[string]TickerResponse, error)
- func (g *Gateio) GetTradeHistory(symbol string) (TradHistoryResponse, error)
- func (g *Gateio) GetWebsocket() (*wshandler.Websocket, error)
- func (g *Gateio) ModifyOrder(action *order.Modify) (string, error)
- func (g *Gateio) Run()
- func (g *Gateio) SendAuthenticatedHTTPRequest(method, endpoint, param string, result interface{}) error
- func (g *Gateio) SendHTTPRequest(path string, result interface{}) error
- func (g *Gateio) SetDefaults()
- func (g *Gateio) Setup(exch *config.ExchangeConfig) error
- func (g *Gateio) SpotNewOrder(arg SpotNewOrderRequestParams) (SpotNewOrderResponse, error)
- func (g *Gateio) Start(wg *sync.WaitGroup)
- func (g *Gateio) SubmitOrder(s *order.Submit) (order.SubmitResponse, error)
- func (g *Gateio) Subscribe(channelToSubscribe wshandler.WebsocketChannelSubscription) error
- func (g *Gateio) SubscribeToWebsocketChannels(channels []wshandler.WebsocketChannelSubscription) error
- func (g *Gateio) Unsubscribe(channelToSubscribe wshandler.WebsocketChannelSubscription) error
- func (g *Gateio) UnsubscribeToWebsocketChannels(channels []wshandler.WebsocketChannelSubscription) error
- func (g *Gateio) UpdateAccountInfo() (account.Holdings, error)
- func (g *Gateio) UpdateOrderbook(p currency.Pair, assetType asset.Item) (*orderbook.Base, error)
- func (g *Gateio) UpdateTicker(p currency.Pair, assetType asset.Item) (*ticker.Price, error)
- func (g *Gateio) UpdateTradablePairs(forceUpdate bool) error
- func (g *Gateio) ValidateCredentials() error
- func (g *Gateio) WithdrawCrypto(currency, address string, amount float64) (*withdraw.ExchangeResponse, error)
- func (g *Gateio) WithdrawCryptocurrencyFunds(withdrawRequest *withdraw.Request) (*withdraw.ExchangeResponse, error)
- func (g *Gateio) WithdrawFiatFunds(withdrawRequest *withdraw.Request) (*withdraw.ExchangeResponse, error)
- func (g *Gateio) WithdrawFiatFundsToInternationalBank(withdrawRequest *withdraw.Request) (*withdraw.ExchangeResponse, error)
- func (g *Gateio) WsConnect() error
- type KLineResponse
- type KlinesRequestParams
- type MarketInfoPairsResponse
- type MarketInfoResponse
- type OpenOrder
- type OpenOrdersResponse
- type Orderbook
- type OrderbookItem
- type OrderbookResponse
- type SpotNewOrderRequestParams
- type SpotNewOrderResponse
- type TickerResponse
- type TimeInterval
- type TradHistoryResponse
- type TradesResponse
- type WebSocketOrderQueryRecords
- type WebSocketOrderQueryResult
- type WebsocketAuthenticationResponse
- type WebsocketBalance
- type WebsocketBalanceCurrency
- type WebsocketError
- type WebsocketRequest
- type WebsocketResponse
- type WebsocketTicker
- type WebsocketTrade
- type WsGetBalanceResponse
- type WsGetBalanceResponseData
Constants ¶
This section is empty.
Variables ¶
var ( TimeIntervalMinute = TimeInterval(60) TimeIntervalThreeMinutes = TimeInterval(60 * 3) TimeIntervalFiveMinutes = TimeInterval(60 * 5) TimeIntervalFifteenMinutes = TimeInterval(60 * 15) TimeIntervalThirtyMinutes = TimeInterval(60 * 30) TimeIntervalHour = TimeInterval(60 * 60) TimeIntervalTwoHours = TimeInterval(2 * 60 * 60) TimeIntervalFourHours = TimeInterval(4 * 60 * 60) TimeIntervalSixHours = TimeInterval(6 * 60 * 60) TimeIntervalDay = TimeInterval(60 * 60 * 24) )
TimeInterval vars
var WithdrawalFees = map[currency.Code]float64{}/* 204 elements not displayed */
WithdrawalFees the large list of predefined withdrawal fees Prone to change
Functions ¶
This section is empty.
Types ¶
type BalancesResponse ¶
type BalancesResponse struct { Result string `json:"result"` Available interface{} `json:"available"` Locked interface{} `json:"locked"` }
BalancesResponse holds the user balances
type Gateio ¶
type Gateio struct { WebsocketConn *wshandler.WebsocketConnection exchange.Base }
Gateio is the overarching type across this package
func (*Gateio) AuthenticateWebsocket ¶
AuthenticateWebsocket sends an authentication message to the websocket
func (*Gateio) CancelAllExistingOrders ¶
CancelAllExistingOrders all orders for a given symbol and side orderType (0: sell,1: buy,-1: unlimited)
func (*Gateio) CancelAllOrders ¶
CancelAllOrders cancels all orders associated with a currency pair
func (*Gateio) CancelExistingOrder ¶
CancelExistingOrder cancels an order given the supplied orderID and symbol orderID order ID number symbol trade pair (ltc_btc)
func (*Gateio) CancelOrder ¶
CancelOrder cancels an order by its corresponding ID number
func (*Gateio) FetchAccountInfo ¶
FetchAccountInfo retrieves balances for all enabled currencies
func (*Gateio) FetchOrderbook ¶
FetchOrderbook returns orderbook base on the currency pair
func (*Gateio) FetchTicker ¶
FetchTicker returns the ticker for a currency pair
func (*Gateio) FetchTradablePairs ¶
FetchTradablePairs returns a list of the exchanges tradable pairs
func (*Gateio) GenerateAuthenticatedSubscriptions ¶
func (g *Gateio) GenerateAuthenticatedSubscriptions()
GenerateAuthenticatedSubscriptions Adds authenticated subscriptions to websocket to be handled by ManageSubscriptions()
func (*Gateio) GenerateDefaultSubscriptions ¶
func (g *Gateio) GenerateDefaultSubscriptions()
GenerateDefaultSubscriptions Adds default subscriptions to websocket to be handled by ManageSubscriptions()
func (*Gateio) GenerateSignature ¶
GenerateSignature returns hash for authenticated requests
func (*Gateio) GetActiveOrders ¶
GetActiveOrders retrieves any orders that are active/open
func (*Gateio) GetBalances ¶
func (g *Gateio) GetBalances() (BalancesResponse, error)
GetBalances obtains the users account balance
func (*Gateio) GetCryptoDepositAddress ¶
GetCryptoDepositAddress returns a deposit address for a cryptocurrency
func (*Gateio) GetDefaultConfig ¶
func (g *Gateio) GetDefaultConfig() (*config.ExchangeConfig, error)
GetDefaultConfig returns a default exchange config
func (*Gateio) GetDepositAddress ¶
GetDepositAddress returns a deposit address for a specified currency
func (*Gateio) GetExchangeHistory ¶
func (g *Gateio) GetExchangeHistory(p currency.Pair, assetType asset.Item) ([]exchange.TradeHistory, error)
GetExchangeHistory returns historic trade data since exchange opening.
func (*Gateio) GetFee ¶
func (g *Gateio) GetFee(feeBuilder *exchange.FeeBuilder) (fee float64, err error)
GetFee returns an estimate of fee based on type of transaction
func (*Gateio) GetFeeByType ¶
func (g *Gateio) GetFeeByType(feeBuilder *exchange.FeeBuilder) (float64, error)
GetFeeByType returns an estimate of fee based on type of transaction
func (*Gateio) GetFundingHistory ¶
func (g *Gateio) GetFundingHistory() ([]exchange.FundHistory, error)
GetFundingHistory returns funding history, deposits and withdrawals
func (*Gateio) GetHistoricCandles ¶
func (g *Gateio) GetHistoricCandles(pair currency.Pair, a asset.Item, start, end time.Time, interval time.Duration) (kline.Item, error)
GetHistoricCandles returns candles between a time period for a set time interval
func (*Gateio) GetLatestSpotPrice ¶
GetLatestSpotPrice returns latest spot price of symbol updated every 10 seconds
symbol: string of currency pair
func (*Gateio) GetMarketInfo ¶
func (g *Gateio) GetMarketInfo() (MarketInfoResponse, error)
GetMarketInfo returns information about all trading pairs, including transaction fee, minimum order quantity, price accuracy and so on
func (*Gateio) GetOpenOrders ¶
func (g *Gateio) GetOpenOrders(symbol string) (OpenOrdersResponse, error)
GetOpenOrders retrieves all open orders with an optional symbol filter
func (*Gateio) GetOrderHistory ¶
GetOrderHistory retrieves account order information Can Limit response to specific order status
func (*Gateio) GetOrderInfo ¶
GetOrderInfo returns information on a current open order
func (*Gateio) GetOrderbook ¶
GetOrderbook returns the orderbook data for a suppled symbol
func (*Gateio) GetSpotKline ¶
func (g *Gateio) GetSpotKline(arg KlinesRequestParams) ([]*KLineResponse, error)
GetSpotKline returns kline data for the most recent time period
func (*Gateio) GetSubscriptions ¶
func (g *Gateio) GetSubscriptions() ([]wshandler.WebsocketChannelSubscription, error)
GetSubscriptions returns a copied list of subscriptions
func (*Gateio) GetSymbols ¶
GetSymbols returns all supported symbols
func (*Gateio) GetTicker ¶
func (g *Gateio) GetTicker(symbol string) (TickerResponse, error)
GetTicker returns a ticker for the supplied symbol updated every 10 seconds
func (*Gateio) GetTickers ¶
func (g *Gateio) GetTickers() (map[string]TickerResponse, error)
GetTickers returns tickers for all symbols
func (*Gateio) GetTradeHistory ¶
func (g *Gateio) GetTradeHistory(symbol string) (TradHistoryResponse, error)
GetTradeHistory retrieves all orders with an optional symbol filter
func (*Gateio) GetWebsocket ¶
GetWebsocket returns a pointer to the exchange websocket
func (*Gateio) ModifyOrder ¶
ModifyOrder will allow of changing orderbook placement and limit to market conversion
func (*Gateio) SendAuthenticatedHTTPRequest ¶
func (g *Gateio) SendAuthenticatedHTTPRequest(method, endpoint, param string, result interface{}) error
SendAuthenticatedHTTPRequest sends authenticated requests to the Gateio API To use this you must setup an APIKey and APISecret from the exchange
func (*Gateio) SendHTTPRequest ¶
SendHTTPRequest sends an unauthenticated HTTP request
func (*Gateio) SetDefaults ¶
func (g *Gateio) SetDefaults()
SetDefaults sets default values for the exchange
func (*Gateio) Setup ¶
func (g *Gateio) Setup(exch *config.ExchangeConfig) error
Setup sets user configuration
func (*Gateio) SpotNewOrder ¶
func (g *Gateio) SpotNewOrder(arg SpotNewOrderRequestParams) (SpotNewOrderResponse, error)
SpotNewOrder places a new order
func (*Gateio) SubmitOrder ¶
SubmitOrder submits a new order TODO: support multiple order types (IOC)
func (*Gateio) Subscribe ¶
func (g *Gateio) Subscribe(channelToSubscribe wshandler.WebsocketChannelSubscription) error
Subscribe sends a websocket message to receive data from the channel
func (*Gateio) SubscribeToWebsocketChannels ¶
func (g *Gateio) SubscribeToWebsocketChannels(channels []wshandler.WebsocketChannelSubscription) error
SubscribeToWebsocketChannels appends to ChannelsToSubscribe which lets websocket.manageSubscriptions handle subscribing
func (*Gateio) Unsubscribe ¶
func (g *Gateio) Unsubscribe(channelToSubscribe wshandler.WebsocketChannelSubscription) error
Unsubscribe sends a websocket message to stop receiving data from the channel
func (*Gateio) UnsubscribeToWebsocketChannels ¶
func (g *Gateio) UnsubscribeToWebsocketChannels(channels []wshandler.WebsocketChannelSubscription) error
UnsubscribeToWebsocketChannels removes from ChannelsToSubscribe which lets websocket.manageSubscriptions handle unsubscribing
func (*Gateio) UpdateAccountInfo ¶
UpdateAccountInfo retrieves balances for all enabled currencies for the ZB exchange
func (*Gateio) UpdateOrderbook ¶
UpdateOrderbook updates and returns the orderbook for a currency pair
func (*Gateio) UpdateTicker ¶
UpdateTicker updates and returns the ticker for a currency pair
func (*Gateio) UpdateTradablePairs ¶
UpdateTradablePairs updates the exchanges available pairs and stores them in the exchanges config
func (*Gateio) ValidateCredentials ¶
ValidateCredentials validates current credentials used for wrapper functionality
func (*Gateio) WithdrawCrypto ¶
func (g *Gateio) WithdrawCrypto(currency, address string, amount float64) (*withdraw.ExchangeResponse, error)
WithdrawCrypto withdraws cryptocurrency to your selected wallet
func (*Gateio) WithdrawCryptocurrencyFunds ¶
func (g *Gateio) WithdrawCryptocurrencyFunds(withdrawRequest *withdraw.Request) (*withdraw.ExchangeResponse, error)
WithdrawCryptocurrencyFunds returns a withdrawal ID when a withdrawal is submitted
func (*Gateio) WithdrawFiatFunds ¶
func (g *Gateio) WithdrawFiatFunds(withdrawRequest *withdraw.Request) (*withdraw.ExchangeResponse, error)
WithdrawFiatFunds returns a withdrawal ID when a withdrawal is submitted
func (*Gateio) WithdrawFiatFundsToInternationalBank ¶
func (g *Gateio) WithdrawFiatFundsToInternationalBank(withdrawRequest *withdraw.Request) (*withdraw.ExchangeResponse, error)
WithdrawFiatFundsToInternationalBank returns a withdrawal ID when a withdrawal is submitted
type KLineResponse ¶
type KLineResponse struct { ID float64 KlineTime time.Time Open float64 Time float64 High float64 Low float64 Close float64 Volume float64 Amount float64 `db:"amount"` }
KLineResponse holds the kline response data
type KlinesRequestParams ¶
type KlinesRequestParams struct { Symbol string // Required field; example LTCBTC,BTCUSDT HourSize int // How many hours of data GroupSec TimeInterval }
KlinesRequestParams represents Klines request data.
type MarketInfoPairsResponse ¶
type MarketInfoPairsResponse struct { Symbol string // DecimalPlaces symbol price accuracy DecimalPlaces float64 // MinAmount minimum order amount MinAmount float64 // Fee transaction fee Fee float64 }
MarketInfoPairsResponse holds the market info response data
type MarketInfoResponse ¶
type MarketInfoResponse struct { Result string `json:"result"` Pairs []MarketInfoPairsResponse `json:"pairs"` }
MarketInfoResponse holds the market info data
type OpenOrder ¶
type OpenOrder struct { Amount float64 `json:"amount,string"` CurrencyPair string `json:"currencyPair"` FilledAmount float64 `json:"filledAmount,string"` FilledRate float64 `json:"filledRate"` InitialAmount float64 `json:"initialAmount"` InitialRate float64 `json:"initialRate"` OrderNumber string `json:"orderNumber"` Rate float64 `json:"rate"` Status string `json:"status"` Timestamp int64 `json:"timestamp"` Total float64 `json:"total,string"` Type string `json:"type"` }
OpenOrder details each open order
type OpenOrdersResponse ¶
type OpenOrdersResponse struct { Code int `json:"code"` Elapsed string `json:"elapsed"` Message string `json:"message"` Orders []OpenOrder `json:"orders"` Result string `json:"result"` }
OpenOrdersResponse the main response from GetOpenOrders
type Orderbook ¶
type Orderbook struct { Result string Elapsed string Bids []OrderbookItem Asks []OrderbookItem }
Orderbook stores the orderbook data
type OrderbookItem ¶
OrderbookItem stores an orderbook item
type OrderbookResponse ¶
type OrderbookResponse struct { Result string `json:"result"` Elapsed string `json:"elapsed"` Asks [][]string Bids [][]string }
OrderbookResponse stores the orderbook data
type SpotNewOrderRequestParams ¶
type SpotNewOrderRequestParams struct { Amount float64 `json:"amount"` // Order quantity Price float64 `json:"price"` // Order price Symbol string `json:"symbol"` // Trading pair; btc_usdt, eth_btc...... Type string `json:"type"` // Order type (buy or sell), }
SpotNewOrderRequestParams Order params
type SpotNewOrderResponse ¶
type SpotNewOrderResponse struct { OrderNumber int64 `json:"orderNumber"` // OrderID number Price float64 `json:"rate,string"` // Order price LeftAmount float64 `json:"leftAmount,string"` // The remaining amount to fill FilledAmount float64 `json:"filledAmount,string"` // The filled amount Filledrate interface{} `json:"filledRate"` // FilledPrice. if we send a market order, the exchange returns float64. }
SpotNewOrderResponse Order response
type TickerResponse ¶
type TickerResponse struct { Period int64 `json:"period"` BaseVolume float64 `json:"baseVolume,string"` Change float64 `json:"change,string"` Close float64 `json:"close,string"` High float64 `json:"high,string"` Last float64 `json:"last,string"` Low float64 `json:"low,string"` Open float64 `json:"open,string"` QuoteVolume float64 `json:"quoteVolume,string"` }
TickerResponse holds the ticker response data
type TradHistoryResponse ¶
type TradHistoryResponse struct { Code int `json:"code,omitempty"` Elapsed string `json:"elapsed,omitempty"` Message string `json:"message"` Trades []TradesResponse `json:"trades"` Result string `json:"result"` }
TradHistoryResponse The full response for retrieving all user trade history
type TradesResponse ¶
type TradesResponse struct { ID int64 `json:"tradeID"` OrderID int64 `json:"orderNumber"` Pair string `json:"pair"` Type string `json:"type"` Rate float64 `json:"rate,string"` Amount float64 `json:"amount,string"` Total float64 `json:"total"` Time string `json:"date"` TimeUnix int64 `json:"time_unix"` }
TradesResponse details trade history
type WebSocketOrderQueryRecords ¶
type WebSocketOrderQueryRecords struct { ID int64 `json:"id"` Market string `json:"market"` User int64 `json:"user"` Ctime float64 `json:"ctime"` Mtime float64 `json:"mtime"` Price float64 `json:"price,string"` Amount float64 `json:"amount,string"` Left float64 `json:"left,string"` DealFee float64 `json:"dealFee,string"` OrderType int64 `json:"orderType"` Type int64 `json:"type"` FilledAmount float64 `json:"filledAmount,string"` FilledTotal float64 `json:"filledTotal,string"` }
WebSocketOrderQueryRecords contains order information from a order.query websocket request
type WebSocketOrderQueryResult ¶
type WebSocketOrderQueryResult struct { Limit int `json:"limit"` Offset int `json:"offset"` Total int `json:"total"` WebSocketOrderQueryRecords []WebSocketOrderQueryRecords `json:"records"` }
WebSocketOrderQueryResult data returned from a websocket ordre query holds slice of WebSocketOrderQueryRecords
type WebsocketAuthenticationResponse ¶
type WebsocketAuthenticationResponse struct { Error string `json:"error,omitempty"` Result struct { Status string `json:"status"` } `json:"result"` ID int64 `json:"id"` }
WebsocketAuthenticationResponse contains the result of a login request
type WebsocketBalance ¶
type WebsocketBalance struct {
Currency []WebsocketBalanceCurrency
}
WebsocketBalance holds a slice of WebsocketBalanceCurrency
type WebsocketBalanceCurrency ¶
type WebsocketBalanceCurrency struct { Currency string Available string `json:"available"` Locked string `json:"freeze"` }
WebsocketBalanceCurrency contains currency name funds available and frozen
type WebsocketError ¶
WebsocketError defines a websocket error type
type WebsocketRequest ¶
type WebsocketRequest struct { ID int64 `json:"id"` Method string `json:"method"` Params []interface{} `json:"params"` }
WebsocketRequest defines the initial request in JSON
type WebsocketResponse ¶
type WebsocketResponse struct { Time int64 `json:"time"` Channel string `json:"channel"` Error WebsocketError `json:"error"` Result json.RawMessage `json:"result"` ID int64 `json:"id"` Method string `json:"method"` Params []json.RawMessage `json:"params"` }
WebsocketResponse defines a websocket response from gateio
type WebsocketTicker ¶
type WebsocketTicker struct { Period int64 `json:"period"` Open float64 `json:"open,string"` Close float64 `json:"close,string"` High float64 `json:"high,string"` Low float64 `json:"Low,string"` Last float64 `json:"last,string"` Change float64 `json:"change,string"` QuoteVolume float64 `json:"quoteVolume,string"` BaseVolume float64 `json:"baseVolume,string"` }
WebsocketTicker defines ticker data
type WebsocketTrade ¶
type WebsocketTrade struct { ID int64 `json:"id"` Time float64 `json:"time"` Price float64 `json:"price,string"` Amount float64 `json:"amount,string"` Type string `json:"type"` }
WebsocketTrade defines trade data
type WsGetBalanceResponse ¶
type WsGetBalanceResponse struct { Error interface{} `json:"error"` Result map[string]WsGetBalanceResponseData `json:"result"` ID int64 `json:"id"` }
WsGetBalanceResponse stores WS GetBalance response
type WsGetBalanceResponseData ¶
type WsGetBalanceResponseData struct { Available float64 `json:"available,string"` Freeze float64 `json:"freeze,string"` }
WsGetBalanceResponseData contains currency data