summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorNick Mathewson <nickm@torproject.org>2006-03-27 05:07:57 +0000
committerNick Mathewson <nickm@torproject.org>2006-03-27 05:07:57 +0000
commit3e8c9a485f280a70122ca8426a77181bce692976 (patch)
tree2e5e52f731d0374a1bcb320b31bb40b6295c0846 /src
parent6f08d121d96be29c2ce2d9ef9df4416141651951 (diff)
downloadtor-3e8c9a485f280a70122ca8426a77181bce692976.tar.gz
tor-3e8c9a485f280a70122ca8426a77181bce692976.zip
Fix for "but need_to_mirror=1" annoyance; is bug 273 fixed?
svn:r6247
Diffstat (limited to 'src')
-rw-r--r--src/or/routerlist.c27
1 files changed, 16 insertions, 11 deletions
diff --git a/src/or/routerlist.c b/src/or/routerlist.c
index faed67b62f..37a36abac2 100644
--- a/src/or/routerlist.c
+++ b/src/or/routerlist.c
@@ -34,6 +34,8 @@ static void update_networkstatus_client_downloads(time_t now);
static int signed_desc_digest_is_recognized(signed_descriptor_t *desc);
static void routerlist_assert_ok(routerlist_t *rl);
static int have_tried_downloading_all_statuses(void);
+static routerstatus_t *networkstatus_find_entry(networkstatus_t *ns,
+ const char *digest);
#define MAX_DESCRIPTORS_PER_ROUTER 5
@@ -1514,6 +1516,17 @@ router_add_to_routerlist(routerinfo_t *router, const char **msg,
}
}
+ /* We no longer need a router with this descriptor digest. */
+ SMARTLIST_FOREACH(networkstatus_list, networkstatus_t *, ns,
+ {
+ routerstatus_t *rs =
+ networkstatus_find_entry(ns, router->cache_info.identity_digest);
+ if (rs && !memcmp(rs->descriptor_digest,
+ router->cache_info.signed_descriptor_digest,
+ DIGEST_LEN))
+ rs->need_to_mirror = 0;
+ });
+
/* If we have a router with this name, and the identity key is the same,
* choose the newer one. If the identity key has changed, and one of the
* routers is named, drop the unnamed ones. (If more than one are named,
@@ -1529,6 +1542,9 @@ router_add_to_routerlist(routerinfo_t *router, const char **msg,
router->nickname);
routerlist_insert_old(routerlist, router);
*msg = "Router descriptor was not new.";
+ /* Only journal this desc if we'll be serving it. */
+ if (!from_cache && get_options()->DirPort)
+ router_append_to_journal(&router->cache_info);
return -1;
} else {
/* Same key, new. */
@@ -3062,7 +3078,6 @@ routers_update_status_from_networkstatus(smartlist_t *routers,
{
trusted_dir_server_t *ds;
local_routerstatus_t *rs;
- routerstatus_t *rs2;
or_options_t *options = get_options();
int authdir = options->AuthoritativeDir;
int namingdir = options->AuthoritativeDir &&
@@ -3098,16 +3113,6 @@ routers_update_status_from_networkstatus(smartlist_t *routers,
rs->n_download_failures = 0;
rs->next_attempt_at = 0;
}
-
- /* Note that we have this descriptor. This may be redundant? */
- SMARTLIST_FOREACH(networkstatus_list, networkstatus_t *, ns,
- {
- rs2 = networkstatus_find_entry(ns, router->cache_info.identity_digest);
- if (rs2 && !memcmp(rs2->descriptor_digest,
- router->cache_info.signed_descriptor_digest,
- DIGEST_LEN))
- rs2->need_to_mirror = 0;
- });
});
}