diff options
author | Nick Mathewson <nickm@torproject.org> | 2008-02-10 18:40:23 +0000 |
---|---|---|
committer | Nick Mathewson <nickm@torproject.org> | 2008-02-10 18:40:23 +0000 |
commit | a4db22f675f5bf14f054249aad801981b70ee08b (patch) | |
tree | bee63c67bb81b43344a1e6620ea4566a5d5577af /src | |
parent | 8a7c4e6b62207598c65e5dc5da0120d56a6aa14c (diff) | |
download | tor-a4db22f675f5bf14f054249aad801981b70ee08b.tar.gz tor-a4db22f675f5bf14f054249aad801981b70ee08b.zip |
r14101@tombo: nickm | 2008-02-10 13:24:27 -0500
Merge connection_or_act_on_netinfo into command.c; remove some fields from or_handshake_state().
svn:r13458
Diffstat (limited to 'src')
-rw-r--r-- | src/or/command.c | 48 | ||||
-rw-r--r-- | src/or/connection_or.c | 39 | ||||
-rw-r--r-- | src/or/or.h | 6 |
3 files changed, 31 insertions, 62 deletions
diff --git a/src/or/command.c b/src/or/command.c index 1e3027581c..ce7919ccb5 100644 --- a/src/or/command.c +++ b/src/or/command.c @@ -503,6 +503,9 @@ command_process_netinfo_cell(cell_t *cell, or_connection_t *conn) uint8_t n_other_addrs; time_t now = time(NULL); + long apparent_skew = 0; + uint32_t my_apparent_addr = 0; + if (conn->link_proto < 2) { log_fn(LOG_PROTOCOL_WARN, LD_OR, "Received a NETINFO cell on %s connection; dropping.", @@ -516,15 +519,10 @@ command_process_netinfo_cell(cell_t *cell, or_connection_t *conn) } tor_assert(conn->handshake_state && conn->handshake_state->received_versions); - if (conn->handshake_state->received_netinfo) { - log_fn(LOG_PROTOCOL_WARN, LD_OR, - "Received a duplicate NETINFO cell; dropping."); - return; - } /* Decode the cell. */ timestamp = ntohl(get_uint32(cell->payload)); if (abs(now - conn->handshake_state->sent_versions_at) < 180) { - conn->handshake_state->apparent_skew = now - timestamp; + apparent_skew = now - timestamp; } my_addr_type = (uint8_t) cell->payload[4]; @@ -538,7 +536,7 @@ command_process_netinfo_cell(cell_t *cell, or_connection_t *conn) connection_mark_for_close(TO_CONN(conn)); return; } else if (my_addr_type == RESOLVED_TYPE_IPV4 && my_addr_len == 4) { - conn->handshake_state->my_apparent_addr = ntohl(get_uint32(my_addr_ptr)); + my_apparent_addr = ntohl(get_uint32(my_addr_ptr)); } n_other_addrs = (uint8_t) *cp++; @@ -556,7 +554,7 @@ command_process_netinfo_cell(cell_t *cell, or_connection_t *conn) if (other_addr_type == RESOLVED_TYPE_IPV4 && other_addr_len == 4) { uint32_t addr = ntohl(get_uint32(cp)); if (addr == conn->real_addr) { - conn->handshake_state->apparently_canonical = 1; + conn->is_canonical = 1; break; } } @@ -564,17 +562,33 @@ command_process_netinfo_cell(cell_t *cell, or_connection_t *conn) --n_other_addrs; } - conn->handshake_state->received_netinfo = 1; - - if (conn->handshake_state->apparently_canonical) { - conn->is_canonical = 1; + /* Act on apparent skew. */ + /** Warn when we get a netinfo skew with at least this value. */ +#define NETINFO_NOTICE_SKEW 3600 + if (abs(apparent_skew) > NETINFO_NOTICE_SKEW && + router_get_by_digest(conn->identity_digest)) { + char dbuf[64]; + /*XXXX020 not always warn!*/ + format_time_interval(dbuf, sizeof(dbuf), apparent_skew); + log_fn(LOG_WARN, LD_HTTP, "Received NETINFO cell with skewed time from " + "server at %s:%d. It seems that our clock is %s by %s, or " + "that theirs is %s. Tor requires an accurate clock to work: " + "please check your time and date settings.", + conn->_base.address, (int)conn->_base.port, + apparent_skew>0 ? "ahead" : "behind", dbuf, + apparent_skew>0 ? "behind" : "ahead"); + control_event_general_status(LOG_WARN, + "CLOCK_SKEW SKEW=%ld SOURCE=OR:%s:%d", + apparent_skew, conn->_base.address, conn->_base.port); } - if (connection_or_act_on_netinfo(conn)<0 || - connection_or_set_state_open(conn)<0) - connection_mark_for_close(TO_CONN(conn)); - log_info(LD_OR, "Got good NETINFO cell from %s", - safe_str(conn->_base.address)); + /*XXX020 maybe act on my_apparent_addr */ + + if (connection_or_set_state_open(conn)<0) + connection_mark_for_close(TO_CONN(conn)); + else + log_info(LD_OR, "Got good NETINFO cell from %s", + safe_str(conn->_base.address)); assert_connection_ok(TO_CONN(conn),time(NULL)); } diff --git a/src/or/connection_or.c b/src/or/connection_or.c index 79e7be2c21..2cd7fb6517 100644 --- a/src/or/connection_or.c +++ b/src/or/connection_or.c @@ -1085,42 +1085,3 @@ connection_or_send_netinfo(or_connection_t *conn) return 0; } -/** DOCDOC Called when we're done authenticating; act on stuff we - * learned in netinfo. */ -int -connection_or_act_on_netinfo(or_connection_t *conn) -{ - long delta; - /*XXXX020 merge this into handle_netinfo.*/ - if (!conn->handshake_state) - return -1; - - tor_assert(conn->handshake_state->received_versions != 0); - - delta = conn->handshake_state->apparent_skew; -/** Warn when we get a netinfo skew with at least this value. */ -#define NETINFO_NOTICE_SKEW 3600 - if (abs(delta) > NETINFO_NOTICE_SKEW && - router_get_by_digest(conn->identity_digest)) { - char dbuf[64]; - /*XXXX020 not always warn!*/ - format_time_interval(dbuf, sizeof(dbuf), delta); - log_fn(LOG_WARN, LD_HTTP, "Received NETINFO cell with skewed time from " - "server at %s:%d. It seems that our clock is %s by %s, or " - "that theirs is %s. Tor requires an accurate clock to work: " - "please check your time and date settings.", - conn->_base.address, (int)conn->_base.port, - delta>0 ? "ahead" : "behind", dbuf, - delta>0 ? "behind" : "ahead"); - control_event_general_status(LOG_WARN, - "CLOCK_SKEW SKEW=%ld SOURCE=OR:%s:%d", - delta, conn->_base.address, conn->_base.port); - } - - if (conn->handshake_state->apparently_canonical) - conn->is_canonical = 1; - - /* XXX020 possibly, learn my address from my_apparent_addr */ - return 0; -} - diff --git a/src/or/or.h b/src/or/or.h index 6ee7de45ce..222133addf 100644 --- a/src/or/or.h +++ b/src/or/or.h @@ -893,11 +893,6 @@ typedef struct or_handshake_state_t { unsigned int started_here : 1; unsigned int received_versions : 1; - /* from netinfo: XXXX020 totally useless. */ - unsigned int received_netinfo : 1; - long apparent_skew; - uint32_t my_apparent_addr; - unsigned int apparently_canonical; } or_handshake_state_t; /** Subtype of connection_t for an "OR connection" -- that is, one that speaks @@ -2870,7 +2865,6 @@ void cell_pack(packed_cell_t *dest, const cell_t *src); void var_cell_pack_header(const var_cell_t *cell, char *hdr_out); var_cell_t *var_cell_new(uint16_t payload_len); void var_cell_free(var_cell_t *cell); -int connection_or_act_on_netinfo(or_connection_t *conn); /********************************* control.c ***************************/ |