Skip to content
Snippets Groups Projects
  1. Dec 05, 2018
    • David Fifield's avatar
      Fix a local variable reference in BucketRateLimit.when. · 5817c257
      David Fifield authored
      ReferenceError: age is not defined	snowflake.js:265:7
              BucketRateLimit.prototype.when	snowflake/proxy/build/snowflake.js:265:7
              ProxyPair.prototype.flush	snowflake/proxy/build/snowflake.js:558:63
              bind/<	snowflake/proxy/build/snowflake.js:10:56
              ProxyPair.prototype.onClientToRelayMessage	snowflake/proxy/build/snowflake.js:495:14
              bind/<	snowflake/proxy/build/snowflake.js:10:56
      5817c257
  2. Dec 04, 2018
  3. Nov 26, 2018
  4. Nov 21, 2018
  5. Nov 05, 2018
  6. Jun 10, 2018
    • David Fifield's avatar
      Log to io.Discard if no log file is set. · 6077141f
      David Fifield authored
      https://bugs.torproject.org/25600#comment:14
      
      Snowflake in Tor Browser has been hanging after surfing for a while.
      (Tor reports "no running bridges".) It only began happening after commit
      12922a23, which caused snowflake-client not to log to a file by
      default (leaving it to log to its default stderr). What seems to be
      happening is that tor doesn't read from its PT clients' stderr, leaving
      a buffer to fill up that eventually causes a hang.
      6077141f
  7. May 08, 2018
  8. Apr 30, 2018
  9. Apr 18, 2018
    • David Fifield's avatar
      Fix text-shadow CSS. · fd9efa10
      David Fifield authored
      The semicolons made it look like the end of a declaration. I got these
      errors in the Firefox console:
      
      Expected declaration but found ‘1px’.  Skipped to next declaration. 1 embed.html:29:17
      Expected declaration but found ‘-1px’.  Skipped to next declaration. 1 embed.html:30:17
      fd9efa10
  10. Apr 17, 2018
  11. Apr 16, 2018
  12. Mar 22, 2018
  13. Mar 21, 2018
  14. Mar 20, 2018
  15. Mar 15, 2018
  16. Mar 14, 2018
    • Arlo Breault's avatar
      f2abf5b6
    • David Fifield's avatar
    • Arlo Breault's avatar
      Allow broker base url to have a path · 42ec097a
      Arlo Breault authored
      42ec097a
    • David Fifield's avatar
      Add a "starting" log line to proxy-go. · 44ab82bc
      David Fifield authored
      44ab82bc
    • David Fifield's avatar
      Wait briefly after calling ListenAndServe{TLS} to see if it errors. · ea7b9c02
      David Fifield authored
      This is a port of commit e3f3054f8b74caa639a6d9be09702693af9a70e7 from
      meek.
      
      In the previous commit, we changed from separate Listen and Serve steps
      to always calling ListenAndServe. However, we would really like to
      immediately get feedback if any errors happen in the Listen step inside
      the call, because it's much better for debugging if those errors get
      reported to tor through SMETHOD-ERROR--rather than reporting success to
      tor and actually logging an error only in the snowflake log. So we wait
      100 ms for an error to occur before deciding that the Listen succeeded.
      
      We don't need to apply this hack to the ACME HTTP-01 listener, because
      it's a plaintext listener. Unlike in the TLS case, there isn't any
      internal magic that the net library does that we have to rely on. We
      just call net.ListenTCP and check for an error.
      ea7b9c02
    • David Fifield's avatar
      Use ListenAndServe{TLS} rather than separate Listen and Serve. · 19b317e7
      David Fifield authored
      This is a port of commit cea86c937dc278ba6b2100c238b1d5206bbae2f0 from
      meek. Its purpose is to remove the need to copy-paste parts of
      net/http.Server.ListenAndServeTLS. Here is a copy of the commit message
      from meek:
      
          The net/http package provides ListenAndServe and ListenAndServeTLS
          functions, but it doesn't provide a way to set up a listener without
          also entering an infinite serve loop. This matters for
          ListenAndServeTLS, which sets up a lot of magic behind the scenes for
          TLS and HTTP/2 support. Formerly, we had copy-pasted code from
          ListenAndServeTLS, but that code has only gotten more complicated in
          upstream net/http.
      
          The price we pay for this is that it's no longer possible for a server
          bindaddr to ask to listen on port 0 (i.e., a random ephemeral port).
          That's because we never get a change to find out what the listening
          address is, before entering the serve loop.
      
          What we gain is HTTP/2 support; formerly our copy-pasted code had the
          side effect of disabling HTTP/2, because it was copied from an older
          version and did things like
                  config.NextProtos = []string{"http/1.1"}
      
          The new code calls http2.ConfigureServer first, but that's not what's
          providing HTTP/2 support. HTTP/2 support happens by default. The reason
          we call http2.ConfigureServer is because we need to set
          TLSConfig.GetCertificate, and http2.ConfigureServer is a convenient way
          to initialize TLSConfig in a way that is guaranteed to work with HTTP/2.
      19b317e7
  17. Mar 13, 2018
Loading