2016-03-29 11:56:58 +00:00
|
|
|
import re, time
|
2018-10-03 12:22:37 +00:00
|
|
|
from src import EventManager, ModuleManager, utils
|
2016-03-29 11:56:58 +00:00
|
|
|
|
2018-09-09 17:39:56 +00:00
|
|
|
REGEX_KARMA = re.compile("^(.*[^-+])[-+]*(\+{2,}|\-{2,})$")
|
2019-01-25 23:45:44 +00:00
|
|
|
WORD_STOP = [",", ":"]
|
2016-03-29 11:56:58 +00:00
|
|
|
KARMA_DELAY_SECONDS = 3
|
|
|
|
|
2018-10-03 12:22:37 +00:00
|
|
|
@utils.export("channelset", {"setting": "karma-verbose",
|
2018-10-02 13:29:32 +00:00
|
|
|
"help": "Enable/disable automatically responding to karma changes",
|
2018-10-03 12:22:37 +00:00
|
|
|
"validate": utils.bool_or_none})
|
|
|
|
@utils.export("serverset", {"setting": "karma-nickname-only",
|
2018-10-02 13:29:32 +00:00
|
|
|
"help": "Enable/disable karma being for nicknames only",
|
2018-10-03 12:22:37 +00:00
|
|
|
"validate": utils.bool_or_none})
|
2018-09-27 11:08:07 +00:00
|
|
|
class Module(ModuleManager.BaseModule):
|
2019-01-11 17:33:43 +00:00
|
|
|
def _karma_str(self, karma):
|
|
|
|
karma_str = str(karma)
|
|
|
|
if karma < 0:
|
|
|
|
return utils.irc.color(str(karma), utils.consts.RED)
|
|
|
|
elif karma > 0:
|
2019-01-11 21:00:09 +00:00
|
|
|
return utils.irc.color(str(karma), utils.consts.LIGHTGREEN)
|
2019-01-11 17:33:43 +00:00
|
|
|
return str(karma)
|
|
|
|
|
|
|
|
|
2018-10-03 12:22:37 +00:00
|
|
|
@utils.hook("new.user")
|
2016-03-29 11:56:58 +00:00
|
|
|
def new_user(self, event):
|
|
|
|
event["user"].last_karma = None
|
|
|
|
|
2019-01-25 23:53:53 +00:00
|
|
|
@utils.hook("received.message.channel")
|
2016-03-29 11:56:58 +00:00
|
|
|
def channel_message(self, event):
|
2016-04-20 23:09:30 +00:00
|
|
|
match = re.match(REGEX_KARMA, event["message"].strip())
|
2016-06-24 12:10:36 +00:00
|
|
|
if match and not event["action"]:
|
2019-05-13 19:57:29 +00:00
|
|
|
is_ignored_f = self.exports.get_one("is-ignored",
|
2019-04-27 13:51:26 +00:00
|
|
|
lambda _1, _2: False)
|
2019-05-06 16:08:56 +00:00
|
|
|
if is_ignored_f(event["server"], event["user"], "karma"):
|
2019-04-27 13:51:26 +00:00
|
|
|
return
|
|
|
|
|
2019-05-13 19:58:44 +00:00
|
|
|
is_silenced_f = self.exports.get_one("is-silenced", lambda _: False)
|
2019-05-13 19:57:47 +00:00
|
|
|
if is_silenced_f(event["channel"]):
|
|
|
|
return
|
|
|
|
|
2016-05-01 21:47:59 +00:00
|
|
|
verbose = event["channel"].get_setting("karma-verbose", False)
|
2018-10-02 13:29:32 +00:00
|
|
|
nickname_only = event["server"].get_setting("karma-nickname-only",
|
|
|
|
False)
|
|
|
|
|
2016-03-29 11:56:58 +00:00
|
|
|
if not event["user"].last_karma or (time.time()-event["user"
|
|
|
|
].last_karma) >= KARMA_DELAY_SECONDS:
|
2019-03-28 14:35:20 +00:00
|
|
|
target = match.group(1).strip().rstrip("".join(WORD_STOP))
|
2019-01-24 17:12:50 +00:00
|
|
|
if event["server"].irc_lower(target) == event["user"].name:
|
2016-04-06 11:02:44 +00:00
|
|
|
if verbose:
|
2018-09-09 16:34:44 +00:00
|
|
|
self.events.on("send.stderr").call(
|
|
|
|
module_name="Karma", target=event["channel"],
|
2018-10-04 13:44:33 +00:00
|
|
|
message="You cannot change your own karma",
|
|
|
|
server=event["server"])
|
2018-10-02 13:29:32 +00:00
|
|
|
return
|
|
|
|
|
|
|
|
setting = "karma-%s" % target
|
|
|
|
setting_target = event["server"]
|
|
|
|
if nickname_only:
|
|
|
|
user = event["server"].get_user(target)
|
2018-10-02 14:14:34 +00:00
|
|
|
setting = "karma"
|
2018-10-02 13:29:32 +00:00
|
|
|
setting_target = user
|
|
|
|
if not event["channel"].has_user(user):
|
|
|
|
return
|
|
|
|
|
|
|
|
positive = match.group(2)[0] == "+"
|
2018-10-02 14:14:34 +00:00
|
|
|
karma = setting_target.get_setting(setting, 0)
|
2018-10-02 13:29:32 +00:00
|
|
|
karma += 1 if positive else -1
|
|
|
|
|
2019-01-11 17:33:43 +00:00
|
|
|
if not karma == 0:
|
2018-10-02 14:14:34 +00:00
|
|
|
setting_target.set_setting(setting, karma)
|
2018-10-02 13:29:32 +00:00
|
|
|
else:
|
2018-10-02 14:14:34 +00:00
|
|
|
setting_target.del_setting(setting)
|
2018-10-02 13:29:32 +00:00
|
|
|
|
2019-01-11 17:33:43 +00:00
|
|
|
karma_str = self._karma_str(karma)
|
2018-10-02 13:29:32 +00:00
|
|
|
if verbose:
|
|
|
|
self.events.on("send.stdout").call(
|
|
|
|
module_name="Karma", target=event["channel"],
|
2019-01-11 17:35:18 +00:00
|
|
|
message="%s now has %s karma" % (target, karma_str),
|
2018-10-04 13:44:33 +00:00
|
|
|
server=event["server"])
|
2018-10-02 13:29:32 +00:00
|
|
|
event["user"].last_karma = time.time()
|
2016-04-20 23:09:30 +00:00
|
|
|
elif verbose:
|
2018-09-09 16:34:44 +00:00
|
|
|
self.events.on("send.stderr").call(module_name="Karma",
|
2018-10-04 13:44:33 +00:00
|
|
|
target=event["channel"], server=event["server"],
|
2018-09-09 16:34:44 +00:00
|
|
|
message="Try again in a couple of seconds")
|
|
|
|
|
2018-10-03 12:22:37 +00:00
|
|
|
@utils.hook("received.command.karma")
|
2016-03-29 11:56:58 +00:00
|
|
|
def karma(self, event):
|
2018-09-26 17:27:17 +00:00
|
|
|
"""
|
2018-09-30 16:29:09 +00:00
|
|
|
:help: Get your or someone else's karma
|
|
|
|
:usage: [target]
|
2018-09-26 17:27:17 +00:00
|
|
|
"""
|
2016-03-29 11:56:58 +00:00
|
|
|
if event["args"]:
|
|
|
|
target = event["args"]
|
|
|
|
else:
|
|
|
|
target = event["user"].nickname
|
2018-10-02 14:14:42 +00:00
|
|
|
target = target.strip()
|
2018-10-02 13:29:32 +00:00
|
|
|
|
|
|
|
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)
|
2019-01-11 17:33:43 +00:00
|
|
|
karma_str = self._karma_str(karma)
|
|
|
|
event["stdout"].write("%s has %s karma" % (target, karma_str))
|
2018-08-18 17:28:27 +00:00
|
|
|
|
2018-10-03 12:22:37 +00:00
|
|
|
@utils.hook("received.command.resetkarma", min_args=1)
|
2018-08-18 17:28:27 +00:00
|
|
|
def reset_karma(self, event):
|
2018-09-26 17:27:17 +00:00
|
|
|
"""
|
2018-09-30 16:29:09 +00:00
|
|
|
:help: Reset a specified karma to 0
|
|
|
|
:usage: <target>
|
|
|
|
:permission: resetkarme
|
2018-09-26 17:27:17 +00:00
|
|
|
"""
|
2018-08-18 17:28:27 +00:00
|
|
|
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])
|