mirror of
https://github.com/d0zingcat/gocryptotrader.git
synced 2026-05-13 23:16:45 +00:00
* First pass at adding new logging system * NewLogger * NewLogger * WIP * silly bug fix * :D removed files * removed old logging interface * added tests * added tests * Started to add new lines to all f calls * Added subsystem log types * Logger improvements * Further performance improvements * changes to logger and sublogger creation * Renamed Logging types * removed old print statement * changes based on feedback * moved sublogger types to own file * :) * added console as output type * added get level command * added get/set log level via grpc command * added check for output being empty for migration support * first pass at log rotation * added log rotation * :D derp fixed * added tests * changes based on feedback * changed log type * comments * renamed file -> fileSettings * typo fix * changes based on feedback * gofmt ran on additional files * gofmt ran on additional files
71 lines
1.6 KiB
Go
71 lines
1.6 KiB
Go
package alphapoint
|
|
|
|
import (
|
|
"net/http"
|
|
|
|
"github.com/gorilla/websocket"
|
|
"github.com/thrasher-/gocryptotrader/common"
|
|
log "github.com/thrasher-/gocryptotrader/logger"
|
|
)
|
|
|
|
const (
|
|
alphapointDefaultWebsocketURL = "wss://sim3.alphapoint.com:8401/v1/GetTicker/"
|
|
)
|
|
|
|
// WebsocketClient starts a new webstocket connection
|
|
func (a *Alphapoint) WebsocketClient() {
|
|
for a.Enabled {
|
|
var Dialer websocket.Dialer
|
|
var err error
|
|
a.WebsocketConn, _, err = Dialer.Dial(a.API.Endpoints.WebsocketURL, http.Header{})
|
|
|
|
if err != nil {
|
|
log.Errorf(log.ExchangeSys, "%s Unable to connect to Websocket. Error: %s\n", a.Name, err)
|
|
continue
|
|
}
|
|
|
|
if a.Verbose {
|
|
log.Debugf(log.ExchangeSys, "%s Connected to Websocket.\n", a.Name)
|
|
}
|
|
|
|
err = a.WebsocketConn.WriteMessage(websocket.TextMessage, []byte(`{"messageType": "logon"}`))
|
|
|
|
if err != nil {
|
|
log.Error(log.ExchangeSys, err)
|
|
return
|
|
}
|
|
|
|
for a.Enabled {
|
|
msgType, resp, err := a.WebsocketConn.ReadMessage()
|
|
if err != nil {
|
|
log.Error(log.ExchangeSys, err)
|
|
break
|
|
}
|
|
|
|
if msgType == websocket.TextMessage {
|
|
type MsgType struct {
|
|
MessageType string `json:"messageType"`
|
|
}
|
|
|
|
msgType := MsgType{}
|
|
err := common.JSONDecode(resp, &msgType)
|
|
if err != nil {
|
|
log.Error(log.ExchangeSys, err)
|
|
continue
|
|
}
|
|
|
|
if msgType.MessageType == "Ticker" {
|
|
ticker := WebsocketTicker{}
|
|
err = common.JSONDecode(resp, &ticker)
|
|
if err != nil {
|
|
log.Error(log.ExchangeSys, err)
|
|
continue
|
|
}
|
|
}
|
|
}
|
|
}
|
|
a.WebsocketConn.Close()
|
|
log.Debugf(log.ExchangeSys, "%s Websocket client disconnected.", a.Name)
|
|
}
|
|
}
|