]> git.ipfire.org Git - thirdparty/tor.git/commitdiff
Add "a" line to status document.
authorLinus Nordberg <linus@nordberg.se>
Wed, 9 May 2012 17:29:46 +0000 (19:29 +0200)
committerLinus Nordberg <linus@torproject.org>
Thu, 19 Jul 2012 16:21:21 +0000 (18:21 +0200)
src/or/dirserv.c
src/or/or.h

index ad3c45da7b53426032a12be70bc43157a04d15ea..2af4e688c7b542646cdc63a97f20d4842e441b14 100644 (file)
@@ -2088,6 +2088,21 @@ routerstatus_format_entry(char *buf, size_t buf_len,
     return 0;
 
   cp = buf + strlen(buf);
+
+  /* Possible "a" line, not included in consensus for now. */
+  if (!tor_addr_is_null(&rs->ipv6_addr)) {
+    char buf[TOR_ADDR_BUF_LEN];
+    r = tor_snprintf(cp, buf_len - (cp-buf),
+                     "a %s:%d\n",
+                     tor_addr_to_str(buf, &rs->ipv6_addr, sizeof(buf), 1),
+                     (int)rs->ipv6_orport);
+    if (r<0) {
+      log_warn(LD_BUG, "Not enough space in buffer.");
+      return -1;
+    }
+    cp += strlen(cp);
+  }
+
   /* NOTE: Whenever this list expands, be sure to increase MAX_FLAG_LINE_LEN*/
   r = tor_snprintf(cp, buf_len - (cp-buf),
                    "s%s%s%s%s%s%s%s%s%s%s%s%s%s\n",
@@ -2453,6 +2468,8 @@ set_routerstatus_from_routerinfo(routerstatus_t *rs,
   strlcpy(rs->nickname, ri->nickname, sizeof(rs->nickname));
   rs->or_port = ri->or_port;
   rs->dir_port = ri->dir_port;
+  tor_addr_copy(&rs->ipv6_addr, &ri->ipv6_addr);
+  rs->ipv6_orport = ri->ipv6_orport;
 }
 
 /** Routerstatus <b>rs</b> is part of a group of routers that are on
index 0684b9d6fefe6eeba591e128d080a41e47c5c56a..a8ef4d97c824a23d5de40fa5934bb38125223b4a 100644 (file)
@@ -1824,6 +1824,8 @@ typedef struct routerstatus_t {
   uint32_t addr; /**< IPv4 address for this router. */
   uint16_t or_port; /**< OR port for this router. */
   uint16_t dir_port; /**< Directory port for this router. */
+  tor_addr_t ipv6_addr; /**< IPv6 address for this router. */
+  uint16_t ipv6_orport; /**<IPV6 OR port for this router. */
   unsigned int is_authority:1; /**< True iff this router is an authority. */
   unsigned int is_exit:1; /**< True iff this router is a good exit. */
   unsigned int is_stable:1; /**< True iff this router stays up a long time. */