2
0

Merge pull request #28 from p4u/master

add a close channel in order to finish the dial loop
This commit is contained in:
Lucas Löffel
2020-10-19 18:07:08 +02:00
committed by GitHub
+43 -35
View File
@@ -54,6 +54,8 @@ type RecConn struct {
httpResp *http.Response httpResp *http.Response
dialErr error dialErr error
dialer *websocket.Dialer dialer *websocket.Dialer
// if set to true, close stops dial reconnection
close chan (bool)
*websocket.Conn *websocket.Conn
} }
@@ -87,7 +89,7 @@ func (rc *RecConn) Close() {
rc.Conn.Close() rc.Conn.Close()
rc.mu.Unlock() rc.mu.Unlock()
} }
rc.close <- true
rc.setIsConnected(false) rc.setIsConnected(false)
} }
@@ -290,6 +292,7 @@ func (rc *RecConn) Dial(urlStr string, reqHeader http.Header) {
log.Fatalf("Dial: %v", err) log.Fatalf("Dial: %v", err)
} }
rc.close = make(chan bool, 1)
// Config // Config
rc.setURL(urlStr) rc.setURL(urlStr)
rc.setReqHeader(reqHeader) rc.setReqHeader(reqHeader)
@@ -394,43 +397,48 @@ func (rc *RecConn) connect() {
rand.Seed(time.Now().UTC().UnixNano()) rand.Seed(time.Now().UTC().UnixNano())
for { for {
nextItvl := b.Duration() select {
wsConn, httpResp, err := rc.dialer.Dial(rc.url, rc.reqHeader) case <-rc.close:
rc.mu.Lock()
rc.Conn = wsConn
rc.dialErr = err
rc.isConnected = err == nil
rc.httpResp = httpResp
rc.mu.Unlock()
if err == nil {
if !rc.getNonVerbose() {
log.Printf("Dial: connection was successfully established with %s\n", rc.url)
}
if rc.hasSubscribeHandler() {
if err := rc.SubscribeHandler(); err != nil {
log.Fatalf("Dial: connect handler failed with %s", err.Error())
}
if !rc.getNonVerbose() {
log.Printf("Dial: connect handler was successfully established with %s\n", rc.url)
}
}
if rc.getKeepAliveTimeout() != 0 {
rc.keepAlive()
}
return return
} default:
nextItvl := b.Duration()
wsConn, httpResp, err := rc.dialer.Dial(rc.url, rc.reqHeader)
if !rc.getNonVerbose() { rc.mu.Lock()
log.Println(err) rc.Conn = wsConn
log.Println("Dial: will try again in", nextItvl, "seconds.") rc.dialErr = err
} rc.isConnected = err == nil
rc.httpResp = httpResp
rc.mu.Unlock()
time.Sleep(nextItvl) if err == nil {
if !rc.getNonVerbose() {
log.Printf("Dial: connection was successfully established with %s\n", rc.url)
}
if rc.hasSubscribeHandler() {
if err := rc.SubscribeHandler(); err != nil {
log.Fatalf("Dial: connect handler failed with %s", err.Error())
}
if !rc.getNonVerbose() {
log.Printf("Dial: connect handler was successfully established with %s\n", rc.url)
}
}
if rc.getKeepAliveTimeout() != 0 {
rc.keepAlive()
}
return
}
if !rc.getNonVerbose() {
log.Println(err)
log.Println("Dial: will try again in", nextItvl, "seconds.")
}
time.Sleep(nextItvl)
}
} }
} }