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

[or-cvs] r12055: When we decode to use consensus method 2 or later, compute U (in tor/trunk: . doc src/or)



Author: nickm
Date: 2007-10-19 16:48:46 -0400 (Fri, 19 Oct 2007)
New Revision: 12055

Modified:
   tor/trunk/
   tor/trunk/doc/TODO
   tor/trunk/src/or/dirvote.c
Log:
 r15974@catbus:  nickm | 2007-10-19 16:47:27 -0400
 When we decode to use consensus method 2 or later, compute Unnamed and Named more or less as described in 122.  Don't actually use consensus method 2 yet, so we can be sure we didn't screw up v1..



Property changes on: tor/trunk
___________________________________________________________________
 svk:merge ticket from /tor/trunk [r15974] on 8246c3cf-6607-4228-993b-4d95d33730f1

Modified: tor/trunk/doc/TODO
===================================================================
--- tor/trunk/doc/TODO	2007-10-19 18:56:30 UTC (rev 12054)
+++ tor/trunk/doc/TODO	2007-10-19 20:48:46 UTC (rev 12055)
@@ -100,8 +100,8 @@
         o Don't reject Unnamed routers.
       . Implement consensus side
         o Generic "pick which voting method to use" code.
-        - When version 2 is set, set the Unnamed flag right.
-        - Mention that we support method 2.
+        o When version 2 is set, set the Unnamed flag right.
+        - Mention (and admit to ourself) that we support method 2.
       o Implement client side
 
   - Refactoring:

Modified: tor/trunk/src/or/dirvote.c
===================================================================
--- tor/trunk/src/or/dirvote.c	2007-10-19 18:56:30 UTC (rev 12054)
+++ tor/trunk/src/or/dirvote.c	2007-10-19 20:48:46 UTC (rev 12055)
@@ -516,7 +516,14 @@
                      * is the same flag as votes[j]->known_flags[b]. */
     int *named_flag; /* Index of the flag "Named" for votes[j] */
     int *unnamed_flag; /* Index of the flag "Unnamed" for votes[j] */
+    int chosen_named_idx, chosen_unnamed_idx;
 
+    strmap_t *name_to_id_map = strmap_new();
+    char conflict[DIGEST_LEN];
+    char unknown[DIGEST_LEN];
+    memset(conflict, 0, sizeof(conflict));
+    memset(unknown, 0xff, sizeof(conflict));
+
     index = tor_malloc_zero(sizeof(int)*smartlist_len(votes));
     size = tor_malloc_zero(sizeof(int)*smartlist_len(votes));
     n_voter_flags = tor_malloc_zero(sizeof(int) * smartlist_len(votes));
@@ -526,6 +533,10 @@
     unnamed_flag = tor_malloc_zero(sizeof(int*) * smartlist_len(votes));
     for (i = 0; i < smartlist_len(votes); ++i)
       unnamed_flag[i] = named_flag[i] = -1;
+    chosen_named_idx = smartlist_string_pos(flags, "Named");
+    chosen_unnamed_idx = smartlist_string_pos(flags, "Unnamed");
+
+    /* Build the flag index. */
     SMARTLIST_FOREACH(votes, networkstatus_vote_t *, v,
     {
       flag_map[v_sl_idx] = tor_malloc_zero(
@@ -538,13 +549,65 @@
         ++n_flag_voters[p];
         if (!strcmp(fl, "Named"))
           named_flag[v_sl_idx] = fl_sl_idx;
-        if (!strcmp(fl, "Named"))
+        if (!strcmp(fl, "Unnamed"))
           unnamed_flag[v_sl_idx] = fl_sl_idx;
       });
       n_voter_flags[v_sl_idx] = smartlist_len(v->known_flags);
       size[v_sl_idx] = smartlist_len(v->routerstatus_list);
     });
 
