aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--changes/bug19816
-rw-r--r--src/or/circuitbuild.c7
2 files changed, 12 insertions, 1 deletions
diff --git a/changes/bug1981 b/changes/bug1981
new file mode 100644
index 0000000000..3e5e1d36fb
--- /dev/null
+++ b/changes/bug1981
@@ -0,0 +1,6 @@
+ o Major bugfixes:
+ - When you use bridges and your network goes away and your bridges
+ get marked as down, recover when you attempt a new socks connection
+ (if the network is back) rather than waiting up to an hour to try
+ fetching new descriptors for your bridges. Bugfix on 0.2.0.3-alpha;
+ fixes bug 1981.
diff --git a/src/or/circuitbuild.c b/src/or/circuitbuild.c
index 35d8087b6f..d696fe1b9b 100644
--- a/src/or/circuitbuild.c
+++ b/src/or/circuitbuild.c
@@ -4551,6 +4551,10 @@ learned_bridge_descriptor(routerinfo_t *ri, int from_cache)
add_an_entry_guard(ri, 1);
log_notice(LD_DIR, "new bridge descriptor '%s' (%s)", ri->nickname,
from_cache ? "cached" : "fresh");
+ /* set entry->made_contact so if it goes down we don't drop it from
+ * our entry node list */
+ entry_guard_register_connect_status(ri->cache_info.identity_digest,
+ 1, 0, now);
if (first)
routerlist_retry_directory_downloads(now);
}
@@ -4616,7 +4620,8 @@ bridges_retry_helper(int act)
}
}
});
- log_debug(LD_DIR, "any_known %d, any_running %d", any_known, any_running);
+ log_debug(LD_DIR, "%d: any_known %d, any_running %d",
+ act, any_known, any_running);
return any_known && !any_running;
}