X-Git-Url: https://jfr.im/git/erebus.git/blobdiff_plain/32cabc3d9b1e7cc05b0c2c7f8519e137053ac66b..321c1b02b1f0f93b82fe3ee84b895d68477ead8a:/modules/eval.py diff --git a/modules/eval.py b/modules/eval.py index 159635f..00f37eb 100644 --- a/modules/eval.py +++ b/modules/eval.py @@ -1,12 +1,15 @@ -# Erebus IRC bot - Author: John Runyon +# Erebus IRC bot - Author: Erebus Team +# vim: fileencoding=utf-8 # !EVAL and !EXEC commands +# This file is released into the public domain; see http://unlicense.org/ # module info modinfo = { - 'author': 'John Runyon (DimeCadmium)', + 'author': 'Erebus Team', 'license': 'public domain', - 'compatible': [1], + 'compatible': [0], 'depends': [], + 'softdeps': ['help'], } # preamble @@ -17,25 +20,36 @@ modstop = lib.modstop # module code import sys +import ctlmod -@lib.hook('eval', needchan=False, glevel=lib.MANAGER) +def module(name): + return lib.mod(name) + +@lib.hook('eval', needchan=False, wantchan=True, glevel=lib.OWNER) +@lib.help("", "eval") @lib.argsGE(1) def cmd_eval(bot, user, chan, realtarget, *args): if chan is not None: replyto = chan else: replyto = user try: ret = eval(' '.join(args)) - except: bot.msg(replyto, "Error (%s): %s" % (sys.exc_info()[0], sys.exc_info()[1])) - else: bot.msg(replyto, "Done: %r" % (ret)) + except Exception: bot.msg(replyto, "Error: %s %s" % (sys.exc_info()[0], sys.exc_info()[1])) + else: bot.msg(replyto, "Done: %r" % (ret,)) -@lib.hook('exec', needchan=False, glevel=lib.MANAGER) +@lib.hook('exec', needchan=False, wantchan=True, glevel=lib.OWNER) +@lib.help("", "exec") @lib.argsGE(1) def cmd_exec(bot, user, chan, realtarget, *args): if chan is not None: replyto = chan else: replyto = user - try: exec ' '.join(args) - except: bot.msg(replyto, "Error: %s %s" % (sys.exc_info()[0], sys.exc_info()[1])) + try: exec(' '.join(args)) + except Exception: bot.msg(replyto, "Error: %s %s" % (sys.exc_info()[0], sys.exc_info()[1])) else: bot.msg(replyto, "Done.") + +@lib.hook('exception', needchan=False, glevel=lib.OWNER) +@lib.help(None, "cause an exception") +def cmd_exception(*args, **kwargs): + raise Exception()