commit 3d8204c242abe5d07db584a7d29477ab3161dcba
Author: Arun Pandian G <arunpandianp(a)gmail.com>
Date: Mon Jan 6 04:10:50 2014 +0530
Support for Additional Tor Configurations
---
data/ooniprobe.conf.sample | 5 +++++
ooni/director.py | 24 ++++++++++++++----------
2 files changed, 19 insertions(+), 10 deletions(-)
diff --git a/data/ooniprobe.conf.sample b/data/ooniprobe.conf.sample
index 3a1b6f4..d1fd847 100644
--- a/data/ooniprobe.conf.sample
+++ b/data/ooniprobe.conf.sample
@@ -57,3 +57,8 @@ tor:
# This should be set to something to avoid having Tor download each time
# the descriptors and consensus data.
#data_dir: ~/.tor/
+ torrc:
+ #HTTPProxy: host:port
+ #HTTPProxyAuthenticator: user:password
+ #HTTPSProxy: host:port
+ #HTTPSProxyAuthenticator: user:password
diff --git a/ooni/director.py b/ooni/director.py
index ed4517c..a988ca0 100644
--- a/ooni/director.py
+++ b/ooni/director.py
@@ -264,7 +264,6 @@ class Director(object):
:param: tor_binary set in ooniprobe.conf
"""
log.msg("Starting Tor...")
-
@defer.inlineCallbacks
def state_complete(state):
config.tor_state = state
@@ -301,17 +300,9 @@ class Director(object):
tor_config = TorConfig()
if config.tor.control_port:
tor_config.ControlPort = config.tor.control_port
- else:
- control_port = int(randomFreePort())
- tor_config.ControlPort = control_port
- config.tor.control_port = control_port
if config.tor.socks_port:
tor_config.SocksPort = config.tor.socks_port
- else:
- socks_port = int(randomFreePort())
- tor_config.SocksPort = socks_port
- config.tor.socks_port = socks_port
if config.tor.data_dir:
data_dir = os.path.expanduser(config.tor.data_dir)
@@ -337,8 +328,22 @@ class Director(object):
bridges.append(bridge.strip())
tor_config.Bridge = bridges
+ for i in config.tor.torrc.keys():
+ setattr(tor_config, i, config.tor.torrc[i])
+
tor_config.save()
+ if not hasattr(tor_config,'ControlPort'):
+ control_port = int(randomFreePort())
+ tor_config.ControlPort = control_port
+ config.tor.control_port = control_port
+
+ if not hasattr(tor_config,'SocksPort'):
+ socks_port = int(randomFreePort())
+ tor_config.SocksPort = socks_port
+ config.tor.socks_port = socks_port
+
+ tor_config.save()
log.debug("Setting control port as %s" % tor_config.ControlPort)
log.debug("Setting SOCKS port as %s" % tor_config.SocksPort)
@@ -349,7 +354,6 @@ class Director(object):
else:
d = launch_tor(tor_config, reactor,
progress_updates=updates)
-
d.addCallback(setup_complete)
d.addErrback(setup_failed)
return d