Compare commits
3 Commits
Author | SHA1 | Date | |
---|---|---|---|
93abb12cfa | |||
e41fdd3561 | |||
896bafe70b |
@ -113,12 +113,21 @@ func (d *Dispatcher) dispatchMessage(msg *message.Message) {
|
|||||||
return
|
return
|
||||||
}
|
}
|
||||||
log.Println("Websocket terminated: reconnecting")
|
log.Println("Websocket terminated: reconnecting")
|
||||||
|
err := d.Disconnect()
|
||||||
|
if err != nil {
|
||||||
|
log.Println(err)
|
||||||
|
}
|
||||||
d.Connect()
|
d.Connect()
|
||||||
|
if err != nil {
|
||||||
|
log.Println(err)
|
||||||
|
}
|
||||||
|
|
||||||
subsList := d.store.GetAll()
|
subsList := d.store.GetAll()
|
||||||
for i := range subsList {
|
for i := range subsList {
|
||||||
sub := subsList[i]
|
sub := subsList[i]
|
||||||
d.Subscribe(sub.Name(), sub.AuthToken())
|
d.Subscribe(sub.Name(), sub.AuthToken())
|
||||||
}
|
}
|
||||||
|
|
||||||
case message.MetaSubscribe:
|
case message.MetaSubscribe:
|
||||||
//handle MetaSubscribe resp
|
//handle MetaSubscribe resp
|
||||||
d.pendingSubsMu.Lock()
|
d.pendingSubsMu.Lock()
|
||||||
|
@ -32,11 +32,18 @@ func NewSubscription(chanel string, unsub Unsubscriber, authToken string, msgCh
|
|||||||
|
|
||||||
func (s *Subscription) OnMessage(onMessage func(channel string, msg message.Data)) error {
|
func (s *Subscription) OnMessage(onMessage func(channel string, msg message.Data)) error {
|
||||||
var inMsg *message.Message
|
var inMsg *message.Message
|
||||||
|
go s.StartMessageLoop(inMsg, onMessage)
|
||||||
|
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func (s *Subscription) StartMessageLoop(inMsg *message.Message, callback func(channel string, msg message.Data)) error {
|
||||||
for inMsg = range s.msgCh {
|
for inMsg = range s.msgCh {
|
||||||
if inMsg.GetError() != nil {
|
if inMsg.GetError() != nil {
|
||||||
|
|
||||||
return inMsg.GetError()
|
return inMsg.GetError()
|
||||||
}
|
}
|
||||||
onMessage(inMsg.Channel, inMsg.Data)
|
callback(inMsg.Channel, inMsg.Data)
|
||||||
}
|
}
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
@ -46,6 +46,10 @@ func (w *Websocket) Init(endpoint string, options *transport.Options) error {
|
|||||||
|
|
||||||
w.stopCh = make(chan error)
|
w.stopCh = make(chan error)
|
||||||
w.conn, _, err = websocket.DefaultDialer.Dial(endpoint, options.Headers)
|
w.conn, _, err = websocket.DefaultDialer.Dial(endpoint, options.Headers)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
err = w.conn.UnderlyingConn().(*tls.Conn).NetConn().(*net.TCPConn).SetKeepAlive(true)
|
err = w.conn.UnderlyingConn().(*tls.Conn).NetConn().(*net.TCPConn).SetKeepAlive(true)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
@ -138,7 +142,8 @@ func (w *Websocket) Handshake(msg *message.Message) (resp *message.Message, err
|
|||||||
// a connection is established by sending a message to the /meta/connect channel
|
// a connection is established by sending a message to the /meta/connect channel
|
||||||
func (w *Websocket) Connect(msg *message.Message) error {
|
func (w *Websocket) Connect(msg *message.Message) error {
|
||||||
go func() {
|
go func() {
|
||||||
log.Fatal(w.readWorker())
|
err := w.readWorker()
|
||||||
|
log.Fatal(err)
|
||||||
}()
|
}()
|
||||||
return w.SendMessage(msg)
|
return w.SendMessage(msg)
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user