diff options
author | Nick Mathewson <nickm@torproject.org> | 2019-06-24 13:36:10 -0400 |
---|---|---|
committer | Nick Mathewson <nickm@torproject.org> | 2019-06-24 13:36:10 -0400 |
commit | 8803930de8c5845fdb56614fbec32604ad64bf6d (patch) | |
tree | 6c3bee8f6ecef95f3d58f3b414a35cb926c47942 /src | |
parent | aab5f42ae01cb33ec32ff02f1468bb0360d341e0 (diff) | |
parent | 8356cc5b514a5d6a0170927d7c3730e2e1164298 (diff) | |
download | tor-8803930de8c5845fdb56614fbec32604ad64bf6d.tar.gz tor-8803930de8c5845fdb56614fbec32604ad64bf6d.zip |
Merge remote-tracking branch 'tor-github/pr/1130' into maint-0.4.1
Diffstat (limited to 'src')
-rw-r--r-- | src/feature/relay/router.c | 17 |
1 files changed, 11 insertions, 6 deletions
diff --git a/src/feature/relay/router.c b/src/feature/relay/router.c index e0daf34db2..25bb1835c2 100644 --- a/src/feature/relay/router.c +++ b/src/feature/relay/router.c @@ -3175,6 +3175,15 @@ extrainfo_dump_to_string(char **s_out, extrainfo_t *extrainfo, published); smartlist_add(chunks, pre); + /* Add information about the pluggable transports we support, even if we + * are not publishing statistics. This information is needed by BridgeDB + * to distribute bridges. */ + if (options->ServerTransportPlugin) { + char *pluggable_transports = pt_get_extra_info_descriptor_string(); + if (pluggable_transports) + smartlist_add(chunks, pluggable_transports); + } + if (options->ExtraInfoStatistics && write_stats_to_extrainfo) { log_info(LD_GENERAL, "Adding stats to extra-info descriptor."); /* Bandwidth usage stats don't have their own option */ @@ -3182,6 +3191,7 @@ extrainfo_dump_to_string(char **s_out, extrainfo_t *extrainfo, contents = rep_hist_get_bandwidth_lines(); smartlist_add(chunks, contents); } + /* geoip hashes aren't useful unless we are publishing other stats */ if (geoip_is_loaded(AF_INET)) smartlist_add_asprintf(chunks, "geoip-db-digest %s\n", geoip_db_digest(AF_INET)); @@ -3223,12 +3233,7 @@ extrainfo_dump_to_string(char **s_out, extrainfo_t *extrainfo, if (contents) smartlist_add(chunks, contents); } - /* Add information about the pluggable transports we support. */ - if (options->ServerTransportPlugin) { - char *pluggable_transports = pt_get_extra_info_descriptor_string(); - if (pluggable_transports) - smartlist_add(chunks, pluggable_transports); - } + /* bridge statistics */ if (should_record_bridge_info(options)) { const char *bridge_stats = geoip_get_bridge_stats_extrainfo(now); if (bridge_stats) { |