From 582f9090f99d2e11992f50a2fcfcd5d19e88f955 Mon Sep 17 00:00:00 2001 From: utarwyn Date: Sun, 6 Feb 2022 14:39:29 +0100 Subject: [PATCH] Support deferred interactions --- src/bot/command/GameCommand.ts | 23 +++++++++---------- .../CommandInteractionMessagingTunnel.ts | 5 ++++ 2 files changed, 16 insertions(+), 12 deletions(-) diff --git a/src/bot/command/GameCommand.ts b/src/bot/command/GameCommand.ts index 1f3e0323..225d053b 100644 --- a/src/bot/command/GameCommand.ts +++ b/src/bot/command/GameCommand.ts @@ -4,7 +4,7 @@ import TextMessagingTunnel from '@bot/messaging/TextMessagingTunnel'; import GameStateManager from '@bot/state/GameStateManager'; import CommandConfig from '@config/CommandConfig'; import localize from '@i18n/localize'; -import { CommandInteraction, GuildMember, Interaction, Message, TextChannel } from 'discord.js'; +import { GuildMember, Interaction, Message } from 'discord.js'; /** * Command to start a duel with someone else. @@ -44,7 +44,7 @@ export default class GameCommand { if ( message.member && !message.author.bot && - message.channel instanceof TextChannel && + message.channel.isText() && (noTrigger || (this.config.textCommand && message.content.startsWith(this.config.textCommand))) ) { @@ -63,22 +63,21 @@ export default class GameCommand { */ public async handleInteraction(interaction: Interaction, noTrigger = false): Promise { if ( - interaction instanceof CommandInteraction && - interaction.channel instanceof TextChannel && - interaction.member instanceof GuildMember && + interaction?.isCommand() && + interaction.inCachedGuild() && + interaction.channel?.isText() && (noTrigger || interaction.commandName === this.config.command) ) { // Retrieve the inviter and create an interaction tunnel - const tunnnel = new CommandInteractionMessagingTunnel(interaction); + const tunnel = new CommandInteractionMessagingTunnel(interaction); // Retrieve invited user from options if provided - const mentionned = interaction.options.getMember( - this.config.commandOptionName ?? 'opponent', - false - ); - const invited = mentionned instanceof GuildMember ? mentionned : undefined; + const member = await interaction.member.fetch(); + const mentionned = + interaction.options.getMember(this.config.commandOptionName ?? 'opponent', false) ?? + undefined; - return this.handleInvitation(tunnnel, interaction.member, invited); + return this.handleInvitation(tunnel, member, mentionned); } } diff --git a/src/bot/messaging/CommandInteractionMessagingTunnel.ts b/src/bot/messaging/CommandInteractionMessagingTunnel.ts index 77fa5f77..f53f8083 100644 --- a/src/bot/messaging/CommandInteractionMessagingTunnel.ts +++ b/src/bot/messaging/CommandInteractionMessagingTunnel.ts @@ -56,6 +56,11 @@ export default class CommandInteractionMessagingTunnel extends MessagingTunnel { * @inheritdoc */ public async replyWith(answer: MessagingAnswer, _direct?: boolean): Promise { + // Fetch current reply if deferred externally and not register in this tunnel + if (!this.reply && this.interaction.deferred) { + this._reply = (await this.interaction.fetchReply()) as Message; + } + // Edit the reply if already exists if (this.reply) { await this.editReply(answer);