summaryrefslogtreecommitdiff
path: root/src/or/router.c
diff options
context:
space:
mode:
authorNick Mathewson <nickm@torproject.org>2006-12-15 07:04:37 +0000
committerNick Mathewson <nickm@torproject.org>2006-12-15 07:04:37 +0000
commit38bd6837dba242bc7e86f033a206cd5082930934 (patch)
tree7c71d9efc16aabd0364661e7c4f5dda4a22fa3d7 /src/or/router.c
parent2ae9615a0bcf512933927345d6365790026b60aa (diff)
downloadtor-38bd6837dba242bc7e86f033a206cd5082930934.tar.gz
tor-38bd6837dba242bc7e86f033a206cd5082930934.zip
r11588@Kushana: nickm | 2006-12-15 02:04:32 -0500
Add a LastRotatedOnionKey variable to the state file, so we can rotate onion keys a week after they change even if we never stay up for a whole week at a time. Should fix bug 368. svn:r9120
Diffstat (limited to 'src/or/router.c')
-rw-r--r--src/or/router.c20
1 files changed, 18 insertions, 2 deletions
diff --git a/src/or/router.c b/src/or/router.c
index 22de65786c..eeb00fc1a9 100644
--- a/src/or/router.c
+++ b/src/or/router.c
@@ -35,7 +35,7 @@ static crypto_pk_env_t *identitykey=NULL;
/** Replace the current onion key with <b>k</b>. Does not affect lastonionkey;
* to update onionkey correctly, call rotate_onion_key().
*/
-void
+static void
set_onion_key(crypto_pk_env_t *k)
{
tor_mutex_acquire(key_lock);
@@ -122,6 +122,8 @@ rotate_onion_key(void)
char fname[512];
char fname_prev[512];
crypto_pk_env_t *prkey;
+ or_state_t *state = get_or_state();
+ time_t now;
tor_snprintf(fname,sizeof(fname),
"%s/keys/secret_onion_key",get_options()->DataDirectory);
tor_snprintf(fname_prev,sizeof(fname_prev),
@@ -148,9 +150,11 @@ rotate_onion_key(void)
crypto_free_pk_env(lastonionkey);
lastonionkey = onionkey;
onionkey = prkey;
- onionkey_set_at = time(NULL);
+ now = time(NULL);
+ state->LastRotatedOnionKey = onionkey_set_at = now;
tor_mutex_release(key_lock);
mark_my_descriptor_dirty();
+ or_state_mark_dirty(state, now+600);
return;
error:
log_warn(LD_GENERAL, "Couldn't rotate onion key.");
@@ -247,6 +251,7 @@ init_keys(void)
crypto_pk_env_t *prkey;
char digest[20];
or_options_t *options = get_options();
+ or_state_t *state = get_or_state();
if (!key_lock)
key_lock = tor_mutex_new();
@@ -293,6 +298,17 @@ init_keys(void)
prkey = init_key_from_file_name_changed(keydir,keydir2);
if (!prkey) return -1;
set_onion_key(prkey);
+ if (state->LastRotatedOnionKey > 100) { /* allow for some parsing slop. */
+ onionkey_set_at = state->LastRotatedOnionKey;
+ } else {
+ /* We have no LastRotatedOnionKey set; either we just created the key
+ * or it's a holdover from 0.1.2.4-alpha-dev or earlier. In either case,
+ * start the clock ticking now so that we will eventually rotate it even
+ * if we don't stay up for a full MIN_ONION_KEY_LIFETIME. */
+ state->LastRotatedOnionKey = time(NULL);
+ or_state_mark_dirty(state, time(NULL)+600);
+ }
+
tor_snprintf(keydir,sizeof(keydir),"%s/keys/secret_onion_key.old",datadir);
if (file_status(keydir) == FN_FILE) {
prkey = init_key_from_file(keydir);