]> git.ipfire.org Git - thirdparty/tor.git/commitdiff
Make direclient_dump_total_dls() respect SafeLogging and pass tests.
authorNick Mathewson <nickm@torproject.org>
Thu, 20 Feb 2020 17:26:32 +0000 (12:26 -0500)
committerNick Mathewson <nickm@torproject.org>
Thu, 20 Feb 2020 17:26:32 +0000 (12:26 -0500)
Don't dump totals with anonymous purposes.  Additionally, don't dump
headers that have nothing underneath them.

src/feature/dirclient/dirclient.c

index 7c7057b102f6e9169b9f13fddefb0c3eb7ca2b52..ecedbddf44a02297b7e22707d068147c8f2fecbe 100644 (file)
@@ -1981,19 +1981,22 @@ static uint64_t total_dl[DIR_PURPOSE_MAX_][2];
 void
 dirclient_dump_total_dls(void)
 {
-  log_notice(LD_NET,
-             "While bootstrapping, fetched this many bytes: ");
-  for (int i=0; i < DIR_PURPOSE_MAX_; ++i) {
-    uint64_t n = total_dl[i][0];
-    if (n) {
-      log_notice(LD_NET, "    %zu (%s)", n, dir_conn_purpose_to_string(i));
-    }
-  }
-  log_notice(LD_NET,
-             "While not bootsrapping, fetched this many bytes: ");
-  for (int i=0; i < DIR_PURPOSE_MAX_; ++i) {
-    uint64_t n = total_dl[i][1];
-    if (n) {
+  const or_options_t *options = get_options();
+  for (int bootstrapped = 0; bootstrapped < 2; ++bootstrapped) {
+    bool first_time = true;
+    for (int i=0; i < DIR_PURPOSE_MAX_; ++i) {
+      uint64_t n = total_dl[i][0];
+      if (n == 0)
+        continue;
+      if (options->SafeLogging_ != SAFELOG_SCRUB_NONE &&
+          purpose_needs_anonymity(i, ROUTER_PURPOSE_GENERAL, NULL))
+        continue;
+      if (first_time) {
+        log_notice(LD_NET,
+                   "While %sbootstrapping, fetched this many bytes: ",
+                   bootstrapped?"not ":"");
+        first_time = false;
+      }
       log_notice(LD_NET, "    %zu (%s)", n, dir_conn_purpose_to_string(i));
     }
   }