diff options
author | Nick Mathewson <nickm@torproject.org> | 2004-04-05 17:20:57 +0000 |
---|---|---|
committer | Nick Mathewson <nickm@torproject.org> | 2004-04-05 17:20:57 +0000 |
commit | 1e2b008700e7e2a8e95a3c43a33cb3eef9fab3c6 (patch) | |
tree | 49900d85bec8cda18ba390400e95abd4088c2e4f /src/or | |
parent | 84b9e90d5f17252e6c919a10482063ffd8c8e41c (diff) | |
download | tor-1e2b008700e7e2a8e95a3c43a33cb3eef9fab3c6.tar.gz tor-1e2b008700e7e2a8e95a3c43a33cb3eef9fab3c6.zip |
Add some temporary log calls to try to debug the "Hash of session info was not as expected" problem
svn:r1479
Diffstat (limited to 'src/or')
-rw-r--r-- | src/or/rendmid.c | 9 | ||||
-rw-r--r-- | src/or/rendservice.c | 7 |
2 files changed, 16 insertions, 0 deletions
diff --git a/src/or/rendmid.c b/src/or/rendmid.c index fd3ee54b0a..aea65f47f2 100644 --- a/src/or/rendmid.c +++ b/src/or/rendmid.c @@ -17,6 +17,7 @@ rend_mid_establish_intro(circuit_t *circ, const char *request, int request_len) int asn1len; circuit_t *c; char hexid[9]; + char hexdigest[20*2+1]; log_fn(LOG_INFO, "Received an ESTABLISH_INTRO request on circuit %d", circ->p_circ_id); @@ -39,6 +40,10 @@ rend_mid_establish_intro(circuit_t *circ, const char *request, int request_len) goto err; } + /* XXX remove after debuggin */ + hex_encode(circ->handshake_digest, 20, hexdigest); + log_fn(LOG_INFO, "Handshake information is: %s", hexdigest); + /* Next 20 bytes: Hash of handshake_digest | "INTRODUCE" */ memcpy(buf, circ->handshake_digest, 20); memcpy(buf+20, "INTRODUCE", 9); @@ -46,6 +51,10 @@ rend_mid_establish_intro(circuit_t *circ, const char *request, int request_len) log_fn(LOG_WARN, "Error computing digest"); goto err; } + hex_encode(expected_digest, 20, hexdigest); + log_fn(LOG_INFO, "Expected digest is: %s", hexdigest); + hex_encode(buf+2+asn1len, 20, hexdigest); + log_fn(LOG_INFO, "Received digest is: %s", hexdigest); if (memcmp(expected_digest, buf+2+asn1len, 20)) { log_fn(LOG_WARN, "Hash of session info was not as expected"); goto err; diff --git a/src/or/rendservice.c b/src/or/rendservice.c index 31f0c8c5dc..65e9a5a8c2 100644 --- a/src/or/rendservice.c +++ b/src/or/rendservice.c @@ -458,6 +458,7 @@ rend_service_intro_is_ready(circuit_t *circuit) char buf[RELAY_PAYLOAD_SIZE]; char auth[DIGEST_LEN + 10]; char hexid[9]; + char hexdigest[DIGEST_LEN*2+1]; assert(circuit->purpose == CIRCUIT_PURPOSE_S_ESTABLISH_INTRO); assert(circuit->cpath); @@ -480,9 +481,15 @@ rend_service_intro_is_ready(circuit_t *circuit) set_uint16(buf, len); len += 2; memcpy(auth, circuit->cpath->prev->handshake_digest, DIGEST_LEN); + /* XXXX remove me once we've debugged this; this info should not be logged. + */ + hex_encode(circuit->cpath->prev->handshake_digest, DIGEST_LEN, hexdigest); + log_fn(LOG_INFO,"Handshake information is: %s", hexdigest); memcpy(auth+DIGEST_LEN, "INTRODUCE", 9); if (crypto_digest(auth, DIGEST_LEN+9, buf+len)) goto err; + hex_encode(buf+len, DIGEST_LEN, hexdigest); + log_fn(LOG_INFO,"Authentication is: %s", hexdigest); len += 20; r = crypto_pk_private_sign_digest(service->private_key, buf, len, buf+len); if (r<0) { |