[tor-commits] [arm/master] Wizard components for a startup option
atagar at torproject.org
atagar at torproject.org
Fri Aug 12 17:03:22 UTC 2011
commit 6cc6ede6e19c28b5df1b0c88288ce3da20f0f84c
Author: Damian Johnson <atagar at torproject.org>
Date: Fri Aug 12 09:48:43 2011 -0700
Wizard components for a startup option
This adds platform detection and a check for the system torrc option for the
wizard startup option. However, this still isn't enabled nor is the option
implemented (so this has no impact on users). I'm suspecting that system
startup is a bigger can of worms than I'd like to open right now, even if
restricted to Debian and Ubuntu platforms so gonna leave the rest unimplemented
for now...
---
src/cli/wizard.py | 34 +++++++++++++++++++++++++++-------
src/resources/torrcTemplate.txt | 2 +-
2 files changed, 28 insertions(+), 8 deletions(-)
diff --git a/src/cli/wizard.py b/src/cli/wizard.py
index 82b2825..40cf632 100644
--- a/src/cli/wizard.py
+++ b/src/cli/wizard.py
@@ -9,6 +9,7 @@ import sys
import random
import shutil
import getpass
+import platform
import functools
import curses
@@ -283,22 +284,29 @@ def showWizard():
config[Options.REUSE].setValidator(_circDurationValidator)
# enables custom policies when 'custom' is selected and disables otherwise
- lowPortsOpt = config[Options.LOWPORTS]
- disclaimerNotice = [config[Options.NOTICE]]
- lowPortsOpt.setValidator(functools.partial(_toggleEnabledAction, disclaimerNotice))
- _toggleEnabledAction(disclaimerNotice, lowPortsOpt, lowPortsOpt.getValue())
-
policyOpt = config[Options.POLICY]
customPolicies = [config[opt] for opt in CUSTOM_POLICIES]
policyOpt.setValidator(functools.partial(_toggleEnabledAction, customPolicies))
_toggleEnabledAction(customPolicies, policyOpt, policyOpt.getValue())
+ lowPortsOpt = config[Options.LOWPORTS]
+ disclaimerNotice = [config[Options.NOTICE]]
+ lowPortsOpt.setValidator(functools.partial(_toggleEnabledAction, disclaimerNotice))
+ _toggleEnabledAction(disclaimerNotice, lowPortsOpt, lowPortsOpt.getValue())
+
# enables bridge entries when "Use Bridges" is set and disables otherwise
useBridgeOpt = config[Options.BRIDGED]
bridgeEntries = [config[opt] for opt in BRIDGE_ENTRIES]
useBridgeOpt.setValidator(functools.partial(_toggleEnabledAction, bridgeEntries))
_toggleEnabledAction(bridgeEntries, useBridgeOpt, useBridgeOpt.getValue())
+ # enables running at startup when 'Use System Instance' is deselected and
+ # disables otherwise
+ systemOpt = config[Options.SYSTEM]
+ startupOpt = [config[Options.STARTUP]]
+ systemOpt.setValidator(functools.partial(_toggleEnabledAction, startupOpt, True))
+ _toggleEnabledAction(startupOpt, systemOpt, not systemOpt.getValue())
+
# remembers the last selection made on the type prompt page
controller = cli.controller.getController()
manager = controller.getTorManager()
@@ -318,11 +326,16 @@ def showWizard():
# If we haven't run 'resources/torrcOverride/override.py --init' or lack
# permissions then we aren't able to deal with the system wide tor instance.
- # Also drop the optoin if we aren't installed since override.py won't be at
+ # Also drop the option if we aren't installed since override.py won't be at
# the expected path.
if not os.path.exists(os.path.dirname(SYSTEM_DROP_PATH)) or not os.path.exists(OVERRIDE_SCRIPT):
disabledOpt.append(Options.SYSTEM)
+ # Running at startup is currently only supported for Debian and Ubuntu.
+ # Patches welcome for supporting other platforms.
+ if not platform.dist()[0] in ("debian", "Ubuntu"):
+ disabledOpt.append(Options.STARTUP)
+
while True:
if relayType == None:
selection = promptRelayType(relaySelection)
@@ -742,6 +755,10 @@ def getTorrc(relayType, config, disabledOpt):
if opt.upper() in templateOptions:
del templateOptions[opt.upper()]
+ startupOpt = Options.STARTUP.upper()
+ if not config[Options.STARTUP].isEnabled() and startupOpt in templateOptions:
+ del templateOptions[startupOpt]
+
# removes options if they match the tor defaults
for opt in TOR_DEFAULTS:
if templateOptions[opt.upper()] == TOR_DEFAULTS[opt]:
@@ -919,7 +936,7 @@ def _obscureChar(inputText, target, options):
return inputText.replace(target, replacement)
-def _toggleEnabledAction(toggleOptions, option, value):
+def _toggleEnabledAction(toggleOptions, option, value, invert = False):
"""
Enables or disables custom exit policy options based on our selection.
@@ -928,8 +945,11 @@ def _toggleEnabledAction(toggleOptions, option, value):
selection (ie, true -> enabled, false -> disabled)
options - our config option
value - the value we're being set to
+ invert - inverts selection if true
"""
+ if invert: value = not value
+
for opt in toggleOptions:
opt.setEnabled(value)
diff --git a/src/resources/torrcTemplate.txt b/src/resources/torrcTemplate.txt
index 744a481..c6e61f0 100644
--- a/src/resources/torrcTemplate.txt
+++ b/src/resources/torrcTemplate.txt
@@ -22,7 +22,7 @@ CookieAuthentication 1 # method for controller authentication
[IF RELAY | EXIT | BRIDGE]
RunAsDaemon 1 # runs as a background process
- [IF LOWPORTS]
+ [IF LOWPORTS | STARTUP]
User [USERNAME] # lowers our permissions to this user
[END IF]
[END IF]
More information about the tor-commits
mailing list