forked from thrasher-corp/gocryptotrader
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathroutines.go
81 lines (71 loc) · 1.91 KB
/
routines.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
package main
import (
"log"
"time"
exchange "github.com/thrasher-/gocryptotrader/exchanges"
)
func TickerUpdaterRoutine() {
log.Println("Starting ticker updater routine")
for {
for x := range bot.exchanges {
if bot.exchanges[x].IsEnabled() {
exchangeName := bot.exchanges[x].GetName()
enabledCurrencies := bot.exchanges[x].GetEnabledCurrencies()
for y := range enabledCurrencies {
currency := enabledCurrencies[y]
result, err := bot.exchanges[x].UpdateTicker(currency)
if err != nil {
log.Printf("failed to get %s ticker", currency.Pair().String())
continue
}
log.Printf("%s %s: Last %.8f Ask %.8f Bid %.8f High %.8f Low %.8f Volume %.8f",
exchangeName,
exchange.FormatCurrency(currency).String(),
result.Last,
result.Ask,
result.Bid,
result.High,
result.Low,
result.Volume)
evt := WebsocketEvent{
Data: result,
Event: "ticker_update",
Exchange: exchangeName,
}
BroadcastWebsocketMessage(evt)
}
}
}
time.Sleep(time.Second * 10)
}
}
func OrderbookUpdaterRoutine() {
log.Println("Starting orderbook updater routine")
for {
for x := range bot.exchanges {
if bot.exchanges[x].IsEnabled() {
exchangeName := bot.exchanges[x].GetName()
enabledCurrencies := bot.exchanges[x].GetEnabledCurrencies()
for y := range enabledCurrencies {
currency := enabledCurrencies[y]
result, err := bot.exchanges[x].UpdateOrderbook(currency)
if err != nil {
log.Printf("failed to get %s orderbook", currency.Pair().String())
continue
}
log.Printf("%s %s %v",
exchangeName,
exchange.FormatCurrency(currency).String(),
result)
evt := WebsocketEvent{
Data: result,
Event: "orderbook_update",
Exchange: exchangeName,
}
BroadcastWebsocketMessage(evt)
}
}
}
time.Sleep(time.Second * 10)
}
}