From 2a33d849e4049668e122ba0c1d39b390f1bd778a Mon Sep 17 00:00:00 2001 From: Half-Shot Date: Tue, 15 Oct 2024 11:11:21 +0100 Subject: [PATCH] Rewrite message handler to handle invalid values. --- src/Mjolnir.ts | 63 +++++++++++++++++++++++++------------------------- 1 file changed, 31 insertions(+), 32 deletions(-) diff --git a/src/Mjolnir.ts b/src/Mjolnir.ts index d76de1b8..79d432e8 100644 --- a/src/Mjolnir.ts +++ b/src/Mjolnir.ts @@ -176,47 +176,46 @@ export class Mjolnir { matrixEmitter.on("room.event", this.handleEvent.bind(this)); matrixEmitter.on("room.message", async (roomId, event) => { + const eventContent = event.content; if (roomId !== this.managementRoomId) return; - if (!event['content']) return; - - const content = event['content']; - if (content['msgtype'] === "m.text" && content['body']) { - const prefixes = [ - COMMAND_PREFIX, - this.localpart + ":", - this.displayName + ":", - await client.getUserId() + ":", - this.localpart + " ", - this.displayName + " ", - await client.getUserId() + " ", - ...config.commands.additionalPrefixes.map(p => `!${p}`), - ...config.commands.additionalPrefixes.map(p => `${p}:`), - ...config.commands.additionalPrefixes.map(p => `${p} `), - ...config.commands.additionalPrefixes, - ]; - if (config.commands.allowNoPrefix) prefixes.push("!"); - - const prefixUsed = prefixes.find(p => content['body'].toLowerCase().startsWith(p.toLowerCase())); - if (!prefixUsed) return; - - // rewrite the event body to make the prefix uniform (in case the bot has spaces in its display name) - let restOfBody = content['body'].substring(prefixUsed.length); - if (!restOfBody.startsWith(" ")) restOfBody = ` ${restOfBody}`; - event['content']['body'] = COMMAND_PREFIX + restOfBody; - LogService.info("Mjolnir", `Command being run by ${event['sender']}: ${event['content']['body']}`); - - client.sendReadReceipt(roomId, event['event_id']).catch((e: any) => { - LogService.warn("Mjolnir", "Error sending read receipt: ", e); - }); - return handleCommand(roomId, event, this); + if (typeof eventContent !== "object") return; + + const {msgtype, body: originalBody, sender, event_id} = eventContent; + if (msgtype !== "m.text" || typeof originalBody !== "string") { + return; } + + const prefixes = [ + COMMAND_PREFIX, + this.localpart + ":", + this.displayName + ":", + await client.getUserId() + ":", + this.localpart + " ", + this.displayName + " ", + await client.getUserId() + " ", + ...config.commands.additionalPrefixes.map(p => `!${p}`), + ...config.commands.additionalPrefixes.map(p => `${p}:`), + ...config.commands.additionalPrefixes.map(p => `${p} `), + ...config.commands.additionalPrefixes, + ]; + if (config.commands.allowNoPrefix) prefixes.push("!"); + const sanitizedBody = originalBody.toLowerCase().trim(); const prefixUsed = prefixes.find(p => sanitizedBody.startsWith(p.toLowerCase())); if (!prefixUsed) return; + // rewrite the event body to make the prefix uniform (in case the bot has spaces in its display name) let restOfBody = originalBody.trim().substring(prefixUsed.length); if (!restOfBody.startsWith(" ")) restOfBody = ` ${restOfBody}`; + + eventContent.body = COMMAND_PREFIX + restOfBody; + LogService.info("Mjolnir", `Command being run by ${sender}: ${eventContent.body}`); + + client.sendReadReceipt(roomId, event_id).catch((e: any) => { + LogService.warn("Mjolnir", "Error sending read receipt: ", e); + }); + return handleCommand(roomId, event, this); }); matrixEmitter.on("room.join", (roomId: string, event: any) => {