[tor-commits] [nyx/master] Allow us to listen to events besides a hardcoded list
atagar at torproject.org
atagar at torproject.org
Tue Jun 7 17:30:03 UTC 2016
commit 05de899d707859e66cbc82c8d72427a0276c2c58
Author: Damian Johnson <atagar at torproject.org>
Date: Tue Jun 7 10:09:33 2016 -0700
Allow us to listen to events besides a hardcoded list
Despite having a dialog that populates from tor we filtered down to a hardcoded
list of acceptable events when registering the actual listener.
---
nyx/arguments.py | 71 ------------------------------------------------
nyx/log.py | 6 +---
nyx/panel/log.py | 2 +-
nyx/settings/strings.cfg | 1 -
4 files changed, 2 insertions(+), 78 deletions(-)
diff --git a/nyx/arguments.py b/nyx/arguments.py
index f771e0b..bb0939e 100644
--- a/nyx/arguments.py
+++ b/nyx/arguments.py
@@ -41,50 +41,6 @@ OPT_EXPANDED = [
'help',
]
-TOR_EVENT_TYPES = {
- # runlevels
-
- 'd': 'DEBUG',
- 'i': 'INFO',
- 'n': 'NOTICE',
- 'w': 'WARN',
- 'e': 'ERR',
-
- # important events
-
- 'b': 'BW',
- 'c': 'CIRC',
- 's': 'STREAM',
-
- # everything else
-
- 'a': 'ADDRMAP',
- 'f': 'AUTHDIR_NEWDESCS',
- 'j': 'BUILDTIMEOUT_SET',
- 'k': 'CELL_STATS',
- 'l': 'CIRC_BW',
- 'm': 'CIRC_MINOR',
- 'p': 'CONF_CHANGED',
- 'q': 'CONN_BW',
- 'r': 'CLIENTS_SEEN',
- 'u': 'DESCCHANGED',
- 'g': 'GUARD',
- 'h': 'HS_DESC',
- 'v': 'HS_DESC_CONTENT',
- 'x': 'NETWORK_LIVENESS',
- 'y': 'NEWCONSENSUS',
- 'z': 'NEWDESC',
- 'B': 'NS',
- 'o': 'ORCONN',
- 'C': 'SIGNAL',
- 'F': 'STREAM_BW',
- 'G': 'STATUS_CLIENT',
- 'H': 'STATUS_GENERAL',
- 'I': 'STATUS_SERVER',
- 'J': 'TB_EMPTY',
- 't': 'TRANSPORT_LAUNCHED',
-}
-
def parse(argv):
"""
@@ -134,11 +90,6 @@ def parse(argv):
elif opt in ('-d', '--debug'):
args['debug_path'] = os.path.expanduser(arg)
elif opt in ('-l', '--log'):
- try:
- validate_events(arg)
- except ValueError as exc:
- raise ValueError(msg('usage.unrecognized_log_events', events = exc))
-
args['logged_events'] = arg
elif opt in ('-v', '--version'):
args['print_version'] = True
@@ -179,25 +130,3 @@ def get_version():
version = nyx.__version__,
date = nyx.__release_date__,
)
-
-
-def validate_events(events):
- """
- Check whether the events are any one of Tor runlevels, Nyx runlevels or
- Tor events.
- """
-
- valid_events = set(TOR_EVENT_TYPES.values() + nyx.log.NYX_RUNLEVELS)
- accepted_events, invalid_events = set(), set()
-
- events = events.split(',')
- for event in events:
- if event in valid_events:
- accepted_events.update([event])
- else:
- invalid_events.update([event])
-
- if invalid_events:
- raise ValueError(','.join(invalid_events))
- else:
- return accepted_events
diff --git a/nyx/log.py b/nyx/log.py
index 3929548..255fac7 100644
--- a/nyx/log.py
+++ b/nyx/log.py
@@ -182,13 +182,9 @@ def listen_for_events(listener, events):
:returns: **list** of event types we're successfully now listening to
"""
- import nyx.arguments
events = set(events) # drops duplicates
-
- # accounts for runlevel naming difference
-
- tor_events = events.intersection(set(nyx.arguments.TOR_EVENT_TYPES.values()))
nyx_events = events.intersection(set(NYX_RUNLEVELS))
+ tor_events = events.difference(nyx_events)
controller = nyx.tor_controller()
controller.remove_event_listener(listener)
diff --git a/nyx/panel/log.py b/nyx/panel/log.py
index 9e530c1..5fd0cdf 100644
--- a/nyx/panel/log.py
+++ b/nyx/panel/log.py
@@ -68,7 +68,7 @@ class LogPanel(nyx.panel.DaemonPanel):
def __init__(self):
nyx.panel.DaemonPanel.__init__(self, 'log', UPDATE_RATE)
- logged_events = nyx.arguments.validate_events(CONFIG['startup.events'])
+ logged_events = CONFIG['startup.events'].split(',')
self._event_log = nyx.log.LogGroup(CONFIG['cache.log_panel.size'], group_by_day = True)
self._event_log_paused = None
self._event_types = nyx.log.listen_for_events(self._register_tor_event, logged_events)
diff --git a/nyx/settings/strings.cfg b/nyx/settings/strings.cfg
index c19930b..98df411 100644
--- a/nyx/settings/strings.cfg
+++ b/nyx/settings/strings.cfg
@@ -48,7 +48,6 @@ msg.tracker.unable_to_use_resolver Unable to query connections with {old_resolve
msg.usage.invalid_arguments {error} (for usage provide --help)
msg.usage.not_a_valid_address '{address_input}' isn't a valid IPv4 address
msg.usage.not_a_valid_port '{port_input}' isn't a valid port number
-msg.usage.unrecognized_log_events Unrecognized events: {events}
msg.usage.unable_to_set_color_override "{color}" isn't a valid color
msg.debug.header
More information about the tor-commits
mailing list