[tor-commits] [tor/master] Merge branch 'bug17750_029_squashed'
nickm at torproject.org
nickm at torproject.org
Fri Jul 7 17:29:20 UTC 2017
commit 948158df33c4cbfa03f2aa4990097b4e9de664a1
Merge: 8e8abbb 527c073
Author: Nick Mathewson <nickm at torproject.org>
Date: Fri Jul 7 13:28:22 2017 -0400
Merge branch 'bug17750_029_squashed'
changes/bug17750 | 4 ++
src/or/directory.c | 54 +++++++++++++++-----
src/or/directory.h | 22 ++++++--
src/or/or.h | 4 +-
src/test/test_dir.c | 142 ++++++++++++++++++++++++++++++++++++++++++++++------
5 files changed, 195 insertions(+), 31 deletions(-)
diff --cc src/or/directory.c
index 69479ad,fc21078..13daea3
--- a/src/or/directory.c
+++ b/src/or/directory.c
@@@ -13,12 -10,8 +13,11 @@@
#include "config.h"
#include "connection.h"
#include "connection_edge.h"
+#include "conscache.h"
+#include "consdiff.h"
+#include "consdiffmgr.h"
#include "control.h"
-#define DIRECTORY_PRIVATE
+#include "compat.h"
- #define DIRECTORY_PRIVATE
#include "directory.h"
#include "dirserv.h"
#include "dirvote.h"
diff --cc src/or/directory.h
index 14d5ae9,0b54943..3e574cc
--- a/src/or/directory.h
+++ b/src/or/directory.h
@@@ -151,25 -143,14 +158,24 @@@ download_status_mark_impossible(downloa
int download_status_get_n_failures(const download_status_t *dls);
int download_status_get_n_attempts(const download_status_t *dls);
- time_t download_status_get_next_attempt_at(const download_status_t *dls);
-/* Yes, these two functions are confusingly similar.
- * Let's sort that out in #20077. */
-int purpose_needs_anonymity(uint8_t dir_purpose, uint8_t router_purpose);
-int is_sensitive_dir_purpose(uint8_t dir_purpose);
+int purpose_needs_anonymity(uint8_t dir_purpose, uint8_t router_purpose,
+ const char *resource);
+
+#ifdef DIRECTORY_PRIVATE
+
+struct get_handler_args_t;
+STATIC int handle_get_hs_descriptor_v3(dir_connection_t *conn,
+ const struct get_handler_args_t *args);
+STATIC int directory_handle_command(dir_connection_t *conn);
+STATIC char *accept_encoding_header(void);
+STATIC int allowed_anonymous_connection_compression_method(compress_method_t);
+STATIC void warn_disallowed_anonymous_compression_method(compress_method_t);
+
+#endif
#ifdef TOR_UNIT_TESTS
-/* Used only by directory.c and test_dir.c */
+/* Used only by test_dir.c */
STATIC int parse_http_url(const char *headers, char **url);
STATIC dirinfo_type_t dir_fetch_type(int dir_purpose, int router_purpose,
@@@ -192,19 -167,25 +198,29 @@@ STATIC int handle_post_hs_descriptor(co
STATIC char* authdir_type_to_string(dirinfo_type_t auth);
STATIC const char * dir_conn_purpose_to_string(int purpose);
STATIC int should_use_directory_guards(const or_options_t *options);
-STATIC zlib_compression_level_t choose_compression_level(ssize_t n_bytes);
+STATIC compression_level_t choose_compression_level(ssize_t n_bytes);
- STATIC const smartlist_t *find_dl_schedule(download_status_t *dls,
+ STATIC const smartlist_t *find_dl_schedule(const download_status_t *dls,
const or_options_t *options);
STATIC void find_dl_min_and_max_delay(download_status_t *dls,
const or_options_t *options,
int *min, int *max);
STATIC int next_random_exponential_delay(int delay, int max_delay);
+STATIC int parse_hs_version_from_post(const char *url, const char *prefix,
+ const char **end_pos);
+
+STATIC unsigned parse_accept_encoding_header(const char *h);
#endif
+ #if defined(TOR_UNIT_TESTS) || defined(DIRECTORY_PRIVATE)
+ /* Used only by directory.c and test_dir.c */
+
+ /* no more than quadruple the previous delay (multiplier + 1) */
+ #define DIR_DEFAULT_RANDOM_MULTIPLIER (3)
+ /* no more than triple the previous delay */
+ #define DIR_TEST_NET_RANDOM_MULTIPLIER (2)
+
+ #endif
+
#endif
More information about the tor-commits
mailing list