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

[or-cvs] r19696: {torctl} Better conserve exits, and also include nodes without a Vali (torctl/trunk/python/TorCtl)



Author: mikeperry
Date: 2009-06-10 11:07:06 -0400 (Wed, 10 Jun 2009)
New Revision: 19696

Modified:
   torctl/trunk/python/TorCtl/PathSupport.py
   torctl/trunk/python/TorCtl/TorCtl.py
Log:

Better conserve exits, and also include nodes without a Valid
flag by default.



Modified: torctl/trunk/python/TorCtl/PathSupport.py
===================================================================
--- torctl/trunk/python/TorCtl/PathSupport.py	2009-06-10 13:51:20 UTC (rev 19695)
+++ torctl/trunk/python/TorCtl/PathSupport.py	2009-06-10 15:07:06 UTC (rev 19696)
@@ -1034,8 +1034,8 @@
       self.path_rstr = PathRestrictionList(
            [Subnet16Restriction(), UniqueRestriction()])
   
-    if self.use_guards: entry_flags = ["Guard", "Valid", "Running", "Fast"]
-    else: entry_flags = ["Valid", "Running", "Fast"]
+    if self.use_guards: entry_flags = ["Guard", "Running", "Fast"]
+    else: entry_flags = ["Running", "Fast"]
 
     if self.restrict_guards_only:
       nonentry_skip = 0
@@ -1046,12 +1046,16 @@
 
     entry_rstr = NodeRestrictionList(
       [PercentileRestriction(self.percent_skip, self.percent_fast, sorted_r),
-       ConserveExitsRestriction(self.exit_ports),
+       OrNodeRestriction(
+           [FlagsRestriction(["BadExit"]),
+           ConserveExitsRestriction(self.exit_ports)]),
        FlagsRestriction(entry_flags, [])]
     )
     mid_rstr = NodeRestrictionList(
       [PercentileRestriction(nonentry_skip, nonentry_fast, sorted_r),
-       ConserveExitsRestriction(self.exit_ports),
+       OrNodeRestriction(
+           [FlagsRestriction(["BadExit"]),
+           ConserveExitsRestriction(self.exit_ports)]),
        FlagsRestriction(["Running","Fast"], [])]
 
     )
@@ -1062,11 +1066,11 @@
       self.exit_rstr = NodeRestrictionList([IdHexRestriction(self.exit_id)])
     elif self.use_all_exits:
       self.exit_rstr = NodeRestrictionList(
-        [FlagsRestriction(["Valid", "Running","Fast"], ["BadExit"])])
+        [FlagsRestriction(["Running","Fast"], ["BadExit"])])
     else:
       self.exit_rstr = NodeRestrictionList(
         [PercentileRestriction(nonentry_skip, nonentry_fast, sorted_r),
-         FlagsRestriction(["Valid", "Running","Fast"], ["BadExit"])])
+         FlagsRestriction(["Running","Fast"], ["BadExit"])])
 
     if self.extra_node_rstr:
       entry_rstr.add_restriction(self.extra_node_rstr)
@@ -1132,9 +1136,12 @@
          ExactUniformGenerator(sorted_r, mid_rstr),
          exitgen, self.path_rstr)
     else:
-      # Remove ConserveExitsRestrictions for entry and middle positions
-      entry_rstr.del_restriction(ConserveExitsRestriction)
-      mid_rstr.del_restriction(ConserveExitsRestriction)
+      # Remove ConserveExitsRestriction for entry and middle positions
+      # by removing the OrNodeRestriction that contains it...
+      # FIXME: This is a landmine for a poor soul to hit.
+      # Then again, most of the rest of this function is, too.
+      entry_rstr.del_restriction(OrNodeRestriction)
+      mid_rstr.del_restriction(OrNodeRestriction)
       self.path_selector = PathSelector(
          BwWeightedGenerator(sorted_r, entry_rstr, self.pathlen,
                              guard=self.use_guards),

Modified: torctl/trunk/python/TorCtl/TorCtl.py
===================================================================
--- torctl/trunk/python/TorCtl/TorCtl.py	2009-06-10 13:51:20 UTC (rev 19695)
+++ torctl/trunk/python/TorCtl/TorCtl.py	2009-06-10 15:07:06 UTC (rev 19696)
@@ -943,7 +943,7 @@
     m = re.match(r"(\S+)\s(\S+)\s(\S+)\s(\S+\s\S+)\s(\S+)\s(\d+)\s(\d+)", nsline)    
     w = re.search(r"^w Bandwidth=(\d+)", nsline, re.M)
     if w:
-      nslist.append(NetworkStatus(*(m.groups() + (flags,) + (int(w.group(1)),))))
+      nslist.append(NetworkStatus(*(m.groups()+(flags,)+(int(w.group(1))*1024,))))
     else:
       nslist.append(NetworkStatus(*(m.groups() + (flags,))))
   return nslist