aboutsummaryrefslogtreecommitdiff
path: root/bot/src/events/MessageUpdate.js
diff options
context:
space:
mode:
authorAndrew Lee <andrew@alee14.me>2025-03-08 23:11:48 -0500
committerAndrew Lee <andrew@alee14.me>2025-03-08 23:11:48 -0500
commitbdeef58376711e9a49c3b6f26aaf3fc65fa6200b (patch)
tree55b4311fbdd71bf90d2f63bdccd01323757c31dd /bot/src/events/MessageUpdate.js
parent48a576ab5605ec3ec9272809668b8d7ce91c477e (diff)
downloadAleeBot-bdeef58376711e9a49c3b6f26aaf3fc65fa6200b.tar.gz
AleeBot-bdeef58376711e9a49c3b6f26aaf3fc65fa6200b.tar.bz2
AleeBot-bdeef58376711e9a49c3b6f26aaf3fc65fa6200b.zip
Added file attachment fallback for delete and update (over 1024 characters); LLM response
Diffstat (limited to 'bot/src/events/MessageUpdate.js')
-rw-r--r--bot/src/events/MessageUpdate.js39
1 files changed, 30 insertions, 9 deletions
diff --git a/bot/src/events/MessageUpdate.js b/bot/src/events/MessageUpdate.js
index 7fc5e1b..b73d6ac 100644
--- a/bot/src/events/MessageUpdate.js
+++ b/bot/src/events/MessageUpdate.js
@@ -1,8 +1,6 @@
-import { EmbedBuilder, Events } from 'discord.js';
+import { EmbedBuilder, Events, AttachmentBuilder } from 'discord.js';
import { guildSettings } from '../models/guild-settings.js';
-// bug: whenever a long message is edited, the bot crashes; also make sure that the log has newline
-
export default {
name: Events.MessageUpdate,
async execute(msg, newmsg) {
@@ -10,20 +8,43 @@ export default {
if (!msg.guild || !guildSetting || !guildSetting.logChannelID) return;
if (msg.content === newmsg.content) return;
+ const useEmbedFields = msg.content.length <= 1023 &&
+ newmsg.content.length <= 1023;
+
const logEmbed = new EmbedBuilder()
.setAuthor({ name: 'AleeBot Logging', iconURL: msg.client.user.avatarURL() })
.setDescription(`A message from ${msg.author.username} was edited in ${msg.channel}`)
- .addFields(
- { name: 'Before: ', value: `\`\`\`${msg.content}\`\`\`` },
- { name: 'After: ', value: `\`\`\`${newmsg.content}\`\`\`` }
- )
.setColor('#ffff1a')
.setTimestamp()
- .setFooter({ text: `Author ID: ${msg.author.id}` });
+ .setFooter({ text: `Author ID: ${msg.author.id}\nMessage ID: ${msg.id}` });
+
+ if (useEmbedFields) {
+ logEmbed.addFields(
+ { name: 'Before: ', value: `\`\`\`\n${msg.content}\n\`\`\`` },
+ { name: 'After: ', value: `\`\`\`\n${newmsg.content}\n\`\`\`` }
+ );
+ }
let editMessage = msg.client.channels.cache.get(guildSetting.logChannelID);
if (!editMessage) return;
- await editMessage.send({ embeds: [logEmbed] });
+ if (useEmbedFields) {
+ await editMessage.send({ embeds: [logEmbed] });
+ } else {
+ let messageContent = [];
+ messageContent.push(`Before:\n${msg.content}`);
+ messageContent.push(`After:\n${newmsg.content}`);
+
+ messageContent = messageContent.join('\n');
+
+ const attachment = new AttachmentBuilder(Buffer.from(messageContent, 'utf-8'), { name: 'message.txt' });
+
+ await editMessage.send({
+ embeds: [logEmbed],
+ files: [attachment],
+ content: 'Message content was too long to display in an embed.'
+ });
+ }
+
}
};