summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorNick Mathewson <nickm@torproject.org>2016-10-19 17:04:44 -0400
committerNick Mathewson <nickm@torproject.org>2016-10-19 17:04:44 -0400
commit87e4b9259ad76ac12613bf569f45a2110ed0e400 (patch)
tree63c7ee346807d5d67299ff78cb81abe805b7325d
parente12560db763bdf03c0b2e53ba34a5a9b1f621bdd (diff)
parentf0fb55ad30ddcb620943490bf11f591d3b2ba694 (diff)
downloadtor-87e4b9259ad76ac12613bf569f45a2110ed0e400.tar.gz
tor-87e4b9259ad76ac12613bf569f45a2110ed0e400.zip
Merge remote-tracking branch 'arma/bug6769'
-rw-r--r--changes/bug202694
-rw-r--r--changes/bug67695
-rw-r--r--src/or/entrynodes.c21
-rw-r--r--src/or/entrynodes.h1
-rw-r--r--src/or/microdesc.c17
5 files changed, 12 insertions, 36 deletions
diff --git a/changes/bug20269 b/changes/bug20269
new file mode 100644
index 0000000000..5d580bf3cc
--- /dev/null
+++ b/changes/bug20269
@@ -0,0 +1,4 @@
+ o Minor bugfixes:
+ - When clients that use bridges start up with a cached consensus
+ on disk, they were ignoring it and downloading a new one. Now they
+ use the cached one. Fixes bug 20269; bugfix on 0.2.3.12-alpha.
diff --git a/changes/bug6769 b/changes/bug6769
new file mode 100644
index 0000000000..83e3aa8b9e
--- /dev/null
+++ b/changes/bug6769
@@ -0,0 +1,5 @@
+ o Minor bugfixes:
+ - Bridges and relays now use microdescriptors (like clients do)
+ rather than old-style router descriptors. Now bridges will blend in
+ with clients in terms of the circuits they build. Fixes bug 6769;
+ bugfix on 0.2.3.2-alpha.
diff --git a/src/or/entrynodes.c b/src/or/entrynodes.c
index 265b6dcda1..ff02fedbd4 100644
--- a/src/or/entrynodes.c
+++ b/src/or/entrynodes.c
@@ -2521,27 +2521,6 @@ entries_retry_all(const or_options_t *options)
entries_retry_helper(options, 1);
}
-/** Return true if at least one of our bridges runs a Tor version that can
- * provide microdescriptors to us. If not, we'll fall back to asking for
- * full descriptors. */
-int
-any_bridge_supports_microdescriptors(void)
-{
- const node_t *node;
- if (!get_options()->UseBridges || !entry_guards)
- return 0;
- SMARTLIST_FOREACH_BEGIN(entry_guards, entry_guard_t *, e) {
- node = node_get_by_id(e->identity);
- if (node && node->is_running &&
- node_is_bridge(node) && node_is_a_configured_bridge(node)) {
- /* This is one of our current bridges, and we know enough about
- * it to know that it will be able to answer our questions. */
- return 1;
- }
- } SMARTLIST_FOREACH_END(e);
- return 0;
-}
-
/** Release all storage held by the list of entry guards and related
* memory structs. */
void
diff --git a/src/or/entrynodes.h b/src/or/entrynodes.h
index 1021e67d43..c0374ae24a 100644
--- a/src/or/entrynodes.h
+++ b/src/or/entrynodes.h
@@ -143,7 +143,6 @@ int any_bridge_descriptors_known(void);
int entries_known_but_down(const or_options_t *options);
void entries_retry_all(const or_options_t *options);
-int any_bridge_supports_microdescriptors(void);
const smartlist_t *get_socks_args_by_bridge_addrport(const tor_addr_t *addr,
uint16_t port);
diff --git a/src/or/microdesc.c b/src/or/microdesc.c
index a81dc54628..140117f683 100644
--- a/src/or/microdesc.c
+++ b/src/or/microdesc.c
@@ -917,20 +917,9 @@ update_microdescs_from_networkstatus(time_t now)
int
we_use_microdescriptors_for_circuits(const or_options_t *options)
{
- int ret = options->UseMicrodescriptors;
- if (ret == -1) {
- /* UseMicrodescriptors is "auto"; we need to decide: */
- /* If we are configured to use bridges and none of our bridges
- * know what a microdescriptor is, the answer is no. */
- if (options->UseBridges && !any_bridge_supports_microdescriptors())
- return 0;
- /* Otherwise, we decide that we'll use microdescriptors iff we are
- * not a server, and we're not autofetching everything. */
- /* XXXX++ what does not being a server have to do with it? also there's
- * a partitioning issue here where bridges differ from clients. */
- ret = !server_mode(options) && !options->FetchUselessDescriptors;
- }
- return ret;
+ if (options->UseMicrodescriptors == 0)
+ return 0; /* the user explicitly picked no */
+ return 1; /* yes and auto both mean yes */
}
/** Return true iff we should try to download microdescriptors at all. */