From 9d458dff7b2fd4f48684f1cd668dc8b6ab6c9500 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marvin=20R=C3=B6sch?= Date: Sat, 20 Jul 2024 12:20:06 +0200 Subject: [PATCH] Do not attempt to auto-publish unpublishable messages --- src/cmds/auto-publish.ts | 21 ++++++++++++++++----- src/cmds/edit-webhook.ts | 37 +++++++++++++++++++++++++++++-------- 2 files changed, 45 insertions(+), 13 deletions(-) diff --git a/src/cmds/auto-publish.ts b/src/cmds/auto-publish.ts index b88b23b..68c5103 100644 --- a/src/cmds/auto-publish.ts +++ b/src/cmds/auto-publish.ts @@ -1,5 +1,16 @@ import { ComplexCommand } from '../commands'; -import { ActionRowBuilder, ButtonBuilder, ButtonStyle, ChannelType, ChatInputCommandInteraction, Client, ColorResolvable, EmbedBuilder, Message, TextChannel } from 'discord.js'; +import { + ActionRowBuilder, + ButtonBuilder, + ButtonStyle, + ChannelType, + ChatInputCommandInteraction, + Client, + ColorResolvable, + EmbedBuilder, + Message, + TextChannel +} from 'discord.js'; import { guilds as storage } from '../utils/storage'; import logger from '../utils/logger'; @@ -21,7 +32,7 @@ async function publishMessage(message: Message): Promise { return true; } - if (message.channel.type !== ChannelType.GuildNews) return; + if (!message.crosspostable || message.channel.isDMBased()) return; const channelName = `#${message.channel.name}`; try { @@ -67,7 +78,7 @@ export default { async start(client: Client, interaction: ChatInputCommandInteraction<'cached'>) { const channel = interaction.options.getChannel('channel', true); - if (channel.type !== ChannelType.GuildNews) { + if (channel.type !== ChannelType.GuildAnnouncement) { await interaction.reply({ embeds: [ buildEmbed( @@ -123,7 +134,7 @@ export default { async stop(client: Client, interaction: ChatInputCommandInteraction<'cached'>) { const channel = interaction.options.getChannel('channel', true); - if (channel.type === ChannelType.GuildNews && !channel.permissionsFor(interaction.user).has('ManageMessages')) { + if (channel.type === ChannelType.GuildAnnouncement && !channel.permissionsFor(interaction.user).has('ManageMessages')) { await interaction.reply({ embeds: [ buildEmbed( @@ -204,7 +215,7 @@ export default { ), additionalHandlers: { async messageCreate(client: Client, message: Message): Promise { - if (message.channel.type !== ChannelType.GuildNews) { + if (!message.crosspostable || message.channel.isDMBased()) { return; } diff --git a/src/cmds/edit-webhook.ts b/src/cmds/edit-webhook.ts index e66df9e..de4506a 100644 --- a/src/cmds/edit-webhook.ts +++ b/src/cmds/edit-webhook.ts @@ -2,6 +2,8 @@ import { ActionRowBuilder, ChannelSelectMenuBuilder, ModalActionRowComponentBuil import { ChannelType, ComponentType, Snowflake, TextInputStyle } from 'discord-api-types/v10'; import { Client, + DiscordjsError, + DiscordjsErrorCodes, MessageContextMenuCommandInteraction, ModalBuilder, ModalSubmitInteraction, @@ -56,11 +58,21 @@ export default { await interaction.showModal(modal); const filter = (interaction: ModalSubmitInteraction) => interaction.customId === modalId; - const answer = await interaction.awaitModalSubmit({ - filter, - time: 300_000 - }); - const newContent = answer.fields.getTextInputValue('content').trim(); + let newContent = message.content; + let answer: ModalSubmitInteraction<'cached'>; + try { + answer = await interaction.awaitModalSubmit({ + filter, + time: 10_000 + }); + newContent = answer.fields.getTextInputValue('content').trim(); + await answer.deferReply({ ephemeral: true }); + } catch (error) { + if (error instanceof DiscordjsError && error.code === DiscordjsErrorCodes.InteractionCollectorError) { + return; + } + throw error; + } try { await webhook.editMessage(interaction.targetMessage, { content: newContent }); @@ -78,7 +90,7 @@ export default { return; } - await answer.reply({ content: 'Webhook message succesfully edited', ephemeral: true }); + await answer.reply({ content: 'Webhook message successfully edited', ephemeral: true }); } ), new SimpleCommand( @@ -104,7 +116,16 @@ export default { .setChannelTypes(ChannelType.GuildText, ChannelType.PublicThread, ChannelType.PrivateThread, ChannelType.GuildForum) ); const reply = await interaction.editReply({ content: 'Which channel should conversation be directed to?', components: [row] }); - const targetChannel = (await reply.awaitMessageComponent({ componentType: ComponentType.ChannelSelect })).values[0]; + let targetChannel: string; + try { + targetChannel = (await reply.awaitMessageComponent({ componentType: ComponentType.ChannelSelect, time: 60_000 })).values[0]; + } catch (error) { + if (error instanceof DiscordjsError && error.code === DiscordjsErrorCodes.InteractionCollectorError) { + await interaction.editReply({ content: 'Did not receive response in time!', components: [] }); + return; + } + throw error; + } let content = message.content; const cta = `-# Want to talk about this? Go to <#${targetChannel}>!`; const regex = /^-# Want to talk about this\? Go to <#[0-9]+>!/m; @@ -130,7 +151,7 @@ export default { return; } - await interaction.editReply({ content: 'Webhook message succesfully edited', components: [] }); + await interaction.editReply({ content: 'Webhook message successfully edited', components: [] }); } ) ]