2016-03-29 11:56:58 +00:00
|
|
|
import re, traceback
|
2016-04-10 16:40:58 +00:00
|
|
|
import Utils
|
2016-03-29 11:56:58 +00:00
|
|
|
|
|
|
|
REGEX_SPLIT = re.compile("(?<!\\\\)/")
|
|
|
|
REGEX_SED = re.compile("^s/")
|
|
|
|
|
|
|
|
class Module(object):
|
2018-09-02 18:54:45 +00:00
|
|
|
def __init__(self, bot, events, exports):
|
2016-03-29 11:56:58 +00:00
|
|
|
self.bot = bot
|
2018-08-31 11:55:52 +00:00
|
|
|
self.events = events
|
2018-09-19 12:25:12 +00:00
|
|
|
events.on("received.message.channel").hook(self.channel_message)
|
2016-03-29 11:56:58 +00:00
|
|
|
|
2018-09-02 18:54:45 +00:00
|
|
|
exports.add("channelset", {"setting": "sed",
|
|
|
|
"help": "Disable/Enable sed in a channel",
|
|
|
|
"validate": Utils.bool_or_none})
|
|
|
|
exports.add("channelset", {"setting": "sed-sender-only",
|
|
|
|
"help": "Disable/Enable sed only looking at the messages "
|
|
|
|
"sent by the user", "validate": Utils.bool_or_none})
|
2016-03-29 11:56:58 +00:00
|
|
|
|
|
|
|
def channel_message(self, event):
|
|
|
|
sed_split = re.split(REGEX_SPLIT, event["message"], 3)
|
|
|
|
if event["message"].startswith("s/") and len(sed_split) > 2:
|
2018-08-05 14:35:23 +00:00
|
|
|
if event["action"] or not Utils.get_closest_setting(
|
2018-09-21 10:55:17 +00:00
|
|
|
event, "sed", False):
|
2018-08-05 14:35:23 +00:00
|
|
|
return
|
|
|
|
|
2016-03-29 11:56:58 +00:00
|
|
|
regex_flags = 0
|
|
|
|
flags = (sed_split[3:] or [""])[0]
|
|
|
|
count = None
|
|
|
|
|
|
|
|
last_flag = ""
|
|
|
|
for flag in flags:
|
|
|
|
if flag.isdigit():
|
|
|
|
if last_flag.isdigit():
|
|
|
|
count = int(str(count) + flag)
|
|
|
|
elif not count:
|
|
|
|
count = int(flag)
|
|
|
|
elif flag == "i":
|
|
|
|
regex_flags |= re.I
|
|
|
|
elif flag == "g":
|
|
|
|
count = 0
|
|
|
|
last_flag = flag
|
|
|
|
if count == None:
|
|
|
|
count = 1
|
|
|
|
|
|
|
|
try:
|
|
|
|
pattern = re.compile(sed_split[1], regex_flags)
|
|
|
|
except:
|
|
|
|
traceback.print_exc()
|
2018-09-19 12:25:12 +00:00
|
|
|
self.events.on("send.stderr").call(target=event["channel"],
|
|
|
|
module_name="Sed", server=event["server"],
|
2016-03-29 11:56:58 +00:00
|
|
|
message="Invalid regex in pattern")
|
|
|
|
return
|
|
|
|
replace = sed_split[2].replace("\\/", "/")
|
|
|
|
|
2017-10-27 12:15:33 +00:00
|
|
|
for_user = event["user"].nickname if Utils.get_closest_setting(
|
|
|
|
event, "sed-sender-only", False
|
|
|
|
) else None
|
2018-08-28 13:55:35 +00:00
|
|
|
line = event["channel"].buffer.find(pattern, from_self=False,
|
2017-10-27 12:15:33 +00:00
|
|
|
for_user=for_user, not_pattern=REGEX_SED)
|
2016-03-29 11:56:58 +00:00
|
|
|
if line:
|
|
|
|
new_message = re.sub(pattern, replace, line.message, count)
|
|
|
|
if line.action:
|
|
|
|
prefix = "* %s" % line.sender
|
|
|
|
else:
|
|
|
|
prefix = "<%s>" % line.sender
|
2018-09-19 12:25:12 +00:00
|
|
|
self.events.on("send.stdout").call(target=event[
|
2016-03-29 11:56:58 +00:00
|
|
|
"channel"], module_name="Sed", server=event["server"],
|
|
|
|
message="%s %s" % (prefix, new_message))
|