[tor-commits] [arm/master] Moving connection resolution init into initController()
atagar at torproject.org
atagar at torproject.org
Mon Oct 21 21:10:15 UTC 2013
commit 7da1bda89b2f49ae75fd0953d6e43d1f1f5468b2
Author: Damian Johnson <atagar at torproject.org>
Date: Fri Oct 18 11:13:46 2013 -0700
Moving connection resolution init into initController()
Shifting where we initialize our connection resolver and provide a notice about
DisableDebuggerAttachment. I'm not a fan of this change, but I'm trying to
eliminate the start_arm() function. This is kicking the can down the road for
this chunk of code, but hopefully by then we'll be able to handle
DisableDebuggerAttachment.
---
arm/controller.py | 67 ++++++++++++++++++++++++++---------------------------
1 file changed, 33 insertions(+), 34 deletions(-)
diff --git a/arm/controller.py b/arm/controller.py
index 8fc198b..247f6a5 100644
--- a/arm/controller.py
+++ b/arm/controller.py
@@ -92,6 +92,39 @@ def initController(stdscr, startTime):
if CONFIG["features.panels.show.connection"]:
pagePanels.append([arm.connections.connPanel.ConnectionPanel(stdscr)])
+ # The DisableDebuggerAttachment will prevent our connection panel from really
+ # functioning. It'll have circuits, but little else. If this is the case then
+ # notify the user and tell them what they can do to fix it.
+
+ controller = torTools.getConn().controller
+
+ if controller.get_conf("DisableDebuggerAttachment", None) == "1":
+ log.notice("Tor is preventing system utilities like netstat and lsof from working. This means that arm can't provide you with connection information. You can change this by adding 'DisableDebuggerAttachment 0' to your torrc and restarting tor. For more information see...\nhttps://trac.torproject.org/3313")
+ connections.get_resolver().set_paused(True)
+ else:
+ # Configures connection resoultions. This is paused/unpaused according to
+ # if Tor's connected or not.
+
+ controller.add_status_listener(connResetListener)
+
+ tor_pid = controller.get_pid(None)
+
+ if tor_pid:
+ # use the tor pid to help narrow connection results
+ tor_cmd = system.get_name_by_pid(tor_pid)
+
+ if tor_cmd is None:
+ tor_cmd = "tor"
+
+ resolver = connections.get_resolver()
+ resolver.set_process(tor_pid, tor_cmd)
+ log.info("Operating System: %s, Connection Resolvers: %s" % (os.uname()[0], ", ".join(resolver._resolvers)))
+ resolver.start()
+ else:
+ # constructs singleton resolver and, if tor isn't connected, initizes
+ # it to be paused
+ connections.get_resolver().set_paused(not controller.is_alive())
+
# third page: config
if CONFIG["features.panels.show.config"]:
pagePanels.append([arm.configPanel.ConfigPanel(stdscr, arm.configPanel.State.TOR)])
@@ -518,40 +551,6 @@ def start_arm():
Initializes the interface and starts the main draw loop.
"""
- if CONFIG["features.panels.show.connection"]:
- # The DisableDebuggerAttachment will prevent our connection panel from really
- # functioning. It'll have circuits, but little else. If this is the case then
- # notify the user and tell them what they can do to fix it.
-
- controller = torTools.getConn().controller
-
- if controller.get_conf("DisableDebuggerAttachment", None) == "1":
- log.notice("Tor is preventing system utilities like netstat and lsof from working. This means that arm can't provide you with connection information. You can change this by adding 'DisableDebuggerAttachment 0' to your torrc and restarting tor. For more information see...\nhttps://trac.torproject.org/3313")
- connections.get_resolver().set_paused(True)
- else:
- # Configures connection resoultions. This is paused/unpaused according to
- # if Tor's connected or not.
-
- controller.add_status_listener(connResetListener)
-
- tor_pid = controller.get_pid(None)
-
- if tor_pid:
- # use the tor pid to help narrow connection results
- tor_cmd = system.get_name_by_pid(tor_pid)
-
- if tor_cmd is None:
- tor_cmd = "tor"
-
- resolver = connections.get_resolver()
- resolver.set_process(tor_pid, tor_cmd)
- log.info("Operating System: %s, Connection Resolvers: %s" % (os.uname()[0], ", ".join(resolver._resolvers)))
- resolver.start()
- else:
- # constructs singleton resolver and, if tor isn't connected, initizes
- # it to be paused
- connections.get_resolver().set_paused(not controller.is_alive())
-
try:
curses.wrapper(drawTorMonitor)
except UnboundLocalError as exc:
More information about the tor-commits
mailing list