[Author Prev][Author Next][Thread Prev][Thread Next][Author Index][Thread Index]

[tor-commits] [stem/master] Transport parsing wasn't idempotent



commit 8870510e4194da6c7ee8fb143e898a7c83932234
Author: Damian Johnson <atagar@xxxxxxxxxxxxxx>
Date:   Sun Jan 18 09:57:03 2015 -0800

    Transport parsing wasn't idempotent
    
    Oops, this parsing function appended to the descriptor's existing dictionary
    rather than assigning one of its own. Assuming it ran over the same content
    this wasn't an issue in practice since it would clobber the existing results,
    but still not rights.
---
 stem/descriptor/extrainfo_descriptor.py |    6 +++++-
 1 file changed, 5 insertions(+), 1 deletion(-)

diff --git a/stem/descriptor/extrainfo_descriptor.py b/stem/descriptor/extrainfo_descriptor.py
index 124ce16..1eebe46 100644
--- a/stem/descriptor/extrainfo_descriptor.py
+++ b/stem/descriptor/extrainfo_descriptor.py
@@ -256,6 +256,8 @@ def _parse_transport_line(descriptor, entries):
   # on non-bridges in the wild when the relay operator configured it this
   # way.
 
+  transports = {}
+
   for value in _values('transport', entries):
     name, address, port, args = None, None, None, None
 
@@ -285,7 +287,9 @@ def _parse_transport_line(descriptor, entries):
       port = int(port_str)
       args = value_comp[2:] if len(value_comp) >= 3 else []
 
-    descriptor.transport[name] = (address, port, args)
+    transports[name] = (address, port, args)
+
+  descriptor.transport = transports
 
 
 def _parse_cell_circuits_per_decline_line(descriptor, entries):



_______________________________________________
tor-commits mailing list
tor-commits@xxxxxxxxxxxxxxxxxxxx
https://lists.torproject.org/cgi-bin/mailman/listinfo/tor-commits