aboutsummaryrefslogtreecommitdiff
path: root/src/or
diff options
context:
space:
mode:
authorNick Mathewson <nickm@torproject.org>2004-04-05 17:20:57 +0000
committerNick Mathewson <nickm@torproject.org>2004-04-05 17:20:57 +0000
commit1e2b008700e7e2a8e95a3c43a33cb3eef9fab3c6 (patch)
tree49900d85bec8cda18ba390400e95abd4088c2e4f /src/or
parent84b9e90d5f17252e6c919a10482063ffd8c8e41c (diff)
downloadtor-1e2b008700e7e2a8e95a3c43a33cb3eef9fab3c6.tar
tor-1e2b008700e7e2a8e95a3c43a33cb3eef9fab3c6.tar.gz
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.c9
-rw-r--r--src/or/rendservice.c7
2 files changed, 16 insertions, 0 deletions
diff --git a/src/or/rendmid.c b/src/or/rendmid.c
index fd3ee54b0..aea65f47f 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 31f0c8c5d..65e9a5a8c 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) {