mirror of
https://github.com/discordjs/discord.js.git
synced 2026-03-19 21:13:30 +01:00
fix: Handle message bulk delete and thread delete in collectors (#6902)
This commit is contained in:
@@ -19,7 +19,8 @@ const { InteractionTypes, MessageComponentTypes } = require('../util/Constants')
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* Collects interactions.
|
* Collects interactions.
|
||||||
* Will automatically stop if the message ({@link Client#event:messageDelete messageDelete}),
|
* Will automatically stop if the message ({@link Client#event:messageDelete messageDelete} or
|
||||||
|
* {@link Client#event:messageDeleteBulk messageDeleteBulk}),
|
||||||
* channel ({@link Client#event:channelDelete channelDelete}), or
|
* channel ({@link Client#event:channelDelete channelDelete}), or
|
||||||
* guild ({@link Client#event:guildDelete guildDelete}) is deleted.
|
* guild ({@link Client#event:guildDelete guildDelete}) is deleted.
|
||||||
* <info>Interaction collectors that do not specify `time` or `idle` may be prone to always running.
|
* <info>Interaction collectors that do not specify `time` or `idle` may be prone to always running.
|
||||||
@@ -92,9 +93,14 @@ class InteractionCollector extends Collector {
|
|||||||
this.empty = this.empty.bind(this);
|
this.empty = this.empty.bind(this);
|
||||||
this.client.incrementMaxListeners();
|
this.client.incrementMaxListeners();
|
||||||
|
|
||||||
|
const bulkDeleteListener = messages => {
|
||||||
|
if (messages.has(this.messageId)) this.stop('messageDelete');
|
||||||
|
};
|
||||||
|
|
||||||
if (this.messageId) {
|
if (this.messageId) {
|
||||||
this._handleMessageDeletion = this._handleMessageDeletion.bind(this);
|
this._handleMessageDeletion = this._handleMessageDeletion.bind(this);
|
||||||
this.client.on(Events.MESSAGE_DELETE, this._handleMessageDeletion);
|
this.client.on(Events.MESSAGE_DELETE, this._handleMessageDeletion);
|
||||||
|
this.client.on(Events.MESSAGE_BULK_DELETE, bulkDeleteListener);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (this.channelId) {
|
if (this.channelId) {
|
||||||
@@ -112,6 +118,7 @@ class InteractionCollector extends Collector {
|
|||||||
this.once('end', () => {
|
this.once('end', () => {
|
||||||
this.client.removeListener(Events.INTERACTION_CREATE, this.handleCollect);
|
this.client.removeListener(Events.INTERACTION_CREATE, this.handleCollect);
|
||||||
this.client.removeListener(Events.MESSAGE_DELETE, this._handleMessageDeletion);
|
this.client.removeListener(Events.MESSAGE_DELETE, this._handleMessageDeletion);
|
||||||
|
this.client.removeListener(Events.MESSAGE_BULK_DELETE, bulkDeleteListener);
|
||||||
this.client.removeListener(Events.CHANNEL_DELETE, this._handleChannelDeletion);
|
this.client.removeListener(Events.CHANNEL_DELETE, this._handleChannelDeletion);
|
||||||
this.client.removeListener(Events.GUILD_DELETE, this._handleGuildDeletion);
|
this.client.removeListener(Events.GUILD_DELETE, this._handleGuildDeletion);
|
||||||
this.client.decrementMaxListeners();
|
this.client.decrementMaxListeners();
|
||||||
|
|||||||
@@ -11,7 +11,9 @@ const { Events } = require('../util/Constants');
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* Collects messages on a channel.
|
* Collects messages on a channel.
|
||||||
* Will automatically stop if the channel (`'channelDelete'`) or guild (`'guildDelete'`) are deleted.
|
* Will automatically stop if the channel ({@link Client#event:channelDelete channelDelete}),
|
||||||
|
* thread ({@link Client#event:threadDelete threadDelete}), or
|
||||||
|
* guild ({@link Client#event:guildDelete guildDelete}) is deleted.
|
||||||
* @extends {Collector}
|
* @extends {Collector}
|
||||||
*/
|
*/
|
||||||
class MessageCollector extends Collector {
|
class MessageCollector extends Collector {
|
||||||
@@ -38,7 +40,9 @@ class MessageCollector extends Collector {
|
|||||||
const bulkDeleteListener = messages => {
|
const bulkDeleteListener = messages => {
|
||||||
for (const message of messages.values()) this.handleDispose(message);
|
for (const message of messages.values()) this.handleDispose(message);
|
||||||
};
|
};
|
||||||
|
|
||||||
this._handleChannelDeletion = this._handleChannelDeletion.bind(this);
|
this._handleChannelDeletion = this._handleChannelDeletion.bind(this);
|
||||||
|
this._handleThreadDeletion = this._handleThreadDeletion.bind(this);
|
||||||
this._handleGuildDeletion = this._handleGuildDeletion.bind(this);
|
this._handleGuildDeletion = this._handleGuildDeletion.bind(this);
|
||||||
|
|
||||||
this.client.incrementMaxListeners();
|
this.client.incrementMaxListeners();
|
||||||
@@ -46,6 +50,7 @@ class MessageCollector extends Collector {
|
|||||||
this.client.on(Events.MESSAGE_DELETE, this.handleDispose);
|
this.client.on(Events.MESSAGE_DELETE, this.handleDispose);
|
||||||
this.client.on(Events.MESSAGE_BULK_DELETE, bulkDeleteListener);
|
this.client.on(Events.MESSAGE_BULK_DELETE, bulkDeleteListener);
|
||||||
this.client.on(Events.CHANNEL_DELETE, this._handleChannelDeletion);
|
this.client.on(Events.CHANNEL_DELETE, this._handleChannelDeletion);
|
||||||
|
this.client.on(Events.THREAD_DELETE, this._handleThreadDeletion);
|
||||||
this.client.on(Events.GUILD_DELETE, this._handleGuildDeletion);
|
this.client.on(Events.GUILD_DELETE, this._handleGuildDeletion);
|
||||||
|
|
||||||
this.once('end', () => {
|
this.once('end', () => {
|
||||||
@@ -53,6 +58,7 @@ class MessageCollector extends Collector {
|
|||||||
this.client.removeListener(Events.MESSAGE_DELETE, this.handleDispose);
|
this.client.removeListener(Events.MESSAGE_DELETE, this.handleDispose);
|
||||||
this.client.removeListener(Events.MESSAGE_BULK_DELETE, bulkDeleteListener);
|
this.client.removeListener(Events.MESSAGE_BULK_DELETE, bulkDeleteListener);
|
||||||
this.client.removeListener(Events.CHANNEL_DELETE, this._handleChannelDeletion);
|
this.client.removeListener(Events.CHANNEL_DELETE, this._handleChannelDeletion);
|
||||||
|
this.client.removeListener(Events.THREAD_DELETE, this._handleThreadDeletion);
|
||||||
this.client.removeListener(Events.GUILD_DELETE, this._handleGuildDeletion);
|
this.client.removeListener(Events.GUILD_DELETE, this._handleGuildDeletion);
|
||||||
this.client.decrementMaxListeners();
|
this.client.decrementMaxListeners();
|
||||||
});
|
});
|
||||||
@@ -107,11 +113,23 @@ class MessageCollector extends Collector {
|
|||||||
* @returns {void}
|
* @returns {void}
|
||||||
*/
|
*/
|
||||||
_handleChannelDeletion(channel) {
|
_handleChannelDeletion(channel) {
|
||||||
if (channel.id === this.channel.id) {
|
if (channel.id === this.channel.id || channel.id === this.channel.parentId) {
|
||||||
this.stop('channelDelete');
|
this.stop('channelDelete');
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Handles checking if the thread has been deleted, and if so, stops the collector with the reason 'threadDelete'.
|
||||||
|
* @private
|
||||||
|
* @param {ThreadChannel} thread The thread that was deleted
|
||||||
|
* @returns {void}
|
||||||
|
*/
|
||||||
|
_handleThreadDeletion(thread) {
|
||||||
|
if (thread.id === this.channel.id) {
|
||||||
|
this.stop('threadDelete');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Handles checking if the guild has been deleted, and if so, stops the collector with the reason 'guildDelete'.
|
* Handles checking if the guild has been deleted, and if so, stops the collector with the reason 'guildDelete'.
|
||||||
* @private
|
* @private
|
||||||
|
|||||||
@@ -13,8 +13,11 @@ const { Events } = require('../util/Constants');
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* Collects reactions on messages.
|
* Collects reactions on messages.
|
||||||
* Will automatically stop if the message (`'messageDelete'`),
|
* Will automatically stop if the message ({@link Client#event:messageDelete messageDelete} or
|
||||||
* channel (`'channelDelete'`), or guild (`'guildDelete'`) are deleted.
|
* {@link Client#event:messageDeleteBulk messageDeleteBulk}),
|
||||||
|
* channel ({@link Client#event:channelDelete channelDelete}),
|
||||||
|
* thread ({@link Client#event:threadDelete threadDelete}), or
|
||||||
|
* guild ({@link Client#event:guildDelete guildDelete}) is deleted.
|
||||||
* @extends {Collector}
|
* @extends {Collector}
|
||||||
*/
|
*/
|
||||||
class ReactionCollector extends Collector {
|
class ReactionCollector extends Collector {
|
||||||
@@ -45,15 +48,22 @@ class ReactionCollector extends Collector {
|
|||||||
|
|
||||||
this.empty = this.empty.bind(this);
|
this.empty = this.empty.bind(this);
|
||||||
this._handleChannelDeletion = this._handleChannelDeletion.bind(this);
|
this._handleChannelDeletion = this._handleChannelDeletion.bind(this);
|
||||||
|
this._handleThreadDeletion = this._handleThreadDeletion.bind(this);
|
||||||
this._handleGuildDeletion = this._handleGuildDeletion.bind(this);
|
this._handleGuildDeletion = this._handleGuildDeletion.bind(this);
|
||||||
this._handleMessageDeletion = this._handleMessageDeletion.bind(this);
|
this._handleMessageDeletion = this._handleMessageDeletion.bind(this);
|
||||||
|
|
||||||
|
const bulkDeleteListener = messages => {
|
||||||
|
if (messages.has(this.message.id)) this.stop('messageDelete');
|
||||||
|
};
|
||||||
|
|
||||||
this.client.incrementMaxListeners();
|
this.client.incrementMaxListeners();
|
||||||
this.client.on(Events.MESSAGE_REACTION_ADD, this.handleCollect);
|
this.client.on(Events.MESSAGE_REACTION_ADD, this.handleCollect);
|
||||||
this.client.on(Events.MESSAGE_REACTION_REMOVE, this.handleDispose);
|
this.client.on(Events.MESSAGE_REACTION_REMOVE, this.handleDispose);
|
||||||
this.client.on(Events.MESSAGE_REACTION_REMOVE_ALL, this.empty);
|
this.client.on(Events.MESSAGE_REACTION_REMOVE_ALL, this.empty);
|
||||||
this.client.on(Events.MESSAGE_DELETE, this._handleMessageDeletion);
|
this.client.on(Events.MESSAGE_DELETE, this._handleMessageDeletion);
|
||||||
|
this.client.on(Events.MESSAGE_BULK_DELETE, bulkDeleteListener);
|
||||||
this.client.on(Events.CHANNEL_DELETE, this._handleChannelDeletion);
|
this.client.on(Events.CHANNEL_DELETE, this._handleChannelDeletion);
|
||||||
|
this.client.on(Events.THREAD_DELETE, this._handleThreadDeletion);
|
||||||
this.client.on(Events.GUILD_DELETE, this._handleGuildDeletion);
|
this.client.on(Events.GUILD_DELETE, this._handleGuildDeletion);
|
||||||
|
|
||||||
this.once('end', () => {
|
this.once('end', () => {
|
||||||
@@ -61,7 +71,9 @@ class ReactionCollector extends Collector {
|
|||||||
this.client.removeListener(Events.MESSAGE_REACTION_REMOVE, this.handleDispose);
|
this.client.removeListener(Events.MESSAGE_REACTION_REMOVE, this.handleDispose);
|
||||||
this.client.removeListener(Events.MESSAGE_REACTION_REMOVE_ALL, this.empty);
|
this.client.removeListener(Events.MESSAGE_REACTION_REMOVE_ALL, this.empty);
|
||||||
this.client.removeListener(Events.MESSAGE_DELETE, this._handleMessageDeletion);
|
this.client.removeListener(Events.MESSAGE_DELETE, this._handleMessageDeletion);
|
||||||
|
this.client.removeListener(Events.MESSAGE_BULK_DELETE, bulkDeleteListener);
|
||||||
this.client.removeListener(Events.CHANNEL_DELETE, this._handleChannelDeletion);
|
this.client.removeListener(Events.CHANNEL_DELETE, this._handleChannelDeletion);
|
||||||
|
this.client.removeListener(Events.THREAD_DELETE, this._handleThreadDeletion);
|
||||||
this.client.removeListener(Events.GUILD_DELETE, this._handleGuildDeletion);
|
this.client.removeListener(Events.GUILD_DELETE, this._handleGuildDeletion);
|
||||||
this.client.decrementMaxListeners();
|
this.client.decrementMaxListeners();
|
||||||
});
|
});
|
||||||
@@ -175,11 +187,23 @@ class ReactionCollector extends Collector {
|
|||||||
* @returns {void}
|
* @returns {void}
|
||||||
*/
|
*/
|
||||||
_handleChannelDeletion(channel) {
|
_handleChannelDeletion(channel) {
|
||||||
if (channel.id === this.message.channelId) {
|
if (channel.id === this.message.channelId || channel.id === this.message.channel.parentId) {
|
||||||
this.stop('channelDelete');
|
this.stop('channelDelete');
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Handles checking if the thread has been deleted, and if so, stops the collector with the reason 'threadDelete'.
|
||||||
|
* @private
|
||||||
|
* @param {ThreadChannel} thread The thread that was deleted
|
||||||
|
* @returns {void}
|
||||||
|
*/
|
||||||
|
_handleThreadDeletion(thread) {
|
||||||
|
if (thread.id === this.message.channelId) {
|
||||||
|
this.stop('threadDelete');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Handles checking if the guild has been deleted, and if so, stops the collector with the reason 'guildDelete'.
|
* Handles checking if the guild has been deleted, and if so, stops the collector with the reason 'guildDelete'.
|
||||||
* @private
|
* @private
|
||||||
|
|||||||
Reference in New Issue
Block a user