Quellcode durchsuchen

Merge remote-tracking branch 'andrea/bug10616'

Nick Mathewson vor 10 Jahren
Ursprung
Commit
0073c5b517
2 geänderte Dateien mit 19 neuen und 7 gelöschten Zeilen
  1. 4 0
      changes/bug10616
  2. 15 7
      src/or/connection_edge.c

+ 4 - 0
changes/bug10616

@@ -0,0 +1,4 @@
+ o Bugfixes:
+   - Squelch a spurious LD_BUG message "No origin circuit for successful
+     SOCKS stream" in certain hidden service failure cases; fixes bug
+     #10616.

+ 15 - 7
src/or/connection_edge.c

@@ -2295,13 +2295,21 @@ connection_ap_handshake_socks_reply(entry_connection_t *conn, char *reply,
       endreason == END_STREAM_REASON_RESOURCELIMIT) {
     if (!conn->edge_.on_circuit ||
        !CIRCUIT_IS_ORIGIN(conn->edge_.on_circuit)) {
-      // DNS remaps can trigger this. So can failed hidden service
-      // lookups.
-      log_info(LD_BUG,
-               "No origin circuit for successful SOCKS stream "U64_FORMAT
-               ". Reason: %d",
-               U64_PRINTF_ARG(ENTRY_TO_CONN(conn)->global_identifier),
-               endreason);
+      if (endreason != END_STREAM_REASON_RESOLVEFAILED) {
+        log_info(LD_BUG,
+                 "No origin circuit for successful SOCKS stream "U64_FORMAT
+                 ". Reason: %d",
+                 U64_PRINTF_ARG(ENTRY_TO_CONN(conn)->global_identifier),
+                 endreason);
+      }
+      /*
+       * Else DNS remaps and failed hidden service lookups can send us
+       * here with END_STREAM_REASON_RESOLVEFAILED; ignore it
+       *
+       * Perhaps we could make the test more precise; we can tell hidden
+       * services by conn->edge_.renddata != NULL; anything analogous for
+       * the DNS remap case?
+       */
     } else {
       // XXX: Hrmm. It looks like optimistic data can't go through this
       // codepath, but someone should probably test it and make sure.