summaryrefslogtreecommitdiff
path: root/src/or
diff options
context:
space:
mode:
authorNick Mathewson <nickm@torproject.org>2010-12-03 13:37:13 -0500
committerSebastian Hahn <sebastian@torproject.org>2011-10-26 14:20:47 +0200
commitd0a91386e5b85c5a0db3981a294c7a75192f9c3a (patch)
tree0b2c88be96a51dc066541f5ad73402a3e8e18f6d /src/or
parent3a890b3b70d53ac864be682f50f07ba07b8f09ba (diff)
downloadtor-d0a91386e5b85c5a0db3981a294c7a75192f9c3a.tar.gz
tor-d0a91386e5b85c5a0db3981a294c7a75192f9c3a.zip
Don't crash when accountingmax is set in non-server Tors
We use a hash of the identity key to seed a prng to tell when an accounting period should end. But thanks to the bug998 changes, clients no longer have server-identity keys to use as a long-term seed in accounting calculations. In any case, their identity keys (as used in TLS) were never never fixed. So we can just set the wakeup time from a random seed instead there. Still open is whether everybody should be random. This patch fixes bug 2235, which was introduced in 0.2.2.18-alpha. Diagnosed with help from boboper on irc.
Diffstat (limited to 'src/or')
-rw-r--r--src/or/hibernate.c21
1 files changed, 13 insertions, 8 deletions
diff --git a/src/or/hibernate.c b/src/or/hibernate.c
index 04e06c8164..dfc4edfc82 100644
--- a/src/or/hibernate.c
+++ b/src/or/hibernate.c
@@ -463,14 +463,19 @@ accounting_set_wakeup_time(void)
}
}
- format_iso_time(buf, interval_start_time);
- crypto_pk_get_digest(get_server_identity_key(), digest);
-
- d_env = crypto_new_digest_env();
- crypto_digest_add_bytes(d_env, buf, ISO_TIME_LEN);
- crypto_digest_add_bytes(d_env, digest, DIGEST_LEN);
- crypto_digest_get_digest(d_env, digest, DIGEST_LEN);
- crypto_free_digest_env(d_env);
+ if (server_identity_key_is_set()) {
+ format_iso_time(buf, interval_start_time);
+
+ crypto_pk_get_digest(get_server_identity_key(), digest);
+
+ d_env = crypto_new_digest_env();
+ crypto_digest_add_bytes(d_env, buf, ISO_TIME_LEN);
+ crypto_digest_add_bytes(d_env, digest, DIGEST_LEN);
+ crypto_digest_get_digest(d_env, digest, DIGEST_LEN);
+ crypto_free_digest_env(d_env);
+ } else {
+ crypto_rand(digest, DIGEST_LEN);
+ }
if (!expected_bandwidth_usage) {
char buf1[ISO_TIME_LEN+1];