[tor-commits] [tor/master] Make relays handle an address suggestion from a directory server giving an IPv6 address.

nickm at torproject.org nickm at torproject.org
Thu Mar 29 14:50:40 UTC 2012


commit 734fad410368951e8f375a78bc8789d24cbe9c52
Author: Linus Nordberg <linus at nordberg.se>
Date:   Tue Mar 27 15:00:34 2012 +0200

    Make relays handle an address suggestion from a directory server giving an IPv6 address.
    
    last_guessed_ip becomes a tor_addr_t.
    
    Most parts of router_new_address_suggestion() learns
    about IPv6 (resolve_my_address() is still IPv4 only).
---
 changes/bug4875      |    3 ++
 src/common/address.h |    2 +
 src/or/config.c      |    1 +
 src/or/router.c      |   57 +++++++++++++++++++++++++++----------------------
 4 files changed, 37 insertions(+), 26 deletions(-)

diff --git a/changes/bug4875 b/changes/bug4875
new file mode 100644
index 0000000..7d19ca3
--- /dev/null
+++ b/changes/bug4875
@@ -0,0 +1,3 @@
+  o Minor bugfixes
+    - Relays now understand an IPv6 address when they get one from a
+      directory server.  Fixes bug 4875.
diff --git a/src/common/address.h b/src/common/address.h
index 4568c32..ede035d 100644
--- a/src/common/address.h
+++ b/src/common/address.h
@@ -38,6 +38,8 @@ typedef struct tor_addr_port_t
   uint16_t port;
 } tor_addr_port_t;
 
+#define TOR_ADDR_NULL {AF_UNSPEC, {{0}}};
+
 static INLINE const struct in6_addr *tor_addr_to_in6(const tor_addr_t *a);
 static INLINE uint32_t tor_addr_to_ipv4n(const tor_addr_t *a);
 static INLINE uint32_t tor_addr_to_ipv4h(const tor_addr_t *a);
diff --git a/src/or/config.c b/src/or/config.c
index 05f53bd..ff9ccc5 100644
--- a/src/or/config.c
+++ b/src/or/config.c
@@ -2802,6 +2802,7 @@ static uint32_t last_resolved_addr = 0;
  * set *<b>hostname_out</b> to a new string holding the hostname we used to
  * get the address. Return 0 if all is well, or -1 if we can't find a suitable
  * public IP address.
