[tor-commits] [arm/master] fix: torrc validation case sensetive
atagar at torproject.org
atagar at torproject.org
Wed Dec 7 17:22:49 UTC 2011
commit e7e4bb5a9a39857436620f71edba9092ff963247
Author: Damian Johnson <atagar at torproject.org>
Date: Wed Dec 7 09:17:29 2011 -0800
fix: torrc validation case sensetive
The torrc validation is case sensetive using tor's camelcase convention, but
tor's torrc parsing is case insensetive. This caused confusing torrc warnings
where, for instance, "Exitpolicy" would be reported as both being unused and
also missing an "ExitPolicy" option. Reported in...
https://trac.torproject.org/projects/tor/ticket/4601
This fix is functional but less than ideal since it makes the case
insensetivity non-obvious (we're essentially converting the torrc arguments
into the camelcase options we expect). I'll look into doing something nicer
while refactoring for stem.
Issue was caught on a Tor Cloud instance by kooly
---
src/util/torConfig.py | 19 ++++++++++++++++++-
1 files changed, 18 insertions(+), 1 deletions(-)
diff --git a/src/util/torConfig.py b/src/util/torConfig.py
index e26f634..851ef77 100644
--- a/src/util/torConfig.py
+++ b/src/util/torConfig.py
@@ -531,6 +531,21 @@ def validate(contents = None):
if len(lineComp) == 2: option, value = lineComp
else: option, value = lineText, ""
+ # Tor is case insensetive when parsing its torrc. This poses a bit of an
+ # issue for us because we want all of our checks to be case insensetive
+ # too but also want messages to match the normal camel-case conventions.
+ #
+ # Using the customOptions to account for this. It contains the tor reported
+ # options (camel case) and is either a matching set or the following defaut
+ # value check will fail. Hence using that hash to correct the case.
+ #
+ # TODO: when refactoring for stem make this less confusing...
+
+ for customOpt in customOptions:
+ if customOpt.lower() == option.lower():
+ option = customOpt
+ break
+
# if an aliased option then use its real name
if option in CONFIG["torrc.alias"]:
option = CONFIG["torrc.alias"][option]
@@ -787,7 +802,9 @@ class Torrc():
skipValidation = not CONFIG["features.torrc.validate"]
skipValidation |= not torTools.getConn().isVersion("0.2.2.7-alpha")
- if skipValidation: returnVal = {}
+ if skipValidation:
+ log.log(log.INFO, "Skipping torrc validation (requires tor 0.2.2.7-alpha)")
+ returnVal = {}
else:
if self.corrections == None:
self.corrections = validate(self.contents)
More information about the tor-commits
mailing list