diff options
author | Roger Dingledine <arma@torproject.org> | 2007-01-26 08:01:29 +0000 |
---|---|---|
committer | Roger Dingledine <arma@torproject.org> | 2007-01-26 08:01:29 +0000 |
commit | 99c177143270544f80d224cc8b85edf351310ff3 (patch) | |
tree | 6e737760a227c1d9cc01c874fd64e6e51a8ca9d3 /src | |
parent | 45e2ea0c2819330ccf8ad3154d98ce58494806dc (diff) | |
download | tor-99c177143270544f80d224cc8b85edf351310ff3.tar.gz tor-99c177143270544f80d224cc8b85edf351310ff3.zip |
never refuse directory requests from local addresses
svn:r9421
Diffstat (limited to 'src')
-rw-r--r-- | src/or/connection.c | 9 | ||||
-rw-r--r-- | src/or/directory.c | 8 | ||||
-rw-r--r-- | src/or/or.h | 2 |
3 files changed, 11 insertions, 8 deletions
diff --git a/src/or/connection.c b/src/or/connection.c index e80633a740..823c5d1a17 100644 --- a/src/or/connection.c +++ b/src/or/connection.c @@ -1175,8 +1175,8 @@ connection_bucket_write_limit(connection_t *conn) } /** Return 1 if the global write bucket is low enough that we shouldn't - * send <b>attempt</b> bytes of low-priority directory stuff out. - * Else return 0. + * send <b>attempt</b> bytes of low-priority directory stuff out to + * <b>conn</b>. Else return 0. * Priority is 1 for v1 requests (directories and running-routers), * and 2 for v2 requests (statuses and descriptors). But see FFFF in @@ -1194,11 +1194,14 @@ connection_bucket_write_limit(connection_t *conn) * that's harder to quantify and harder to keep track of. */ int -global_write_bucket_low(size_t attempt, int priority) +global_write_bucket_low(connection_t *conn, size_t attempt, int priority) { if (authdir_mode(get_options()) && priority>1) return 0; /* there's always room to answer v2 if we're an auth dir */ + if (is_internal_IP(conn->addr, 0)) + return 0; /* local conns don't get limited */ + if (global_write_bucket < (int)attempt) return 1; /* not enough space no matter the priority */ diff --git a/src/or/directory.c b/src/or/directory.c index 1ea605de1a..46855e4591 100644 --- a/src/or/directory.c +++ b/src/or/directory.c @@ -1603,7 +1603,7 @@ directory_handle_command_get(dir_connection_t *conn, char *headers, } dlen = deflated ? d->dir_z_len : d->dir_len; - if (global_write_bucket_low(dlen, 1)) { + if (global_write_bucket_low(TO_CONN(conn), dlen, 1)) { log_info(LD_DIRSERV, "Client asked for the mirrored directory, but we've been " "writing too many bytes lately. Sending 503 Dir busy."); @@ -1645,7 +1645,7 @@ directory_handle_command_get(dir_connection_t *conn, char *headers, tor_free(url); return 0; } - if (global_write_bucket_low(dlen, 1)) { + if (global_write_bucket_low(TO_CONN(conn), dlen, 1)) { log_info(LD_DIRSERV, "Client asked for running-routers, but we've been " "writing too many bytes lately. Sending 503 Dir busy."); @@ -1689,7 +1689,7 @@ directory_handle_command_get(dir_connection_t *conn, char *headers, return 0; } dlen = dirserv_estimate_data_size(dir_fps, 0, deflated); - if (global_write_bucket_low(dlen, 2)) { + if (global_write_bucket_low(TO_CONN(conn), dlen, 2)) { log_info(LD_DIRSERV, "Client asked for network status lists, but we've been " "writing too many bytes lately. Sending 503 Dir busy."); @@ -1758,7 +1758,7 @@ directory_handle_command_get(dir_connection_t *conn, char *headers, else { dlen = dirserv_estimate_data_size(conn->fingerprint_stack, 1, deflated); - if (global_write_bucket_low(dlen, 2)) { + if (global_write_bucket_low(TO_CONN(conn), dlen, 2)) { log_info(LD_DIRSERV, "Client asked for server descriptors, but we've been " "writing too many bytes lately. Sending 503 Dir busy."); diff --git a/src/or/or.h b/src/or/or.h index f53555453d..4e4ba5557b 100644 --- a/src/or/or.h +++ b/src/or/or.h @@ -2042,7 +2042,7 @@ int retry_all_listeners(int force, smartlist_t *replaced_conns, smartlist_t *new_conns); int connection_bucket_write_limit(connection_t *conn); -int global_write_bucket_low(size_t attempt, int priority); +int global_write_bucket_low(connection_t *conn, size_t attempt, int priority); void connection_bucket_init(void); void connection_bucket_refill(int seconds_elapsed); |