import re, time from src import EventManager, ModuleManager, utils REGEX_KARMA = re.compile("^(.*[^-+])[-+]*(\+{2,}|\-{2,})$") KARMA_DELAY_SECONDS = 3 @utils.export("channelset", {"setting": "karma-verbose", "help": "Enable/disable automatically responding to karma changes", "validate": utils.bool_or_none}) @utils.export("serverset", {"setting": "karma-nickname-only", "help": "Enable/disable karma being for nicknames only", "validate": utils.bool_or_none}) class Module(ModuleManager.BaseModule): @utils.hook("new.user") def new_user(self, event): event["user"].last_karma = None @utils.hook("received.message.channel", priority=EventManager.PRIORITY_MONITOR) def channel_message(self, event): match = re.match(REGEX_KARMA, event["message"].strip()) if match and not event["action"]: verbose = event["channel"].get_setting("karma-verbose", False) nickname_only = event["server"].get_setting("karma-nickname-only", False) if not event["user"].last_karma or (time.time()-event["user" ].last_karma) >= KARMA_DELAY_SECONDS: target = match.group(1).strip() if utils.irc.lower(event["server"].case_mapping, target ) == event["user"].name: if verbose: self.events.on("send.stderr").call( module_name="Karma", target=event["channel"], message="You cannot change your own karma", server=event["server"]) return setting = "karma-%s" % target setting_target = event["server"] if nickname_only: user = event["server"].get_user(target) setting = "karma" setting_target = user if not event["channel"].has_user(user): return positive = match.group(2)[0] == "+" karma = setting_target.get_setting(setting, 0) karma += 1 if positive else -1 if karma: setting_target.set_setting(setting, karma) else: setting_target.del_setting(setting) if verbose: self.events.on("send.stdout").call( module_name="Karma", target=event["channel"], message="%s now has %d karma" % (target, karma), server=event["server"]) event["user"].last_karma = time.time() elif verbose: self.events.on("send.stderr").call(module_name="Karma", target=event["channel"], server=event["server"], message="Try again in a couple of seconds") @utils.hook("received.command.karma") def karma(self, event): """ :help: Get your or someone else's karma :usage: [target] """ if event["args"]: target = event["args"] else: target = event["user"].nickname target = target.strip() if event["server"].get_setting("karma-nickname-only", False): karma = event["server"].get_user(target).get_setting("karma", 0) else: karma = event["server"].get_setting("karma-%s" % target, 0) event["stdout"].write("%s has %s karma" % (target, karma)) @utils.hook("received.command.resetkarma", min_args=1) def reset_karma(self, event): """ :help: Reset a specified karma to 0 :usage: :permission: resetkarme """ setting = "karma-%s" % event["args_split"][0] karma = event["server"].get_setting(setting, 0) if karma == 0: event["stderr"].write("%s already has 0 karma" % event[ "args_split"][0]) else: event["server"].del_setting(setting) event["stdout"].write("Reset karma for %s" % event[ "args_split"][0])