diff options
author | June McEnroe <june@causal.agency> | 2020-04-05 11:42:45 -0400 |
---|---|---|
committer | June McEnroe <june@causal.agency> | 2020-04-05 11:42:45 -0400 |
commit | b9afd7f8f8bbb799ec3e2f6c18edca1593c2c61b (patch) | |
tree | d064b9f0e43cf53c744e43ad67e3e35acc17fab5 /litterbox.c | |
parent | Parse mode types from ISUPPORT (diff) | |
download | litterbox-b9afd7f8f8bbb799ec3e2f6c18edca1593c2c61b.tar.gz litterbox-b9afd7f8f8bbb799ec3e2f6c18edca1593c2c61b.zip |
Log bans and unbans
Diffstat (limited to 'litterbox.c')
-rw-r--r-- | litterbox.c | 33 |
1 files changed, 33 insertions, 0 deletions
diff --git a/litterbox.c b/litterbox.c index aa6ca1a..4a65166 100644 --- a/litterbox.c +++ b/litterbox.c @@ -585,6 +585,38 @@ static void handleTopic(struct Message *msg) { insertEvent(msg, Topic, msg->params[0], NULL, msg->params[1]); } +static void handleMode(struct Message *msg) { + require(msg, true, 2); + if (!strchr(chanTypes, msg->params[0][0])) return; + insertContext(msg->params[0], false); + insertName(msg); + + bool set = true; + size_t param = 2; + for (char *ch = msg->params[1]; *ch; ++ch) { + if (*ch == '+') { + set = true; + } else if (*ch == '-') { + set = false; + } else if (*ch == 'b') { + if (param >= ParamCap || !msg->params[param]) { + errx(EX_PROTOCOL, "MODE missing ban target"); + } + insertEvent( + msg, (set ? Ban : Unban), msg->params[0], + msg->params[param++], NULL + ); + } else if ( + strchr(prefixModes, *ch) || + strchr(listModes, *ch) || + strchr(paramModes, *ch) || + (set && strchr(setParamModes, *ch)) + ) { + param++; + } + } +} + static void handlePing(struct Message *msg) { require(msg, false, 1); format("PONG :%s\r\n", msg->params[0]); @@ -617,6 +649,7 @@ static const struct Handler { { "ERROR", false, handleError }, { "JOIN", true, handleJoin }, { "KICK", true, handleKick }, + { "MODE", true, handleMode }, { "NICK", true, handleNick }, { "NOTICE", true, handlePrivmsg }, { "PART", true, handlePart }, |