[tor-commits] [snowflake/master] Avoid double delay in client from ReconnectTimeout

cohosh at torproject.org cohosh at torproject.org
Sat Dec 5 20:52:39 UTC 2020


commit 3e8947bfc9af1b299bc202d0252245c03ba20f11
Author: Cecylia Bocovich <cohosh at torproject.org>
Date:   Fri Dec 4 13:41:11 2020 -0500

    Avoid double delay in client from ReconnectTimeout
    
    Run the snowflake collection ReconnectTimeout timer in parallel to the
    negotiation with the broker. This way, if the broker takes a long time
    to respond the client doesn't have to wait the full timeout to respond.
---
 client/lib/snowflake.go | 6 +++---
 1 file changed, 3 insertions(+), 3 deletions(-)

diff --git a/client/lib/snowflake.go b/client/lib/snowflake.go
index 171e173..10a2c0d 100644
--- a/client/lib/snowflake.go
+++ b/client/lib/snowflake.go
@@ -136,13 +136,13 @@ func Handler(socks net.Conn, tongue Tongue) error {
 // transfer to the Tor SOCKS handler when needed.
 func connectLoop(snowflakes SnowflakeCollector) {
 	for {
+		timer := time.After(ReconnectTimeout)
 		_, err := snowflakes.Collect()
 		if err != nil {
-			log.Printf("WebRTC: %v  Retrying in %v...",
-				err, ReconnectTimeout)
+			log.Printf("WebRTC: %v  Retrying...", err)
 		}
 		select {
-		case <-time.After(ReconnectTimeout):
+		case <-timer:
 			continue
 		case <-snowflakes.Melted():
 			log.Println("ConnectLoop: stopped.")



More information about the tor-commits mailing list