+    /* Named and Unnamed get treated specially */
+    if (consensus_method >= 2) {
+      SMARTLIST_FOREACH(votes, networkstatus_vote_t *, v,
+      {
+        uint64_t nf;
+        if (named_flag[v_sl_idx]<0)
+          continue;
+        nf = U64_LITERAL(1) << named_flag[v_sl_idx];
+        SMARTLIST_FOREACH(v->routerstatus_list, vote_routerstatus_t *, rs,
+        {
+          if ((rs->flags & nf) != 0) {
+            const char *d = strmap_get_lc(name_to_id_map, rs->status.nickname);
+            if (!d) {
+              /* We have no name officially mapped to this digest. */
+              strmap_set_lc(name_to_id_map, rs->status.nickname,
+                            rs->status.identity_digest);
+            } else if (d != conflict &&
+                memcmp(d, rs->status.identity_digest, DIGEST_LEN)) {
+              /* Authorities disagree about this nickname. */
+              strmap_set_lc(name_to_id_map, rs->status.nickname, conflict);
+            } else {
+              /* It's already a conflict, or it's already this ID. */
+            }
+          }
+        });
+      });
+      SMARTLIST_FOREACH(votes, networkstatus_vote_t *, v,
+      {
+        uint64_t uf;
+        if (unnamed_flag[v_sl_idx]<0)
+          continue;
+        uf = U64_LITERAL(1) << unnamed_flag[v_sl_idx];
+        SMARTLIST_FOREACH(v->routerstatus_list, vote_routerstatus_t *, rs,
+        {
+          if ((rs->flags & uf) != 0) {
+            const char *d = strmap_get_lc(name_to_id_map, rs->status.nickname);
+            if (d == conflict || d == unknown) {
+              /* Leave it alone; we know what it is. */
+            } else if (!d) {
+              /* We have no name officially mapped to this digest. */
+              strmap_set_lc(name_to_id_map, rs->status.nickname, unknown);
+            } else if (!memcmp(d, rs->status.identity_digest, DIGEST_LEN)) {
+              /* Authorities disagree about this nickname. */
+              strmap_set_lc(name_to_id_map, rs->status.nickname, conflict);
+            } else {
+              /* It's mapped to a different name. */
+            }
+          }
+        });
+      });
+    }
+
     /* Now go through all the votes */
     flag_counts = tor_malloc(sizeof(int) * smartlist_len(flags));
     while (1) {
@@ -553,6 +616,7 @@
       const char *lowest_id = NULL;
       const char *chosen_version;
       const char *chosen_name = NULL;
+      int is_named = 0, is_unnamed = 0;
       int naming_conflict = 0;
       int n_listing = 0;
       int i;
@@ -605,7 +669,6 @@
           }
           chosen_name = rs->status.nickname;
         }
-
       });
 
       /* We don't include this router at all unless more than half of
@@ -632,16 +695,33 @@
         strlcpy(rs_out.nickname, rs->status.nickname, sizeof(rs_out.nickname));
       }
 
+      if (consensus_method == 1) {
+        is_named = chosen_named_idx >= 0 &&
+          (!naming_conflict && flag_counts[chosen_named_idx]);
+      } else {
+        const char *d = strmap_get_lc(name_to_id_map, rs_out.nickname);
+        if (!d) {
+          is_named = is_unnamed = 0;
+        } else if (!memcmp(d, lowest_id, DIGEST_LEN)) {
+          is_named = 1; is_unnamed = 0;
+        } else {
+          is_named = 0; is_unnamed = 1;
+        }
+      }
+
       /* Set the flags. */
       smartlist_add(chosen_flags, (char*)"s"); /* for the start of the line. */
       SMARTLIST_FOREACH(flags, const char *, fl,
       {
-        if (strcmp(fl, "Named")) {
+        if (!strcmp(fl, "Named")) {
+          if (is_named)
+            smartlist_add(chosen_flags, (char*)fl);
+        } else if (!strcmp(fl, "Unnamed") && consensus_method >= 2) {
+          if (is_unnamed)
+            smartlist_add(chosen_flags, (char*)fl);
+        } else {
           if (flag_counts[fl_sl_idx] > n_flag_voters[fl_sl_idx]/2)
             smartlist_add(chosen_flags, (char*)fl);
-        } else {
-          if (!naming_conflict && flag_counts[fl_sl_idx])
-            smartlist_add(chosen_flags, (char*)"Named");
         }
       });
 
@@ -680,6 +760,7 @@
     tor_free(flag_counts);
     tor_free(named_flag);
     tor_free(unnamed_flag);
+    strmap_free(name_to_id_map, NULL);
     smartlist_free(matching_descs);
     smartlist_free(chosen_flags);
     smartlist_free(versions);