Documentation ¶
Overview ¶
Package gemini exchange documentation can be found at https://docs.sandbox.gemini.com
Index ¶
- type Auction
- type AuctionHistory
- type Balance
- type DepositAddress
- type ErrorCapture
- type Gemini
- func (g *Gemini) CancelAllOrders(ctx context.Context, _ *order.Cancel) (order.CancelAllResponse, error)
- func (g *Gemini) CancelBatchOrders(ctx context.Context, o []order.Cancel) (order.CancelBatchResponse, error)
- func (g *Gemini) CancelExistingOrder(ctx context.Context, orderID int64) (Order, error)
- func (g *Gemini) CancelExistingOrders(ctx context.Context, cancelBySession bool) (OrderResult, error)
- func (g *Gemini) CancelOrder(ctx context.Context, o *order.Cancel) error
- func (g *Gemini) FetchAccountInfo(ctx context.Context, assetType asset.Item) (account.Holdings, error)
- func (g *Gemini) FetchOrderbook(ctx context.Context, p currency.Pair, assetType asset.Item) (*orderbook.Base, error)
- func (g *Gemini) FetchTicker(ctx context.Context, p currency.Pair, assetType asset.Item) (*ticker.Price, error)
- func (g *Gemini) FetchTradablePairs(ctx context.Context, asset asset.Item) ([]string, error)
- func (g *Gemini) GenerateDefaultSubscriptions() ([]stream.ChannelSubscription, error)
- func (g *Gemini) GetActiveOrders(ctx context.Context, req *order.GetOrdersRequest) ([]order.Detail, error)
- func (g *Gemini) GetAuction(ctx context.Context, currencyPair string) (Auction, error)
- func (g *Gemini) GetAuctionHistory(ctx context.Context, currencyPair string, params url.Values) ([]AuctionHistory, error)
- func (g *Gemini) GetBalances(ctx context.Context) ([]Balance, error)
- func (g *Gemini) GetCryptoDepositAddress(ctx context.Context, depositAddlabel, currency string) (DepositAddress, error)
- func (g *Gemini) GetDefaultConfig() (*config.Exchange, error)
- func (g *Gemini) GetDepositAddress(ctx context.Context, cryptocurrency currency.Code, _, _ string) (*deposit.Address, error)
- func (g *Gemini) GetFee(ctx context.Context, feeBuilder *exchange.FeeBuilder) (float64, error)
- func (g *Gemini) GetFeeByType(ctx context.Context, feeBuilder *exchange.FeeBuilder) (float64, error)
- func (g *Gemini) GetFundingHistory(ctx context.Context) ([]exchange.FundHistory, error)
- func (g *Gemini) GetHistoricCandles(ctx context.Context, pair currency.Pair, a asset.Item, start, end time.Time, ...) (kline.Item, error)
- func (g *Gemini) GetHistoricCandlesExtended(ctx context.Context, pair currency.Pair, a asset.Item, start, end time.Time, ...) (kline.Item, error)
- func (g *Gemini) GetHistoricTrades(ctx context.Context, p currency.Pair, assetType asset.Item, ...) ([]trade.Data, error)
- func (g *Gemini) GetNotionalVolume(ctx context.Context) (NotionalVolume, error)
- func (g *Gemini) GetOrderHistory(ctx context.Context, req *order.GetOrdersRequest) ([]order.Detail, error)
- func (g *Gemini) GetOrderInfo(ctx context.Context, orderID string, pair currency.Pair, assetType asset.Item) (order.Detail, error)
- func (g *Gemini) GetOrderStatus(ctx context.Context, orderID int64) (Order, error)
- func (g *Gemini) GetOrderbook(ctx context.Context, currencyPair string, params url.Values) (Orderbook, error)
- func (g *Gemini) GetOrders(ctx context.Context) ([]Order, error)
- func (g *Gemini) GetRecentTrades(ctx context.Context, pair currency.Pair, assetType asset.Item) ([]trade.Data, error)
- func (g *Gemini) GetSymbols(ctx context.Context) ([]string, error)
- func (g *Gemini) GetTicker(ctx context.Context, currencyPair string) (TickerV2, error)
- func (g *Gemini) GetTradeHistory(ctx context.Context, currencyPair string, timestamp int64) ([]TradeHistory, error)
- func (g *Gemini) GetTradeVolume(ctx context.Context) ([][]TradeVolume, error)
- func (g *Gemini) GetTrades(ctx context.Context, currencyPair string, since, limit int64, ...) ([]Trade, error)
- func (g *Gemini) GetWithdrawalsHistory(ctx context.Context, c currency.Code) (resp []exchange.WithdrawalHistory, err error)
- func (g *Gemini) ModifyOrder(ctx context.Context, action *order.Modify) (order.Modify, error)
- func (g *Gemini) NewOrder(ctx context.Context, symbol string, amount, price float64, ...) (int64, error)
- func (g *Gemini) PostHeartbeat(ctx context.Context) (string, error)
- func (g *Gemini) Run()
- func (g *Gemini) SendAuthenticatedHTTPRequest(ctx context.Context, ep exchange.URL, method, path string, ...) (err error)
- func (g *Gemini) SendHTTPRequest(ctx context.Context, ep exchange.URL, path string, result interface{}) error
- func (g *Gemini) SetDefaults()
- func (g *Gemini) Setup(exch *config.Exchange) error
- func (g *Gemini) Start(wg *sync.WaitGroup) error
- func (g *Gemini) SubmitOrder(ctx context.Context, s *order.Submit) (order.SubmitResponse, error)
- func (g *Gemini) Subscribe(channelsToSubscribe []stream.ChannelSubscription) error
- func (g *Gemini) Unsubscribe(channelsToUnsubscribe []stream.ChannelSubscription) error
- func (g *Gemini) UpdateAccountInfo(ctx context.Context, assetType asset.Item) (account.Holdings, error)
- func (g *Gemini) UpdateOrderbook(ctx context.Context, p currency.Pair, assetType asset.Item) (*orderbook.Base, error)
- func (g *Gemini) UpdateTicker(ctx context.Context, p currency.Pair, a asset.Item) (*ticker.Price, error)
- func (g *Gemini) UpdateTickers(ctx context.Context, a asset.Item) error
- func (g *Gemini) UpdateTradablePairs(ctx context.Context, forceUpdate bool) error
- func (g *Gemini) ValidateCredentials(ctx context.Context, assetType asset.Item) error
- func (g *Gemini) WithdrawCrypto(ctx context.Context, address, currency string, amount float64) (WithdrawalAddress, error)
- func (g *Gemini) WithdrawCryptocurrencyFunds(ctx context.Context, withdrawRequest *withdraw.Request) (*withdraw.ExchangeResponse, error)
- func (g *Gemini) WithdrawFiatFunds(_ context.Context, _ *withdraw.Request) (*withdraw.ExchangeResponse, error)
- func (g *Gemini) WithdrawFiatFundsToInternationalBank(_ context.Context, _ *withdraw.Request) (*withdraw.ExchangeResponse, error)
- func (g *Gemini) WsAuth(dialer *websocket.Dialer) error
- func (g *Gemini) WsConnect() error
- type NotionalVolume
- type OneDayNotionalVolume
- type Order
- type OrderResult
- type Orderbook
- type OrderbookEntry
- type RateLimit
- type Ticker
- type TickerV2
- type Trade
- type TradeHistory
- type TradeVolume
- type WithdrawalAddress
- type WsHeartbeatResponse
- type WsOrderFilledData
- type WsOrderResponse
- type WsRequestPayload
- type WsSubscriptionAcknowledgementResponse
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type Auction ¶
type Auction struct { LastAuctionEID int64 `json:"last_auction_eid"` ClosedUntilMs int64 `json:"closed_until_ms"` LastAuctionPrice float64 `json:"last_auction_price,string"` LastAuctionQuantity float64 `json:"last_auction_quantity,string"` LastHighestBidPrice float64 `json:"last_highest_bid_price,string"` LastLowestAskPrice float64 `json:"last_lowest_ask_price,string"` NextAuctionMS int64 `json:"next_auction_ms"` NextUpdateMS int64 `json:"next_update_ms"` MostRecentIndicativePrice float64 `json:"most_recent_indicative_price,string"` MostRecentIndicativeQuantity float64 `json:"most_recent_indicative_quantity,string"` MostRecentHighestBidPrice float64 `json:"most_recent_highest_bid_price,string"` MostRecentLowestAskPrice float64 `json:"most_recent_lowest_ask_price,string"` }
Auction is generalized response type
type AuctionHistory ¶
type AuctionHistory struct { AuctionID int64 `json:"auction_id"` AuctionPrice float64 `json:"auction_price,string"` AuctionQuantity float64 `json:"auction_quantity,string"` EID int64 `json:"eid"` HighestBidPrice float64 `json:"highest_bid_price,string"` LowestAskPrice float64 `json:"lowest_ask_price,string"` AuctionResult string `json:"auction_result"` Timestamp int64 `json:"timestamp"` TimestampMS int64 `json:"timestampms"` EventType string `json:"event_type"` }
AuctionHistory holds auction history information
type Balance ¶
type Balance struct { Currency string `json:"currency"` Amount float64 `json:"amount,string"` Available float64 `json:"available,string"` }
Balance is a simple balance type
type DepositAddress ¶
type DepositAddress struct { Currency string `json:"currency"` Address string `json:"address"` Label string `json:"label"` Message string `json:"message"` }
DepositAddress holds assigned deposit address for a specific currency
type ErrorCapture ¶
type ErrorCapture struct { Result string `json:"result"` Reason string `json:"reason"` Message string `json:"message"` }
ErrorCapture is a generlized error response from the server
type Gemini ¶
Gemini is the overarching type across the Gemini package, create multiple instances with differing APIkeys for segregation of roles for authenticated requests & sessions by appending new sessions to the Session map using AddSession, if sandbox test is needed append a new session with with the same API keys and change the IsSandbox variable to true.
func (*Gemini) CancelAllOrders ¶
func (g *Gemini) CancelAllOrders(ctx context.Context, _ *order.Cancel) (order.CancelAllResponse, error)
CancelAllOrders cancels all orders associated with a currency pair
func (*Gemini) CancelBatchOrders ¶
func (g *Gemini) CancelBatchOrders(ctx context.Context, o []order.Cancel) (order.CancelBatchResponse, error)
CancelBatchOrders cancels an orders by their corresponding ID numbers
func (*Gemini) CancelExistingOrder ¶
CancelExistingOrder will cancel an order. If the order is already canceled, the message will succeed but have no effect.
func (*Gemini) CancelExistingOrders ¶
func (g *Gemini) CancelExistingOrders(ctx context.Context, cancelBySession bool) (OrderResult, error)
CancelExistingOrders will cancel all outstanding orders created by all sessions owned by this account, including interactive orders placed through the UI. If sessions = true will only cancel the order that is called on this session asssociated with the APIKEY
func (*Gemini) CancelOrder ¶
CancelOrder cancels an order by its corresponding ID number
func (*Gemini) FetchAccountInfo ¶
func (g *Gemini) FetchAccountInfo(ctx context.Context, assetType asset.Item) (account.Holdings, error)
FetchAccountInfo retrieves balances for all enabled currencies
func (*Gemini) FetchOrderbook ¶
func (g *Gemini) FetchOrderbook(ctx context.Context, p currency.Pair, assetType asset.Item) (*orderbook.Base, error)
FetchOrderbook returns orderbook base on the currency pair
func (*Gemini) FetchTicker ¶
func (g *Gemini) FetchTicker(ctx context.Context, p currency.Pair, assetType asset.Item) (*ticker.Price, error)
FetchTicker returns the ticker for a currency pair
func (*Gemini) FetchTradablePairs ¶
FetchTradablePairs returns a list of the exchanges tradable pairs
func (*Gemini) GenerateDefaultSubscriptions ¶
func (g *Gemini) GenerateDefaultSubscriptions() ([]stream.ChannelSubscription, error)
GenerateDefaultSubscriptions Adds default subscriptions to websocket to be handled by ManageSubscriptions()
func (*Gemini) GetActiveOrders ¶
func (g *Gemini) GetActiveOrders(ctx context.Context, req *order.GetOrdersRequest) ([]order.Detail, error)
GetActiveOrders retrieves any orders that are active/open
func (*Gemini) GetAuction ¶
GetAuction returns auction information
func (*Gemini) GetAuctionHistory ¶
func (g *Gemini) GetAuctionHistory(ctx context.Context, currencyPair string, params url.Values) ([]AuctionHistory, error)
GetAuctionHistory returns the auction events, optionally including publications of indicative prices, since the specific timestamp.
currencyPair - example "btcusd" params -- [optional]
since - [timestamp] Only returns auction events after the specified
timestamp.
limit_auction_results - [integer] The maximum number of auction
events to return.
include_indicative - [bool] Whether to include publication of
indicative prices and quantities.
func (*Gemini) GetBalances ¶
GetBalances returns available balances in the supported currencies
func (*Gemini) GetCryptoDepositAddress ¶
func (g *Gemini) GetCryptoDepositAddress(ctx context.Context, depositAddlabel, currency string) (DepositAddress, error)
GetCryptoDepositAddress returns a deposit address
func (*Gemini) GetDefaultConfig ¶
GetDefaultConfig returns a default exchange config
func (*Gemini) GetDepositAddress ¶
func (g *Gemini) GetDepositAddress(ctx context.Context, cryptocurrency currency.Code, _, _ string) (*deposit.Address, error)
GetDepositAddress returns a deposit address for a specified currency
func (*Gemini) GetFeeByType ¶
func (g *Gemini) GetFeeByType(ctx context.Context, feeBuilder *exchange.FeeBuilder) (float64, error)
GetFeeByType returns an estimate of fee based on type of transaction
func (*Gemini) GetFundingHistory ¶
GetFundingHistory returns funding history, deposits and withdrawals
func (*Gemini) GetHistoricCandles ¶
func (g *Gemini) GetHistoricCandles(ctx context.Context, pair currency.Pair, a asset.Item, start, end time.Time, interval kline.Interval) (kline.Item, error)
GetHistoricCandles returns candles between a time period for a set time interval
func (*Gemini) GetHistoricCandlesExtended ¶
func (g *Gemini) GetHistoricCandlesExtended(ctx context.Context, pair currency.Pair, a asset.Item, start, end time.Time, interval kline.Interval) (kline.Item, error)
GetHistoricCandlesExtended returns candles between a time period for a set time interval
func (*Gemini) GetHistoricTrades ¶
func (g *Gemini) GetHistoricTrades(ctx context.Context, p currency.Pair, assetType asset.Item, timestampStart, timestampEnd time.Time) ([]trade.Data, error)
GetHistoricTrades returns historic trade data within the timeframe provided
func (*Gemini) GetNotionalVolume ¶
func (g *Gemini) GetNotionalVolume(ctx context.Context) (NotionalVolume, error)
GetNotionalVolume returns the volume in price currency that has been traded across all pairs over a period of 30 days
func (*Gemini) GetOrderHistory ¶
func (g *Gemini) GetOrderHistory(ctx context.Context, req *order.GetOrdersRequest) ([]order.Detail, error)
GetOrderHistory retrieves account order information Can Limit response to specific order status
func (*Gemini) GetOrderInfo ¶
func (g *Gemini) GetOrderInfo(ctx context.Context, orderID string, pair currency.Pair, assetType asset.Item) (order.Detail, error)
GetOrderInfo returns order information based on order ID
func (*Gemini) GetOrderStatus ¶
GetOrderStatus returns the status for an order
func (*Gemini) GetOrderbook ¶
func (g *Gemini) GetOrderbook(ctx context.Context, currencyPair string, params url.Values) (Orderbook, error)
GetOrderbook returns the current order book, as two arrays, one of bids, and one of asks
params - limit_bids or limit_asks [OPTIONAL] default 50, 0 returns all Values Type is an integer ie "params.Set("limit_asks", 30)"
func (*Gemini) GetRecentTrades ¶
func (g *Gemini) GetRecentTrades(ctx context.Context, pair currency.Pair, assetType asset.Item) ([]trade.Data, error)
GetRecentTrades returns the most recent trades for a currency and asset
func (*Gemini) GetSymbols ¶
GetSymbols returns all available symbols for trading
func (*Gemini) GetTicker ¶
GetTicker returns information about recent trading activity for the symbol
func (*Gemini) GetTradeHistory ¶
func (g *Gemini) GetTradeHistory(ctx context.Context, currencyPair string, timestamp int64) ([]TradeHistory, error)
GetTradeHistory returns an array of trades that have been on the exchange
currencyPair - example "btcusd" timestamp - [optional] Only return trades on or after this timestamp.
func (*Gemini) GetTradeVolume ¶
func (g *Gemini) GetTradeVolume(ctx context.Context) ([][]TradeVolume, error)
GetTradeVolume returns a multi-arrayed volume response
func (*Gemini) GetTrades ¶
func (g *Gemini) GetTrades(ctx context.Context, currencyPair string, since, limit int64, includeBreaks bool) ([]Trade, error)
GetTrades return the trades that have executed since the specified timestamp. Timestamps are either seconds or milliseconds since the epoch (1970-01-01).
currencyPair - example "btcusd" params -- since, timestamp [optional] limit_trades integer Optional. The maximum number of trades to return. include_breaks boolean Optional. Whether to display broken trades. False by default. Can be '1' or 'true' to activate
func (*Gemini) GetWithdrawalsHistory ¶
func (g *Gemini) GetWithdrawalsHistory(ctx context.Context, c currency.Code) (resp []exchange.WithdrawalHistory, err error)
GetWithdrawalsHistory returns previous withdrawals data
func (*Gemini) ModifyOrder ¶
ModifyOrder will allow of changing orderbook placement and limit to market conversion
func (*Gemini) NewOrder ¶
func (g *Gemini) NewOrder(ctx context.Context, symbol string, amount, price float64, side, orderType string) (int64, error)
NewOrder Only limit orders are supported through the API at present. returns order ID if successful
func (*Gemini) PostHeartbeat ¶
PostHeartbeat sends a maintenance heartbeat to the exchange for all heartbeat maintaned sessions
func (*Gemini) SendAuthenticatedHTTPRequest ¶
func (g *Gemini) SendAuthenticatedHTTPRequest(ctx context.Context, ep exchange.URL, method, path string, params map[string]interface{}, result interface{}) (err error)
SendAuthenticatedHTTPRequest sends an authenticated HTTP request to the exchange and returns an error
func (*Gemini) SendHTTPRequest ¶
func (g *Gemini) SendHTTPRequest(ctx context.Context, ep exchange.URL, path string, result interface{}) error
SendHTTPRequest sends an unauthenticated request
func (*Gemini) SetDefaults ¶
func (g *Gemini) SetDefaults()
SetDefaults sets package defaults for gemini exchange
func (*Gemini) SubmitOrder ¶
SubmitOrder submits a new order
func (*Gemini) Subscribe ¶
func (g *Gemini) Subscribe(channelsToSubscribe []stream.ChannelSubscription) error
Subscribe sends a websocket message to receive data from the channel
func (*Gemini) Unsubscribe ¶
func (g *Gemini) Unsubscribe(channelsToUnsubscribe []stream.ChannelSubscription) error
Unsubscribe sends a websocket message to stop receiving data from the channel
func (*Gemini) UpdateAccountInfo ¶
func (g *Gemini) UpdateAccountInfo(ctx context.Context, assetType asset.Item) (account.Holdings, error)
UpdateAccountInfo Retrieves balances for all enabled currencies for the Gemini exchange
func (*Gemini) UpdateOrderbook ¶
func (g *Gemini) UpdateOrderbook(ctx context.Context, p currency.Pair, assetType asset.Item) (*orderbook.Base, error)
UpdateOrderbook updates and returns the orderbook for a currency pair
func (*Gemini) UpdateTicker ¶
func (g *Gemini) UpdateTicker(ctx context.Context, p currency.Pair, a asset.Item) (*ticker.Price, error)
UpdateTicker updates and returns the ticker for a currency pair
func (*Gemini) UpdateTickers ¶
UpdateTickers updates the ticker for all currency pairs of a given asset type
func (*Gemini) UpdateTradablePairs ¶
UpdateTradablePairs updates the exchanges available pairs and stores them in the exchanges config
func (*Gemini) ValidateCredentials ¶
ValidateCredentials validates current credentials used for wrapper functionality
func (*Gemini) WithdrawCrypto ¶
func (g *Gemini) WithdrawCrypto(ctx context.Context, address, currency string, amount float64) (WithdrawalAddress, error)
WithdrawCrypto withdraws crypto currency to a whitelisted address
func (*Gemini) WithdrawCryptocurrencyFunds ¶
func (g *Gemini) WithdrawCryptocurrencyFunds(ctx context.Context, withdrawRequest *withdraw.Request) (*withdraw.ExchangeResponse, error)
WithdrawCryptocurrencyFunds returns a withdrawal ID when a withdrawal is submitted
func (*Gemini) WithdrawFiatFunds ¶
func (g *Gemini) WithdrawFiatFunds(_ context.Context, _ *withdraw.Request) (*withdraw.ExchangeResponse, error)
WithdrawFiatFunds returns a withdrawal ID when a withdrawal is submitted
func (*Gemini) WithdrawFiatFundsToInternationalBank ¶
func (g *Gemini) WithdrawFiatFundsToInternationalBank(_ context.Context, _ *withdraw.Request) (*withdraw.ExchangeResponse, error)
WithdrawFiatFundsToInternationalBank returns a withdrawal ID when a withdrawal is submitted
type NotionalVolume ¶
type NotionalVolume struct { APIAuctionFeeBPS int64 `json:"api_auction_fee_bps"` APIMakerFeeBPS int64 `json:"api_maker_fee_bps"` APITakerFeeBPS int64 `json:"api_taker_fee_bps"` BlockMakerFeeBPS int64 `json:"block_maker_fee_bps"` BlockTakerFeeBPS int64 `json:"block_taker_fee_bps"` FixAuctionFeeBPS int64 `json:"fix_auction_fee_bps"` FixMakerFeeBPS int64 `json:"fix_maker_fee_bps"` FixTakerFeeBPS int64 `json:"fix_taker_fee_bps"` OneDayNotionalVolumes []OneDayNotionalVolume `json:"notional_1d_volume"` ThirtyDayVolume float64 `json:"notional_30d_volume"` WebAuctionFeeBPS int64 `json:"web_auction_fee_bps"` WebMakerFeeBPS int64 `json:"web_maker_fee_bps"` WebTakerFeeBPS int64 `json:"web_taker_fee_bps"` LastedUpdated int64 `json:"last_updated_ms"` Date string `json:"date"` }
NotionalVolume api call for fees, all return fee amounts are in basis points
type OneDayNotionalVolume ¶
type OneDayNotionalVolume struct { Date string `json:"date"` NotationalVolume float64 `json:"notional_volume"` }
OneDayNotionalVolume Contains the notioanl volume for a single day
type Order ¶
type Order struct { OrderID int64 `json:"order_id,string"` ID int64 `json:"id,string"` ClientOrderID string `json:"client_order_id"` Symbol string `json:"symbol"` Exchange string `json:"exchange"` Price float64 `json:"price,string"` AvgExecutionPrice float64 `json:"avg_execution_price,string"` Side string `json:"side"` Type string `json:"type"` Timestamp int64 `json:"timestamp,string"` TimestampMS int64 `json:"timestampms"` IsLive bool `json:"is_live"` IsCancelled bool `json:"is_cancelled"` IsHidden bool `json:"is_hidden"` Options []string `json:"options"` WasForced bool `json:"was_forced"` ExecutedAmount float64 `json:"executed_amount,string"` RemainingAmount float64 `json:"remaining_amount,string"` OriginalAmount float64 `json:"original_amount,string"` Message string `json:"message"` }
Order contains order information
type OrderResult ¶
type OrderResult struct { Result string `json:"result"` Details struct { CancelledOrders []string `json:"cancelledOrders"` CancelRejects []string `json:"cancelRejects"` } `json:"details"` Message string `json:"message"` }
OrderResult holds cancelled order information
type Orderbook ¶
type Orderbook struct { Bids []OrderbookEntry `json:"bids"` Asks []OrderbookEntry `json:"asks"` }
Orderbook contains orderbook information for both bid and ask side
type OrderbookEntry ¶
type OrderbookEntry struct { Price float64 `json:"price,string"` Amount float64 `json:"amount,string"` }
OrderbookEntry subtype of orderbook information
type RateLimit ¶
RateLimit implements the request.Limiter interface
func SetRateLimit ¶
func SetRateLimit() *RateLimit
SetRateLimit returns the rate limit for the exchange
type Ticker ¶
type Ticker struct { Ask float64 `json:"ask,string"` Bid float64 `json:"bid,string"` Last float64 `json:"last,string"` Volume struct { Currency float64 USD float64 BTC float64 ETH float64 Timestamp int64 } }
Ticker holds returned ticker data from the exchange
type TickerV2 ¶
type TickerV2 struct { Ask float64 `json:"ask,string"` Bid float64 `json:"bid,string"` Changes []string `json:"changes"` Close float64 `json:"close,string"` High float64 `json:"high,string"` Low float64 `json:"low,string"` Open float64 `json:"open,string"` Message string `json:"message,omitempty"` Reason string `json:"reason,omitempty"` Result string `json:"result,omitempty"` Symbol currency.Pair `json:"symbol"` }
TickerV2 holds returned ticker data from the exchange
type Trade ¶
type Trade struct { Timestamp int64 `json:"timestamp"` Timestampms int64 `json:"timestampms"` TID int64 `json:"tid"` Price float64 `json:"price,string"` Amount float64 `json:"amount,string"` Exchange string `json:"exchange"` Type string `json:"type"` }
Trade holds trade history for a specific currency pair
type TradeHistory ¶
type TradeHistory struct { Price float64 `json:"price,string"` Amount float64 `json:"amount,string"` Timestamp int64 `json:"timestamp"` TimestampMS int64 `json:"timestampms"` Type string `json:"type"` FeeCurrency string `json:"fee_currency"` FeeAmount float64 `json:"fee_amount,string"` TID int64 `json:"tid"` OrderID int64 `json:"order_id,string"` Exchange string `json:"exchange"` IsAuctionFilled bool `json:"is_auction_fill"` ClientOrderID string `json:"client_order_id"` // Used to store values BaseCurrency string QuoteCurrency string }
TradeHistory holds trade history information
type TradeVolume ¶
type TradeVolume struct { AccountID int64 `json:"account_id"` Symbol string `json:"symbol"` BaseCurrency string `json:"base_currency"` NotionalCurrency string `json:"notional_currency"` Date string `json:"date_date"` TotalVolumeBase float64 `json:"total_volume_base"` MakerBuySellRatio float64 `json:"maker_buy_sell_ratio"` BuyMakerBase float64 `json:"buy_maker_base"` BuyMakerNotional float64 `json:"buy_maker_notional"` BuyMakerCount float64 `json:"buy_maker_count"` SellMakerBase float64 `json:"sell_maker_base"` SellMakerNotional float64 `json:"sell_maker_notional"` SellMakerCount float64 `json:"sell_maker_count"` BuyTakerBase float64 `json:"buy_taker_base"` BuyTakerNotional float64 `json:"buy_taker_notional"` BuyTakerCount float64 `json:"buy_taker_count"` SellTakerBase float64 `json:"sell_taker_base"` SellTakerNotional float64 `json:"sell_taker_notional"` SellTakerCount float64 `json:"sell_taker_count"` }
TradeVolume holds Volume information
type WithdrawalAddress ¶
type WithdrawalAddress struct { Address string `json:"address"` Amount float64 `json:"amount"` TXHash string `json:"txHash"` Message string `json:"message"` Result string `json:"result"` Reason string `json:"reason"` }
WithdrawalAddress holds withdrawal information
type WsHeartbeatResponse ¶
type WsHeartbeatResponse struct { Type string `json:"type"` Timestampms int64 `json:"timestampms"` Sequence int64 `json:"sequence"` TraceID string `json:"trace_id"` SocketSequence int64 `json:"socket_sequence"` }
WsHeartbeatResponse Gemini will send a heartbeat every five seconds so you'll know your WebSocket connection is active.
type WsOrderFilledData ¶
type WsOrderFilledData struct { TradeID string `json:"trade_id"` Liquidity string `json:"liquidity"` Price float64 `json:"price,string"` Amount float64 `json:"amount,string"` Fee float64 `json:"fee,string"` FeeCurrency string `json:"fee_currency"` }
WsOrderFilledData ws response data
type WsOrderResponse ¶
type WsOrderResponse struct { IsLive bool `json:"is_live"` IsCancelled bool `json:"is_cancelled"` IsHidden bool `json:"is_hidden"` SocketSequence int64 `json:"socket_sequence"` Timestampms int64 `json:"timestampms"` AvgExecutionPrice float64 `json:"avg_execution_price,string"` ExecutedAmount float64 `json:"executed_amount,string"` RemainingAmount float64 `json:"remaining_amount,string"` OriginalAmount float64 `json:"original_amount,string"` Price float64 `json:"price,string"` EventID string `json:"event_id"` CancelCommandID string `json:"cancel_command_id"` Reason string `json:"reason"` Type string `json:"type"` OrderID string `json:"order_id"` APISession string `json:"api_session"` Symbol string `json:"symbol"` Side string `json:"side"` OrderType string `json:"order_type"` Timestamp string `json:"timestamp"` Fill WsOrderFilledData `json:"fill"` }
WsOrderResponse contains active orders
type WsRequestPayload ¶
WsRequestPayload Request info to subscribe to a WS enpoint
type WsSubscriptionAcknowledgementResponse ¶
type WsSubscriptionAcknowledgementResponse struct { Type string `json:"type"` AccountID int64 `json:"accountId"` SubscriptionID string `json:"subscriptionId"` SymbolFilter []string `json:"symbolFilter"` APISessionFilter []string `json:"apiSessionFilter"` EventTypeFilter []string `json:"eventTypeFilter"` }
WsSubscriptionAcknowledgementResponse The first message you receive acknowledges your subscription