aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorNick Mathewson <nickm@torproject.org>2010-10-21 11:08:15 -0400
committerNick Mathewson <nickm@torproject.org>2010-11-12 19:52:27 -0500
commit2392290c1887b732fd2309e57ce04ab71b9b4e69 (patch)
tree8dc9c78acc8bb3ec42c0e4c062338ab8a47b3f31 /src
parent5cd7953a2112d6ae8702c741d73b8b6a2d0c5251 (diff)
downloadtor-2392290c1887b732fd2309e57ce04ab71b9b4e69.tar
tor-2392290c1887b732fd2309e57ce04ab71b9b4e69.tar.gz
Fix a remaining bug in Robert's bug1859 fix.
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.
Diffstat (limited to 'src')
-rw-r--r--src/or/rendclient.c5
1 files changed, 4 insertions, 1 deletions
diff --git a/src/or/rendclient.c b/src/or/rendclient.c
index ca3f213dc..1f253c10b 100644
--- a/src/or/rendclient.c
+++ b/src/or/rendclient.c
@@ -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);