diff options
-rw-r--r-- | contrib/ExerciseServer.py | 109 | ||||
-rwxr-xr-x | contrib/TorControl.py | 2 |
2 files changed, 110 insertions, 1 deletions
diff --git a/contrib/ExerciseServer.py b/contrib/ExerciseServer.py new file mode 100644 index 0000000000..06c9a6a40e --- /dev/null +++ b/contrib/ExerciseServer.py @@ -0,0 +1,109 @@ +#!/usr/bin/python + +import TorControl +import threading +import socket +import struct +import random + +SOCKS_PORT=9050 +CONTROL_PORT=9051 + +def runSocks4A(nonce, targetHost, targetPort, targetURL): + s = socket.socket(socket.AF_INET, socket.SOCK_STREAM) + s.connect(("127.0.0.1", SOCKS_PORT)) + socksheader = struct.pack("!BBHL", 4, 0x01, targetPort, 1) + username = "" + socksheader = "%s%s\x00%s\x00" %(socksheader, username, nonce) + s.send(socksheader) + response = s.recv(8) + version,status,port=struct.unpack("!BBH",response[:4]) + if status != 90: + print "Error: non-successful SOCKS status" + s.close() + return 0 + + s.send("GET %s HTTP/1.0\r\nHost: %s\r\n\r\n"%(targetURL,targetHost)) + while 1: + r = s.recv(1024) + if not r: + s.close() + return 1 + +HOSTS_TO_TEST = [ "moria1", "mordor", "tor26"] +EXITS_TO_TEST = [ "pvt", ] +TARGETS = [ ("www.seul.org", "/"), ] + +CIRCS_AT_A_TIME = 3 +CIRC_LEN = 3 + +def launchCirc(s): + htt = HOSTS_TO_TEST[:] + random.shuffle(htt) + path = htt[:CIRC_LEN-1]+[random.choice(EXITS_TO_TEST)] + circid = TorControl.extend_circuit(s, 0, path) + return circid, path + +def runControl(s): + circs = {} + streams = {} + _h = lambda body,circs=circs,streams=streams,s=s:handleEvent(s,body, + circs,streams) + TorControl._event_handler = _h + TorControl.set_events(s, + [TorControl.EVENT_TYPE.CIRCSTATUS, + TorControl.EVENT_TYPE.STREAMSTATUS]) + TorControl.set_option(s,"__LeaveStreamsUnattached 1") + while 1: + while len(circs) < CIRCS_AT_A_TIME: + c,p = launchCirc(s) + print "launching circuit %s to %s"%(c,p) + circs[c]=p + _, tp, body = TorControl.receive_message(s) + if tp == TorControl.MSG_TYPE.EVENT: + handleEvent(s, body, circs, streams) + +def handleEvent(s, body, circs, streams): + event, args = TorControl.unpack_event(body) + if event == TorControl.EVENT_TYPE.STREAMSTATUS: + status, ident, target = args + print "Got stream event:",TorControl.STREAM_STATUS.nameOf[status],\ + ident,target + if status in (TorControl.STREAM_STATUS.NEW_CONNECT, + TorControl.STREAM_STATUS.NEW_RESOLVE, + TorControl.STREAM_STATUS.DETACHED): + if not target.endswith(".exnonce"): + TorControl.attach_stream(s, ident, 0) + else: + circid, (host,url) = streams[target] + TorControl.redirect_stream(s, ident, host) + TorControl.attach_stream(s, ident, circid) + elif event == TorControl.EVENT_TYPE.CIRCSTATUS: + status, ident, path = args + print "Got circuit event",TorControl.CIRC_STATUS.nameOf[status],\ + ident,path + if status in (TorControl.CIRC_STATUS.CLOSED, + TorControl.CIRC_STATUS.FAILED): + if circs.has_key(ident): + print "Circuit failed." + del circs[ident] + elif status == TorControl.CIRC_STATUS.BUILT: + nonce = random.randint(1,100000000) + nonce = "%s.exnonce" % nonce + host,url = random.choice(TARGETS) + streams[nonce] = ident, (host,url) + print "Launching socks4a connection" + t = threading.Thread(target=runSocks4A, args=(nonce, host, 80, url)) + t.setDaemon(1) + t.start() + + +def run(): + s = socket.socket(socket.AF_INET, socket.SOCK_STREAM) + s.connect(("127.0.0.1", CONTROL_PORT)) + TorControl.authenticate(s) + runControl(s) + +if __name__ == '__main__': + run() + diff --git a/contrib/TorControl.py b/contrib/TorControl.py index 5a63ad4187..815ceecc83 100755 --- a/contrib/TorControl.py +++ b/contrib/TorControl.py @@ -206,7 +206,7 @@ def receive_reply(s, expected=None): _, tp, body = receive_message(s) if tp == MSG_TYPE.EVENT: if _event_handler is not None: - _event_handler(tp, body) + _event_handler(body) elif tp == MSG_TYPE.ERROR: if len(body)<2: raise ProtocolError("(Truncated error message)") |