summary refs log tree commit diff
diff options
context:
space:
mode:
authorJune McEnroe <june@causal.agency>2019-11-10 18:13:52 -0500
committerJune McEnroe <june@causal.agency>2019-11-10 18:13:52 -0500
commitdbfe19bb701fdef6e5a7d5d73c0856cac741d82e (patch)
tree08b59b4cd13bafa822bd006421d96ceea619e78b
parentRename listen to local (diff)
downloadpounce-dbfe19bb701fdef6e5a7d5d73c0856cac741d82e.tar.gz
pounce-dbfe19bb701fdef6e5a7d5d73c0856cac741d82e.zip
Filter ACCOUNT, AWAY, CHGHOST for incapable clients
Diffstat (limited to '')
-rw-r--r--client.c42
1 files changed, 42 insertions, 0 deletions
diff --git a/client.c b/client.c
index 40bba1c..ec07b91 100644
--- a/client.c
+++ b/client.c
@@ -275,10 +275,52 @@ size_t clientDiff(const struct Client *client) {
 	return ringDiff(client->consumer);
 }
 
+typedef const char *Filter(const char *line);
+
+static const char *cmd(const char *line) {
+	static char buf[512];
+	if (*line == ':') {
+		line += strcspn(line, " ");
+		if (*line) line++;
+	}
+	snprintf(buf, sizeof(buf), "%.*s", (int)strcspn(line, " "), line);
+	return buf;
+}
+
+static const char *filterAccountNotify(const char *line) {
+	return (strcmp(cmd(line), "ACCOUNT") ? line : NULL);
+}
+
+static const char *filterAwayNotify(const char *line) {
+	return (strcmp(cmd(line), "AWAY") ? line : NULL);
+}
+
+static const char *filterChghost(const char *line) {
+	return (strcmp(cmd(line), "CHGHOST") ? line : NULL);
+}
+
+static Filter *Filters[] = {
+	[CapAccountNotifyBit] = filterAccountNotify,
+	[CapAwayNotifyBit] = filterAwayNotify,
+	[CapChghostBit] = filterChghost,
+};
+
 void clientConsume(struct Client *client) {
 	time_t time;
 	const char *line = ringPeek(&time, client->consumer);
 	if (!line) return;
+
+	enum Cap diff = client->caps ^ stateCaps;
+	for (size_t i = 0; line && i < ARRAY_LEN(Filters); ++i) {
+		if (!Filters[i]) continue;
+		if (diff & (1 << i)) line = Filters[i](line);
+	}
+	if (!line) {
+		ringConsume(NULL, client->consumer);
+		return;
+	}
+
+	// TODO: Move into a filter?
 	if (client->caps & CapServerTime) {
 		char ts[sizeof("YYYY-MM-DDThh:mm:ss.sssZ")];
 		struct tm *tm = gmtime(&time);
2020-02-11Add -R restricted flagJune McEnroe 2020-02-11Add chroot targetJune McEnroe 2020-02-11Exit focus and paste modes on err exitJune McEnroe 2020-02-11Add startup GPLv3 note and URLJune McEnroe I am a degenerate. 2020-02-11Make sure -D_GNU_SOURCE ends up in CFLAGS on LinuxJune McEnroe 2020-02-11Add note about setting PKG_CONFIG_PATHJune McEnroe 2020-02-11Rename query ID on nick changeJune McEnroe 2020-02-11Call completeClear when closing a windowJune McEnroe 2020-02-11Don't insert color codes for non-mentionsJune McEnroe 2020-02-11Take first two words in colorMentionsJune McEnroe This lets phrases like "hi june" get colored, but still doesn't get carried away. 2020-02-11Use time_t for save signatureJune McEnroe It's actually more likely to be 64-bit than size_t anyway, and it eliminates some helper functions. Also don't error when reading an empty save file. 2020-02-11Set self.nick to * initiallyJune McEnroe Allows removing a bunch of checks that self.nick is set, and it's what the server usually calls you before registration. Never highlight notices as mentions. 2020-02-11Define ColorCap instead of hardcoding 100June McEnroe 2020-02-11Move hash to top of chat.hJune McEnroe 2020-02-11Move base64 out of chat.hJune McEnroe 2020-02-11Move XDG_SUBDIR out of chat.hJune McEnroe 2020-02-11Fix whois idle unit calculationJune McEnroe Rookie mistake. 2020-02-11Cast towupper to wchar_tJune McEnroe For some reason it takes and returns wint_t... 2020-02-11Cast set but unused variables to voidJune McEnroe 2020-02-11Declare strlcatJune McEnroe 2020-02-11Check if VDSUSP existsJune McEnroe 2020-02-11Fix completeReplace iterationJune McEnroe 2020-02-11Use pkg(8) to configure on FreeBSDJune McEnroe 2020-02-11Remove legacy codeJune McEnroe 2020-02-11Add INSTALLING section to READMEJune McEnroe