[tor-commits] [bridgedb/master] Refactor Bridge.updateFromExtraInfoDescriptor() transport handling code.

isis at torproject.org isis at torproject.org
Sat Mar 21 02:02:59 UTC 2015


commit ff1349df3b04225ce62358b39ad2f94cce039f27
Author: Isis Lovecruft <isis at torproject.org>
Date:   Wed Dec 24 08:58:54 2014 +0000

    Refactor Bridge.updateFromExtraInfoDescriptor() transport handling code.
---
 lib/bridgedb/bridges.py |   91 ++++++++++++++++++++++++++++++++---------------
 1 file changed, 62 insertions(+), 29 deletions(-)

diff --git a/lib/bridgedb/bridges.py b/lib/bridgedb/bridges.py
index 71afe3b..4327f28 100644
--- a/lib/bridgedb/bridges.py
+++ b/lib/bridgedb/bridges.py
@@ -1449,6 +1449,21 @@ class Bridge(BridgeBackwardsCompatibility):
     def updateFromExtraInfoDescriptor(self, descriptor, verify=True):
         """Update this bridge's information from an extrainfo descriptor.
 
+        Stem's
+        :api:`stem.descriptor.extrainfo_descriptor.BridgeExtraInfoDescriptor`
+        parses extrainfo ``transport`` lines into a dictionary with the
+        following structure::
+
+            {u'obfs2': (u'34.230.223.87', 37339, []),
+             u'obfs3': (u'34.230.223.87', 37338, []),
+             u'obfs4': (u'34.230.223.87', 37341, [
+                 (u'iat-mode=0,'
+                  u'node-id=2a79f14120945873482b7823caabe2fcde848722,'
+                  u'public-key=0a5b046d07f6f971b7776de682f57c5b9cdc8fa060db7ef59de82e721c8098f4')]),
+             u'scramblesuit': (u'34.230.223.87', 37340, [
+                 u'password=ABCDEFGHIJKLMNOPQRSTUVWXYZ234567'])}
+
+
         .. todo:: The ``transport`` attribute of Stem's
             ``BridgeExtraInfoDescriptor`` class is a dictionary that uses the
             Pluggable Transport's eype as the keys. Meaning that if a bridge
@@ -1473,36 +1488,54 @@ class Bridge(BridgeBackwardsCompatibility):
 
         self.descriptors['extrainfo'] = descriptor
 
-        updatedTransports = []
+        oldTransports = self.transports[:]
+
+        for methodname, (address, port, args) in descriptor.transport.items():
+            updated = False
+            # See if we already know about this transport. If so, update its
+            # info; otherwise, add a new transport below.
+            for pt in self.transports:
+                if pt.methodname == methodname:
+
+                    logging.info("Found old %s transport for %s... Updating..."
+                                 % (methodname, self))
+
+                    if not (address == str(pt.address)) and (port == pt.port):
+                        logging.info(("Address/port for %s transport for "
+                                      "%s changed: old=%s:%s new=%s:%s")
+                                     % (methodname, self, pt.address, pt.port,
+                                        address, port))
+
+                    oldTransports.remove(pt)
+                    pt.updateFromStemTransport(str(self.fingerprint),
+                                               methodname,
+                                               (address, port, args,))
+                    updated = True
+                    break
+
+            if updated:
+                continue
+            else:
+                # We didn't update it. It must be a new transport for this
+                # bridges that we're hearing about for the first time, so add
+                # it:
+                logging.info(
+                    "Received new %s pluggable transport for bridge %s."
+                    % (methodname, safelog.logSafely(self.fingerprint)))
+                transport = PluggableTransport()
+                transport.updateFromStemTransport(str(self.fingerprint),
+                                                  methodname,
+                                                  (address, port, args,))
+                self.transports.append(transport)
+
+        # These are the pluggable transports which we knew about before, which
+        # however were not updated in this descriptor, ergo the bridge must
+        # not have them any more:
+        for pt in oldTransports:
+            logging.info("Removing dead transport for bridge %s: %s %s:%s %s" %
+                         (self, pt.methodname, pt.address, pt.port, pt.arguments))
+            self.transports.remove(pt)
 
-        for transport in self.transports:
-            for methodname, kitchenSink in descriptor.transport:
-                if transport.methodname == methodname:
-                    if transport.address == kitchenSink[0]:
-                        logging.info(
-                            "Updating %s pluggable transport for bridge %s." %
-                            (methodname, safelog.logSafely(self.fingerprint)))
-                        updatedTransports.append(transport)
-                        transport.updateFromStemTransport(self.fingerprint,
-                                                          methodname,
-                                                          kitchenSink)
-                    else:
-                        logging.info(
-                            ("Received new %s pluggable transport for bridge "
-                             "%s.") %
-                            (methodname, safelog.logSafely(self.fingerprint)))
-                        pt = PluggableTransport()
-                        pt.updateFromStemTransport(self.fingerprint,
-                                                   methodname,
-                                                   kitchenSink)
-                        updatedTransports.append(pt)
-                        self.transports.append(pt)
-
-        dead = set(self.transports).difference(set(updatedTransports))
-        logging.info("The following transports for bridge %s died: %s"
-                     % (self, ' '.join(dead)))
-        for died in dead:
-            self.transports.remove(died)
 
     # Bridge Stability (`#5482 <https://bugs.torproject.org>`_) properties.
     @property





More information about the tor-commits mailing list