]> git.ipfire.org Git - thirdparty/tor.git/commitdiff
Fix a remaining bug in Robert's bug1859 fix.
authorNick Mathewson <nickm@torproject.org>
Thu, 21 Oct 2010 15:08:15 +0000 (11:08 -0400)
committerNick Mathewson <nickm@torproject.org>
Sat, 13 Nov 2010 00:52:27 +0000 (19:52 -0500)
When intro->extend_info is created for an introduction point, it
only starts out with a nickname, not necessarily an identity digest.
Thus, doing router_get_by_digest isn't necessarily safe.

src/or/rendclient.c

index ca3f213dca363daed850bfe1716f332258d991b2..1f253c10bde9d6b6aa7986c18de8681a45d8c851 100644 (file)
@@ -810,7 +810,10 @@ rend_client_get_random_intro(const rend_data_t *rend_query)
   intro = smartlist_get(entry->parsed->intro_nodes, i);
   /* Do we need to look up the router or is the extend info complete? */
   if (!intro->extend_info->onion_key) {
-    router = router_get_by_digest(intro->extend_info->identity_digest);
+    if (tor_digest_is_zero(intro->extend_info->identity_digest))
+      router = router_get_by_hexdigest(intro->extend_info->nickname);
+    else
+      router = router_get_by_digest(intro->extend_info->identity_digest);
     if (!router) {
       log_info(LD_REND, "Unknown router with nickname '%s'; trying another.",
                intro->extend_info->nickname);