mirror of
https://github.com/d0zingcat/gocryptotrader.git
synced 2026-05-13 23:16:45 +00:00
* SyncManager: Optimise and fixes This is a fairly invasive change which addresses the amount of work the sync manager does each cycle and the cycle intervals. We switch to using discrete locks for each type of work on each pair, so each worker can take a discrete chunk of work safely. For performance and simplicity we now use a map for the currencyPairs. * fix reporting when a websocket is reconnected * fix not switching REST off after websocket available again * fix race condition in isProcessing flag This PR still could go further by avoiding cycling through everything each time, and by pushing some one-time work for adding enabled pairs down to a later stage off the hot path. This was the smallest chunk of refactoring I felt could address everything without changing too much. Significant manual testing done with a variety of Timeouts to test for edgecases and handling. * SyncManager: Fix ticker/orderbook tracker linked * SyncManager: Fix sync complete logging in update * SyncManager: Fix pair format breaking sync key Kraken seems to always switch to XBT_USDT format, but websockets still pass around XBTUSDT format. Just to be safe this just removes the delimiter to avoid any such issues * SyncManager: Remove unused error * SyncManager: Remove unused IsProcessing flag * SyncManager: Fix Update test add() pair format We had to unify pair format inside sync manager, so test needs to do the same
87 lines
3.2 KiB
Go
87 lines
3.2 KiB
Go
package engine
|
|
|
|
import (
|
|
"context"
|
|
"errors"
|
|
|
|
"github.com/thrasher-corp/gocryptotrader/communications/base"
|
|
"github.com/thrasher-corp/gocryptotrader/currency"
|
|
"github.com/thrasher-corp/gocryptotrader/database"
|
|
exchange "github.com/thrasher-corp/gocryptotrader/exchanges"
|
|
"github.com/thrasher-corp/gocryptotrader/exchanges/asset"
|
|
"github.com/thrasher-corp/gocryptotrader/exchanges/order"
|
|
"github.com/thrasher-corp/gocryptotrader/exchanges/orderbook"
|
|
"github.com/thrasher-corp/gocryptotrader/exchanges/ticker"
|
|
"github.com/thrasher-corp/gocryptotrader/portfolio"
|
|
)
|
|
|
|
const (
|
|
// MsgSubSystemStarting message to return when subsystem is starting up
|
|
MsgSubSystemStarting = "starting..."
|
|
// MsgSubSystemStarted message to return when subsystem has started
|
|
MsgSubSystemStarted = "started."
|
|
// MsgSubSystemShuttingDown message to return when a subsystem is shutting down
|
|
MsgSubSystemShuttingDown = "shutting down..."
|
|
// MsgSubSystemShutdown message to return when a subsystem has shutdown
|
|
MsgSubSystemShutdown = "shutdown."
|
|
)
|
|
|
|
var (
|
|
// ErrSubSystemAlreadyStarted message to return when a subsystem is already started
|
|
ErrSubSystemAlreadyStarted = errors.New("subsystem already started")
|
|
// ErrSubSystemNotStarted message to return when subsystem not started
|
|
ErrSubSystemNotStarted = errors.New("subsystem not started")
|
|
// ErrNilSubsystem is returned when a subsystem hasn't had its Setup() func run
|
|
ErrNilSubsystem = errors.New("subsystem not setup")
|
|
errNilWaitGroup = errors.New("nil wait group received")
|
|
errNilExchangeManager = errors.New("cannot start with nil exchange manager")
|
|
errNilDatabaseConnectionManager = errors.New("cannot start with nil database connection manager")
|
|
errNilConfig = errors.New("received nil config")
|
|
)
|
|
|
|
// iExchangeManager limits exposure of accessible functions to exchange manager
|
|
// so that subsystems can use some functionality
|
|
type iExchangeManager interface {
|
|
GetExchanges() ([]exchange.IBotExchange, error)
|
|
GetExchangeByName(string) (exchange.IBotExchange, error)
|
|
}
|
|
|
|
// iCommsManager limits exposure of accessible functions to communication manager
|
|
type iCommsManager interface {
|
|
PushEvent(evt base.Event)
|
|
}
|
|
|
|
// iOrderManager defines a limited scoped order manager
|
|
type iOrderManager interface {
|
|
Exists(*order.Detail) bool
|
|
Add(*order.Detail) error
|
|
Cancel(context.Context, *order.Cancel) error
|
|
GetByExchangeAndID(string, string) (*order.Detail, error)
|
|
UpdateExistingOrder(*order.Detail) error
|
|
}
|
|
|
|
// iPortfolioManager limits exposure of accessible functions to portfolio manager
|
|
type iPortfolioManager interface {
|
|
GetPortfolioSummary() portfolio.Summary
|
|
IsWhiteListed(string) bool
|
|
IsExchangeSupported(string, string) bool
|
|
}
|
|
|
|
// iBot limits exposure of accessible functions to engine bot
|
|
type iBot interface {
|
|
SetupExchanges() error
|
|
}
|
|
|
|
// iCurrencyPairSyncer defines a limited scoped currency pair syncer
|
|
type iCurrencyPairSyncer interface {
|
|
IsRunning() bool
|
|
PrintTickerSummary(*ticker.Price, string, error)
|
|
PrintOrderbookSummary(*orderbook.Base, string, error)
|
|
Update(string, currency.Pair, asset.Item, syncItemType, error) error
|
|
}
|
|
|
|
// iDatabaseConnectionManager defines a limited scoped databaseConnectionManager
|
|
type iDatabaseConnectionManager interface {
|
|
GetInstance() database.IDatabase
|
|
}
|