mirror of
https://github.com/d0zingcat/gocryptotrader.git
synced 2026-05-14 07:26:47 +00:00
* Update URLs for transfer into org repo * Update codecov, travis and othe remaining links * Update appveyor paths
109 lines
3.1 KiB
Go
109 lines
3.1 KiB
Go
package base
|
|
|
|
import (
|
|
"time"
|
|
|
|
"github.com/thrasher-corp/gocryptotrader/config"
|
|
"github.com/thrasher-corp/gocryptotrader/exchanges/orderbook"
|
|
"github.com/thrasher-corp/gocryptotrader/exchanges/ticker"
|
|
log "github.com/thrasher-corp/gocryptotrader/logger"
|
|
)
|
|
|
|
// IComm is the main interface array across the communication packages
|
|
type IComm []ICommunicate
|
|
|
|
// ICommunicate enforces standard functions across communication packages
|
|
type ICommunicate interface {
|
|
Setup(config *config.CommunicationsConfig)
|
|
Connect() error
|
|
PushEvent(Event) error
|
|
IsEnabled() bool
|
|
IsConnected() bool
|
|
GetName() string
|
|
}
|
|
|
|
// Setup sets up communication variables and intiates a connection to the
|
|
// communication mediums
|
|
func (c IComm) Setup() {
|
|
TickerStaged = make(map[string]map[string]map[string]ticker.Price)
|
|
OrderbookStaged = make(map[string]map[string]map[string]Orderbook)
|
|
ServiceStarted = time.Now()
|
|
|
|
for i := range c {
|
|
if c[i].IsEnabled() && !c[i].IsConnected() {
|
|
err := c[i].Connect()
|
|
if err != nil {
|
|
log.Errorf("Communications: %s failed to connect. Err: %s", c[i].GetName(), err)
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
// PushEvent pushes triggered events to all enabled communication links
|
|
func (c IComm) PushEvent(event Event) {
|
|
for i := range c {
|
|
if c[i].IsEnabled() && c[i].IsConnected() {
|
|
err := c[i].PushEvent(event)
|
|
if err != nil {
|
|
log.Errorf("Communications error - PushEvent() in package %s with %v",
|
|
c[i].GetName(), event)
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
// GetEnabledCommunicationMediums prints out enabled and connected communication
|
|
// packages
|
|
// (#debug output only)
|
|
func (c IComm) GetEnabledCommunicationMediums() {
|
|
var count int
|
|
for i := range c {
|
|
if c[i].IsEnabled() && c[i].IsConnected() {
|
|
log.Debugf("Communications: Medium %s is enabled.", c[i].GetName())
|
|
count++
|
|
}
|
|
}
|
|
if count == 0 {
|
|
log.Warnf("Communications: No communication mediums are enabled.")
|
|
}
|
|
}
|
|
|
|
// StageTickerData stages updated ticker data for the communications package
|
|
func (c IComm) StageTickerData(exchangeName, assetType string, tickerPrice *ticker.Price) {
|
|
m.Lock()
|
|
defer m.Unlock()
|
|
|
|
if _, ok := TickerStaged[exchangeName]; !ok {
|
|
TickerStaged[exchangeName] = make(map[string]map[string]ticker.Price)
|
|
}
|
|
|
|
if _, ok := TickerStaged[exchangeName][assetType]; !ok {
|
|
TickerStaged[exchangeName][assetType] = make(map[string]ticker.Price)
|
|
}
|
|
|
|
TickerStaged[exchangeName][assetType][tickerPrice.Pair.String()] = *tickerPrice
|
|
}
|
|
|
|
// StageOrderbookData stages updated orderbook data for the communications
|
|
// package
|
|
func (c IComm) StageOrderbookData(exchangeName, assetType string, ob *orderbook.Base) {
|
|
m.Lock()
|
|
defer m.Unlock()
|
|
|
|
if _, ok := OrderbookStaged[exchangeName]; !ok {
|
|
OrderbookStaged[exchangeName] = make(map[string]map[string]Orderbook)
|
|
}
|
|
|
|
if _, ok := OrderbookStaged[exchangeName][assetType]; !ok {
|
|
OrderbookStaged[exchangeName][assetType] = make(map[string]Orderbook)
|
|
}
|
|
|
|
_, totalAsks := ob.TotalAsksAmount()
|
|
_, totalBids := ob.TotalBidsAmount()
|
|
|
|
OrderbookStaged[exchangeName][assetType][ob.Pair.String()] = Orderbook{
|
|
CurrencyPair: ob.Pair.String(),
|
|
TotalAsks: totalAsks,
|
|
TotalBids: totalBids}
|
|
}
|