Documentation ¶
Index ¶
- Constants
- Variables
- func AllFuturesMarketsHuobi() []string
- func FloatToString(input_num float64) string
- func GzipDecode(in []byte) (content []byte, err error)
- func NewTrade(pair dia.ExchangePair, info krakenapi.TradeInfo, foreignTradeID string, ...) *dia.Trade
- func Populate(datastore *models.DB, rdb *models.RelDB, pairs []string)
- func Round(x, unit float64) float64
- type APIScraper
- type AllDeribitOptionsScrapers
- func (s *AllDeribitOptionsScrapers) AddMarket(market string)
- func (s *AllDeribitOptionsScrapers) Authenticate(websocketConnection interface{}) error
- func (s *AllDeribitOptionsScrapers) Close()
- func (s *AllDeribitOptionsScrapers) GetAndStoreOptionsMeta(market string) error
- func (s *AllDeribitOptionsScrapers) GetMetas()
- func (s *AllDeribitOptionsScrapers) MetaOnOptionIsAvailable(option deribitInstrument) (bool, error)
- func (s *AllDeribitOptionsScrapers) RefreshMetas(currency string) error
- func (s *AllDeribitOptionsScrapers) ScrapeMarkets()
- type AllOKEXMarketResponse
- type BalancerPairScraper
- type BalancerScraper
- func (scraper *BalancerScraper) Channel() chan *dia.Trade
- func (scraper *BalancerScraper) Close() error
- func (scraper *BalancerScraper) FetchAvailablePairs() (pairs []dia.ExchangePair, err error)
- func (scraper *BalancerScraper) FillSymbolData(symbol string) (dia.Asset, error)
- func (s *BalancerScraper) NormalizePair(pair dia.ExchangePair) (dia.ExchangePair, error)
- func (scraper *BalancerScraper) ScrapePair(pair dia.ExchangePair) (PairScraper, error)
- type BalancerSwap
- type BalancerToken
- type BancorAssetPairs
- type BancorPairScraper
- type BancorScraper
- func (scraper *BancorScraper) Channel() chan *dia.Trade
- func (scraper *BancorScraper) Close() error
- func (scraper *BancorScraper) FetchAvailablePairs() (pairs []dia.ExchangePair, err error)
- func (scraper *BancorScraper) FillSymbolData(symbol string) (dia.Asset, error)
- func (scraper *BancorScraper) NormalizePair(pair dia.ExchangePair) (dia.ExchangePair, error)
- func (scraper *BancorScraper) ScrapePair(pair dia.ExchangePair) (PairScraper, error)
- type BancorTicker
- type BinancePairScraper
- type BinanceScraper
- func (ps *BinanceScraper) Channel() chan *dia.Trade
- func (s *BinanceScraper) Close() error
- func (s *BinanceScraper) FetchAvailablePairs() (pairs []dia.ExchangePair, err error)
- func (s *BinanceScraper) FillSymbolData(symbol string) (dia.Asset, error)
- func (up *BinanceScraper) NormalizePair(pair dia.ExchangePair) (dia.ExchangePair, error)
- func (s *BinanceScraper) ScrapePair(pair dia.ExchangePair) (PairScraper, error)
- type BitBayMarket
- type BitBayMarkets
- type BitBayPairScraper
- type BitBayScraper
- func (s *BitBayScraper) Channel() chan *dia.Trade
- func (s *BitBayScraper) Close() error
- func (s *BitBayScraper) Error() error
- func (s *BitBayScraper) FetchAvailablePairs() (pairs []dia.ExchangePair, err error)
- func (s *BitBayScraper) FillSymbolData(symbol string) (dia.Asset, error)
- func (s *BitBayScraper) NormalizePair(pair dia.ExchangePair) (dia.ExchangePair, error)
- func (s *BitBayScraper) ScrapePair(pair dia.ExchangePair) (PairScraper, error)
- type BitBaySubscribe
- type BitBayTrade
- type BitBayTransaction
- type BitBayWSResponse
- type BitMaxAsset
- type BitMaxAssets
- type BitMaxPair
- type BitMaxPairResponse
- type BitMaxPairScraper
- type BitMaxRequest
- type BitMaxScraper
- func (ps *BitMaxScraper) Channel() chan *dia.Trade
- func (s *BitMaxScraper) Close() error
- func (s *BitMaxScraper) FetchAvailablePairs() (pairs []dia.ExchangePair, err error)
- func (s *BitMaxScraper) FillSymbolData(symbol string) (asset dia.Asset, err error)
- func (s *BitMaxScraper) NormalizePair(pair dia.ExchangePair) (dia.ExchangePair, error)
- func (s *BitMaxScraper) ScrapePair(pair dia.ExchangePair) (PairScraper, error)
- type BitMaxTradeResponse
- type BitfinexPairScraper
- type BitfinexScraper
- func (ps *BitfinexScraper) Channel() chan *dia.Trade
- func (s *BitfinexScraper) Close() error
- func (s *BitfinexScraper) FetchAvailablePairs() (pairs []dia.ExchangePair, err error)
- func (s *BitfinexScraper) NormalizePair(pair dia.ExchangePair) (dia.ExchangePair, error)
- func (s *BitfinexScraper) ScrapePair(pair dia.ExchangePair) (PairScraper, error)
- type BitflyerScraper
- type BitmexScraper
- type BittrexAsset
- type BittrexPairScraper
- type BittrexScraper
- func (ps *BittrexScraper) Channel() chan *dia.Trade
- func (s *BittrexScraper) Close() error
- func (s *BittrexScraper) FetchAvailablePairs() (pairs []dia.ExchangePair, err error)
- func (s *BittrexScraper) FillSymbolData(symbol string) (asset dia.Asset, err error)
- func (s *BittrexScraper) NormalizePair(pair dia.ExchangePair) (dia.ExchangePair, error)
- func (s *BittrexScraper) ScrapePair(pair dia.ExchangePair) (PairScraper, error)
- type CREX24ApiInstrument
- type CREX24ApiTrade
- type CREX24ApiTradeUpdate
- type CREX24PairScraper
- type CREX24Scraper
- func (s *CREX24Scraper) Channel() chan *dia.Trade
- func (s *CREX24Scraper) Close() error
- func (s *CREX24Scraper) FetchAvailablePairs() (pairs []dia.ExchangePair, err error)
- func (s *CREX24Scraper) FillSymbolData(symbol string) (asset dia.Asset, err error)
- func (s *CREX24Scraper) NormalizePair(pair dia.ExchangePair) (dia.ExchangePair, error)
- func (s *CREX24Scraper) ScrapePair(pair dia.ExchangePair) (PairScraper, error)
- type CREX4Asset
- type Channel
- type CoinBasePairScraper
- type CoinBaseScraper
- func (ps *CoinBaseScraper) Channel() chan *dia.Trade
- func (s *CoinBaseScraper) Close() error
- func (s *CoinBaseScraper) FetchAvailablePairs() (pairs []dia.ExchangePair, err error)
- func (s *CoinBaseScraper) FillSymbolData(symbol string) (asset dia.Asset, err error)
- func (s *CoinBaseScraper) NormalizePair(pair dia.ExchangePair) (dia.ExchangePair, error)
- func (s *CoinBaseScraper) ScrapePair(pair dia.ExchangePair) (PairScraper, error)
- type CoinflexFuturesScraper
- type ComputedCVI
- type ComputedCVIs
- type Confirm
- type ConfirmData
- type CurveCoin
- type CurveFIPairScraper
- type CurveFIScraper
- func (scraper *CurveFIScraper) Channel() chan *dia.Trade
- func (scraper *CurveFIScraper) Close() error
- func (scraper *CurveFIScraper) FetchAvailablePairs() (pairs []dia.ExchangePair, err error)
- func (scraper *CurveFIScraper) FillSymbolData(symbol string) (dia.Asset, error)
- func (scraper *CurveFIScraper) NormalizePair(pair dia.ExchangePair) (dia.ExchangePair, error)
- func (scraper *CurveFIScraper) ScrapePair(pair dia.ExchangePair) (PairScraper, error)
- type DeribitOptionsScraper
- type DeribitScraper
- type DeribitScraperKind
- type DforcePairScraper
- type DforceScraper
- func (scraper *DforceScraper) Channel() chan *dia.Trade
- func (scraper *DforceScraper) Close() error
- func (scraper *DforceScraper) FetchAvailablePairs() (pairs []dia.ExchangePair, err error)
- func (scraper *DforceScraper) FillSymbolData(symbol string) (dia.Asset, error)
- func (scraper *DforceScraper) NormalizePair(pair dia.ExchangePair) (dia.ExchangePair, error)
- func (scraper *DforceScraper) ScrapePair(pair dia.ExchangePair) (PairScraper, error)
- type DforceToken
- type ECBPairScraper
- type ECBScraper
- type Event
- type EventType
- type FTXFuturesScraper
- type FuturesScraper
- func NewBitflyerFuturesScraper(markets []string) FuturesScraper
- func NewBitmexFuturesScraper(markets []string) FuturesScraper
- func NewCoinflexFuturesScraper(markets []string) FuturesScraper
- func NewDeribitFuturesScraper(markets []string, accessKey string, accessSecret string) FuturesScraper
- func NewFTXFuturesScraper(markets []string) FuturesScraper
- func NewHuobiFuturesScraper(markets []string) FuturesScraper
- type GateIOCurrency
- type GateIOPair
- type GateIOPairScraper
- type GateIOResponseTrade
- type GateIOScraper
- func (ps *GateIOScraper) Channel() chan *dia.Trade
- func (s *GateIOScraper) Close() error
- func (s *GateIOScraper) FetchAvailablePairs() (pairs []dia.ExchangePair, err error)
- func (s *GateIOScraper) FillSymbolData(symbol string) (asset dia.Asset, err error)
- func (s *GateIOScraper) NormalizePair(pair dia.ExchangePair) (dia.ExchangePair, error)
- func (s *GateIOScraper) ScrapePair(pair dia.ExchangePair) (PairScraper, error)
- type GateIOTickerData
- type GateIPPairResponse
- type GnosisPairScraper
- type GnosisScraper
- func (scraper *GnosisScraper) Channel() chan *dia.Trade
- func (scraper *GnosisScraper) Close() error
- func (scraper *GnosisScraper) FetchAvailablePairs() (pairs []dia.ExchangePair, err error)
- func (s *GnosisScraper) FillSymbolData(symbol string) (dia.Asset, error)
- func (scraper *GnosisScraper) NormalizePair(pair dia.ExchangePair) (dia.ExchangePair, error)
- func (scraper *GnosisScraper) ScrapePair(pair dia.ExchangePair) (PairScraper, error)
- type GnosisToken
- type HitBTCAsset
- type HitBTCPairScraper
- type HitBTCScraper
- func (ps *HitBTCScraper) Channel() chan *dia.Trade
- func (s *HitBTCScraper) Close() error
- func (s *HitBTCScraper) FetchAvailablePairs() (pairs []dia.ExchangePair, err error)
- func (ps *HitBTCScraper) FillSymbolData(symbol string) (asset dia.Asset, err error)
- func (s *HitBTCScraper) NormalizePair(pair dia.ExchangePair) (dia.ExchangePair, error)
- func (s *HitBTCScraper) ScrapePair(pair dia.ExchangePair) (PairScraper, error)
- type HuobiCurrency
- type HuobiFuturesScraper
- type HuobiPairScraper
- type HuobiScraper
- func (ps *HuobiScraper) Channel() chan *dia.Trade
- func (s *HuobiScraper) Close() error
- func (s *HuobiScraper) FetchAvailablePairs() (pairs []dia.ExchangePair, err error)
- func (s *HuobiScraper) FillSymbolData(symbol string) (asset dia.Asset, err error)
- func (s *HuobiScraper) NormalizePair(pair dia.ExchangePair) (dia.ExchangePair, error)
- func (s *HuobiScraper) ScrapePair(pair dia.ExchangePair) (PairScraper, error)
- type KrakenPairScraper
- type KrakenScraper
- func (ps *KrakenScraper) Channel() chan *dia.Trade
- func (s *KrakenScraper) Close() error
- func (s *KrakenScraper) FetchAvailablePairs() (pairs []dia.ExchangePair, err error)
- func (s *KrakenScraper) FillSymbolData(symbol string) (dia.Asset, error)
- func (ps *KrakenScraper) NormalizePair(pair dia.ExchangePair) (dia.ExchangePair, error)
- func (s *KrakenScraper) ScrapePair(pair dia.ExchangePair) (PairScraper, error)
- func (s *KrakenScraper) Update()
- type KuCoinPairScraper
- type KuCoinScraper
- func (ps *KuCoinScraper) Channel() chan *dia.Trade
- func (s *KuCoinScraper) Close() error
- func (s *KuCoinScraper) FetchAvailablePairs() (pairs []dia.ExchangePair, err error)
- func (s *KuCoinScraper) FillSymbolData(symbol string) (asset dia.Asset, err error)
- func (s *KuCoinScraper) NormalizePair(pair dia.ExchangePair) (dia.ExchangePair, error)
- func (s *KuCoinScraper) ScrapePair(pair dia.ExchangePair) (PairScraper, error)
- type KuExchangePair
- type KuExchangePairs
- type KucoinCurrency
- type KucoinMarketMatch
- type KyberPairScraper
- type KyberScraper
- func (scraper *KyberScraper) Channel() chan *dia.Trade
- func (scraper *KyberScraper) Close() error
- func (scraper *KyberScraper) FetchAvailablePairs() (pairs []dia.ExchangePair, err error)
- func (scraper *KyberScraper) FillSymbolData(symbol string) (dia.Asset, error)
- func (scraper *KyberScraper) NormalizePair(pair dia.ExchangePair) (dia.ExchangePair, error)
- func (scraper *KyberScraper) ScrapePair(pair dia.ExchangePair) (PairScraper, error)
- type KyberToken
- type LBankPairScraper
- type LBankScraper
- func (ps *LBankScraper) Channel() chan *dia.Trade
- func (s *LBankScraper) Close() error
- func (s *LBankScraper) FetchAvailablePairs() (pairs []dia.ExchangePair, err error)
- func (s *LBankScraper) FillSymbolData(symbol string) (dia.Asset, error)
- func (s *LBankScraper) NormalizePair(pair dia.ExchangePair) (dia.ExchangePair, error)
- func (s *LBankScraper) ScrapePair(pair dia.ExchangePair) (PairScraper, error)
- type LiquidChannel
- type LiquidProduct
- type LiquidProducts
- type LiquidResponse
- type LiquidResponseTrade
- type LiquidSubscribe
- type LoopringKey
- type LoopringMarket
- type LoopringPairScraper
- type LoopringScraper
- func (ps *LoopringScraper) Channel() chan *dia.Trade
- func (s *LoopringScraper) Close() error
- func (s *LoopringScraper) FetchAvailablePairs() (pairs []dia.ExchangePair, err error)
- func (s *LoopringScraper) FillSymbolData(symbol string) (dia.Asset, error)
- func (s *LoopringScraper) NormalizePair(pair dia.ExchangePair) (dia.ExchangePair, error)
- func (s *LoopringScraper) ScrapePair(pair dia.ExchangePair) (PairScraper, error)
- type LoopringTopic
- type MakerPair
- type MakerPairResponse
- type MakerPairScraper
- type MakerScraper
- func (scraper *MakerScraper) Channel() chan *dia.Trade
- func (scraper *MakerScraper) Close() error
- func (scraper *MakerScraper) FetchAvailablePairs() (pairs []dia.ExchangePair, err error)
- func (scraper *MakerScraper) FillSymbolData(symbol string) (dia.Asset, error)
- func (scraper *MakerScraper) GetNewTrades(pair string, startTradeID string) ([]MakerTrade, error)
- func (scraper *MakerScraper) NormalizePair(pair dia.ExchangePair) (dia.ExchangePair, error)
- func (scraper *MakerScraper) ScrapePair(pair dia.ExchangePair) (PairScraper, error)
- type MakerTrade
- type MakerTradeResponse
- type Message
- type OKEXArgs
- type OKEXMarket
- type OKEXWSResponse
- type OKExPairScraper
- type OKExScraper
- func (s *OKExScraper) Channel() chan *dia.Trade
- func (s *OKExScraper) Close() error
- func (s *OKExScraper) FetchAvailablePairs() (pairs []dia.ExchangePair, err error)
- func (s *OKExScraper) NormalizePair(pair dia.ExchangePair) (dia.ExchangePair, error)
- func (s *OKExScraper) ScrapePair(pair dia.ExchangePair) (PairScraper, error)
- type OptionSettlement
- type OptionsScraper
- type PairIdMap
- type PairScraper
- type ParsedDeribitOptionOrderbookEntry
- type ParsedDeribitResponse
- type ParsedDeribitResponseParams
- type Pools
- type QuoinePairScraper
- type QuoineScraper
- func (pairScraper *QuoineScraper) Channel() chan *dia.Trade
- func (scraper *QuoineScraper) Close() error
- func (scraper *QuoineScraper) FetchAvailablePairs() (pairs []dia.ExchangePair, err error)
- func (scraper *QuoineScraper) FillSymbolData(symbol string) (dia.Asset, error)
- func (s *QuoineScraper) NormalizePair(pair dia.ExchangePair) (dia.ExchangePair, error)
- func (scraper *QuoineScraper) ScrapePair(pair dia.ExchangePair) (PairScraper, error)
- type Response
- type ResponseGate
- type ResponseLBank
- type ResponseType
- type Responses
- type STEXAsset
- type STEXPairScraper
- type STEXScraper
- func (ps *STEXScraper) Channel() chan *dia.Trade
- func (s *STEXScraper) Close() error
- func (s *STEXScraper) FetchAvailablePairs() (pairs []dia.ExchangePair, err error)
- func (s *STEXScraper) FillSymbolData(symbol string) (asset dia.Asset, err error)
- func (s *STEXScraper) GetNewTrades(pairID string, fromTimestamp time.Time) ([]STEXTrade, error)
- func (s *STEXScraper) NormalizePair(pair dia.ExchangePair) (dia.ExchangePair, error)
- func (s *STEXScraper) ScrapePair(pair dia.ExchangePair) (PairScraper, error)
- type STEXTickerData
- type STEXTrade
- type SimexAsset
- type SimexPairScraper
- type SimexScraper
- func (ps *SimexScraper) Channel() chan *dia.Trade
- func (s *SimexScraper) Close() error
- func (s *SimexScraper) FetchAvailablePairs() (pairs []dia.ExchangePair, err error)
- func (s *SimexScraper) FetchTickerData(symbol string) (asset dia.Asset, err error)
- func (s *SimexScraper) NormalizePair(pair dia.ExchangePair) (dia.ExchangePair, error)
- func (s *SimexScraper) ScrapePair(pair dia.ExchangePair) (PairScraper, error)
- type SimexTicker
- type StexTradeResponse
- type Subscribe
- type SubscribeGate
- type SubscribeLBank
- type Topic
- type Trade
- type UniswapPair
- type UniswapPairScraper
- type UniswapScraper
- func (ps *UniswapScraper) Channel() chan *dia.Trade
- func (s *UniswapScraper) Close() error
- func (s *UniswapScraper) FetchAvailablePairs() (pairs []dia.ExchangePair, err error)
- func (s *UniswapScraper) FillSymbolData(symbol string) (dia.Asset, error)
- func (s *UniswapScraper) GetAllPairs() ([]UniswapPair, error)
- func (s *UniswapScraper) GetDecimals(tokenAddress common.Address) (decimals uint8, err error)
- func (s *UniswapScraper) GetName(tokenAddress common.Address) (name string, err error)
- func (s *UniswapScraper) GetPairByAddress(pairAddress common.Address) (pair UniswapPair, err error)
- func (s *UniswapScraper) GetPairByID(num int64) (UniswapPair, error)
- func (s *UniswapScraper) GetSwapsChannel(pairAddress common.Address) (chan *uniswap.UniswapV2PairSwap, error)
- func (up *UniswapScraper) NormalizePair(pair dia.ExchangePair) (dia.ExchangePair, error)
- func (s *UniswapScraper) ScrapePair(pair dia.ExchangePair) (PairScraper, error)
- type UniswapSwap
- type UniswapToken
- type WebSocketRequest
- type WebSocketResponse
- type XMLCube
- type XMLCubeTime
- type XMLEnvelope
- type XMLHistoricalEnvelope
- type XMLObs
- type XMLObsDimension
- type XMLObsValue
- type ZBPairScraper
- type ZBScraper
- func (ps *ZBScraper) Channel() chan *dia.Trade
- func (s *ZBScraper) Close() error
- func (s *ZBScraper) FetchAvailablePairs() (pairs []dia.ExchangePair, err error)
- func (s *ZBScraper) FillSymbolData(symbol string) (dia.Asset, error)
- func (s *ZBScraper) NormalizePair(pair dia.ExchangePair) (dia.ExchangePair, error)
- func (s *ZBScraper) ScrapePair(pair dia.ExchangePair) (PairScraper, error)
- type ZBSubscribe
- type ZBTradeResponse
- type ZeroxPairScraper
- type ZeroxScraper
- func (scraper *ZeroxScraper) Channel() chan *dia.Trade
- func (scraper *ZeroxScraper) Close() error
- func (scraper *ZeroxScraper) FetchAvailablePairs() (pairs []dia.ExchangePair, err error)
- func (scraper *ZeroxScraper) FetchTickerData(symbol string) (dia.Asset, error)
- func (scraper *ZeroxScraper) FillSymbolData(symbol string) (dia.Asset, error)
- func (s *ZeroxScraper) NormalizePair(pair dia.ExchangePair) (dia.ExchangePair, error)
- func (scraper *ZeroxScraper) ScrapePair(pair dia.ExchangePair) (PairScraper, error)
- type ZeroxToken
Constants ¶
const ( BalancerApiDelay = 20 BalancerBatchDelay = 60 * 1 )
const ( ChannelHeartbeat = "heartbeat" ChannelTicker = "ticker" ChannelLevel2 = "level2" ChannelUser = "user" ChannelMatches = "matches" ChannelFull = "full" )
const ( API_DELAY = 1*time.Second + 500*time.Millisecond EXECUTION_LIMIT = 200 )
const ( // Set delay to one day and divide by number of pairs. In this way, we can // use 24h volume as averaged trade volume BancorApiDelay = 60 * 60 * 24 )
const (
MakerBatchDelay = 60 * 1
)
const WS_TIMEOUT = 10 * time.Second
Variables ¶
var BitBaySocketURL string = "wss://api.bitbay.net/websocket/"
var Exchanges map[string]dia.Exchange
var LiquidSocketRestURL string = "http://api.liquid.com"
var LiquidSocketURL string = "wss://tap.liquid.com/app/LiquidTapClient"
var ZBSocketURL string = "wss://api.zb.today/websocket"
Functions ¶
func AllFuturesMarketsHuobi ¶
func AllFuturesMarketsHuobi() []string
AllFuturesMarketsHuobi - returns all the futures markets tradable on Huobi. Lists all of the Huobi Futures markets. TODO: add a REST HTTP call to obtain the list of trdabale markets.
func FloatToString ¶
func GzipDecode ¶
Types ¶
type APIScraper ¶
type APIScraper interface { io.Closer // ScrapePair returns a PairScraper that continuously scrapes trades for a // single pair from this APIScraper ScrapePair(pair dia.ExchangePair) (PairScraper, error) // FetchAvailablePairs returns a list with all trading pairs available on // the exchange associated to the APIScraper. The format is such that it can // be used by the corr. pairScraper in order to fetch trades. FetchAvailablePairs() ([]dia.ExchangePair, error) // FillSymbolData collects information associated to the symbol ticker of an // asset traded on the exchange associated to the APIScraper. // Ideally, data is returned as close to original (blockchain) notation as possible. // This is only needed for CEX. For DEX the trade can be filled. FillSymbolData(symbol string) (dia.Asset, error) NormalizePair(pair dia.ExchangePair) (dia.ExchangePair, error) // Channel returns a channel that can be used to receive trades Channel() chan *dia.Trade }
APIScraper provides common methods needed to get Trade information from exchange APIs.
func NewAPIScraper ¶
func NewAPIScraper(exchange string, scrape bool, key string, secret string, relDB *models.RelDB) APIScraper
NewAPIScraper returns an API scraper for @exchange. If scrape==true it actually does scraping. Otherwise can be used for pairdiscovery.
type AllDeribitOptionsScrapers ¶
type AllDeribitOptionsScrapers struct { Scrapers []*DeribitOptionsScraper WsConnection *websocket.Conn RefreshTokenEvery int16 // contains filtered or unexported fields }
func (*AllDeribitOptionsScrapers) AddMarket ¶
func (s *AllDeribitOptionsScrapers) AddMarket(market string)
func (*AllDeribitOptionsScrapers) Authenticate ¶
func (s *AllDeribitOptionsScrapers) Authenticate(websocketConnection interface{}) error
Authenticate - authenticates with your access key and access secret to retrieve the trade details
func (*AllDeribitOptionsScrapers) Close ¶
func (s *AllDeribitOptionsScrapers) Close()
func (*AllDeribitOptionsScrapers) GetAndStoreOptionsMeta ¶
func (s *AllDeribitOptionsScrapers) GetAndStoreOptionsMeta(market string) error
GetAndStoreOptionsMeta - will make a REST API call to obtain options meta, it then checks if we already have this data. If we do not, we save the new data.
func (*AllDeribitOptionsScrapers) GetMetas ¶
func (s *AllDeribitOptionsScrapers) GetMetas()
func (*AllDeribitOptionsScrapers) MetaOnOptionIsAvailable ¶
func (s *AllDeribitOptionsScrapers) MetaOnOptionIsAvailable(option deribitInstrument) (bool, error)
note, this function requires meta to be stored in a file
func (*AllDeribitOptionsScrapers) RefreshMetas ¶
func (s *AllDeribitOptionsScrapers) RefreshMetas(currency string) error
func (*AllDeribitOptionsScrapers) ScrapeMarkets ¶
func (s *AllDeribitOptionsScrapers) ScrapeMarkets()
ScrapeMarkets - scrapes all the options markets
type AllOKEXMarketResponse ¶
type AllOKEXMarketResponse struct { Code string `json:"code"` Data []OKEXMarket `json:"data"` Msg string `json:"msg"` }
type BalancerPairScraper ¶
type BalancerPairScraper struct {
// contains filtered or unexported fields
}
func (*BalancerPairScraper) Close ¶
func (pairScraper *BalancerPairScraper) Close() error
func (*BalancerPairScraper) Error ¶
func (pairScraper *BalancerPairScraper) Error() error
func (*BalancerPairScraper) Pair ¶
func (pairScraper *BalancerPairScraper) Pair() dia.ExchangePair
type BalancerScraper ¶
type BalancerScraper struct { WsClient *ethclient.Client RestClient *ethclient.Client // contains filtered or unexported fields }
func NewBalancerScraper ¶
func NewBalancerScraper(exchange dia.Exchange, scrape bool) *BalancerScraper
func (*BalancerScraper) Channel ¶
func (scraper *BalancerScraper) Channel() chan *dia.Trade
func (*BalancerScraper) Close ¶
func (scraper *BalancerScraper) Close() error
func (*BalancerScraper) FetchAvailablePairs ¶
func (scraper *BalancerScraper) FetchAvailablePairs() (pairs []dia.ExchangePair, err error)
FetchAvailablePairs get pairs by getting all the LOGNEWPOOL contract events, and calling the method getCurrentTokens from each pool contract
func (*BalancerScraper) FillSymbolData ¶
func (scraper *BalancerScraper) FillSymbolData(symbol string) (dia.Asset, error)
func (*BalancerScraper) NormalizePair ¶
func (s *BalancerScraper) NormalizePair(pair dia.ExchangePair) (dia.ExchangePair, error)
func (*BalancerScraper) ScrapePair ¶
func (scraper *BalancerScraper) ScrapePair(pair dia.ExchangePair) (PairScraper, error)
type BalancerSwap ¶
type BalancerToken ¶
type BancorAssetPairs ¶
type BancorAssetPairs struct { Data struct { ETH string `json:"ETH"` EOS string `json:"EOS"` STX string `json:"STX"` BNB string `json:"BNB"` BAT string `json:"BAT"` OMG string `json:"OMG"` DICE string `json:"DICE"` BLACK string `json:"BLACK"` IQ string `json:"IQ"` MANA string `json:"MANA"` SRN string `json:"SRN"` LOC string `json:"LOC"` MKR string `json:"MKR"` ENJ string `json:"ENJ"` SNT string `json:"SNT"` GTO string `json:"GTO"` HORUS string `json:"HORUS"` POWR string `json:"POWR"` EMCO string `json:"EMCO"` KNC string `json:"KNC"` XDCE string `json:"XDCE"` XPAT string `json:"XPAT"` PLR string `json:"PLR"` EPRA string `json:"EPRA"` AMN string `json:"AMN"` MEV string `json:"MEV"` MEETONE string `json:"MEETONE"` CEEK string `json:"CEEK"` MYB string `json:"MYB"` TKN string `json:"TKN"` X8X string `json:"X8X"` SPD string `json:"SPD"` XNK string `json:"XNK"` AGRI string `json:"AGRI"` REAL string `json:"REAL"` RBLX string `json:"RBLX"` ONG string `json:"ONG"` ZIPT string `json:"ZIPT"` CAN string `json:"CAN"` WAND string `json:"WAND"` DTRC string `json:"DTRC"` OCT string `json:"OCT"` VEE string `json:"VEE"` POA20 string `json:"POA20"` REQ string `json:"REQ"` MFT string `json:"MFT"` RVT string `json:"RVT"` ELF string `json:"ELF"` RDN string `json:"RDN"` ANT string `json:"ANT"` WINGS string `json:"WINGS"` EURS string `json:"EURS"` GNO string `json:"GNO"` AID string `json:"AID"` TNS string `json:"TNS"` TAEL string `json:"TAEL"` GRID string `json:"GRID"` ZINC string `json:"ZINC"` HVT string `json:"HVT"` SVD string `json:"SVD"` MRG string `json:"MRG"` LOCI string `json:"LOCI"` BETR string `json:"BETR"` LDC string `json:"LDC"` MFG string `json:"MFG"` AUC string `json:"AUC"` BOXX string `json:"BOXX"` DRT string `json:"DRT"` WLK string `json:"WLK"` RLC string `json:"RLC"` RCN string `json:"RCN"` DATA string `json:"DATA"` MRPH string `json:"MRPH"` IND string `json:"IND"` CAT string `json:"CAT"` LUME string `json:"LUME"` VIB string `json:"VIB"` SCL string `json:"SCL"` REM string `json:"REM"` AIX string `json:"AIX"` TBX string `json:"TBX"` STAC string `json:"STAC"` ABX string `json:"ABX"` COT string `json:"COT"` PEOS string `json:"PEOS"` FTX string `json:"FTX"` ZOS string `json:"ZOS"` BCS string `json:"BCS"` REF string `json:"REF"` J8T string `json:"J8T"` FLIXX string `json:"FLIXX"` EQUA string `json:"EQUA"` MNTP string `json:"MNTP"` MTL string `json:"MTL"` MDT string `json:"MDT"` SXL string `json:"SXL"` XBP string `json:"XBP"` SAN string `json:"SAN"` UP string `json:"UP"` DAPP string `json:"DAPP"` EOSDT string `json:"EOSDT"` FINX string `json:"FINX"` EMT string `json:"EMT"` NUT string `json:"NUT"` EFOOD string `json:"EFOOD"` HEDG string `json:"HEDG"` PIXEOS string `json:"PIXEOS"` CHEX string `json:"CHEX"` USDQ string `json:"USDQ"` QDAO string `json:"QDAO"` ELET string `json:"ELET"` AMPL string `json:"AMPL"` USDB string `json:"USDB"` SENSE string `json:"SENSE"` USDT string `json:"USDT"` NMR string `json:"NMR"` MET string `json:"MET"` CUSD string `json:"CUSD"` UBT string `json:"UBT"` ANK string `json:"ANK"` DAI string `json:"DAI"` GRIG string `json:"GRIG"` UPT string `json:"UPT"` RPL string `json:"RPL"` PBTC string `json:"PBTC"` JRT string `json:"JRT"` STM string `json:"STM"` INVOX string `json:"INVOX"` XRT string `json:"XRT"` } `json:"data"` }
type BancorPairScraper ¶
type BancorPairScraper struct {
// contains filtered or unexported fields
}
func (*BancorPairScraper) Close ¶
func (pairScraper *BancorPairScraper) Close() error
func (*BancorPairScraper) Error ¶
func (pairScraper *BancorPairScraper) Error() error
func (*BancorPairScraper) Pair ¶
func (pairScraper *BancorPairScraper) Pair() dia.ExchangePair
type BancorScraper ¶
type BancorScraper struct {
// contains filtered or unexported fields
}
func NewBancorScraper ¶
func NewBancorScraper(exchange dia.Exchange, scrape bool) *BancorScraper
func (*BancorScraper) Channel ¶
func (scraper *BancorScraper) Channel() chan *dia.Trade
func (*BancorScraper) Close ¶
func (scraper *BancorScraper) Close() error
func (*BancorScraper) FetchAvailablePairs ¶
func (scraper *BancorScraper) FetchAvailablePairs() (pairs []dia.ExchangePair, err error)
func (*BancorScraper) FillSymbolData ¶
func (scraper *BancorScraper) FillSymbolData(symbol string) (dia.Asset, error)
func (*BancorScraper) NormalizePair ¶
func (scraper *BancorScraper) NormalizePair(pair dia.ExchangePair) (dia.ExchangePair, error)
func (*BancorScraper) ScrapePair ¶
func (scraper *BancorScraper) ScrapePair(pair dia.ExchangePair) (PairScraper, error)
type BancorTicker ¶
type BancorTicker struct { Data struct { Name string `json:"name"` Symbol string `json:"symbol"` Code string `json:"code"` Decimals int `json:"decimals"` TotalSupply string `json:"totalSupply"` TotalSupplyD string `json:"totalSupplyD"` Volume24H string `json:"volume24h"` Volume24HD float64 `json:"volume24hD"` DisplayCurrency string `json:"displayCurrency"` Price24H string `json:"price24h"` Price float64 `json:"price"` } `json:"data"` }
type BinancePairScraper ¶
type BinancePairScraper struct {
// contains filtered or unexported fields
}
BinancePairScraper implements PairScraper for Binance
func (*BinancePairScraper) Close ¶
func (ps *BinancePairScraper) Close() error
Close stops listening for trades of the pair associated with s
func (*BinancePairScraper) Error ¶
func (ps *BinancePairScraper) Error() error
Error returns an error when the channel Channel() is closed and nil otherwise
func (*BinancePairScraper) Pair ¶
func (ps *BinancePairScraper) Pair() dia.ExchangePair
Pair returns the pair this scraper is subscribed to
type BinanceScraper ¶
type BinanceScraper struct {
// contains filtered or unexported fields
}
BinanceScraper is a Scraper for collecting trades from the Binance websocket API
func NewBinanceScraper ¶
func NewBinanceScraper(apiKey string, secretKey string, exchange dia.Exchange, scrape bool, relDB *models.RelDB) *BinanceScraper
NewBinanceScraper returns a new BinanceScraper for the given pair
func (*BinanceScraper) Channel ¶
func (ps *BinanceScraper) Channel() chan *dia.Trade
Channel returns a channel that can be used to receive trades
func (*BinanceScraper) Close ¶
func (s *BinanceScraper) Close() error
Close closes any existing API connections, as well as channels of PairScrapers from calls to ScrapePair
func (*BinanceScraper) FetchAvailablePairs ¶
func (s *BinanceScraper) FetchAvailablePairs() (pairs []dia.ExchangePair, err error)
FetchAvailablePairs returns a list with all available trade pairs
func (*BinanceScraper) FillSymbolData ¶
func (s *BinanceScraper) FillSymbolData(symbol string) (dia.Asset, error)
func (*BinanceScraper) NormalizePair ¶
func (up *BinanceScraper) NormalizePair(pair dia.ExchangePair) (dia.ExchangePair, error)
func (*BinanceScraper) ScrapePair ¶
func (s *BinanceScraper) ScrapePair(pair dia.ExchangePair) (PairScraper, error)
ScrapePair returns a PairScraper that can be used to get trades for a single pair from this APIScraper
type BitBayMarket ¶
type BitBayMarket struct { Code string `json:"code"` First struct { Currency string `json:"currency"` MinOffer string `json:"minOffer"` Scale int `json:"scale"` } `json:"first"` Second struct { Currency string `json:"currency"` MinOffer string `json:"minOffer"` Scale int `json:"scale"` } `json:"second"` }
type BitBayMarkets ¶
type BitBayMarkets struct { Status string `json:"status"` Items map[string]BitBayMarket `json:"items"` }
type BitBayPairScraper ¶
type BitBayPairScraper struct {
// contains filtered or unexported fields
}
BitBayPairScraper implements PairScraper for BitBay
func (*BitBayPairScraper) Close ¶
func (ps *BitBayPairScraper) Close() error
Close stops listening for trades of the pair associated
func (*BitBayPairScraper) Error ¶
func (ps *BitBayPairScraper) Error() error
Error returns an error when the channel Channel() is closed and nil otherwise
func (*BitBayPairScraper) Pair ¶
func (ps *BitBayPairScraper) Pair() dia.ExchangePair
Pair returns the pair this scraper is subscribed to
type BitBayScraper ¶
type BitBayScraper struct {
// contains filtered or unexported fields
}
BitBayScraper provides methods needed to get Trade information from BitBay
func NewBitBayScraper ¶
NewBitBayScraper get a scrapper for BitBay exchange
func (*BitBayScraper) Channel ¶
func (s *BitBayScraper) Channel() chan *dia.Trade
Channel returns the channel to get trades
func (*BitBayScraper) Close ¶
func (s *BitBayScraper) Close() error
Close any existing API connections, as well as channels, and terminates main loop
func (*BitBayScraper) Error ¶
func (s *BitBayScraper) Error() error
Error returns an error when the channel Channel() is closed and nil otherwise
func (*BitBayScraper) FetchAvailablePairs ¶
func (s *BitBayScraper) FetchAvailablePairs() (pairs []dia.ExchangePair, err error)
FetchAvailablePairs returns a list with all available trade pairs
func (*BitBayScraper) FillSymbolData ¶
func (s *BitBayScraper) FillSymbolData(symbol string) (dia.Asset, error)
func (*BitBayScraper) NormalizePair ¶
func (s *BitBayScraper) NormalizePair(pair dia.ExchangePair) (dia.ExchangePair, error)
func (*BitBayScraper) ScrapePair ¶
func (s *BitBayScraper) ScrapePair(pair dia.ExchangePair) (PairScraper, error)
ScrapePair returns a PairScraper that can be used to get trades for a single pair from this APIScraper
type BitBaySubscribe ¶
type BitBayTrade ¶
type BitBayTrade struct { Date int64 `json:"date"` Price float64 `json:"price"` TransactionType string `json:"type"` Amount float64 `json:"amount"` Tid string `json:"tid"` }
TradeInfo as received from API response
type BitBayTransaction ¶
type BitBayWSResponse ¶
type BitMaxAsset ¶
type BitMaxAsset struct { AssetCode string `json:"assetCode"` AssetName string `json:"assetName"` PrecisionScale int `json:"precisionScale"` NativeScale int `json:"nativeScale"` WithdrawalFee string `json:"withdrawalFee"` MinWithdrawalAmt string `json:"minWithdrawalAmt"` Status string `json:"status"` }
type BitMaxAssets ¶
type BitMaxAssets struct { Code int `json:"code"` Data []BitMaxAsset `json:"data"` }
type BitMaxPair ¶
type BitMaxPair struct { Symbol string `json:"symbol"` DisplayName string `json:"displayName"` BaseAsset string `json:"baseAsset"` QuoteAsset string `json:"quoteAsset"` Status string `json:"status"` MinNotional string `json:"minNotional"` MaxNotional string `json:"maxNotional"` MarginTradable bool `json:"marginTradable"` CommissionType string `json:"commissionType"` CommissionReserveRate string `json:"commissionReserveRate"` TickSize string `json:"tickSize"` LotSize string `json:"lotSize"` }
type BitMaxPairResponse ¶
type BitMaxPairResponse struct { Code int `json:"code"` Data []BitMaxPair `json:"data"` }
type BitMaxPairScraper ¶
type BitMaxPairScraper struct {
// contains filtered or unexported fields
}
BitMax implements PairScraper for BitMax
func (*BitMaxPairScraper) Close ¶
func (ps *BitMaxPairScraper) Close() error
Close stops listening for trades of the pair associated with s
func (*BitMaxPairScraper) Error ¶
func (ps *BitMaxPairScraper) Error() error
Error returns an error when the channel Channel() is closed and nil otherwise
func (*BitMaxPairScraper) Pair ¶
func (ps *BitMaxPairScraper) Pair() dia.ExchangePair
Pair returns the pair this scraper is subscribed to
type BitMaxRequest ¶
type BitMaxScraper ¶
type BitMaxScraper struct {
// contains filtered or unexported fields
}
func NewBitMaxScraper ¶
func (*BitMaxScraper) Channel ¶
func (ps *BitMaxScraper) Channel() chan *dia.Trade
Channel returns a channel that can be used to receive trades
func (*BitMaxScraper) Close ¶
func (s *BitMaxScraper) Close() error
// closes all connected PairScrapers // must only be called from mainLoop
func (s *BitMaxScraper) cleanup(err error) { s.errorLock.Lock() defer s.errorLock.Unlock() if err != nil { s.error = err } s.closed = true close(s.shutdownDone) }
Close closes any existing API connections, as well as channels of PairScrapers from calls to ScrapePair
func (*BitMaxScraper) FetchAvailablePairs ¶
func (s *BitMaxScraper) FetchAvailablePairs() (pairs []dia.ExchangePair, err error)
func (*BitMaxScraper) FillSymbolData ¶
func (s *BitMaxScraper) FillSymbolData(symbol string) (asset dia.Asset, err error)
FillSymbolData collects all available information on an asset traded on Bitmax
func (*BitMaxScraper) NormalizePair ¶
func (s *BitMaxScraper) NormalizePair(pair dia.ExchangePair) (dia.ExchangePair, error)
func (*BitMaxScraper) ScrapePair ¶
func (s *BitMaxScraper) ScrapePair(pair dia.ExchangePair) (PairScraper, error)
ScrapePair returns a PairScraper that can be used to get trades for a single pair from this APIScraper
type BitMaxTradeResponse ¶
type BitfinexPairScraper ¶
type BitfinexPairScraper struct {
// contains filtered or unexported fields
}
BitfinexPairScraper implements PairScraper for Bitfinex
func (*BitfinexPairScraper) Close ¶
func (ps *BitfinexPairScraper) Close() error
Close stops listening for trades of the pair associated with s
func (*BitfinexPairScraper) Error ¶
func (ps *BitfinexPairScraper) Error() error
Error returns an error when the channel Channel() is closed and nil otherwise
func (*BitfinexPairScraper) Pair ¶
func (ps *BitfinexPairScraper) Pair() dia.ExchangePair
Pair returns the pair this scraper is subscribed to
type BitfinexScraper ¶
type BitfinexScraper struct {
// contains filtered or unexported fields
}
BitfinexScraper is a Scraper for collecting trades from the Bitfinex websocket API
func NewBitfinexScraper ¶
func NewBitfinexScraper(key string, secret string, exchange dia.Exchange, scrape bool) *BitfinexScraper
NewBitfinexScraper returns a new BitfinexScraper for the given pair
func (*BitfinexScraper) Channel ¶
func (ps *BitfinexScraper) Channel() chan *dia.Trade
Channel returns a channel that can be used to receive trades
func (*BitfinexScraper) Close ¶
func (s *BitfinexScraper) Close() error
Close closes any existing API connections, as well as channels of PairScrapers from calls to ScrapePair
func (*BitfinexScraper) FetchAvailablePairs ¶
func (s *BitfinexScraper) FetchAvailablePairs() (pairs []dia.ExchangePair, err error)
FetchAvailablePairs returns a list with all available trade pairs
func (*BitfinexScraper) NormalizePair ¶
func (s *BitfinexScraper) NormalizePair(pair dia.ExchangePair) (dia.ExchangePair, error)
func (*BitfinexScraper) ScrapePair ¶
func (s *BitfinexScraper) ScrapePair(pair dia.ExchangePair) (PairScraper, error)
ScrapePair returns a PairScraper that can be used to get trades for a single pair from this APIScraper
type BitflyerScraper ¶
type BitflyerScraper struct { Markets []string WaitGroup *sync.WaitGroup Writer writers.Writer Logger *zap.SugaredLogger }
BitflyerScraper - use the NewBitflyerFuturesScraper function to create an instance
func (*BitflyerScraper) Authenticate ¶
func (s *BitflyerScraper) Authenticate(market string, connection interface{}) error
Authenticate - placeholder here, since we do not need to authneticate the connection.
func (*BitflyerScraper) Scrape ¶
func (s *BitflyerScraper) Scrape(market string)
Scrape starts a websocket scraper for market
func (*BitflyerScraper) ScrapeMarkets ¶
func (s *BitflyerScraper) ScrapeMarkets()
ScrapeMarkets - will scrape the markets specified during instantiation
func (*BitflyerScraper) ScraperClose ¶
func (s *BitflyerScraper) ScraperClose(market string, connection interface{}) error
ScraperClose - safely closes the scraper; We pass the interface connection as the second argument primarily for the reason that Huobi scraper does not use the gorilla websocket; It uses golang's x websocket; If we did not define this method in our FuturesScraper interface, we could have easily used the pointer to gorilla websocket here; However, to make FuturesScraper more ubiquituous, we need an interface here.
type BitmexScraper ¶
type BitmexScraper struct { Markets []string WaitGroup *sync.WaitGroup Writer writers.Writer Logger *zap.SugaredLogger }
BitmexScraper - use the NewBitmexFuturesScraper function to create an instance
func (*BitmexScraper) Authenticate ¶
func (s *BitmexScraper) Authenticate(market string, connection interface{}) error
Authenticate - placeholder here, since we do not need to authneticate the connection.
func (*BitmexScraper) Scrape ¶
func (s *BitmexScraper) Scrape(market string)
Scrape starts a websocket scraper for market
func (*BitmexScraper) ScrapeMarkets ¶
func (s *BitmexScraper) ScrapeMarkets()
ScrapeMarkets - will scrape the markets specified during instantiation
func (*BitmexScraper) ScraperClose ¶
func (s *BitmexScraper) ScraperClose(market string, connection interface{}) error
ScraperClose - safely closes the scraper; We pass the interface connection as the second argument primarily for the reason that Huobi scraper does not use the gorilla websocket; It uses golang's x websocket; If we did not define this method in our FuturesScraper interface, we could have easily used the pointer to gorilla websocket here; However, to make FuturesScraper more ubiquituous, we need an interface here.
type BittrexAsset ¶
type BittrexAsset struct { Symbol string `json:"symbol"` Name string `json:"name"` CoinType string `json:"coinType"` Status string `json:"status"` MinConfirmations int `json:"minConfirmations"` Notice string `json:"notice"` TxFee string `json:"txFee"` LogoURL string `json:"logoUrl"` ProhibitedIn []interface{} `json:"prohibitedIn"` BaseAddress string `json:"baseAddress"` AssociatedTermsOfService []interface{} `json:"associatedTermsOfService"` Tags []interface{} `json:"tags"` }
type BittrexPairScraper ¶
type BittrexPairScraper struct {
// contains filtered or unexported fields
}
BittrexPairScraper implements PairScraper for Bittrex
func (*BittrexPairScraper) Close ¶
func (ps *BittrexPairScraper) Close() error
Close stops listening for trades of the pair associated with s
func (*BittrexPairScraper) Error ¶
func (ps *BittrexPairScraper) Error() error
Error returns an error when the channel Channel() is closed and nil otherwise
func (*BittrexPairScraper) Pair ¶
func (ps *BittrexPairScraper) Pair() dia.ExchangePair
Pair returns the pair this scraper is subscribed to
type BittrexScraper ¶
type BittrexScraper struct {
// contains filtered or unexported fields
}
func NewBittrexScraper ¶
func (*BittrexScraper) Channel ¶
func (ps *BittrexScraper) Channel() chan *dia.Trade
Channel returns a channel that can be used to receive trades
func (*BittrexScraper) Close ¶
func (s *BittrexScraper) Close() error
Close closes any existing API connections, as well as channels of PairScrapers from calls to ScrapePair
func (*BittrexScraper) FetchAvailablePairs ¶
func (s *BittrexScraper) FetchAvailablePairs() (pairs []dia.ExchangePair, err error)
FetchAvailablePairs returns a list with all available trade pairs
func (*BittrexScraper) FillSymbolData ¶
func (s *BittrexScraper) FillSymbolData(symbol string) (asset dia.Asset, err error)
func (*BittrexScraper) NormalizePair ¶
func (s *BittrexScraper) NormalizePair(pair dia.ExchangePair) (dia.ExchangePair, error)
func (*BittrexScraper) ScrapePair ¶
func (s *BittrexScraper) ScrapePair(pair dia.ExchangePair) (PairScraper, error)
ScrapePair returns a PairScraper that can be used to get trades for a single pair from this APIScraper
type CREX24ApiInstrument ¶
type CREX24ApiTrade ¶
type CREX24ApiTradeUpdate ¶
type CREX24ApiTradeUpdate struct { I string NT []CREX24ApiTrade }
type CREX24PairScraper ¶
type CREX24PairScraper struct {
// contains filtered or unexported fields
}
func (*CREX24PairScraper) Close ¶
func (ps *CREX24PairScraper) Close() error
func (*CREX24PairScraper) Error ¶
func (ps *CREX24PairScraper) Error() error
func (*CREX24PairScraper) Pair ¶
func (ps *CREX24PairScraper) Pair() dia.ExchangePair
type CREX24Scraper ¶
type CREX24Scraper struct {
// contains filtered or unexported fields
}
CREX24 Scraper is a scraper for collecting trades from the CREX24 signalR api
func NewCREX24Scraper ¶
func NewCREX24Scraper(exchange dia.Exchange, relDB *models.RelDB) *CREX24Scraper
func (*CREX24Scraper) Channel ¶
func (s *CREX24Scraper) Channel() chan *dia.Trade
func (*CREX24Scraper) Close ¶
func (s *CREX24Scraper) Close() error
func (*CREX24Scraper) FetchAvailablePairs ¶
func (s *CREX24Scraper) FetchAvailablePairs() (pairs []dia.ExchangePair, err error)
func (*CREX24Scraper) FillSymbolData ¶
func (s *CREX24Scraper) FillSymbolData(symbol string) (asset dia.Asset, err error)
FillSymbolData collects all available information on an asset traded on CREX24
func (*CREX24Scraper) NormalizePair ¶
func (s *CREX24Scraper) NormalizePair(pair dia.ExchangePair) (dia.ExchangePair, error)
func (*CREX24Scraper) ScrapePair ¶
func (s *CREX24Scraper) ScrapePair(pair dia.ExchangePair) (PairScraper, error)
type CREX4Asset ¶
type CREX4Asset []struct { Symbol string `json:"symbol"` Name string `json:"name"` IsFiat bool `json:"isFiat"` DepositsAllowed bool `json:"depositsAllowed"` DepositConfirmationCount int `json:"depositConfirmationCount"` MinDeposit float64 `json:"minDeposit"` WithdrawalsAllowed bool `json:"withdrawalsAllowed"` WithdrawalPrecision int `json:"withdrawalPrecision"` MinWithdrawal float64 `json:"minWithdrawal"` MaxWithdrawal float64 `json:"maxWithdrawal"` IsDelisted bool `json:"isDelisted"` Transports interface{} `json:"transports"` }
type CoinBasePairScraper ¶
type CoinBasePairScraper struct {
// contains filtered or unexported fields
}
CoinBasePairScraper implements PairScraper for GDax
func (*CoinBasePairScraper) Close ¶
func (ps *CoinBasePairScraper) Close() error
func (*CoinBasePairScraper) Error ¶
func (ps *CoinBasePairScraper) Error() error
Error returns an error when the channel Channel() is closed and nil otherwise
func (*CoinBasePairScraper) Pair ¶
func (ps *CoinBasePairScraper) Pair() dia.ExchangePair
Pair returns the pair this scraper is subscribed to
type CoinBaseScraper ¶
type CoinBaseScraper struct {
// contains filtered or unexported fields
}
func NewCoinBaseScraper ¶
NewCoinBaseScraper returns a new CoinBaseScraper initialized with default values. The instance is asynchronously scraping as soon as it is created.
func (*CoinBaseScraper) Channel ¶
func (ps *CoinBaseScraper) Channel() chan *dia.Trade
Channel returns a channel that can be used to receive trades/pricing information
func (*CoinBaseScraper) Close ¶
func (s *CoinBaseScraper) Close() error
Close closes any existing API connections, as well as channels of PairScrapers from calls to ScrapePair
func (*CoinBaseScraper) FetchAvailablePairs ¶
func (s *CoinBaseScraper) FetchAvailablePairs() (pairs []dia.ExchangePair, err error)
FetchAvailablePairs returns a list with all available trade pairs
func (*CoinBaseScraper) FillSymbolData ¶
func (s *CoinBaseScraper) FillSymbolData(symbol string) (asset dia.Asset, err error)
FillSymbolData collects all available information on an asset traded on CoinBase
func (*CoinBaseScraper) NormalizePair ¶
func (s *CoinBaseScraper) NormalizePair(pair dia.ExchangePair) (dia.ExchangePair, error)
func (*CoinBaseScraper) ScrapePair ¶
func (s *CoinBaseScraper) ScrapePair(pair dia.ExchangePair) (PairScraper, error)
ScrapePair returns a PairScraper that can be used to get trades for a single pair from this APIScraper
type CoinflexFuturesScraper ¶
type CoinflexFuturesScraper struct { Markets []string WaitGroup *sync.WaitGroup Writer writers.Writer Logger *zap.SugaredLogger }
CoinflexFuturesScraper - scrapes the futures from the Coinflex exchange
func (*CoinflexFuturesScraper) Authenticate ¶
func (s *CoinflexFuturesScraper) Authenticate(market string, connection interface{}) error
Authenticate - placeholder here, since we do not need to authneticate the connection.
func (*CoinflexFuturesScraper) Scrape ¶
func (s *CoinflexFuturesScraper) Scrape(market string)
Scrape starts a websocket scraper for market
func (*CoinflexFuturesScraper) ScrapeMarkets ¶
func (s *CoinflexFuturesScraper) ScrapeMarkets()
ScrapeMarkets - will scrape the markets specified during instantiation
func (*CoinflexFuturesScraper) ScraperClose ¶
func (s *CoinflexFuturesScraper) ScraperClose(market string, connection interface{}) error
ScraperClose - safely closes the scraper; We pass the interface connection as the second argument primarily for the reason that Huobi scraper does not use the gorilla websocket; It uses golang's x websocket; If we did not define this method in our FuturesScraper interface, we could have easily used the pointer to gorilla websocket here; However, to make FuturesScraper more ubiquituous, we need an interface here.
type ComputedCVI ¶
ComputedCVI is a struct representing our CVI value at a point in time
type ComputedCVIs ¶
type ComputedCVIs chan ComputedCVI
ComputedCVIs is the channel type that will communicate the cvis
type ConfirmData ¶
type CurveFIPairScraper ¶
type CurveFIPairScraper struct {
// contains filtered or unexported fields
}
func (*CurveFIPairScraper) Close ¶
func (pairScraper *CurveFIPairScraper) Close() error
func (*CurveFIPairScraper) Error ¶
func (pairScraper *CurveFIPairScraper) Error() error
func (*CurveFIPairScraper) Pair ¶
func (pairScraper *CurveFIPairScraper) Pair() dia.ExchangePair
type CurveFIScraper ¶
type CurveFIScraper struct { WsClient *ethclient.Client RestClient *ethclient.Client // contains filtered or unexported fields }
func NewCurveFIScraper ¶
func NewCurveFIScraper(exchange dia.Exchange, scrape bool) *CurveFIScraper
func (*CurveFIScraper) Channel ¶
func (scraper *CurveFIScraper) Channel() chan *dia.Trade
func (*CurveFIScraper) Close ¶
func (scraper *CurveFIScraper) Close() error
func (*CurveFIScraper) FetchAvailablePairs ¶
func (scraper *CurveFIScraper) FetchAvailablePairs() (pairs []dia.ExchangePair, err error)
func (*CurveFIScraper) FillSymbolData ¶
func (scraper *CurveFIScraper) FillSymbolData(symbol string) (dia.Asset, error)
func (*CurveFIScraper) NormalizePair ¶
func (scraper *CurveFIScraper) NormalizePair(pair dia.ExchangePair) (dia.ExchangePair, error)
func (*CurveFIScraper) ScrapePair ¶
func (scraper *CurveFIScraper) ScrapePair(pair dia.ExchangePair) (PairScraper, error)
type DeribitOptionsScraper ¶
type DeribitOptionsScraper struct { ScraperIsRunning bool ScraperIsRunningMu *sync.Mutex // contains filtered or unexported fields }
DeribitOptionsScraper - used to maintain the order book and save it every x seconds
func NewDeribitOptionsScraper ¶
func NewDeribitOptionsScraper(ds *models.DB, owg *sync.WaitGroup, market string, accessKey string, accessSecret string, ws *websocket.Conn) DeribitOptionsScraper
NewDeribitOptionsScraper - returns an instance of an options scraper.
func (*DeribitOptionsScraper) Scrape ¶
func (s *DeribitOptionsScraper) Scrape(market string)
Scrape - scrapes the options markets (meta + order book data)
func (*DeribitOptionsScraper) ScraperClose ¶
func (s *DeribitOptionsScraper) ScraperClose(market string, websocketConnection interface{}) error
ScraperClose - responsible for closing out the scraper for a market
type DeribitScraper ¶
type DeribitScraper struct { Markets []string WaitGroup *sync.WaitGroup Logger *zap.SugaredLogger DataStore *models.DB WsConnection *websocket.Conn // required for deribit to: // 1. authenticate (trades is a private channel) // 2. referesh the token from step 1., so that the channel isn't closed AccessKey string AccessSecret string RefreshTokenEvery int16 // how often we refresh the token (in seconds) MarketKind DeribitScraperKind }
DeribitScraper - used in conjunction with the DeribitScraperKind in a new struct to define futures and options scrapers
func (*DeribitScraper) Scrape ¶
func (s *DeribitScraper) Scrape(market string)
Scrape starts a websocket scraper for market
func (*DeribitScraper) ScrapeMarkets ¶
func (s *DeribitScraper) ScrapeMarkets()
ScrapeMarkets - will scrape the markets specified during instantiation
func (*DeribitScraper) ScraperClose ¶
func (s *DeribitScraper) ScraperClose(market string, websocketConnection interface{}) error
ScraperClose - responsible for closing out the scraper for a market
type DeribitScraperKind ¶
type DeribitScraperKind int
DeribitScraperKind - used to distinguish between the futures and options scrapers
const ( // DeribitFuture - constant to signal the futures scraper DeribitFuture DeribitScraperKind = iota + 1 // DeribitOption - constant to signal the options scraper DeribitOption )
type DforcePairScraper ¶
type DforcePairScraper struct {
// contains filtered or unexported fields
}
func (*DforcePairScraper) Close ¶
func (pairScraper *DforcePairScraper) Close() error
func (*DforcePairScraper) Error ¶
func (pairScraper *DforcePairScraper) Error() error
func (*DforcePairScraper) Pair ¶
func (pairScraper *DforcePairScraper) Pair() dia.ExchangePair
type DforceScraper ¶
type DforceScraper struct { WsClient *ethclient.Client RestClient *ethclient.Client // contains filtered or unexported fields }
func NewDforceScraper ¶
func NewDforceScraper(exchange dia.Exchange, scrape bool) *DforceScraper
func (*DforceScraper) Channel ¶
func (scraper *DforceScraper) Channel() chan *dia.Trade
func (*DforceScraper) Close ¶
func (scraper *DforceScraper) Close() error
func (*DforceScraper) FetchAvailablePairs ¶
func (scraper *DforceScraper) FetchAvailablePairs() (pairs []dia.ExchangePair, err error)
func (*DforceScraper) FillSymbolData ¶
func (scraper *DforceScraper) FillSymbolData(symbol string) (dia.Asset, error)
func (*DforceScraper) NormalizePair ¶
func (scraper *DforceScraper) NormalizePair(pair dia.ExchangePair) (dia.ExchangePair, error)
func (*DforceScraper) ScrapePair ¶
func (scraper *DforceScraper) ScrapePair(pair dia.ExchangePair) (PairScraper, error)
type DforceToken ¶
type ECBPairScraper ¶
type ECBPairScraper struct {
// contains filtered or unexported fields
}
ECBPairScraper implements PairScraper for ECB
func (*ECBPairScraper) Close ¶
func (ps *ECBPairScraper) Close() error
func (*ECBPairScraper) Error ¶
func (ps *ECBPairScraper) Error() error
Error returns an error when the channel Channel() is closed and nil otherwise
func (*ECBPairScraper) Pair ¶
func (ps *ECBPairScraper) Pair() dia.ExchangePair
Pair returns the pair this scraper is subscribed to
type ECBScraper ¶
type ECBScraper struct {
// contains filtered or unexported fields
}
func SpawnECBScraper ¶
func SpawnECBScraper(datastore models.Datastore) *ECBScraper
SpawnECBScraper returns a new ECBScraper initialized with default values. The instance is asynchronously scraping as soon as it is created.
func (*ECBScraper) Channel ¶
func (ps *ECBScraper) Channel() chan *dia.Trade
Channel returns a channel that can be used to receive trades/pricing information
func (*ECBScraper) Close ¶
func (s *ECBScraper) Close() error
Close closes any existing API connections, as well as channels of PairScrapers from calls to ScrapePair
func (*ECBScraper) ScrapePair ¶
func (s *ECBScraper) ScrapePair(pair dia.ExchangePair) (PairScraper, error)
ScrapePair returns a PairScraper that can be used to get trades for a single pair from this APIScraper
func (*ECBScraper) Update ¶
func (s *ECBScraper) Update() error
Update performs a HTTP Get request for the rss feed and decodes the results.
type FTXFuturesScraper ¶
type FTXFuturesScraper struct { Markets []string WaitGroup *sync.WaitGroup Writer writers.Writer Logger *zap.SugaredLogger }
FTXFuturesScraper - scrapes the futures from the FTX exchange
func (*FTXFuturesScraper) Authenticate ¶
func (s *FTXFuturesScraper) Authenticate(market string, connection interface{}) error
Authenticate - placeholder here, since we do not need to authneticate the connection.
func (*FTXFuturesScraper) Scrape ¶
func (s *FTXFuturesScraper) Scrape(market string)
Scrape starts a websocket scraper for market
func (*FTXFuturesScraper) ScrapeMarkets ¶
func (s *FTXFuturesScraper) ScrapeMarkets()
ScrapeMarkets - will scrape the markets specified during instantiation
func (*FTXFuturesScraper) ScraperClose ¶
func (s *FTXFuturesScraper) ScraperClose(market string, connection interface{}) error
ScraperClose - safely closes the scraper; We pass the interface connection as the second argument primarily for the reason that Huobi scraper does not use the gorilla websocket; It uses golang's x websocket; If we did not define this method in our FuturesScraper interface, we could have easily used the pointer to gorilla websocket here; However, to make FuturesScraper more ubiquituous, we need an interface here.
type FuturesScraper ¶
type FuturesScraper interface { Scrape(market string) // a self-sustained goroutine that scrapes a single market ScrapeMarkets() // will scrape the futures markets defined during instantiation of the scraper ScraperClose(market string, websocketConnection interface{}) error }
FuturesScraper is an interface for all of the Futures Contracts scrapers
func NewBitflyerFuturesScraper ¶
func NewBitflyerFuturesScraper(markets []string) FuturesScraper
NewBitflyerFuturesScraper - returns an instance of an options scraper.
func NewBitmexFuturesScraper ¶
func NewBitmexFuturesScraper(markets []string) FuturesScraper
NewBitmexFuturesScraper - returns an instance of an options scraper.
func NewCoinflexFuturesScraper ¶
func NewCoinflexFuturesScraper(markets []string) FuturesScraper
NewCoinflexFuturesScraper - returns an instance of the coinflex scraper
func NewDeribitFuturesScraper ¶
func NewDeribitFuturesScraper(markets []string, accessKey string, accessSecret string) FuturesScraper
NewDeribitFuturesScraper - creates a deribit futures scraper for you for the markets that you supply. Some of the markets available are: "BTC-PERPETUAL" and "ETH-PERPETUAL".
func NewFTXFuturesScraper ¶
func NewFTXFuturesScraper(markets []string) FuturesScraper
NewFTXFuturesScraper - returns an instance of the FTX scraper
func NewHuobiFuturesScraper ¶
func NewHuobiFuturesScraper(markets []string) FuturesScraper
NewHuobiFuturesScraper - returns an instance of the Huobi scraper
type GateIOCurrency ¶
type GateIOCurrency struct { No int `json:"no"` Symbol string `json:"symbol"` Name string `json:"name"` NameEn string `json:"name_en"` NameCn string `json:"name_cn"` Pair string `json:"pair"` Rate string `json:"rate"` VolA string `json:"vol_a"` VolB string `json:"vol_b"` CurrA string `json:"curr_a"` CurrB string `json:"curr_b"` CurrSuffix string `json:"curr_suffix"` RatePercent string `json:"rate_percent"` Trend string `json:"trend"` Lq string `json:"lq"` PRate int `json:"p_rate"` }
type GateIOPair ¶
type GateIOPair struct { ID string `json:"id"` Base string `json:"base"` Quote string `json:"quote"` Fee string `json:"fee"` MinQuoteAmount string `json:"min_quote_amount,omitempty"` AmountPrecision int `json:"amount_precision"` Precision int `json:"precision"` TradeStatus string `json:"trade_status"` SellStart int `json:"sell_start"` BuyStart int `json:"buy_start"` MinBaseAmount string `json:"min_base_amount,omitempty"` }
type GateIOPairScraper ¶
type GateIOPairScraper struct {
// contains filtered or unexported fields
}
GateIOPairScraper implements PairScraper for GateIO
func (*GateIOPairScraper) Close ¶
func (ps *GateIOPairScraper) Close() error
Close stops listening for trades of the pair associated with s
func (*GateIOPairScraper) Error ¶
func (ps *GateIOPairScraper) Error() error
Error returns an error when the channel Channel() is closed and nil otherwise
func (*GateIOPairScraper) Pair ¶
func (ps *GateIOPairScraper) Pair() dia.ExchangePair
Pair returns the pair this scraper is subscribed to
type GateIOResponseTrade ¶
type GateIOResponseTrade struct { Time int `json:"time"` Channel string `json:"channel"` Event string `json:"event"` Result struct { ID int `json:"id"` CreateTime int `json:"create_time"` CreateTimeMs string `json:"create_time_ms"` Side string `json:"side"` CurrencyPair string `json:"currency_pair"` Amount string `json:"amount"` Price string `json:"price"` } `json:"result"` }
type GateIOScraper ¶
type GateIOScraper struct {
// contains filtered or unexported fields
}
func NewGateIOScraper ¶
func NewGateIOScraper(exchange dia.Exchange, scrape bool) *GateIOScraper
NewGateIOScraper returns a new GateIOScraper for the given pair
func (*GateIOScraper) Channel ¶
func (ps *GateIOScraper) Channel() chan *dia.Trade
Channel returns a channel that can be used to receive trades
func (*GateIOScraper) Close ¶
func (s *GateIOScraper) Close() error
Close closes any existing API connections, as well as channels of PairScrapers from calls to ScrapePair
func (*GateIOScraper) FetchAvailablePairs ¶
func (s *GateIOScraper) FetchAvailablePairs() (pairs []dia.ExchangePair, err error)
FetchAvailablePairs returns a list with all available trade pairs
func (*GateIOScraper) FillSymbolData ¶
func (s *GateIOScraper) FillSymbolData(symbol string) (asset dia.Asset, err error)
FetchTickerData collects all available information on an asset traded on GateIO
func (*GateIOScraper) NormalizePair ¶
func (s *GateIOScraper) NormalizePair(pair dia.ExchangePair) (dia.ExchangePair, error)
func (*GateIOScraper) ScrapePair ¶
func (s *GateIOScraper) ScrapePair(pair dia.ExchangePair) (PairScraper, error)
ScrapePair returns a PairScraper that can be used to get trades for a single pair from this APIScraper
type GateIOTickerData ¶
type GateIOTickerData struct { Result string `json:"result"` Data []GateIOCurrency `json:"data"` }
type GateIPPairResponse ¶
type GateIPPairResponse []GateIOPair
type GnosisPairScraper ¶
type GnosisPairScraper struct {
// contains filtered or unexported fields
}
func (*GnosisPairScraper) Close ¶
func (pairScraper *GnosisPairScraper) Close() error
func (*GnosisPairScraper) Error ¶
func (pairScraper *GnosisPairScraper) Error() error
func (*GnosisPairScraper) Pair ¶
func (pairScraper *GnosisPairScraper) Pair() dia.ExchangePair
type GnosisScraper ¶
type GnosisScraper struct { WsClient *ethclient.Client RestClient *ethclient.Client // contains filtered or unexported fields }
func NewGnosisScraper ¶
func NewGnosisScraper(exchange dia.Exchange, scrape bool) *GnosisScraper
func (*GnosisScraper) Channel ¶
func (scraper *GnosisScraper) Channel() chan *dia.Trade
func (*GnosisScraper) Close ¶
func (scraper *GnosisScraper) Close() error
func (*GnosisScraper) FetchAvailablePairs ¶
func (scraper *GnosisScraper) FetchAvailablePairs() (pairs []dia.ExchangePair, err error)
func (*GnosisScraper) FillSymbolData ¶
func (s *GnosisScraper) FillSymbolData(symbol string) (dia.Asset, error)
FillSymbolData is not used by DEX scrapers.
func (*GnosisScraper) NormalizePair ¶
func (scraper *GnosisScraper) NormalizePair(pair dia.ExchangePair) (dia.ExchangePair, error)
func (*GnosisScraper) ScrapePair ¶
func (scraper *GnosisScraper) ScrapePair(pair dia.ExchangePair) (PairScraper, error)
type GnosisToken ¶
type HitBTCAsset ¶
type HitBTCAsset struct { ID string `json:"id"` FullName string `json:"fullName"` Crypto bool `json:"crypto"` PayinEnabled bool `json:"payinEnabled"` PayinPaymentID bool `json:"payinPaymentId"` PayinConfirmations int `json:"payinConfirmations"` PayoutEnabled bool `json:"payoutEnabled"` PayoutIsPaymentID bool `json:"payoutIsPaymentId"` TransferEnabled bool `json:"transferEnabled"` Delisted bool `json:"delisted"` PayoutFee string `json:"payoutFee"` PrecisionPayout int `json:"precisionPayout"` PrecisionTransfer int `json:"precisionTransfer"` }
type HitBTCPairScraper ¶
type HitBTCPairScraper struct {
// contains filtered or unexported fields
}
HitBTCPairScraper implements PairScraper for HitBTC
func (*HitBTCPairScraper) Close ¶
func (ps *HitBTCPairScraper) Close() error
Close stops listening for trades of the pair associated with s
func (*HitBTCPairScraper) Error ¶
func (ps *HitBTCPairScraper) Error() error
Error returns an error when the channel Channel() is closed and nil otherwise
func (*HitBTCPairScraper) Pair ¶
func (ps *HitBTCPairScraper) Pair() dia.ExchangePair
Pair returns the pair this scraper is subscribed to
type HitBTCScraper ¶
type HitBTCScraper struct {
// contains filtered or unexported fields
}
func NewHitBTCScraper ¶
NewHitBTCScraper returns a new HitBTCScraper for the given pair
func (*HitBTCScraper) Channel ¶
func (ps *HitBTCScraper) Channel() chan *dia.Trade
Channel returns a channel that can be used to receive trades
func (*HitBTCScraper) Close ¶
func (s *HitBTCScraper) Close() error
Close closes any existing API connections, as well as channels of PairScrapers from calls to ScrapePair
func (*HitBTCScraper) FetchAvailablePairs ¶
func (s *HitBTCScraper) FetchAvailablePairs() (pairs []dia.ExchangePair, err error)
FetchAvailablePairs returns a list with all available trade pairs
func (*HitBTCScraper) FillSymbolData ¶
func (ps *HitBTCScraper) FillSymbolData(symbol string) (asset dia.Asset, err error)
FillSymbolData collects all available information on an asset traded on HitBTC
func (*HitBTCScraper) NormalizePair ¶
func (s *HitBTCScraper) NormalizePair(pair dia.ExchangePair) (dia.ExchangePair, error)
func (*HitBTCScraper) ScrapePair ¶
func (s *HitBTCScraper) ScrapePair(pair dia.ExchangePair) (PairScraper, error)
ScrapePair returns a PairScraper that can be used to get trades for a single pair from this APIScraper
type HuobiCurrency ¶
type HuobiCurrency struct { Code int `json:"code"` Data []struct { Currency string `json:"currency"` AssetType int `json:"assetType"` Chains []struct { Chain string `json:"chain"` DisplayName string `json:"displayName"` BaseChain string `json:"baseChain"` BaseChainProtocol string `json:"baseChainProtocol"` IsDynamic bool `json:"isDynamic"` NumOfConfirmations int `json:"numOfConfirmations"` NumOfFastConfirmations int `json:"numOfFastConfirmations"` DepositStatus string `json:"depositStatus"` MinDepositAmt string `json:"minDepositAmt"` WithdrawStatus string `json:"withdrawStatus"` MinWithdrawAmt string `json:"minWithdrawAmt"` WithdrawPrecision int `json:"withdrawPrecision"` MaxWithdrawAmt string `json:"maxWithdrawAmt"` WithdrawQuotaPerDay string `json:"withdrawQuotaPerDay"` WithdrawQuotaPerYear interface{} `json:"withdrawQuotaPerYear"` WithdrawQuotaTotal interface{} `json:"withdrawQuotaTotal"` WithdrawFeeType string `json:"withdrawFeeType"` TransactFeeWithdraw string `json:"transactFeeWithdraw"` AddrWithTag bool `json:"addrWithTag"` AddrDepositTag bool `json:"addrDepositTag"` } `json:"chains"` InstStatus string `json:"instStatus"` } `json:"data"` }
type HuobiFuturesScraper ¶
type HuobiFuturesScraper struct { Markets []string // markets to scrape. To scrape all, call AllFuturesMarketsHuobi() WaitGroup *sync.WaitGroup Writer writers.Writer // an interface to write the messages Logger *zap.SugaredLogger }
HuobiFuturesScraper - scrapes huobi's futures markets
func (*HuobiFuturesScraper) Authenticate ¶
func (s *HuobiFuturesScraper) Authenticate(market string, connection interface{}) error
Authenticate - not required for Huobi to scrape the futures data.
func (*HuobiFuturesScraper) Scrape ¶
func (s *HuobiFuturesScraper) Scrape(market string)
Scrape starts a websocket scraper for market
func (*HuobiFuturesScraper) ScrapeMarkets ¶
func (s *HuobiFuturesScraper) ScrapeMarkets()
ScrapeMarkets - will scrape the markets specified during instantiation
func (*HuobiFuturesScraper) ScraperClose ¶
func (s *HuobiFuturesScraper) ScraperClose(market string, connection interface{}) error
ScraperClose - clean up after the scraper.
type HuobiPairScraper ¶
type HuobiPairScraper struct {
// contains filtered or unexported fields
}
HuobiPairScraper implements PairScraper for Huobi exchange
func (*HuobiPairScraper) Close ¶
func (ps *HuobiPairScraper) Close() error
Close stops listening for trades of the pair associated with s
func (*HuobiPairScraper) Error ¶
func (ps *HuobiPairScraper) Error() error
Error returns an error when the channel Channel() is closed and nil otherwise
func (*HuobiPairScraper) Pair ¶
func (ps *HuobiPairScraper) Pair() dia.ExchangePair
Pair returns the pair this scraper is subscribed to
type HuobiScraper ¶
type HuobiScraper struct {
// contains filtered or unexported fields
}
func NewHuobiScraper ¶
func NewHuobiScraper(exchange dia.Exchange, scrape bool) *HuobiScraper
NewHuobiScraper returns a new HuobiScraper for the given pair
func (*HuobiScraper) Channel ¶
func (ps *HuobiScraper) Channel() chan *dia.Trade
Channel returns a channel that can be used to receive trades
func (*HuobiScraper) Close ¶
func (s *HuobiScraper) Close() error
Close closes any existing API connections, as well as channels of PairScrapers from calls to ScrapePair
func (*HuobiScraper) FetchAvailablePairs ¶
func (s *HuobiScraper) FetchAvailablePairs() (pairs []dia.ExchangePair, err error)
FetchAvailablePairs returns a list with all available trade pairs
func (*HuobiScraper) FillSymbolData ¶
func (s *HuobiScraper) FillSymbolData(symbol string) (asset dia.Asset, err error)
FillSymbolData collects all available information on an asset traded on huobi
func (*HuobiScraper) NormalizePair ¶
func (s *HuobiScraper) NormalizePair(pair dia.ExchangePair) (dia.ExchangePair, error)
func (*HuobiScraper) ScrapePair ¶
func (s *HuobiScraper) ScrapePair(pair dia.ExchangePair) (PairScraper, error)
ScrapePair returns a PairScraper that can be used to get trades for a single pair from this APIScraper
type KrakenPairScraper ¶
type KrakenPairScraper struct {
// contains filtered or unexported fields
}
KrakenPairScraper implements PairScraper for Kraken
func (*KrakenPairScraper) Close ¶
func (ps *KrakenPairScraper) Close() error
func (*KrakenPairScraper) Error ¶
func (ps *KrakenPairScraper) Error() error
Error returns an error when the channel Channel() is closed and nil otherwise
func (*KrakenPairScraper) Pair ¶
func (ps *KrakenPairScraper) Pair() dia.ExchangePair
Pair returns the pair this scraper is subscribed to
type KrakenScraper ¶
type KrakenScraper struct {
// contains filtered or unexported fields
}
func NewKrakenScraper ¶
func NewKrakenScraper(key string, secret string, exchange dia.Exchange, scrape bool, relDB *models.RelDB) *KrakenScraper
NewKrakenScraper returns a new KrakenScraper initialized with default values. The instance is asynchronously scraping as soon as it is created.
func (*KrakenScraper) Channel ¶
func (ps *KrakenScraper) Channel() chan *dia.Trade
Channel returns a channel that can be used to receive trades/pricing information
func (*KrakenScraper) Close ¶
func (s *KrakenScraper) Close() error
Close closes any existing API connections, as well as channels of PairScrapers from calls to ScrapePair
func (*KrakenScraper) FetchAvailablePairs ¶
func (s *KrakenScraper) FetchAvailablePairs() (pairs []dia.ExchangePair, err error)
FetchAvailablePairs returns a list with all available trade pairs
func (*KrakenScraper) FillSymbolData ¶
func (s *KrakenScraper) FillSymbolData(symbol string) (dia.Asset, error)
func (*KrakenScraper) NormalizePair ¶
func (ps *KrakenScraper) NormalizePair(pair dia.ExchangePair) (dia.ExchangePair, error)
NormalizePair accounts for the par
func (*KrakenScraper) ScrapePair ¶
func (s *KrakenScraper) ScrapePair(pair dia.ExchangePair) (PairScraper, error)
ScrapePair returns a PairScraper that can be used to get trades for a single pair from this APIScraper
func (*KrakenScraper) Update ¶
func (s *KrakenScraper) Update()
type KuCoinPairScraper ¶
type KuCoinPairScraper struct {
// contains filtered or unexported fields
}
KuCoinPairScraper implements PairScraper for kuCoin
func (*KuCoinPairScraper) Close ¶
func (ps *KuCoinPairScraper) Close() error
Close stops listening for trades of the pair associated with s
func (*KuCoinPairScraper) Error ¶
func (ps *KuCoinPairScraper) Error() error
Error returns an error when the channel Channel() is closed and nil otherwise
func (*KuCoinPairScraper) Pair ¶
func (ps *KuCoinPairScraper) Pair() dia.ExchangePair
Pair returns the pair this scraper is subscribed to
type KuCoinScraper ¶
type KuCoinScraper struct {
// contains filtered or unexported fields
}
func NewKuCoinScraper ¶
func (*KuCoinScraper) Channel ¶
func (ps *KuCoinScraper) Channel() chan *dia.Trade
Channel returns a channel that can be used to receive trades
func (*KuCoinScraper) Close ¶
func (s *KuCoinScraper) Close() error
Close closes any existing API connections, as well as channels of PairScrapers from calls to ScrapePair
func (*KuCoinScraper) FetchAvailablePairs ¶
func (s *KuCoinScraper) FetchAvailablePairs() (pairs []dia.ExchangePair, err error)
FetchAvailablePairs returns all traded pairs on kucoin.
func (*KuCoinScraper) FillSymbolData ¶
func (s *KuCoinScraper) FillSymbolData(symbol string) (asset dia.Asset, err error)
FillSymbolData adds the name to the asset underlying @symbol on kucoin.
func (*KuCoinScraper) NormalizePair ¶
func (s *KuCoinScraper) NormalizePair(pair dia.ExchangePair) (dia.ExchangePair, error)
func (*KuCoinScraper) ScrapePair ¶
func (s *KuCoinScraper) ScrapePair(pair dia.ExchangePair) (PairScraper, error)
ScrapePair returns a PairScraper that can be used to get trades for a single pair from this APIScraper
type KuExchangePair ¶
type KuExchangePair struct { Symbol string `json:"symbol"` Name string `json:"name"` BaseCurrency string `json:"baseCurrency"` QuoteCurrency string `json:"quoteCurrency"` FeeCurrency string `json:"feeCurrency"` Market string `json:"market"` BaseMinSize string `json:"baseMinSize"` QuoteMinSize string `json:"quoteMinSize"` BaseMaxSize string `json:"baseMaxSize"` QuoteMaxSize string `json:"quoteMaxSize"` BaseIncrement string `json:"baseIncrement"` QuoteIncrement string `json:"quoteIncrement"` PriceIncrement string `json:"priceIncrement"` PriceLimitRate string `json:"priceLimitRate"` IsMarginEnabled bool `json:"isMarginEnabled"` EnableTrading bool `json:"enableTrading"` }
type KuExchangePairs ¶
type KuExchangePairs []KuExchangePair
type KucoinCurrency ¶
type KucoinMarketMatch ¶
type KucoinMarketMatch struct { Symbol string `json:"symbol"` Sequence string `json:"sequence"` Side string `json:"side"` Size string `json:"size"` Price string `json:"price"` TakerOrderID string `json:"takerOrderId"` Time string `json:"time"` Type string `json:"type"` MakerOrderID string `json:"makerOrderId"` TradeID string `json:"tradeId"` }
type KyberPairScraper ¶
type KyberPairScraper struct {
// contains filtered or unexported fields
}
func (*KyberPairScraper) Close ¶
func (pairScraper *KyberPairScraper) Close() error
func (*KyberPairScraper) Error ¶
func (pairScraper *KyberPairScraper) Error() error
func (*KyberPairScraper) Pair ¶
func (pairScraper *KyberPairScraper) Pair() dia.ExchangePair
type KyberScraper ¶
type KyberScraper struct { WsClient *ethclient.Client RestClient *ethclient.Client // contains filtered or unexported fields }
func NewKyberScraper ¶
func NewKyberScraper(exchange dia.Exchange, scrape bool) *KyberScraper
func (*KyberScraper) Channel ¶
func (scraper *KyberScraper) Channel() chan *dia.Trade
func (*KyberScraper) Close ¶
func (scraper *KyberScraper) Close() error
func (*KyberScraper) FetchAvailablePairs ¶
func (scraper *KyberScraper) FetchAvailablePairs() (pairs []dia.ExchangePair, err error)
func (*KyberScraper) FillSymbolData ¶
func (scraper *KyberScraper) FillSymbolData(symbol string) (dia.Asset, error)
func (*KyberScraper) NormalizePair ¶
func (scraper *KyberScraper) NormalizePair(pair dia.ExchangePair) (dia.ExchangePair, error)
func (*KyberScraper) ScrapePair ¶
func (scraper *KyberScraper) ScrapePair(pair dia.ExchangePair) (PairScraper, error)
type KyberToken ¶
type LBankPairScraper ¶
type LBankPairScraper struct {
// contains filtered or unexported fields
}
LBankPairScraper implements PairScraper for LBank exchange
func (*LBankPairScraper) Close ¶
func (ps *LBankPairScraper) Close() error
Close stops listening for trades of the pair associated with s
func (*LBankPairScraper) Error ¶
func (ps *LBankPairScraper) Error() error
Error returns an error when the channel Channel() is closed and nil otherwise
func (*LBankPairScraper) Pair ¶
func (ps *LBankPairScraper) Pair() dia.ExchangePair
Pair returns the pair this scraper is subscribed to
type LBankScraper ¶
type LBankScraper struct {
// contains filtered or unexported fields
}
func NewLBankScraper ¶
func NewLBankScraper(exchange dia.Exchange, scrape bool) *LBankScraper
NewLBankScraper returns a new LBankScraper for the given pair
func (*LBankScraper) Channel ¶
func (ps *LBankScraper) Channel() chan *dia.Trade
Channel returns a channel that can be used to receive trades
func (*LBankScraper) Close ¶
func (s *LBankScraper) Close() error
Close closes any existing API connections, as well as channels of PairScrapers from calls to ScrapePair
func (*LBankScraper) FetchAvailablePairs ¶
func (s *LBankScraper) FetchAvailablePairs() (pairs []dia.ExchangePair, err error)
FetchAvailablePairs returns a list with all available trade pairs
func (*LBankScraper) FillSymbolData ¶
func (s *LBankScraper) FillSymbolData(symbol string) (dia.Asset, error)
func (*LBankScraper) NormalizePair ¶
func (s *LBankScraper) NormalizePair(pair dia.ExchangePair) (dia.ExchangePair, error)
func (*LBankScraper) ScrapePair ¶
func (s *LBankScraper) ScrapePair(pair dia.ExchangePair) (PairScraper, error)
ScrapePair returns a PairScraper that can be used to get trades for a single pair from this APIScraper
type LiquidChannel ¶
type LiquidChannel struct {
Channel string `json:"channel"`
}
type LiquidProduct ¶
type LiquidProduct struct { ID string `json:"id"` ProductType string `json:"product_type"` Code string `json:"code"` Name interface{} `json:"name"` MarketAsk float64 `json:"market_ask"` MarketBid float64 `json:"market_bid"` Indicator interface{} `json:"indicator"` Currency string `json:"currency"` CurrencyPairCode string `json:"currency_pair_code"` Symbol interface{} `json:"symbol"` BtcMinimumWithdraw interface{} `json:"btc_minimum_withdraw"` FiatMinimumWithdraw interface{} `json:"fiat_minimum_withdraw"` PusherChannel string `json:"pusher_channel"` TakerFee string `json:"taker_fee"` MakerFee string `json:"maker_fee"` LowMarketBid string `json:"low_market_bid"` HighMarketAsk string `json:"high_market_ask"` Volume24H string `json:"volume_24h"` LastPrice24H string `json:"last_price_24h"` LastTradedPrice string `json:"last_traded_price"` LastTradedQuantity string `json:"last_traded_quantity"` AveragePrice string `json:"average_price"` QuotedCurrency string `json:"quoted_currency"` BaseCurrency string `json:"base_currency"` TickSize string `json:"tick_size"` Disabled bool `json:"disabled"` MarginEnabled bool `json:"margin_enabled"` CfdEnabled bool `json:"cfd_enabled"` PerpetualEnabled bool `json:"perpetual_enabled"` LastEventTimestamp string `json:"last_event_timestamp"` Timestamp string `json:"timestamp"` MultiplierUp string `json:"multiplier_up"` MultiplierDown string `json:"multiplier_down"` AverageTimeInterval int `json:"average_time_interval"` ProgressiveTierEligible bool `json:"progressive_tier_eligible"` }
type LiquidProducts ¶
type LiquidProducts []LiquidProduct
type LiquidResponse ¶
type LiquidResponseTrade ¶
type LiquidSubscribe ¶
type LiquidSubscribe struct { Event string `json:"event"` Data LiquidChannel `json:"data"` }
type LoopringKey ¶
type LoopringKey struct {
Key string `json:"key"`
}
type LoopringMarket ¶
type LoopringMarket struct { ResultInfo struct { Code int `json:"code"` Message string `json:"message"` } `json:"resultInfo"` Data []struct { Market string `json:"market"` BaseTokenID int `json:"baseTokenId"` QuoteTokenID int `json:"quoteTokenId"` PrecisionForPrice int `json:"precisionForPrice"` OrderbookAggLevels int `json:"orderbookAggLevels"` Enabled bool `json:"enabled"` } `json:"data"` }
type LoopringPairScraper ¶
type LoopringPairScraper struct {
// contains filtered or unexported fields
}
LoopringPairScraper implements PairScraper for Loopring exchange
func (*LoopringPairScraper) Close ¶
func (ps *LoopringPairScraper) Close() error
Close stops listening for trades of the pair associated with s
func (*LoopringPairScraper) Error ¶
func (ps *LoopringPairScraper) Error() error
Error returns an error when the channel Channel() is closed and nil otherwise
func (*LoopringPairScraper) Pair ¶
func (ps *LoopringPairScraper) Pair() dia.ExchangePair
Pair returns the pair this scraper is subscribed to
type LoopringScraper ¶
type LoopringScraper struct {
// contains filtered or unexported fields
}
func NewLoopringScraper ¶
func NewLoopringScraper(exchange dia.Exchange, scrape bool) *LoopringScraper
NewLoopringScraper returns a new LoopringScraper for the given pair
func (*LoopringScraper) Channel ¶
func (ps *LoopringScraper) Channel() chan *dia.Trade
Channel returns a channel that can be used to receive trades
func (*LoopringScraper) Close ¶
func (s *LoopringScraper) Close() error
Close closes any existing API connections, as well as channels of PairScrapers from calls to ScrapePair
func (*LoopringScraper) FetchAvailablePairs ¶
func (s *LoopringScraper) FetchAvailablePairs() (pairs []dia.ExchangePair, err error)
FetchAvailablePairs returns a list with all available trade pairs
func (*LoopringScraper) FillSymbolData ¶
func (s *LoopringScraper) FillSymbolData(symbol string) (dia.Asset, error)
func (*LoopringScraper) NormalizePair ¶
func (s *LoopringScraper) NormalizePair(pair dia.ExchangePair) (dia.ExchangePair, error)
func (*LoopringScraper) ScrapePair ¶
func (s *LoopringScraper) ScrapePair(pair dia.ExchangePair) (PairScraper, error)
ScrapePair returns a PairScraper that can be used to get trades for a single pair from this APIScraper
type LoopringTopic ¶
type MakerPairResponse ¶
type MakerPairScraper ¶
type MakerPairScraper struct {
// contains filtered or unexported fields
}
func (*MakerPairScraper) Close ¶
func (pairScraper *MakerPairScraper) Close() error
func (*MakerPairScraper) Error ¶
func (pairScraper *MakerPairScraper) Error() error
func (*MakerPairScraper) Pair ¶
func (pairScraper *MakerPairScraper) Pair() dia.ExchangePair
type MakerScraper ¶
type MakerScraper struct {
// contains filtered or unexported fields
}
func NewMakerScraper ¶
func NewMakerScraper(exchange dia.Exchange, scrape bool) *MakerScraper
func (*MakerScraper) Channel ¶
func (scraper *MakerScraper) Channel() chan *dia.Trade
func (*MakerScraper) Close ¶
func (scraper *MakerScraper) Close() error
func (*MakerScraper) FetchAvailablePairs ¶
func (scraper *MakerScraper) FetchAvailablePairs() (pairs []dia.ExchangePair, err error)
func (*MakerScraper) FillSymbolData ¶
func (scraper *MakerScraper) FillSymbolData(symbol string) (dia.Asset, error)
FillSymbolData is not used by DEX scrapers.
func (*MakerScraper) GetNewTrades ¶
func (scraper *MakerScraper) GetNewTrades(pair string, startTradeID string) ([]MakerTrade, error)
func (*MakerScraper) NormalizePair ¶
func (scraper *MakerScraper) NormalizePair(pair dia.ExchangePair) (dia.ExchangePair, error)
func (*MakerScraper) ScrapePair ¶
func (scraper *MakerScraper) ScrapePair(pair dia.ExchangePair) (PairScraper, error)
type MakerTrade ¶
type MakerTradeResponse ¶
type MakerTradeResponse struct { MakerTrades []MakerTrade `json:"data"` Time time.Time `json:"time"` Message string `json:"message"` }
type Message ¶
type Message struct {
Transactions []BitBayTransaction `json:"transactions"`
}
type OKEXMarket ¶
type OKEXMarket struct { Alias string `json:"alias"` BaseCcy string `json:"baseCcy"` Category string `json:"category"` CtMult string `json:"ctMult"` CtType string `json:"ctType"` CtVal string `json:"ctVal"` CtValCcy string `json:"ctValCcy"` ExpTime string `json:"expTime"` InstID string `json:"instId"` InstType string `json:"instType"` Lever string `json:"lever"` ListTime string `json:"listTime"` LotSz string `json:"lotSz"` MinSz string `json:"minSz"` OptType string `json:"optType"` QuoteCcy string `json:"quoteCcy"` SettleCcy string `json:"settleCcy"` State string `json:"state"` Stk string `json:"stk"` TickSz string `json:"tickSz"` Uly string `json:"uly"` }
type OKEXWSResponse ¶
type OKEXWSResponse struct { Arg struct { Channel string `json:"channel"` InstID string `json:"instId"` } `json:"arg"` Data []struct { InstID string `json:"instId"` TradeID string `json:"tradeId"` Px string `json:"px"` Sz string `json:"sz"` Side string `json:"side"` Ts string `json:"ts"` } `json:"data"` }
type OKExPairScraper ¶
type OKExPairScraper struct {
// contains filtered or unexported fields
}
OKExPairScraper implements PairScraper for OKEx exchange
func (*OKExPairScraper) Close ¶
func (ps *OKExPairScraper) Close() error
Close stops listening for trades of the pair associated with s
func (*OKExPairScraper) Error ¶
func (ps *OKExPairScraper) Error() error
Error returns an error when the channel Channel() is closed and nil otherwise
func (*OKExPairScraper) Pair ¶
func (ps *OKExPairScraper) Pair() dia.ExchangePair
Pair returns the pair this scraper is subscribed to
type OKExScraper ¶
type OKExScraper struct {
// contains filtered or unexported fields
}
func NewOKExScraper ¶
func NewOKExScraper(exchange dia.Exchange, scrape bool) *OKExScraper
NewOKExScraper returns a new OKExScraper for the given pair
func (*OKExScraper) Channel ¶
func (s *OKExScraper) Channel() chan *dia.Trade
Channel returns a channel that can be used to receive trades
func (*OKExScraper) Close ¶
func (s *OKExScraper) Close() error
Close closes any existing API connections, as well as channels of PairScrapers from calls to ScrapePair
func (*OKExScraper) FetchAvailablePairs ¶
func (s *OKExScraper) FetchAvailablePairs() (pairs []dia.ExchangePair, err error)
FetchAvailablePairs returns a list with all available trade pairs
func (*OKExScraper) NormalizePair ¶
func (s *OKExScraper) NormalizePair(pair dia.ExchangePair) (dia.ExchangePair, error)
func (*OKExScraper) ScrapePair ¶
func (s *OKExScraper) ScrapePair(pair dia.ExchangePair) (PairScraper, error)
ScrapePair returns a PairScraper that can be used to get trades for a single pair from this APIScraper
type OptionSettlement ¶
type OptionSettlement int
OptionSettlement - is an enum, signalling if the settlement is regular or weekly
const ( RegularOptionSettlement OptionSettlement = iota + 1 WeeklyOptionSettlement )
OptionSettlement enums
type OptionsScraper ¶
type OptionsScraper interface { Scrape(market string) // a self-sustained goroutine that scrapes a single market // ScrapeMarkets() // will scrape the options markets defined during instantiation of the scraper ScraperClose(market string, websocketConnection interface{}) error Authenticate(market string, websocketConnection interface{}) error }
OptionsScraper is an interface for all of the Options Contracts scrapers
type PairScraper ¶
type PairScraper interface { io.Closer // Error returns an error when the channel Channel() is closed // and nil otherwise Error() error // Pair returns the pair this scraper is subscribed to Pair() dia.ExchangePair }
PairScraper receives trades for a single pc.ExchangePair from a single exchange.
type ParsedDeribitResponse ¶
type ParsedDeribitResponse struct { Jsonrpc string `json:"jsonrpc"` Method string `json:"method"` Params ParsedDeribitResponseParams `json:"params"` }
type ParsedDeribitResponseParams ¶
type ParsedDeribitResponseParams struct { Channel string `json:"channel"` Data ParsedDeribitOptionOrderbookEntry `json:"data"` }
type QuoinePairScraper ¶
type QuoinePairScraper struct {
// contains filtered or unexported fields
}
func (*QuoinePairScraper) Close ¶
func (pairScraper *QuoinePairScraper) Close() error
func (*QuoinePairScraper) Error ¶
func (pairScraper *QuoinePairScraper) Error() error
func (*QuoinePairScraper) Pair ¶
func (pairScraper *QuoinePairScraper) Pair() dia.ExchangePair
type QuoineScraper ¶
type QuoineScraper struct {
// contains filtered or unexported fields
}
func NewQuoineScraper ¶
func (*QuoineScraper) Channel ¶
func (pairScraper *QuoineScraper) Channel() chan *dia.Trade
func (*QuoineScraper) Close ¶
func (scraper *QuoineScraper) Close() error
func (*QuoineScraper) FetchAvailablePairs ¶
func (scraper *QuoineScraper) FetchAvailablePairs() (pairs []dia.ExchangePair, err error)
func (*QuoineScraper) FillSymbolData ¶
func (scraper *QuoineScraper) FillSymbolData(symbol string) (dia.Asset, error)
func (*QuoineScraper) NormalizePair ¶
func (s *QuoineScraper) NormalizePair(pair dia.ExchangePair) (dia.ExchangePair, error)
func (*QuoineScraper) ScrapePair ¶
func (scraper *QuoineScraper) ScrapePair(pair dia.ExchangePair) (PairScraper, error)
type ResponseGate ¶
type ResponseGate struct { Method string `json:"method,omitempty"` Params []interface{} `json:"params,omitempty"` Id interface{} `json:"id,omitempty"` }
type ResponseLBank ¶
type ResponseType ¶
type STEXPairScraper ¶
type STEXPairScraper struct {
// contains filtered or unexported fields
}
STEXPairScraper implements PairScraper for STEX
func (*STEXPairScraper) Close ¶
func (ps *STEXPairScraper) Close() error
Close stops listening for trades of the pair associated with s
func (*STEXPairScraper) Error ¶
func (ps *STEXPairScraper) Error() error
Error returns an error when the channel Channel() is closed and nil otherwise
func (*STEXPairScraper) Pair ¶
func (ps *STEXPairScraper) Pair() dia.ExchangePair
Pair returns the pair this scraper is subscribed to
type STEXScraper ¶
type STEXScraper struct {
// contains filtered or unexported fields
}
func NewSTEXScraper ¶
NewSTEXScraper returns a new STEXScraper for the given pair
func (*STEXScraper) Channel ¶
func (ps *STEXScraper) Channel() chan *dia.Trade
Channel returns a channel that can be used to receive trades
func (*STEXScraper) Close ¶
func (s *STEXScraper) Close() error
Close closes any existing API connections, as well as channels of PairScrapers from calls to ScrapePair
func (*STEXScraper) FetchAvailablePairs ¶
func (s *STEXScraper) FetchAvailablePairs() (pairs []dia.ExchangePair, err error)
FetchAvailablePairs returns a list with all available trade pairs
func (*STEXScraper) FillSymbolData ¶
func (s *STEXScraper) FillSymbolData(symbol string) (asset dia.Asset, err error)
FillSymbolData collects all available information on an asset traded on STEX
func (*STEXScraper) GetNewTrades ¶
GetNewTrades fetches new trades from the STEX restAPI dating back until @fromTimestamp
func (*STEXScraper) NormalizePair ¶
func (s *STEXScraper) NormalizePair(pair dia.ExchangePair) (dia.ExchangePair, error)
func (*STEXScraper) ScrapePair ¶
func (s *STEXScraper) ScrapePair(pair dia.ExchangePair) (PairScraper, error)
ScrapePair returns a PairScraper that can be used to get trades for a single pair from this APIScraper
type STEXTickerData ¶
type SimexAsset ¶
type SimexPairScraper ¶
type SimexPairScraper struct {
// contains filtered or unexported fields
}
SimexPairScraper implements PairScraper for Simex
func (*SimexPairScraper) Close ¶
func (ps *SimexPairScraper) Close() error
Close stops listening for trades of the pair associated with s
func (*SimexPairScraper) Error ¶
func (ps *SimexPairScraper) Error() error
Error returns an error when the channel Channel() is closed and nil otherwise
func (*SimexPairScraper) Pair ¶
func (ps *SimexPairScraper) Pair() dia.ExchangePair
Pair returns the pair this scraper is subscribed to
type SimexScraper ¶
type SimexScraper struct {
// contains filtered or unexported fields
}
func NewSimexScraper ¶
func NewSimexScraper(exchange dia.Exchange, scrape bool) *SimexScraper
func (*SimexScraper) Channel ¶
func (ps *SimexScraper) Channel() chan *dia.Trade
Channel returns a channel that can be used to receive trades
func (*SimexScraper) Close ¶
func (s *SimexScraper) Close() error
Close closes any existing API connections, as well as channels of PairScrapers from calls to ScrapePair
func (*SimexScraper) FetchAvailablePairs ¶
func (s *SimexScraper) FetchAvailablePairs() (pairs []dia.ExchangePair, err error)
FetchAvailablePairs returns a list with all available trade pairs
func (*SimexScraper) FetchTickerData ¶
func (s *SimexScraper) FetchTickerData(symbol string) (asset dia.Asset, err error)
func (*SimexScraper) NormalizePair ¶
func (s *SimexScraper) NormalizePair(pair dia.ExchangePair) (dia.ExchangePair, error)
func (*SimexScraper) ScrapePair ¶
func (s *SimexScraper) ScrapePair(pair dia.ExchangePair) (PairScraper, error)
ScrapePair returns a PairScraper that can be used to get trades for a single pair from this APIScraper
type SimexTicker ¶
type SimexTicker struct {
Data []SimexAsset `json:"data"`
}
type StexTradeResponse ¶
type SubscribeGate ¶
type SubscribeLBank ¶
type Trade ¶
type Trade struct { Amount string `json:"amount"` Amount2 float64 `json:"amount2"` BuyOrderID int64 `json:"buy_order_id"` CurrencyPairID int64 `json:"currency_pair_id"` Date string `json:"date"` ID int64 `json:"id"` OrderType string `json:"order_type"` Price string `json:"price"` SellOrderID int64 `json:"sell_order_id"` Socket interface{} `json:"socket"` Timestamp int64 `json:"timestamp"` }
type UniswapPair ¶
type UniswapPair struct { Token0 UniswapToken Token1 UniswapToken ForeignName string Address common.Address }
type UniswapPairScraper ¶
type UniswapPairScraper struct {
// contains filtered or unexported fields
}
UniswapPairScraper implements PairScraper for Uniswap
func (*UniswapPairScraper) Close ¶
func (ps *UniswapPairScraper) Close() error
Close stops listening for trades of the pair associated with s
func (*UniswapPairScraper) Error ¶
func (ps *UniswapPairScraper) Error() error
Error returns an error when the channel Channel() is closed and nil otherwise
func (*UniswapPairScraper) Pair ¶
func (ps *UniswapPairScraper) Pair() dia.ExchangePair
Pair returns the pair this scraper is subscribed to
type UniswapScraper ¶
type UniswapScraper struct { WsClient *ethclient.Client RestClient *ethclient.Client // contains filtered or unexported fields }
func NewUniswapScraper ¶
func NewUniswapScraper(exchange dia.Exchange, scrape bool) *UniswapScraper
NewUniswapScraper returns a new UniswapScraper for the given pair
func (*UniswapScraper) Channel ¶
func (ps *UniswapScraper) Channel() chan *dia.Trade
Channel returns a channel that can be used to receive trades
func (*UniswapScraper) Close ¶
func (s *UniswapScraper) Close() error
Close closes any existing API connections, as well as channels of PairScrapers from calls to ScrapePair
func (*UniswapScraper) FetchAvailablePairs ¶
func (s *UniswapScraper) FetchAvailablePairs() (pairs []dia.ExchangePair, err error)
FetchAvailablePairs returns a list with all available trade pairs as dia.ExchangePair for the pairDiscorvery service
func (*UniswapScraper) FillSymbolData ¶
func (s *UniswapScraper) FillSymbolData(symbol string) (dia.Asset, error)
FillSymbolData is not used by DEX scrapers.
func (*UniswapScraper) GetAllPairs ¶
func (s *UniswapScraper) GetAllPairs() ([]UniswapPair, error)
GetAllPairs is similar to FetchAvailablePairs. But instead of dia.ExchangePairs it returns all pairs as UniswapPairs, i.e. including the pair's address
func (*UniswapScraper) GetDecimals ¶
func (s *UniswapScraper) GetDecimals(tokenAddress common.Address) (decimals uint8, err error)
GetDecimals returns the decimals of the token with address @tokenAddress
func (*UniswapScraper) GetName ¶
func (s *UniswapScraper) GetName(tokenAddress common.Address) (name string, err error)
func (*UniswapScraper) GetPairByAddress ¶
func (s *UniswapScraper) GetPairByAddress(pairAddress common.Address) (pair UniswapPair, err error)
GetPairByAddress returns the UniswapPair with pair address @pairAddress
func (*UniswapScraper) GetPairByID ¶
func (s *UniswapScraper) GetPairByID(num int64) (UniswapPair, error)
GetPairByID returns the UniswapPair with the integer id @num
func (*UniswapScraper) GetSwapsChannel ¶
func (s *UniswapScraper) GetSwapsChannel(pairAddress common.Address) (chan *uniswap.UniswapV2PairSwap, error)
GetSwapsChannel returns a channel for swaps of the pair with address @pairAddress
func (*UniswapScraper) NormalizePair ¶
func (up *UniswapScraper) NormalizePair(pair dia.ExchangePair) (dia.ExchangePair, error)
func (*UniswapScraper) ScrapePair ¶
func (s *UniswapScraper) ScrapePair(pair dia.ExchangePair) (PairScraper, error)
ScrapePair returns a PairScraper that can be used to get trades for a single pair from this APIScraper
type UniswapSwap ¶
type UniswapToken ¶
type WebSocketRequest ¶
type WebSocketRequest struct { Op string `json:"op"` Sequence int `json:"sequence"` Topics []LoopringTopic `json:"topics"` }
type WebSocketResponse ¶
type XMLCubeTime ¶
type XMLEnvelope ¶
type XMLEnvelope struct { XMLName xml.Name `xml:"Envelope"` CubeTime []XMLCubeTime `xml:"Cube>Cube"` }
type XMLHistoricalEnvelope ¶
type XMLObs ¶
type XMLObs struct { XMLName xml.Name `xml:"Obs"` Timestamp XMLObsDimension `xml:"ObsDimension"` Price XMLObsValue `xml:"ObsValue"` }
type XMLObsDimension ¶
type XMLObsValue ¶
type ZBPairScraper ¶
type ZBPairScraper struct {
// contains filtered or unexported fields
}
ZBPairScraper implements PairScraper for ZB
func (*ZBPairScraper) Close ¶
func (ps *ZBPairScraper) Close() error
Close stops listening for trades of the pair associated with s
func (*ZBPairScraper) Error ¶
func (ps *ZBPairScraper) Error() error
Error returns an error when the channel Channel() is closed and nil otherwise
func (*ZBPairScraper) Pair ¶
func (ps *ZBPairScraper) Pair() dia.ExchangePair
Pair returns the pair this scraper is subscribed to
type ZBScraper ¶
type ZBScraper struct {
// contains filtered or unexported fields
}
func NewZBScraper ¶
NewZBScraper returns a new ZBScraper for the given pair
func (*ZBScraper) Close ¶
Close closes any existing API connections, as well as channels of PairScrapers from calls to ScrapePair
func (*ZBScraper) FetchAvailablePairs ¶
func (s *ZBScraper) FetchAvailablePairs() (pairs []dia.ExchangePair, err error)
FetchAvailablePairs returns a list with all available trade pairs
func (*ZBScraper) FillSymbolData ¶
FillSymbolData is not used by DEX scrapers.
func (*ZBScraper) NormalizePair ¶
func (s *ZBScraper) NormalizePair(pair dia.ExchangePair) (dia.ExchangePair, error)
func (*ZBScraper) ScrapePair ¶
func (s *ZBScraper) ScrapePair(pair dia.ExchangePair) (PairScraper, error)
ScrapePair returns a PairScraper that can be used to get trades for a single pair from this APIScraper
type ZBSubscribe ¶
type ZBTradeResponse ¶
type ZeroxPairScraper ¶
type ZeroxPairScraper struct {
// contains filtered or unexported fields
}
func (*ZeroxPairScraper) Close ¶
func (pairScraper *ZeroxPairScraper) Close() error
func (*ZeroxPairScraper) Error ¶
func (pairScraper *ZeroxPairScraper) Error() error
func (*ZeroxPairScraper) Pair ¶
func (pairScraper *ZeroxPairScraper) Pair() dia.ExchangePair
type ZeroxScraper ¶
type ZeroxScraper struct { WsClient *ethclient.Client RestClient *ethclient.Client // contains filtered or unexported fields }
func NewZeroxScraper ¶
func NewZeroxScraper(exchange dia.Exchange, scrape bool) *ZeroxScraper
func (*ZeroxScraper) Channel ¶
func (scraper *ZeroxScraper) Channel() chan *dia.Trade
func (*ZeroxScraper) Close ¶
func (scraper *ZeroxScraper) Close() error
func (*ZeroxScraper) FetchAvailablePairs ¶
func (scraper *ZeroxScraper) FetchAvailablePairs() (pairs []dia.ExchangePair, err error)
func (*ZeroxScraper) FetchTickerData ¶
func (scraper *ZeroxScraper) FetchTickerData(symbol string) (dia.Asset, error)
func (*ZeroxScraper) FillSymbolData ¶
func (scraper *ZeroxScraper) FillSymbolData(symbol string) (dia.Asset, error)
FillSymbolData is not used by DEX scrapers.
func (*ZeroxScraper) NormalizePair ¶
func (s *ZeroxScraper) NormalizePair(pair dia.ExchangePair) (dia.ExchangePair, error)
func (*ZeroxScraper) ScrapePair ¶
func (scraper *ZeroxScraper) ScrapePair(pair dia.ExchangePair) (PairScraper, error)
type ZeroxToken ¶
Source Files ¶
- APIDerivativesScraper.go
- APIFuturesScraper.go
- APIOptionsScraper.go
- APIScraper.go
- BalancerScraper.go
- BancorScraper.go
- BinanceScraper.go
- BitBayScraper.go
- BitfinexScraper.go
- BitmaxScraper.go
- BittrexScraper.go
- CREX24Scraper.go
- CoinBaseScraper.go
- CurvefiScraper.go
- DforceScraper.go
- ECBScraper.go
- FuturesBitflyerScraper.go
- FuturesBitmexScraper.go
- FuturesCoinflexScraper.go
- FuturesDeribitScraper.go
- FuturesFTXScraper.go
- FuturesHuobiScraper.go
- GateIOScraper.go
- GnosisScraper.go
- HitBTCScraper.go
- HuobiScraper.go
- KrakenScraper.go
- KuCoinScraper.go
- KyberScraper.go
- LBankScraper.go
- LoopringScraper.go
- MakerScraper.go
- OKExScraper.go
- OptionsDeribitScraper.go
- QuoineScraper.go
- STEXScraper.go
- SimexScraper.go
- UniswapV2Scraper.go
- ZBScraper.go
- ZeroxScraper.go
- init.go