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

[or-cvs] auth dir servers were only modifying a server"s is_running ...



Update of /home2/or/cvsroot/tor/src/or
In directory moria:/home/arma/work/onion/cvs/tor/src/or

Modified Files:
	circuitbuild.c connection.c connection_or.c directory.c or.h 
	routerlist.c 
Log Message:
auth dir servers were only modifying a server's is_running field
when they created a network status. so if nobody asked for a
network status, they would never discover that any servers are
is_running, so they could never build a circuit.


Index: circuitbuild.c
===================================================================
RCS file: /home2/or/cvsroot/tor/src/or/circuitbuild.c,v
retrieving revision 1.225
retrieving revision 1.226
diff -u -p -d -r1.225 -r1.226
--- circuitbuild.c	18 Mar 2006 00:22:23 -0000	1.225
+++ circuitbuild.c	18 Mar 2006 01:24:04 -0000	1.226
@@ -1410,19 +1410,20 @@ count_acceptable_routers(smartlist_t *ro
   n = smartlist_len(routers);
   for (i=0;i<n;i++) {
     r = smartlist_get(routers, i);
-//    log_fn(LOG_DEBUG,"Contemplating whether router %d (%s) is a new option.",
-//           i, r->nickname);
+//    log_debug(LD_CIRC,
+//              "Contemplating whether router %d (%s) is a new option.",
+//              i, r->nickname);
     if (r->is_running == 0) {
-//      log_fn(LOG_DEBUG,"Nope, the directory says %d is not running.",i);
+//      log_debug(LD_CIRC,"Nope, the directory says %d is not running.",i);
       goto next_i_loop;
     }
     if (r->is_verified == 0) {
-//      log_fn(LOG_DEBUG,"Nope, the directory says %d is not verified.",i);
+//      log_debug(LD_CIRC,"Nope, the directory says %d is not verified.",i);
       /* XXXX009 But unverified routers *are* sometimes acceptable. */
       goto next_i_loop;
     }
     num++;
-//    log_fn(LOG_DEBUG,"I like %d. num_acceptable_routers now %d.",i, num);
+//    log_debug(LD_CIRC,"I like %d. num_acceptable_routers now %d.",i, num);
     next_i_loop:
       ; /* C requires an explicit statement after the label */
   }

Index: connection.c
===================================================================
RCS file: /home2/or/cvsroot/tor/src/or/connection.c,v
retrieving revision 1.446
retrieving revision 1.447
diff -u -p -d -r1.446 -r1.447
--- connection.c	12 Mar 2006 23:31:16 -0000	1.446
+++ connection.c	18 Mar 2006 01:24:04 -0000	1.447
@@ -348,6 +348,7 @@ connection_about_to_close_connection(con
         if (connection_or_nonopen_was_started_here(conn)) {
           rep_hist_note_connect_failed(conn->identity_digest, time(NULL));
           entry_guard_set_status(conn->identity_digest, 0);
+          router_set_status(conn->identity_digest, 0);
           control_event_or_conn_status(conn, OR_CONN_EVENT_FAILED);
         }
       } else if (conn->hold_open_until_flushed) {
@@ -1425,11 +1426,11 @@ connection_handle_write(connection_t *co
 
         connection_close_immediate(conn);
         connection_mark_for_close(conn);
-        /* it's safe to pass OPs to router_mark_as_down(), since it just
+        /* it's safe to pass OPs to router_set_status(), since it just
          * ignores unrecognized routers
          */
         if (conn->type == CONN_TYPE_OR && !get_options()->HttpsProxy)
-          router_mark_as_down(conn->identity_digest);
+          router_set_status(conn->identity_digest, 0);
         return -1;
       } else {
         return 0; /* no change, see if next time is better */

Index: connection_or.c
===================================================================
RCS file: /home2/or/cvsroot/tor/src/or/connection_or.c,v
retrieving revision 1.215
retrieving revision 1.216
diff -u -p -d -r1.215 -r1.216
--- connection_or.c	12 Mar 2006 23:31:16 -0000	1.215
+++ connection_or.c	18 Mar 2006 01:24:04 -0000	1.216
@@ -462,8 +462,8 @@ connection_or_connect(uint32_t addr, uin
        * an https proxy, our https proxy is down. Don't blame the
        * Tor server. */
       if (!options->HttpsProxy) {
-        router_mark_as_down(conn->identity_digest);
         entry_guard_set_status(conn->identity_digest, 0);
+        router_set_status(conn->identity_digest, 0);
       }
       control_event_or_conn_status(conn, OR_CONN_EVENT_FAILED);
       connection_free(conn);
@@ -637,6 +637,7 @@ connection_or_check_valid_handshake(conn
              "but got %s",
              conn->address, conn->port, expected, seen);
       entry_guard_set_status(conn->identity_digest, 0);
+      router_set_status(conn->identity_digest, 0);
       control_event_or_conn_status(conn, OR_CONN_EVENT_FAILED);
       as_advertised = 0;
     }
@@ -703,6 +704,7 @@ connection_tls_finish_handshake(connecti
       /* pending circs get closed in circuit_about_to_close_connection() */
       return -1;
     }
+    router_set_status(conn->identity_digest, 1);
   }
   connection_watch_events(conn, EV_READ);
   circuit_n_conn_done(conn, 1); /* send the pending creates, if any. */

Index: directory.c
===================================================================
RCS file: /home2/or/cvsroot/tor/src/or/directory.c,v
retrieving revision 1.362
retrieving revision 1.363
diff -u -p -d -r1.362 -r1.363
--- directory.c	12 Mar 2006 22:48:17 -0000	1.362
+++ directory.c	18 Mar 2006 01:24:04 -0000	1.363
@@ -310,7 +310,7 @@ connection_dir_request_failed(connection
 {
   if (router_digest_is_me(conn->identity_digest))
     return; /* this was a test fetch. don't retry. */
-  router_mark_as_down(conn->identity_digest); /* don't try him again */
+  router_set_status(conn->identity_digest, 0); /* don't try him again */
   if (conn->purpose == DIR_PURPOSE_FETCH_DIR ||
       conn->purpose == DIR_PURPOSE_FETCH_RUNNING_LIST) {
     log_info(LD_DIR, "Giving up on directory server at '%s:%d'; retrying",

Index: or.h
===================================================================
RCS file: /home2/or/cvsroot/tor/src/or/or.h,v
retrieving revision 1.808
retrieving revision 1.809
diff -u -p -d -r1.808 -r1.809
--- or.h	17 Mar 2006 22:08:59 -0000	1.808
+++ or.h	18 Mar 2006 01:24:04 -0000	1.809
@@ -2323,7 +2323,7 @@ void routerstatus_free(routerstatus_t *r
 void networkstatus_free(networkstatus_t *networkstatus);
 void routerlist_free_all(void);
 routerinfo_t *routerinfo_copy(const routerinfo_t *router);
-void router_mark_as_down(const char *digest);
+void router_set_status(const char *digest, int up);
 void routerlist_remove_old_routers(void);
 void networkstatus_list_clean(time_t now);
 int router_add_to_routerlist(routerinfo_t *router, const char **msg,

Index: routerlist.c
===================================================================
RCS file: /home2/or/cvsroot/tor/src/or/routerlist.c,v
retrieving revision 1.461
retrieving revision 1.462
diff -u -p -d -r1.461 -r1.462
--- routerlist.c	18 Mar 2006 00:22:23 -0000	1.461
+++ routerlist.c	18 Mar 2006 01:24:04 -0000	1.462
@@ -1409,9 +1409,10 @@ routerlist_reset_warnings(void)
   have_warned_about_new_version = 0;
 }
 
-/** Mark the router with ID <b>digest</b> as non-running in our routerlist. */
+/** Mark the router with ID <b>digest</b> as running or non-running
+ * in our routerlist. */
 void
-router_mark_as_down(const char *digest)
+router_set_status(const char *digest, int up)
 {
   routerinfo_t *router;
   local_routerstatus_t *status;
@@ -1419,19 +1420,20 @@ router_mark_as_down(const char *digest)
 
   SMARTLIST_FOREACH(trusted_dir_servers, trusted_dir_server_t *, d,
                     if (!memcmp(d->digest, digest, DIGEST_LEN))
-                      d->is_running = 0);
+                      d->is_running = up);
 
   router = router_get_by_digest(digest);
   if (router) {
-    log_debug(LD_DIR,"Marking router '%s' as down.",router->nickname);
-    if (router_is_me(router) && !we_are_hibernating())
+    log_debug(LD_DIR,"Marking router '%s' as %s.",
+              router->nickname, up ? "up" : "down");
+    if (!up && router_is_me(router) && !we_are_hibernating())
       log_warn(LD_NET, "We just marked ourself as down. Are your external "
                "addresses reachable?");
-    router->is_running = 0;
+    router->is_running = up;
   }
   status = router_get_combined_status_by_digest(digest);
   if (status) {
-    status->status.is_running = 0;
+    status->status.is_running = up;
   }
 }