summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorNick Mathewson <nickm@torproject.org>2008-04-08 17:06:38 +0000
committerNick Mathewson <nickm@torproject.org>2008-04-08 17:06:38 +0000
commit0c9efd6a1e252c2d6f495d158fdc1ec6877e0f10 (patch)
treeb69733280b66a411dafd60a8ad9a9020e32007d9
parente57264fee816617bffe18eb78a78c76f4591262a (diff)
downloadtor-0c9efd6a1e252c2d6f495d158fdc1ec6877e0f10.tar.gz
tor-0c9efd6a1e252c2d6f495d158fdc1ec6877e0f10.zip
r19231@catbus: nickm | 2008-04-07 12:45:58 -0400
Update last_listed_as_valid_until for new routers based on v2 networkstatus as well as consensus networkstatus. svn:r14317
-rw-r--r--src/or/networkstatus.c22
1 files changed, 21 insertions, 1 deletions
diff --git a/src/or/networkstatus.c b/src/or/networkstatus.c
index 2aa0fb496a..54caf187c3 100644
--- a/src/or/networkstatus.c
+++ b/src/or/networkstatus.c
@@ -1688,6 +1688,8 @@ routers_update_status_from_consensus_networkstatus(smartlist_t *routers,
networkstatus_t *ns = current_consensus;
if (!ns || !smartlist_len(ns->routerstatus_list))
return;
+ if (!networkstatus_v2_list)
+ networkstatus_v2_list = smartlist_create();
routers_sort_by_identity(routers);
@@ -1704,6 +1706,7 @@ routers_update_status_from_consensus_networkstatus(smartlist_t *routers,
router_clear_status_flags(router);
}
}) {
+ /* We have a routersatus for this router. */
const char *digest = router->cache_info.identity_digest;
ds = router_get_trusteddirserver_by_digest(digest);
@@ -1714,7 +1717,7 @@ routers_update_status_from_consensus_networkstatus(smartlist_t *routers,
else
router->is_named = 0;
}
- /*XXXX021 this should always be true! */
+ /* Is it the same descriptor, or only the same identity? */
if (!memcmp(router->cache_info.signed_descriptor_digest,
rs->descriptor_digest, DIGEST_LEN)) {
if (ns->valid_until > router->cache_info.last_listed_as_valid_until)
@@ -1741,6 +1744,23 @@ routers_update_status_from_consensus_networkstatus(smartlist_t *routers,
}
} SMARTLIST_FOREACH_JOIN_END(rs, router);
+ /* Now update last_listed_as_valid_until from v2 networkstatuses. */
+ /* XXXX021 If this is slow, we need to rethink the code. */
+ SMARTLIST_FOREACH(networkstatus_v2_list, networkstatus_v2_t *, ns, {
+ time_t live_until = ns->published_on + V2_NETWORKSTATUS_LIFETIME;
+ SMARTLIST_FOREACH_JOIN(ns->entries, routerstatus_t *, rs,
+ routers, routerinfo_t *, ri,
+ memcmp(rs->identity_digest,
+ ri->cache_info.identity_digest, DIGEST_LEN),
+ STMT_NIL) {
+ if (!memcmp(ri->cache_info.signed_descriptor_digest,
+ rs->descriptor_digest, DIGEST_LEN)) {
+ if (live_until > ri->cache_info.last_listed_as_valid_until)
+ ri->cache_info.last_listed_as_valid_until = live_until;
+ }
+ } SMARTLIST_FOREACH_JOIN_END(rs, ri);
+ });
+
router_dir_info_changed();
}