[Author Prev][Author Next][Thread Prev][Thread Next][Author Index][Thread Index]
[or-cvs] r18559: {torflow} Update TorFlow utilities to use the NEWCONSENSUS event. This (in torflow/trunk: . CircuitAnalysis/BuildTimes NetworkScanners)
Author: mikeperry
Date: 2009-02-16 04:18:49 -0500 (Mon, 16 Feb 2009)
New Revision: 18559
Modified:
torflow/trunk/CircuitAnalysis/BuildTimes/buildtimes.py
torflow/trunk/NetworkScanners/README.ExitScanning
torflow/trunk/NetworkScanners/soat.py
torflow/trunk/README
torflow/trunk/metatroller.py
torflow/trunk/torrc
Log:
Update TorFlow utilities to use the NEWCONSENSUS event. This
means they too require Tor r18556 or newer.
Modified: torflow/trunk/CircuitAnalysis/BuildTimes/buildtimes.py
===================================================================
--- torflow/trunk/CircuitAnalysis/BuildTimes/buildtimes.py 2009-02-16 09:17:22 UTC (rev 18558)
+++ torflow/trunk/CircuitAnalysis/BuildTimes/buildtimes.py 2009-02-16 09:18:49 UTC (rev 18559)
@@ -114,17 +114,8 @@
self.failfile.flush()
StatsHandler.circ_status_event(self,circ_event)
- def new_desc_event(self, d):
- for idhex in d.idlist:
- if not idhex in self.routers:
- continue
- r = self.routers[idhex]
- r.bw_history.append(r.bw)
- for r in self.sorted_r:
- r.rank_history.append(r.list_rank)
- StatsHandler.new_desc_event(self, d)
-
- def ns_event(self, n):
+ def newconsensus_event(self, n):
+ # Record previous rank and history.
for ns in n.nslist:
if not ns.idhex in self.routers:
continue
@@ -132,7 +123,7 @@
r.bw_history.append(r.bw)
for r in self.sorted_r:
r.rank_history.append(r.list_rank)
- StatsHandler.ns_event(self, n)
+ StatsHandler.newconsensus_event(self, n)
def cleanup():
@@ -162,10 +153,10 @@
c.set_events([TorCtl.EVENT_TYPE.STREAM,
TorCtl.EVENT_TYPE.BW,
- TorCtl.EVENT_TYPE.NS,
+ TorCtl.EVENT_TYPE.NEWCONSENSUS,
+ #TorCtl.EVENT_TYPE.NEWDESC,
TorCtl.EVENT_TYPE.CIRC,
- TorCtl.EVENT_TYPE.STREAM_BW,
- TorCtl.EVENT_TYPE.NEWDESC], True)
+ TorCtl.EVENT_TYPE.STREAM_BW], True)
return c
def getargs():
Modified: torflow/trunk/NetworkScanners/README.ExitScanning
===================================================================
--- torflow/trunk/NetworkScanners/README.ExitScanning 2009-02-16 09:17:22 UTC (rev 18558)
+++ torflow/trunk/NetworkScanners/README.ExitScanning 2009-02-16 09:18:49 UTC (rev 18559)
@@ -15,7 +15,7 @@
II. Prerequisites
Python 2.4+
-Tor 0.2.1.13 (r18516 or later)
+Tor 0.2.1.13 (r18556 or later)
Super Secret SoaT Sauce
py-openssl/pyOpenSSL
Bonus: 500M of disk space
Modified: torflow/trunk/NetworkScanners/soat.py
===================================================================
--- torflow/trunk/NetworkScanners/soat.py 2009-02-16 09:17:22 UTC (rev 18558)
+++ torflow/trunk/NetworkScanners/soat.py 2009-02-16 09:18:49 UTC (rev 18559)
@@ -263,18 +263,14 @@
return random.choice(list(self.nodes))
def update_nodes(self):
- all_old_nodes = sets.Set(self.node_map.keys())
nodes = metacon.node_manager.get_nodes_for_port(self.port)
self.node_map = {}
for n in nodes:
self.node_map[n.idhex] = n
self.total_nodes = len(nodes)
- all_new_nodes = sets.Set(map(lambda n: n.idhex, nodes))
+ self.nodes = sets.Set(map(lambda n: n.idhex, nodes))
marked_nodes = sets.Set(self.node_results.keys())
- new_nodes = all_new_nodes - all_old_nodes
- new_nodes -= marked_nodes
- self.nodes &= all_new_nodes # Clear down nodes
- self.nodes = self.nodes | new_nodes # add new ones
+ self.nodes -= marked_nodes # Remove marked nodes
# Only scan the stuff loaded from the rescan
if self.rescan_nodes: self.nodes &= self.rescan_nodes
if not self.nodes:
@@ -2072,7 +2068,7 @@
self._read_routers(self.c.get_network_status())
self.new_nodes=True
c.set_event_handler(self)
- c.set_events([TorCtl.EVENT_TYPE.NEWDESC, TorCtl.EVENT_TYPE.NS], True)
+ c.set_events([TorCtl.EVENT_TYPE.NEWCONSENSUS], True)
def has_new_nodes(self):
ret = False
@@ -2101,44 +2097,27 @@
def _read_routers(self, nslist):
routers = self.c.read_routers(nslist)
- new_routers = []
+ self.sorted_r = []
+ self.routers = {}
for r in routers:
- if r.idhex in self.routers:
- if self.routers[r.idhex].nickname != r.nickname:
- plog("NOTICE", "Router "+r.idhex+" changed names from "
- +self.routers[r.idhex].nickname+" to "+r.nickname)
- self.sorted_r.remove(self.routers[r.idhex])
self.routers[r.idhex] = r
- new_routers.append(r)
+ self.sorted_r.append(r)
- self.sorted_r.extend(new_routers)
self.sorted_r.sort(lambda x, y: cmp(y.bw, x.bw))
# This is an OK update because of the GIL (also we don't touch it)
for i in xrange(len(self.sorted_r)): self.sorted_r[i].list_rank = i
- def ns_event(self, n):
- plog("DEBUG", "ns_event begin")
+ def newconsensus_event(self, n):
+ plog("DEBUG", "newconsensus_event begin")
try:
self.rlock.acquire()
self._read_routers(n.nslist)
self.new_nodes = True
finally:
self.rlock.release()
- plog("DEBUG", "Read " + str(len(n.nslist))+" NS => "
+ plog("DEBUG", "Read " + str(len(n.nslist))+" NC => "
+ str(len(self.sorted_r)) + " routers")
-
- def new_desc_event(self, d):
- plog("DEBUG", "new_desc_event begin")
- try:
- self.rlock.acquire()
- for i in d.idlist: # Is this too slow?
- self._read_routers(self.c.get_network_status("id/"+i))
- self.new_nodes = True
- finally:
- self.rlock.release()
- plog("DEBUG", "Read " + str(len(d.idlist))+" Desc => "
- + str(len(self.sorted_r)) + " routers")
-
+
class DNSRebindScanner(EventHandler):
'''
Modified: torflow/trunk/README
===================================================================
--- torflow/trunk/README 2009-02-16 09:17:22 UTC (rev 18558)
+++ torflow/trunk/README 2009-02-16 09:18:49 UTC (rev 18559)
@@ -63,7 +63,7 @@
or get it from http://pyopenssl.sourceforge.net/
-3b. NetworkScanners/speedracer.pl
+3b. NetworkScanners/speedracer.py
SpeedRacer fetches a file repeatedly through circuits built by
metatroller. It divides the Tor network into tiers based on percentiles
Modified: torflow/trunk/metatroller.py
===================================================================
--- torflow/trunk/metatroller.py 2009-02-16 09:17:22 UTC (rev 18558)
+++ torflow/trunk/metatroller.py 2009-02-16 09:18:49 UTC (rev 18559)
@@ -253,10 +253,10 @@
c.set_events([TorCtl.EVENT_TYPE.STREAM,
TorCtl.EVENT_TYPE.BW,
- TorCtl.EVENT_TYPE.NS,
+ TorCtl.EVENT_TYPE.NEWCONSENSUS,
+ #TorCtl.EVENT_TYPE.NEWDESC,
TorCtl.EVENT_TYPE.CIRC,
- TorCtl.EVENT_TYPE.STREAM_BW,
- TorCtl.EVENT_TYPE.NEWDESC], True)
+ TorCtl.EVENT_TYPE.STREAM_BW], True)
c.set_option("__LeaveStreamsUnattached", "1")
f = c.get_option("FetchUselessDescriptors")[0][1]
c.set_option("FetchUselessDescriptors", "1")
Modified: torflow/trunk/torrc
===================================================================
--- torflow/trunk/torrc 2009-02-16 09:17:22 UTC (rev 18558)
+++ torflow/trunk/torrc 2009-02-16 09:18:49 UTC (rev 18559)
@@ -2,5 +2,9 @@
SocksPort 9060 # what port to advertise for application connections
ControlPort 9061
SafeLogging 0
-Log info stderr
+Log debug stderr
FetchUselessDescriptors 1
+
+# XXX: This should be for test scans only. Our timeout values must match the
+# normal Tor clients.
+SocksTimeout 45