[tor-commits] [flashproxy/master] Do the __name__ == "__main__" trick in connector.py.
dcf at torproject.org
dcf at torproject.org
Mon Apr 9 04:08:42 UTC 2012
commit c6e3c10ef6e73ca9fd6fe730699e1f2161114df3
Author: David Fifield <david at bamsoftware.com>
Date: Sun Mar 25 10:53:23 2012 -0700
Do the __name__ == "__main__" trick in connector.py.
---
connector.py | 139 +++++++++++++++++++++++++++++-----------------------------
1 files changed, 70 insertions(+), 69 deletions(-)
diff --git a/connector.py b/connector.py
index 85fc4ad..f84f8a2 100755
--- a/connector.py
+++ b/connector.py
@@ -115,40 +115,6 @@ def format_addr(addr):
else:
return u"%s:%d" % (host, port)
-opts, args = getopt.gnu_getopt(sys.argv[1:], "f:hl:", ["daemon", "facilitator=", "help", "log=", "pidfile="])
-for o, a in opts:
- if o == "--daemon":
- options.daemonize = True
- elif o == "-f" or o == "--facilitator":
- options.facilitator_addr = parse_addr_spec(a, None, DEFAULT_FACILITATOR_PORT)
- elif o == "-h" or o == "--help":
- usage()
- sys.exit()
- elif o == "-l" or o == "--log":
- options.log_filename = a
- elif o == "--pidfile":
- options.pid_filename = a
-
-if len(args) == 0:
- options.local_addr = (DEFAULT_LOCAL_ADDRESS, DEFAULT_LOCAL_PORT)
- options.remote_addr = (DEFAULT_REMOTE_ADDRESS, DEFAULT_REMOTE_PORT)
-elif len(args) == 1:
- options.local_addr = parse_addr_spec(args[0], DEFAULT_LOCAL_ADDRESS, DEFAULT_LOCAL_PORT)
- options.remote_addr = (DEFAULT_REMOTE_ADDRESS, DEFAULT_REMOTE_PORT)
-elif len(args) == 2:
- options.local_addr = parse_addr_spec(args[0], DEFAULT_LOCAL_ADDRESS, DEFAULT_LOCAL_PORT)
- options.remote_addr = parse_addr_spec(args[1], DEFAULT_REMOTE_ADDRESS, DEFAULT_REMOTE_PORT)
-else:
- usage(sys.stderr)
- sys.exit(1)
-
-if options.log_filename:
- options.log_file = open(options.log_filename, "a")
- # Send error tracebacks to the log.
- sys.stderr = options.log_file
-else:
- options.log_file = sys.stdout
-
class BufferSocket(object):
"""A socket containing a time of creation and a buffer of data received. The
@@ -180,22 +146,6 @@ def format_peername(s):
except socket.error, e:
return "<unconnected>"
-# Local socket, accepting SOCKS requests from localhost
-local_s = listen_socket(options.local_addr)
-# Remote socket, accepting remote WebSocket connections from proxies.
-remote_s = listen_socket(options.remote_addr)
-
-# Remote connection sockets.
-remotes = []
-# New local sockets waiting to finish their SOCKS negotiation.
-socks_pending = []
-# Local Tor sockets, after SOCKS negotiation.
-locals = []
-
-# Bidirectional mapping between local sockets and remote sockets.
-local_for = {}
-remote_for = {}
-
def grab_string(s, pos):
"""Grab a NUL-terminated string from the given string, starting at the given
@@ -327,18 +277,6 @@ def match_proxies():
remote_for[local.fd] = remote.fd
local_for[remote.fd] = local.fd
-if options.daemonize:
- log(u"Daemonizing.")
- pid = os.fork()
- if pid != 0:
- if options.pid_filename:
- f = open(options.pid_filename, "w")
- print >> f, pid
- f.close()
- sys.exit(0)
-
-register()
-
def main():
while True:
rset = [remote_s, local_s] + socks_pending + remote_for.keys() + local_for.keys() + locals + remotes
@@ -347,8 +285,9 @@ def main():
if fd == remote_s:
remote_c, addr = fd.accept()
log(u"Remote connection from %s." % format_addr(addr))
- remotes.append(fd)
- handle_remote_connection(fd)
+ remotes.append(BufferSocket(remote_c))
+ handle_remote_connection(remote_c)
+ report_pending()
elif fd == local_s:
local_c, addr = fd.accept()
log(u"Local connection from %s." % format_addr(addr))
@@ -385,8 +324,70 @@ def main():
report_pending()
match_proxies()
-try:
- main()
-except Exception:
- exc = traceback.format_exc()
- log("".join(exc))
+if __name__ == "__main__":
+ opts, args = getopt.gnu_getopt(sys.argv[1:], "f:hl:", ["daemon", "facilitator=", "help", "log=", "pidfile="])
+ for o, a in opts:
+ if o == "--daemon":
+ options.daemonize = True
+ elif o == "-f" or o == "--facilitator":
+ options.facilitator_addr = parse_addr_spec(a, None, DEFAULT_FACILITATOR_PORT)
+ elif o == "-h" or o == "--help":
+ usage()
+ sys.exit()
+ elif o == "-l" or o == "--log":
+ options.log_filename = a
+ elif o == "--pidfile":
+ options.pid_filename = a
+
+ if len(args) == 0:
+ options.local_addr = (DEFAULT_LOCAL_ADDRESS, DEFAULT_LOCAL_PORT)
+ options.remote_addr = (DEFAULT_REMOTE_ADDRESS, DEFAULT_REMOTE_PORT)
+ elif len(args) == 1:
+ options.local_addr = parse_addr_spec(args[0], DEFAULT_LOCAL_ADDRESS, DEFAULT_LOCAL_PORT)
+ options.remote_addr = (DEFAULT_REMOTE_ADDRESS, DEFAULT_REMOTE_PORT)
+ elif len(args) == 2:
+ options.local_addr = parse_addr_spec(args[0], DEFAULT_LOCAL_ADDRESS, DEFAULT_LOCAL_PORT)
+ options.remote_addr = parse_addr_spec(args[1], DEFAULT_REMOTE_ADDRESS, DEFAULT_REMOTE_PORT)
+ else:
+ usage(sys.stderr)
+ sys.exit(1)
+
+ if options.log_filename:
+ options.log_file = open(options.log_filename, "a")
+ # Send error tracebacks to the log.
+ sys.stderr = options.log_file
+ else:
+ options.log_file = sys.stdout
+
+ # Local socket, accepting SOCKS requests from localhost
+ local_s = listen_socket(options.local_addr)
+ # Remote socket, accepting remote WebSocket connections from proxies.
+ remote_s = listen_socket(options.remote_addr)
+
+ # Remote connection sockets.
+ remotes = []
+ # New local sockets waiting to finish their SOCKS negotiation.
+ socks_pending = []
+ # Local Tor sockets, after SOCKS negotiation.
+ locals = []
+
+ # Bidirectional mapping between local sockets and remote sockets.
+ local_for = {}
+ remote_for = {}
+
+ register()
+
+ if options.daemonize:
+ log(u"Daemonizing.")
+ pid = os.fork()
+ if pid != 0:
+ if options.pid_filename:
+ f = open(options.pid_filename, "w")
+ print >> f, pid
+ f.close()
+ sys.exit(0)
+ try:
+ main()
+ except Exception:
+ exc = traceback.format_exc()
+ log("".join(exc))
More information about the tor-commits
mailing list