From 7d995ca1d53231e51e016b8190cb51d83e9b7dfb Mon Sep 17 00:00:00 2001 From: Brian Warner Date: Sun, 1 Jan 2017 13:00:35 -0500 Subject: [PATCH] transit server: respect --blur-usage= by not logging connections --- src/wormhole/server/server.py | 2 +- src/wormhole/server/transit_server.py | 32 ++++++++++++++++++--------- 2 files changed, 23 insertions(+), 11 deletions(-) diff --git a/src/wormhole/server/server.py b/src/wormhole/server/server.py index 3ac8215..72ef694 100644 --- a/src/wormhole/server/server.py +++ b/src/wormhole/server/server.py @@ -105,7 +105,7 @@ class RelayServer(service.MultiService): log.msg("Wormhole relay server (Rendezvous and Transit) running") if self._blur_usage: log.msg("blurring access times to %d seconds" % self._blur_usage) - log.msg("not logging HTTP requests") + log.msg("not logging HTTP requests or Transit connections") else: log.msg("not blurring access times") diff --git a/src/wormhole/server/transit_server.py b/src/wormhole/server/transit_server.py index d2e5ffa..92265a5 100644 --- a/src/wormhole/server/transit_server.py +++ b/src/wormhole/server/transit_server.py @@ -44,6 +44,7 @@ class TransitConnection(protocol.Protocol): def connectionMade(self): self._started = time.time() + self._log_requests = self.factory._log_requests def dataReceived(self, data): if self._sent_ok: @@ -59,7 +60,8 @@ class TransitConnection(protocol.Protocol): if self._got_token: # but not yet sent_ok self.transport.write(b"impatient\n") - log.msg("transit impatience failure") + if self._log_requests: + log.msg("transit impatience failure") return self.disconnect() # impatience yields failure # else this should be (part of) the token @@ -75,7 +77,8 @@ class TransitConnection(protocol.Protocol): # handshake until we've said go if len(buf) > handshake_len: self.transport.write(b"impatient\n") - log.msg("transit impatience failure") + if self._log_requests: + log.msg("transit impatience failure") return self.disconnect() # impatience yields failure return self._got_handshake(token, None) (new, handshake_len, token, side) = self._check_new_handshake(buf) @@ -83,12 +86,14 @@ class TransitConnection(protocol.Protocol): if new == "yes": if len(buf) > handshake_len: self.transport.write(b"impatient\n") - log.msg("transit impatience failure") + if self._log_requests: + log.msg("transit impatience failure") return self.disconnect() # impatience yields failure return self._got_handshake(token, side) if (old == "no" and new == "no"): self.transport.write(b"bad handshake\n") - log.msg("transit handshake failure") + if self._log_requests: + log.msg("transit handshake failure") return self.disconnect() # incorrectness yields failure # else we'll keep waiting @@ -142,7 +147,8 @@ class TransitConnection(protocol.Protocol): # there will be two producer/consumer pairs. def buddy_disconnected(self): - log.msg("buddy_disconnected %s" % self.describeToken()) + if self._log_requests: + log.msg("buddy_disconnected %s" % self.describeToken()) self._buddy = None self.transport.loseConnection() @@ -219,6 +225,7 @@ class Transit(protocol.ServerFactory, service.MultiService): service.MultiService.__init__(self) self._db = db self._blur_usage = blur_usage + self._log_requests = blur_usage is None self._pending_requests = {} # token -> set((side, TransitConnection)) self._active_connections = set() # TransitConnection self._counts = collections.defaultdict(int) @@ -234,7 +241,8 @@ class Transit(protocol.ServerFactory, service.MultiService): or (new_side is None) or (old_side != new_side)): # we found a match - log.msg("transit relay 2: %s" % new_tc.describeToken()) + if self._log_requests: + log.msg("transit relay 2: %s" % new_tc.describeToken()) # drop and stop tracking the rest potentials.remove(old) @@ -248,13 +256,15 @@ class Transit(protocol.ServerFactory, service.MultiService): new_tc.buddy_connected(old_tc) old_tc.buddy_connected(new_tc) return - log.msg("transit relay 1: %s" % new_tc.describeToken()) + if self._log_requests: + log.msg("transit relay 1: %s" % new_tc.describeToken()) potentials.add((new_side, new_tc)) # TODO: timer def recordUsage(self, started, result, total_bytes, total_time, waiting_time): - log.msg("Transit.recordUsage (%dB)" % total_bytes) + if self._log_requests: + log.msg("Transit.recordUsage (%dB)" % total_bytes) if self._blur_usage: started = self._blur_usage * (started // self._blur_usage) total_bytes = blur_size(total_bytes) @@ -275,11 +285,13 @@ class Transit(protocol.ServerFactory, service.MultiService): self._pending_requests[token].remove(side_tc) if not self._pending_requests[token]: # set is now empty del self._pending_requests[token] - log.msg("transitFinished %s" % (description,)) + if self._log_requests: + log.msg("transitFinished %s" % (description,)) self._active_connections.discard(tc) def transitFailed(self, p): - log.msg("transitFailed %r" % p) + if self._log_requests: + log.msg("transitFailed %r" % p) pass def get_stats(self):