Quellcode durchsuchen

Fix dangling goroutine on session expiration

The timer channel may already have been drained by `case <-timer.C`. In
this case, we need not to drain it again or we'll block forever.

To fix this, stop draining the timer channel. Since we're not going to
use the timer again anyway, it should be fine.
master
Simon Ser vor 4 Jahren
Ursprung
Commit
e6e457e4a7
Es konnte kein GPG-Schlüssel zu dieser Signatur gefunden werden GPG-Schlüssel-ID: FDE7BE0E88F5E48
1 geänderte Dateien mit 1 neuen und 3 gelöschten Zeilen
  1. +1
    -3
      session.go

+ 1
- 3
session.go Datei anzeigen

@@ -237,9 +237,7 @@ func (sm *SessionManager) Put(username, password string) (*Session, error) {
}
}

if !timer.Stop() {
<-timer.C
}
timer.Stop()

s.locker.Lock()
if s.imapConn != nil {


Laden…
Abbrechen
Speichern