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
dialErr error
dialer *websocket.Dialer
// if set to true, close stops dial reconnection
close chan (bool)
*websocket.Conn
}
@@ -87,7 +89,7 @@ func (rc *RecConn) Close() {
rc.Conn.Close()
rc.mu.Unlock()
}
rc.close <- true
rc.setIsConnected(false)
}
@@ -290,6 +292,7 @@ func (rc *RecConn) Dial(urlStr string, reqHeader http.Header) {
log.Fatalf("Dial: %v", err)
}
rc.close = make(chan bool, 1)
// Config
rc.setURL(urlStr)
rc.setReqHeader(reqHeader)
@@ -394,43 +397,48 @@ func (rc *RecConn) connect() {
rand.Seed(time.Now().UTC().UnixNano())
for {
nextItvl := b.Duration()
wsConn, httpResp, err := rc.dialer.Dial(rc.url, rc.reqHeader)
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()
}
select {
case <-rc.close:
return
}
default:
nextItvl := b.Duration()
wsConn, httpResp, err := rc.dialer.Dial(rc.url, rc.reqHeader)
if !rc.getNonVerbose() {
log.Println(err)
log.Println("Dial: will try again in", nextItvl, "seconds.")
}
rc.mu.Lock()
rc.Conn = wsConn
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)
}
}
}