|
- # -*- coding: utf-8 -*-
-
- # Manage wiki tasks from IRC, and check on thread status.
-
- import threading, re
-
- from irc.base_command import BaseCommand
- from irc.data import *
- from wiki import task_manager
- from config.main import *
- from config.irc import *
-
- class Tasks(BaseCommand):
- def get_hooks(self):
- return ["msg"]
-
- def get_help(self, command):
- return "Manage wiki tasks from IRC, and check on thread status."
-
- def check(self, data):
- if data.is_command and data.command in ["tasks", "threads", "tasklist"]:
- return True
- return False
-
- def process(self, data):
- self.data = data
- if data.host not in OWNERS:
- self.connection.reply(data, "at this time, you must be a bot owner to use this command.")
- return
-
- if not data.args:
- if data.command == "tasklist":
- self.do_list()
- else:
- self.connection.reply(data, "no arguments provided. Maybe you wanted '!{cmnd} list', '!{cmnd} start', or '!{cmnd} listall'?".format(cmnd=data.command))
- return
-
- if data.args[0] == "list":
- self.do_list()
-
- elif data.args[0] == "start":
- self.do_start()
-
- elif data.args[0] in ["listall", "all"]:
- self.do_listall()
-
- else: # they asked us to do something we don't know
- self.connection.reply(data, "unknown argument: \x0303{}\x0301.".format(data.args[0]))
-
- def do_list(self):
- threads = threading.enumerate()
-
- normal_threads = []
- task_threads = []
-
- for thread in threads:
- tname = thread.name
- if tname == "MainThread":
- tname = self.get_main_thread_name()
- normal_threads.append("\x0302{}\x0301 (as main thread, id {})".format(tname, thread.ident))
- elif tname in ["irc-frontend", "irc-watcher", "wiki-scheduler"]:
- normal_threads.append("\x0302{}\x0301 (id {})".format(tname, thread.ident))
- else:
- tname, start_time = re.findall("^(.*?) \((.*?)\)$")[0]
- task_threads.append("\x0302{}\x0301 (id {}, spawned at {})".format(tname, thread.ident, start_time))
-
- if task_threads:
- msg = "\x02{}\x0F threads active: {}, and \x02{}\x0F task threads: {}.".format(len(threads), ', '.join(normal_threads), len(task_threads), ', '.join(task_threads))
- else:
- msg = "\x02{}\x0F threads active: {}, and \x020\x0F task threads.".format(len(threads), ', '.join(normal_threads))
- self.connection.reply(self.data, msg)
-
- def do_listall(self):
- tasks = task_manager.task_list.keys()
- threadlist = threading.enumerate()
- threads = map(lambda t: t.name, threadlist)
- tasklist = []
-
- tasks.sort()
-
- for task in tasks:
- if task in threads:
- threads_running_task = [t for t in threads if t.name.startswith(task)]
- ids = map(lambda t: t.ident, threads_running_task)
- if len(ids) == 1:
- tasklist.append("\x0302{}\x0301 (\x02active\x0F as id {})".format(task, ids[0]))
- else:
- tasklist.append("\x0302{}\x0301 (\x02active\x0F as ids {})".format(task, ' ,'.join(ids)))
- else:
- tasklist.append("\x0302{}\x0301 (idle)".format(task))
-
- tasklist = ", ".join(tasklist)
-
- msg = "{} tasks loaded: {}.".format(len(tasks), tasklist)
- self.connection.reply(self.data, msg)
-
- def do_start(self):
- data = self.data
-
- try:
- task_name = data.args[1]
- except IndexError: # no task name given
- self.connection.reply(data, "what task do you want me to start?")
- return
-
- try:
- data.parse_kwargs()
- except KwargParseException, arg:
- self.connection.reply(data, "error parsing argument: \x0303{}\x0301.".format(arg))
- return
-
- if task_name not in task_manager.task_list.keys(): # this task does not exist or hasn't been loaded
- self.connection.reply(data, "task could not be found; either wiki/tasks/{}.py doesn't exist, or it wasn't loaded correctly.".format(task_name))
- return
-
- if data.kwargs:
- task_manager.start_task(task_name, **data.kwargs)
- self.connection.reply(data, "task \x0302{}\x0301 started with arguments: {}.".format(task_name, data.kwargs))
- else:
- task_manager.start_task(task_name)
- self.connection.reply(data, "task \x0302{}\x0301 started.".format(task_name))
-
- def get_main_thread_name(self):
- """Return the "proper" name of the MainThread; e.g. "irc-frontend" or "irc-watcher"."""
- if enable_irc_frontend:
- return "irc-frontend"
- elif enable_wiki_schedule:
- return "wiki-scheduler"
- else:
- return "irc-watcher"
|