[or-cvs] r23866: {arm} Display and validation for multiline torrc entries. fix: err (in arm/trunk: . src/interface src/util)
Damian Johnson
atagar1 at gmail.com
Sun Nov 28 00:03:04 UTC 2010
Author: atagar
Date: 2010-11-28 00:03:03 +0000 (Sun, 28 Nov 2010)
New Revision: 23866
Modified:
arm/trunk/README
arm/trunk/src/interface/configPanel.py
arm/trunk/src/interface/controller.py
arm/trunk/src/interface/torrcPanel.py
arm/trunk/src/util/torConfig.py
Log:
Display and validation for multiline torrc entries.
fix: error in parsing single line csv values (wasn't stripping internal spaces)
Modified: arm/trunk/README
===================================================================
--- arm/trunk/README 2010-11-27 21:55:13 UTC (rev 23865)
+++ arm/trunk/README 2010-11-28 00:03:03 UTC (rev 23866)
@@ -122,8 +122,8 @@
connPanel.py - (page 2) displays information on tor connections
descriptorPopup.py - (popup) displays connection descriptor data
- configFilePanel.py - (page 3) displays torrc/armrc and validation
- configStatePanel.py - editor panel for the tor and arm config states
+ configPanel.py - (page 3) editor panel for the tor configuration
+ torrcPanel.py - (page 4) displays torrc and validation
util/
__init__.py
Modified: arm/trunk/src/interface/configPanel.py
===================================================================
--- arm/trunk/src/interface/configPanel.py 2010-11-27 21:55:13 UTC (rev 23865)
+++ arm/trunk/src/interface/configPanel.py 2010-11-28 00:03:03 UTC (rev 23866)
@@ -101,7 +101,7 @@
return [self.get(field) for field in argTypes]
-class ConfigStatePanel(panel.Panel):
+class ConfigPanel(panel.Panel):
"""
Renders a listing of the tor or arm configuration state, allowing options to
be selected and edited.
Modified: arm/trunk/src/interface/controller.py
===================================================================
--- arm/trunk/src/interface/controller.py 2010-11-27 21:55:13 UTC (rev 23865)
+++ arm/trunk/src/interface/controller.py 2010-11-28 00:03:03 UTC (rev 23866)
@@ -517,8 +517,8 @@
panels["conn"] = connPanel.ConnPanel(stdscr, conn, isBlindMode)
panels["control"] = ControlPanel(stdscr, isBlindMode)
- panels["config"] = configPanel.ConfigStatePanel(stdscr, configPanel.TOR_STATE, config)
- panels["torrc"] = torrcPanel.ConfigFilePanel(stdscr, torrcPanel.TORRC, config)
+ panels["config"] = configPanel.ConfigPanel(stdscr, configPanel.TOR_STATE, config)
+ panels["torrc"] = torrcPanel.TorrcPanel(stdscr, torrcPanel.TORRC, config)
# provides error if pid coulnd't be determined (hopefully shouldn't happen...)
if not torPid: log.log(log.WARN, "Unable to resolve tor pid, abandoning connection listing")
Modified: arm/trunk/src/interface/torrcPanel.py
===================================================================
--- arm/trunk/src/interface/torrcPanel.py 2010-11-27 21:55:13 UTC (rev 23865)
+++ arm/trunk/src/interface/torrcPanel.py 2010-11-28 00:03:03 UTC (rev 23866)
@@ -13,7 +13,7 @@
TORRC, ARMRC = range(1, 3) # configuration file types that can be displayed
-class ConfigFilePanel(panel.Panel):
+class TorrcPanel(panel.Panel):
"""
Renders the current torrc or armrc with syntax highlighting in a scrollable
area.
@@ -111,6 +111,7 @@
locationLabel = " (%s)" % confLocation if confLocation else ""
self.addstr(0, 0, "%s Configuration File%s:" % (sourceLabel, locationLabel), curses.A_STANDOUT)
+ isMultiline = False # set if we're in the middle of a multiline torrc entry
for lineNumber in range(0, len(renderedContents)):
lineText = renderedContents[lineNumber]
lineText = lineText.rstrip() # remove ending whitespace
@@ -133,14 +134,23 @@
# splits the option and argument, preserving any whitespace around them
strippedLine = lineText.strip()
optionIndex = strippedLine.find(" ")
- if optionIndex == -1:
- lineComp["option"][0] = lineText # no argument provided
+ if isMultiline:
+ # part of a multiline entry started on a previous line so everything
+ # is part of the argument
+ lineComp["argument"][0] = lineText
+ elif optionIndex == -1:
+ # no argument provided
+ lineComp["option"][0] = lineText
else:
optionText = strippedLine[:optionIndex]
optionEnd = lineText.find(optionText) + len(optionText)
lineComp["option"][0] = lineText[:optionEnd]
lineComp["argument"][0] = lineText[optionEnd:]
+ # flags following lines as belonging to this multiline entry if it ends
+ # with a slash
+ if strippedLine: isMultiline = strippedLine.endswith("\\")
+
# gets the correction
if lineNumber in corrections:
lineIssue, lineIssueMsg = corrections[lineNumber]
Modified: arm/trunk/src/util/torConfig.py
===================================================================
--- arm/trunk/src/util/torConfig.py 2010-11-27 21:55:13 UTC (rev 23865)
+++ arm/trunk/src/util/torConfig.py 2010-11-28 00:03:03 UTC (rev 23866)
@@ -333,14 +333,27 @@
contents - torrc contents
"""
- # TODO: needs to recognize tor's new multiline values
+ conn = torTools.getConn()
+ issuesFound, seenOptions = {}, []
+
+ # Strips comments and collapses multiline multi-line entries, for more
+ # information see:
# https://trac.torproject.org/projects/tor/ticket/1929
+ strippedContents, multilineBuffer = [], ""
+ for line in _stripComments(contents):
+ if not line: strippedContents.append("")
+ else:
+ line = multilineBuffer + line
+ multilineBuffer = ""
+
+ if line.endswith("\\"):
+ multilineBuffer = line[:-1]
+ strippedContents.append("")
+ else:
+ strippedContents.append(line.strip())
- conn = torTools.getConn()
- contents = _stripComments(contents)
- issuesFound, seenOptions = {}, []
- for lineNumber in range(len(contents) - 1, -1, -1):
- lineText = contents[lineNumber]
+ for lineNumber in range(len(strippedContents) - 1, -1, -1):
+ lineText = strippedContents[lineNumber]
if not lineText: continue
lineComp = lineText.split(None, 1)
@@ -367,6 +380,14 @@
# issues GETCONF to get the values tor's currently configured to use
torValues = conn.getOption(option, [], True)
+ # Some singleline entries are lists, in which case tor provides csv values
+ # without spaces, such as:
+ # lolcat1,lolcat2,cutebunny,extracutebunny,birthdaynode
+ # so we need to strip spaces in comma separated values.
+
+ if "," in value:
+ value = ",".join([val.strip() for val in value.split(",")])
+
# multiline entries can be comma separated values (for both tor and conf)
valueList = [value]
if option in getMultilineParameters():
More information about the tor-commits
mailing list