+ * XXXX ipv6
  */
 int
 resolve_my_address(int warn_severity, const or_options_t *options,
diff --git a/src/or/router.c b/src/or/router.c
index d86c5f3..cfd5818 100644
--- a/src/or/router.c
+++ b/src/or/router.c
@@ -1775,21 +1775,20 @@ check_descriptor_bandwidth_changed(time_t now)
 /** Note at log level severity that our best guess of address has changed from
  * <b>prev</b> to <b>cur</b>. */
 static void
-log_addr_has_changed(int severity, uint32_t prev, uint32_t cur,
+log_addr_has_changed(int severity,
+                     const tor_addr_t *prev,
+                     const tor_addr_t *cur,
                      const char *source)
 {
-  char addrbuf_prev[INET_NTOA_BUF_LEN];
-  char addrbuf_cur[INET_NTOA_BUF_LEN];
-  struct in_addr in_prev;
-  struct in_addr in_cur;
+  char addrbuf_prev[TOR_ADDR_BUF_LEN];
+  char addrbuf_cur[TOR_ADDR_BUF_LEN];
 
-  in_prev.s_addr = htonl(prev);
-  tor_inet_ntoa(&in_prev, addrbuf_prev, sizeof(addrbuf_prev));
+  if (tor_addr_to_str(addrbuf_prev, prev, sizeof(addrbuf_prev), 1) == NULL)
+    strlcpy(addrbuf_prev, "???", TOR_ADDR_BUF_LEN);
+  if (tor_addr_to_str(addrbuf_cur, cur, sizeof(addrbuf_cur), 1) == NULL)
+    strlcpy(addrbuf_cur, "???", TOR_ADDR_BUF_LEN);
 
-  in_cur.s_addr = htonl(cur);
-  tor_inet_ntoa(&in_cur, addrbuf_cur, sizeof(addrbuf_cur));
-
-  if (prev)
+  if (!tor_addr_is_null(prev))
     log_fn(severity, LD_GENERAL,
            "Our IP Address has changed from %s to %s; "
            "rebuilding descriptor (source: %s).",
@@ -1813,6 +1812,7 @@ check_descriptor_ipaddress_changed(time_t now)
   if (!desc_routerinfo)
     return;
 
+  /* XXXX ipv6 */
   prev = desc_routerinfo->addr;
   if (resolve_my_address(LOG_INFO, options, &cur, NULL) < 0) {
     log_info(LD_CONFIG,"options->Address didn't resolve into an IP.");
@@ -1820,14 +1820,17 @@ check_descriptor_ipaddress_changed(time_t now)
   }
 
   if (prev != cur) {
-    log_addr_has_changed(LOG_NOTICE, prev, cur, "resolve");
+    tor_addr_t tmp_prev, tmp_cur;
+    tor_addr_from_ipv4h(&tmp_prev, prev);
+    tor_addr_from_ipv4h(&tmp_cur, cur);
+    log_addr_has_changed(LOG_NOTICE, &tmp_prev, &tmp_cur, "resolve");
     ip_address_changed(0);
   }
 }
 
 /** The most recently guessed value of our IP address, based on directory
  * headers. */
-static uint32_t last_guessed_ip = 0;
+static tor_addr_t last_guessed_ip = TOR_ADDR_NULL;
 
 /** A directory server <b>d_conn</b> told us our IP address is
  * <b>suggestion</b>.
@@ -1837,35 +1840,36 @@ void
 router_new_address_suggestion(const char *suggestion,
                               const dir_connection_t *d_conn)
 {
-  uint32_t addr, cur = 0;
-  struct in_addr in;
+  tor_addr_t addr;
+  uint32_t cur = 0;             /* Current IPv4 address.  */
   const or_options_t *options = get_options();
 
   /* first, learn what the IP address actually is */
-  if (!tor_inet_aton(suggestion, &in)) {
+  if (tor_addr_parse(&addr, suggestion) == -1) {
     log_debug(LD_DIR, "Malformed X-Your-Address-Is header %s. Ignoring.",
               escaped(suggestion));
     return;
   }
-  addr = ntohl(in.s_addr);
 
   log_debug(LD_DIR, "Got X-Your-Address-Is: %s.", suggestion);
 
   if (!server_mode(options)) {
-    last_guessed_ip = addr; /* store it in case we need it later */
+    tor_addr_copy(&last_guessed_ip, &addr);
     return;
   }
 
+  /* XXXX ipv6 */
   if (resolve_my_address(LOG_INFO, options, &cur, NULL) >= 0) {
     /* We're all set -- we already know our address. Great. */
-    last_guessed_ip = cur; /* store it in case we need it later */
+    tor_addr_from_ipv4h(&last_guessed_ip, cur); /* store it in case we
+                                                   need it later */
     return;
   }
-  if (is_internal_IP(addr, 0)) {
+  if (tor_addr_is_internal(&addr, 0)) {
     /* Don't believe anybody who says our IP is, say, 127.0.0.1. */
     return;
   }
-  if (tor_addr_eq_ipv4h(&d_conn->_base.addr, addr)) {
+  if (tor_addr_eq(&d_conn->_base.addr, &addr)) {
     /* Don't believe anybody who says our IP is their IP. */
     log_debug(LD_DIR, "A directory server told us our IP address is %s, "
               "but he's just reporting his own IP address. Ignoring.",
@@ -1876,14 +1880,15 @@ router_new_address_suggestion(const char *suggestion,
   /* Okay.  We can't resolve our own address, and X-Your-Address-Is is giving
    * us an answer different from what we had the last time we managed to
    * resolve it. */
-  if (last_guessed_ip != addr) {
+  if (!tor_addr_eq(&last_guessed_ip, &addr)) {
     control_event_server_status(LOG_NOTICE,
                                 "EXTERNAL_ADDRESS ADDRESS=%s METHOD=DIRSERV",
                                 suggestion);
-    log_addr_has_changed(LOG_NOTICE, last_guessed_ip, addr,
+    log_addr_has_changed(LOG_NOTICE, &last_guessed_ip, &addr,
                          d_conn->_base.address);
     ip_address_changed(0);
-    last_guessed_ip = addr; /* router_rebuild_descriptor() will fetch it */
+    tor_addr_copy(&last_guessed_ip, &addr); /* router_rebuild_descriptor()
+                                               will fetch it */
   }
 }
 
@@ -1894,8 +1899,8 @@ router_new_address_suggestion(const char *suggestion,
 static int
 router_guess_address_from_dir_headers(uint32_t *guess)
 {
-  if (last_guessed_ip) {
-    *guess = last_guessed_ip;
+  if (!tor_addr_is_null(&last_guessed_ip)) {
+    *guess = tor_addr_to_ipv4h(&last_guessed_ip);
     return 0;
   }
   return -1;





More information about the tor-commits mailing list