diff options
author | Alexander Færøy <ahf@torproject.org> | 2017-05-11 01:43:37 +0200 |
---|---|---|
committer | Alexander Færøy <ahf@torproject.org> | 2017-05-12 17:18:45 +0200 |
commit | a3a31fa120a62d51e136317df84a7202dfad214d (patch) | |
tree | 6c7987c2ff98c5cd65f182cf5a4af4c301f48db7 /src/or/directory.c | |
parent | 630563719728e039364b1e4cc2ada9017405a383 (diff) | |
download | tor-a3a31fa120a62d51e136317df84a7202dfad214d.tar.gz tor-a3a31fa120a62d51e136317df84a7202dfad214d.zip |
Send "Accept-Encoding" to directory servers.
See: https://bugs.torproject.org/21667
Diffstat (limited to 'src/or/directory.c')
-rw-r--r-- | src/or/directory.c | 30 |
1 files changed, 30 insertions, 0 deletions
diff --git a/src/or/directory.c b/src/or/directory.c index 56d1cca333..ca493888c2 100644 --- a/src/or/directory.c +++ b/src/or/directory.c @@ -1667,6 +1667,7 @@ directory_send_command(dir_connection_t *conn, char decorated_address[128]; smartlist_t *headers = smartlist_new(); char *url; + char *accept_encoding; size_t url_len; char request[8192]; size_t request_len, total_request_len = 0; @@ -1723,6 +1724,12 @@ directory_send_command(dir_connection_t *conn, proxystring[0] = 0; } + /* Add Accept-Encoding. */ + accept_encoding = accept_encoding_header(); + smartlist_add_asprintf(headers, "Accept-Encoding: %s\r\n", + accept_encoding); + tor_free(accept_encoding); + /* Add additional headers, if any */ { config_line_t *h; @@ -3333,6 +3340,29 @@ parse_accept_encoding_header(const char *h) return result; } +/** Return a newly allocated string containing a comma separated list of + * supported encodings. */ +STATIC char * +accept_encoding_header(void) +{ + smartlist_t *methods = smartlist_new(); + char *header = NULL; + compress_method_t method; + + // FIXME(ahf): Should we rename `srv_meth_pref_precompressed` and use this + // instead to define the order in the directory module rather than the order + // defined in the compression module? + for (method = UNKNOWN_METHOD; method > NO_METHOD; --method) { + if (tor_compress_supports_method(method)) + smartlist_add(methods, (char *)compression_method_get_name(method)); + } + + header = smartlist_join_strings(methods, ", ", 0, NULL); + smartlist_free(methods); + + return header; +} + /** Decide whether a client would accept the consensus we have. * * Clients can say they only want a consensus if it's signed by more |