[Author Prev][Author Next][Thread Prev][Thread Next][Author Index][Thread Index]

[or-cvs] r11922: backport r11499, r11500, r11501: hidserv hexdigests rather t (in tor/branches/tor-0_1_2-patches: . doc src/or)



Author: arma
Date: 2007-10-14 03:51:39 -0400 (Sun, 14 Oct 2007)
New Revision: 11922

Modified:
   tor/branches/tor-0_1_2-patches/ChangeLog
   tor/branches/tor-0_1_2-patches/doc/TODO.012
   tor/branches/tor-0_1_2-patches/src/or/rendcommon.c
   tor/branches/tor-0_1_2-patches/src/or/rendservice.c
Log:
backport r11499, r11500, r11501: hidserv hexdigests rather than nicknames


Modified: tor/branches/tor-0_1_2-patches/ChangeLog
===================================================================
--- tor/branches/tor-0_1_2-patches/ChangeLog	2007-10-14 07:47:30 UTC (rev 11921)
+++ tor/branches/tor-0_1_2-patches/ChangeLog	2007-10-14 07:51:39 UTC (rev 11922)
@@ -2,6 +2,13 @@
   o Major bugfixes:
     - Fix possible segfaults in functions called from
       rend_process_relay_cell().
+    - Hidden services were choosing introduction points uniquely by
+      hexdigest, but when constructing the hidden service descriptor
+      they merely wrote the (potentially ambiguous) nickname.
+    - Clients now use the v2 intro format for hidden service
+      connections: they specify their chosen rendezvous point by identity
+      digest rather than by (potentially ambiguous) nickname. These
+      changes could speed up hidden service connections dramatically.
 
   o Minor bugfixes:
     - Don't try to access (or alter) the state file when running

Modified: tor/branches/tor-0_1_2-patches/doc/TODO.012
===================================================================
--- tor/branches/tor-0_1_2-patches/doc/TODO.012	2007-10-14 07:47:30 UTC (rev 11921)
+++ tor/branches/tor-0_1_2-patches/doc/TODO.012	2007-10-14 07:51:39 UTC (rev 11922)
@@ -12,7 +12,7 @@
 P - r10579: new addsysuser implementation for osx (??)
   D r11287: Reject address mappings to internal addresses. (??)
     (this will break some existing test-network configurations, yes?)
-R - r11499, r11500, r11501: hidserv hexdigests rather than nicknames
+  o r11499, r11500, r11501: hidserv hexdigests rather than nicknames
 P - r11548, the osx /tmp fix
 N - r11829: Don't warn when cancel_pending_resolve() finds a cached failure.
 R - r11915: just because you hup, don't publish a near-duplicate descriptor

Modified: tor/branches/tor-0_1_2-patches/src/or/rendcommon.c
===================================================================
--- tor/branches/tor-0_1_2-patches/src/or/rendcommon.c	2007-10-14 07:47:30 UTC (rev 11921)
+++ tor/branches/tor-0_1_2-patches/src/or/rendcommon.c	2007-10-14 07:51:39 UTC (rev 11922)
@@ -146,7 +146,7 @@
     result->protocols = ntohs(get_uint16(cp));
     cp += 2;
   } else {
-    result->protocols = 1;
+    result->protocols = 1<<2; /* always use intro format 2 */
   }
   if (end-cp < 2) goto truncated;
   result->n_intro_points = ntohs(get_uint16(cp));

Modified: tor/branches/tor-0_1_2-patches/src/or/rendservice.c
===================================================================
--- tor/branches/tor-0_1_2-patches/src/or/rendservice.c	2007-10-14 07:47:30 UTC (rev 11921)
+++ tor/branches/tor-0_1_2-patches/src/or/rendservice.c	2007-10-14 07:51:39 UTC (rev 11922)
@@ -303,16 +303,17 @@
   d->intro_point_extend_info = tor_malloc_zero(sizeof(extend_info_t*)*n);
   d->protocols = (1<<2) | (1<<0); /* We support protocol 2 and protocol 0. */
   for (i=0; i < n; ++i) {
-    router = router_get_by_nickname(smartlist_get(service->intro_nodes, i),1);
+    const char *name = smartlist_get(service->intro_nodes, i);
+    router = router_get_by_nickname(name, 1);
     if (!router) {
       log_info(LD_REND,"Router '%s' not found for intro point %d. Skipping.",
-               safe_str((char*)smartlist_get(service->intro_nodes, i)), i);
+               safe_str(name), i);
       continue;
     }
     circ = find_intro_circuit(router, service->pk_digest);
     if (circ && circ->_base.purpose == CIRCUIT_PURPOSE_S_INTRO) {
       /* We have an entirely established intro circuit. */
-      d->intro_points[d->n_intro_points] = tor_strdup(router->nickname);
+      d->intro_points[d->n_intro_points] = tor_strdup(name);
       d->intro_point_extend_info[d->n_intro_points] =
         extend_info_from_router(router);
       d->n_intro_points++;