summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorNick Mathewson <nickm@torproject.org>2005-03-31 23:30:13 +0000
committerNick Mathewson <nickm@torproject.org>2005-03-31 23:30:13 +0000
commite04a82ecaf1641961b64580a8c1694a54606ede4 (patch)
tree18c2b34f574086fa44065b4ee473b03473ab01c5
parent801d5ef1de1d9d2206dcb9a6bc473a5d51187f67 (diff)
downloadtor-e04a82ecaf1641961b64580a8c1694a54606ede4.tar.gz
tor-e04a82ecaf1641961b64580a8c1694a54606ede4.zip
Patch: when extending to an unknown router, compare identity to expected identity; not nickname-to-expected identity.
svn:r3937
-rw-r--r--src/or/connection_or.c13
1 files changed, 12 insertions, 1 deletions
diff --git a/src/or/connection_or.c b/src/or/connection_or.c
index 675e9e89e8..82c93d09d7 100644
--- a/src/or/connection_or.c
+++ b/src/or/connection_or.c
@@ -495,7 +495,18 @@ connection_tls_finish_handshake(connection_t *conn) {
if (connection_or_nonopen_was_started_here(conn)) {
/* I initiated this connection. */
- if (strcasecmp(conn->nickname, nickname)) {
+ if (conn->nickname[0] == '$') {
+ /* I was aiming for a particular digest. Did I get it? */
+ char d[HEX_DIGEST_LEN+1];
+ base16_encode(d, HEX_DIGEST_LEN+1, digest_rcvd, DIGEST_LEN);
+ if (strcasecmp(d,conn->nickname+1)) {
+ log_fn(LOG_WARN, "Identity key not as expected for router at %s:%d: wanted %s but got %s",
+ conn->address, conn->port, conn->nickname, d);
+ control_event_or_conn_status(conn, OR_CONN_EVENT_FAILED);
+ return -1;
+ }
+ } else if (strcasecmp(conn->nickname, nickname)) {
+ /* I was aiming for a nickname. Did I get it? */
log_fn(authdir_mode(options) ? LOG_WARN : LOG_INFO,
"Other side (%s:%d) is '%s', but we tried to connect to '%s'",
conn->address, conn->port, nickname, conn->nickname);