package btcc import ( "log" "github.com/thrasher-/gocryptotrader/common" "github.com/thrasher-/gocryptotrader/config" "github.com/thrasher-/gocryptotrader/currency/pair" exchange "github.com/thrasher-/gocryptotrader/exchanges" "github.com/thrasher-/gocryptotrader/exchanges/orderbook" "github.com/thrasher-/gocryptotrader/exchanges/ticker" ) // Start starts the BTCC go routine func (b *BTCC) Start() { go b.Run() } // Run implements the BTCC wrapper func (b *BTCC) Run() { if b.Verbose { log.Printf("%s Websocket: %s.", b.GetName(), common.IsEnabled(b.Websocket)) log.Printf("%s polling delay: %ds.\n", b.GetName(), b.RESTPollingDelay) log.Printf("%s %d currencies enabled: %s.\n", b.GetName(), len(b.EnabledPairs), b.EnabledPairs) } if b.Websocket { go b.WebsocketClient() } if common.DataContains(b.EnabledPairs, "CNY") || common.DataContains(b.AvailablePairs, "CNY") || common.DataContains(b.BaseCurrencies, "CNY") { log.Println("WARNING: BTCC only supports BTCUSD now, upgrading available, enabled and base currencies to BTCUSD/USD") pairs := []string{"BTCUSD"} cfg := config.GetConfig() exchCfg, err := cfg.GetExchangeConfig(b.Name) if err != nil { log.Printf("%s failed to get exchange config. %s\n", b.Name, err) return } exchCfg.BaseCurrencies = "USD" exchCfg.AvailablePairs = pairs[0] exchCfg.EnabledPairs = pairs[0] b.BaseCurrencies = []string{"USD"} err = b.UpdateAvailableCurrencies(pairs, true) if err != nil { log.Printf("%s failed to update available currencies. %s\n", b.Name, err) } err = b.UpdateEnabledCurrencies(pairs, true) if err != nil { log.Printf("%s failed to update enabled currencies. %s\n", b.Name, err) } err = cfg.UpdateExchangeConfig(exchCfg) if err != nil { log.Printf("%s failed to update config. %s\n", b.Name, err) return } } } // UpdateTicker updates and returns the ticker for a currency pair func (b *BTCC) UpdateTicker(p pair.CurrencyPair, assetType string) (ticker.Price, error) { var tickerPrice ticker.Price tick, err := b.GetTicker(exchange.FormatExchangeCurrency(b.GetName(), p).String()) if err != nil { return tickerPrice, err } tickerPrice.Pair = p tickerPrice.Ask = tick.AskPrice tickerPrice.Bid = tick.BidPrice tickerPrice.Low = tick.Low tickerPrice.Last = tick.Last tickerPrice.Volume = tick.Volume24H tickerPrice.High = tick.High ticker.ProcessTicker(b.GetName(), p, tickerPrice, assetType) return ticker.GetTicker(b.Name, p, assetType) } // GetTickerPrice returns the ticker for a currency pair func (b *BTCC) GetTickerPrice(p pair.CurrencyPair, assetType string) (ticker.Price, error) { tickerNew, err := ticker.GetTicker(b.GetName(), p, assetType) if err != nil { return b.UpdateTicker(p, assetType) } return tickerNew, nil } // GetOrderbookEx returns the orderbook for a currency pair func (b *BTCC) GetOrderbookEx(p pair.CurrencyPair, assetType string) (orderbook.Base, error) { ob, err := orderbook.GetOrderbook(b.GetName(), p, assetType) if err != nil { return b.UpdateOrderbook(p, assetType) } return ob, nil } // UpdateOrderbook updates and returns the orderbook for a currency pair func (b *BTCC) UpdateOrderbook(p pair.CurrencyPair, assetType string) (orderbook.Base, error) { var orderBook orderbook.Base orderbookNew, err := b.GetOrderBook(exchange.FormatExchangeCurrency(b.GetName(), p).String(), 100) if err != nil { return orderBook, err } for x := range orderbookNew.Bids { data := orderbookNew.Bids[x] orderBook.Bids = append(orderBook.Bids, orderbook.Item{Price: data[0], Amount: data[1]}) } for x := range orderbookNew.Asks { data := orderbookNew.Asks[x] orderBook.Asks = append(orderBook.Asks, orderbook.Item{Price: data[0], Amount: data[1]}) } orderbook.ProcessOrderbook(b.GetName(), p, orderBook, assetType) return orderbook.GetOrderbook(b.Name, p, assetType) } // GetExchangeAccountInfo : Retrieves balances for all enabled currencies for // the Kraken exchange - TODO func (b *BTCC) GetExchangeAccountInfo() (exchange.AccountInfo, error) { var response exchange.AccountInfo response.ExchangeName = b.GetName() return response, nil }