[tor-commits] [arm/master] Input field validation for circ reuse durations
atagar at torproject.org
atagar at torproject.org
Mon Jul 4 15:40:31 UTC 2011
commit 5e0178152ddf08b4c1a8011dc74667c65c9a750a
Author: Damian Johnson <atagar at torproject.org>
Date: Sun Jul 3 18:08:36 2011 -0700
Input field validation for circ reuse durations
---
src/cli/wizard.py | 22 ++++++++++++++++++++--
1 files changed, 20 insertions(+), 2 deletions(-)
diff --git a/src/cli/wizard.py b/src/cli/wizard.py
index 16752e7..80d2fd1 100644
--- a/src/cli/wizard.py
+++ b/src/cli/wizard.py
@@ -215,6 +215,7 @@ def showWizard():
config[Options.BRIDGE1].setValidator(_bridgeDestinationValidator)
config[Options.BRIDGE2].setValidator(_bridgeDestinationValidator)
config[Options.BRIDGE3].setValidator(_bridgeDestinationValidator)
+ config[Options.REUSE].setValidator(_circDurationValidator)
# enables custom policies when 'custom' is selected and disables otherwise
policyOpt = config[Options.POLICY]
@@ -432,7 +433,7 @@ def _toggleEnabledAction(toggleOptions, option, value):
def _relayRateValidator(option, value):
if value.count(" ") != 1:
- msg = "This should be a measurement followed by the rate (for instance, \"5 MB/s\")"
+ msg = "This should be a rate measurement (for instance, \"5 MB/s\")"
raise ValueError(msg)
rate, units = value.split(" ", 1)
@@ -447,7 +448,7 @@ def _relayRateValidator(option, value):
def _monthlyLimitValidator(option, value):
if value.count(" ") != 1:
- msg = "This should be a measurement followed by the units (for instance, \"5 MB\")"
+ msg = "This should be a traffic size (for instance, \"5 MB\")"
raise ValueError(msg)
rate, units = value.split(" ", 1)
@@ -457,6 +458,8 @@ def _monthlyLimitValidator(option, value):
elif not units in acceptedUnits:
msg = "'%s' is an invalid unit, options include \"%s\"" % (units, "\", \"".join(acceptedUnits))
raise ValueError(msg)
+ elif (int(rate) < 50 and units == "MB") or int(rate) < 1:
+ raise ValueError("To be usable as a relay's monthly limit should be at least 50 MB")
def _bridgeDestinationValidator(option, value):
if value.count(":") != 1:
@@ -468,3 +471,18 @@ def _bridgeDestinationValidator(option, value):
elif not port.isdigit() or int(port) < 0 or int(port) > 65535:
raise ValueError("'%s' isn't a valid port number" % port)
+def _circDurationValidator(option, value):
+ if value.count(" ") != 1:
+ msg = "This should be a time measurement (for instance, \"10 minutes\")"
+ raise ValueError(msg)
+
+ rate, units = value.split(" ", 1)
+ acceptedUnits = ("minute", "minutes", "hour", "hours")
+ if not rate.isdigit():
+ raise ValueError("'%s' isn't an integer" % rate)
+ elif not units in acceptedUnits:
+ msg = "'%s' is an invalid rate, options include \"minutes\" or \"hours\""
+ raise ValueError(msg)
+ elif (int(rate) < 5 and units in ("minute", "minutes")) or int(rate) < 1:
+ raise ValueError("This would cause high network load, don't set this to less than five minutes")
+
More information about the tor-commits
mailing list