X-Git-Url: https://jfr.im/git/erebus.git/blobdiff_plain/b2a896c852df233548af2c772bac07c76f184e3d..d431e54309841dcdb50d440e440234200d0de2fc:/modlib.py diff --git a/modlib.py b/modlib.py index abf1a3d..717406a 100644 --- a/modlib.py +++ b/modlib.py @@ -13,13 +13,24 @@ class error(object): return self.errormsg class modlib(object): - # default access levels + # default (global) access levels MANAGER = 100 - ADMIN = 90 - STAFF = 80 + ADMIN = 75 + STAFF = 50 AUTHED = 0 ANYONE = -1 + # (channel) access levels + OWNER = -10 + MASTER = -8 #master is {-8,-9} + OP = -5 #op is {-5,-6,-7} + VOICE = -4 + KNOWN = -3 + PUBLIC = -2 #anyone (use glevel to control auth-needed) + + # messages + WRONGARGS = "Wrong number of arguments." + def __init__(self, name): self.hooks = {} self.parent = None @@ -30,15 +41,40 @@ class modlib(object): self.parent = parent for cmd, func in self.hooks.iteritems(): self.parent.hook(cmd, func) + return True def modstop(self, parent): for cmd, func in self.hooks.iteritems(): - self.parent.unhook(cmd, func) + self.parent.unhook(cmd) + return True - def hook(self, cmd, level=ANYONE): + def hook(self, cmd, needchan=True, glevel=ANYONE, clevel=PUBLIC): def realhook(func): - func.reqlevel = level + func.needchan = needchan + func.reqglevel = glevel + func.reqclevel = clevel + self.hooks[cmd] = func if self.parent is not None: self.parent.hook(cmd, func) return func return realhook + + def argsEQ(self, num): + def realhook(func): + def checkargs(bot, user, chan, realtarget, *args): + if len(args) == num: + return func(bot, user, chan, realtarget, *args) + else: + bot.msg(user, self.WRONGARGS) + return checkargs + return realhook + + def argsGE(self, num): + def realhook(func): + def checkargs(bot, user, chan, realtarget, *args): + if len(args) >= num: + return func(bot, user, chan, realtarget, *args) + else: + bot.msg(user, self.WRONGARGS) + return checkargs + return realhook