From a31ba30ae6665ebb3153d1743685e97df3f9c5a5 Mon Sep 17 00:00:00 2001 From: Roger Dingledine Date: Tue, 28 Sep 2004 23:27:41 +0000 Subject: if our local cached directory is new enough, go ahead and start building circuits while we're fetching a new one svn:r2394 --- src/or/dirserv.c | 2 +- src/or/or.h | 3 ++- src/or/routerlist.c | 4 ++++ 3 files changed, 7 insertions(+), 2 deletions(-) diff --git a/src/or/dirserv.c b/src/or/dirserv.c index 55c2b9835b..067554ffd3 100644 --- a/src/or/dirserv.c +++ b/src/or/dirserv.c @@ -182,7 +182,7 @@ dirserv_router_fingerprint_is_known(const routerinfo_t *router) } } -/** If we are an authoritative directory, and the list of approved +/** If we are an authoritative dirserver, and the list of approved * servers contains one whose identity key digest is digest, * return that router's nickname. Otherwise return NULL. */ const char *dirserv_get_nickname_by_digest(const char *digest) diff --git a/src/or/or.h b/src/or/or.h index 23414425dc..eba01b8e61 100644 --- a/src/or/or.h +++ b/src/or/or.h @@ -136,7 +136,8 @@ #endif /** How often do we rotate onion keys? */ -#define MIN_ONION_KEY_LIFETIME (12*60*60) +#define OLD_MIN_ONION_KEY_LIFETIME (12*60*60) /* twice a day */ +#define MIN_ONION_KEY_LIFETIME (7*24*60*60) /* once a week */ /** How often do we rotate TLS contexts? */ #define MAX_SSL_KEY_LIFETIME (120*60) diff --git a/src/or/routerlist.c b/src/or/routerlist.c index 3c4e39ff61..63a72d1ca9 100644 --- a/src/or/routerlist.c +++ b/src/or/routerlist.c @@ -68,6 +68,10 @@ int router_reload_router_list(void) if (router_load_routerlist_from_directory(s, NULL) < 0) { log_fn(LOG_WARN, "Cached directory '%s' was unparseable; ignoring.", filename); } + if(routerlist->published_on > time(NULL) - OLD_MIN_ONION_KEY_LIFETIME/2) { + /* XXX use new onion key lifetime when 0.0.8 servers are obsolete */ + directory_has_arrived(); /* do things we've been waiting to do */ + } tor_free(s); } } -- cgit v1.2.3-54-g00ecf