Browse Source

Redesign bulk delete events

Change `parse_message_delete_bulk` to not dispatch individual
`message_delete` events, and instead `bulk_message_delete`. Also make
`raw_bulk_message` delete and `raw_message_delete` have message
objects attached.

Fixes #1807
pull/2049/head
Vexs 6 years ago
committed by Rapptz
parent
commit
9591b00dcf
  1. 11
      discord/raw_models.py
  2. 15
      discord/state.py
  3. 40
      docs/api.rst

11
discord/raw_models.py

@ -35,14 +35,16 @@ class RawMessageDeleteEvent:
The guild ID where the deletion took place, if applicable. The guild ID where the deletion took place, if applicable.
message_id: :class:`int` message_id: :class:`int`
The message ID that got deleted. The message ID that got deleted.
cached_message: Optional[:class:`Message`]
The cached message, if found in the internal message cache.
""" """
__slots__ = ('message_id', 'channel_id', 'guild_id') __slots__ = ('message_id', 'channel_id', 'guild_id', 'cached_message')
def __init__(self, data): def __init__(self, data):
self.message_id = int(data['id']) self.message_id = int(data['id'])
self.channel_id = int(data['channel_id']) self.channel_id = int(data['channel_id'])
self.cached_message = None
try: try:
self.guild_id = int(data['guild_id']) self.guild_id = int(data['guild_id'])
except KeyError: except KeyError:
@ -59,13 +61,16 @@ class RawBulkMessageDeleteEvent:
The channel ID where the message got deleted. The channel ID where the message got deleted.
guild_id: Optional[:class:`int`] guild_id: Optional[:class:`int`]
The guild ID where the message got deleted, if applicable. The guild ID where the message got deleted, if applicable.
cached_messages: List[:class:`Message`]
The cached messages, if found in the internal message cache.
""" """
__slots__ = ('message_ids', 'channel_id', 'guild_id') __slots__ = ('message_ids', 'channel_id', 'guild_id', 'cached_messages')
def __init__(self, data): def __init__(self, data):
self.message_ids = {int(x) for x in data.get('ids', [])} self.message_ids = {int(x) for x in data.get('ids', [])}
self.channel_id = int(data['channel_id']) self.channel_id = int(data['channel_id'])
self.cached_messages = []
try: try:
self.guild_id = int(data['guild_id']) self.guild_id = int(data['guild_id'])

15
discord/state.py

@ -366,21 +366,22 @@ class ConnectionState:
def parse_message_delete(self, data): def parse_message_delete(self, data):
raw = RawMessageDeleteEvent(data) raw = RawMessageDeleteEvent(data)
self.dispatch('raw_message_delete', raw)
found = self._get_message(raw.message_id) found = self._get_message(raw.message_id)
raw.cached_message = found
self.dispatch('raw_message_delete', raw)
if found is not None: if found is not None:
self.dispatch('message_delete', found) self.dispatch('message_delete', found)
self._messages.remove(found) self._messages.remove(found)
def parse_message_delete_bulk(self, data): def parse_message_delete_bulk(self, data):
raw = RawBulkMessageDeleteEvent(data) raw = RawBulkMessageDeleteEvent(data)
found_messages = [message for message in self._messages if message.id in raw.message_ids]
raw.cached_messages = found_messages
self.dispatch('raw_bulk_message_delete', raw) self.dispatch('raw_bulk_message_delete', raw)
if found_messages:
to_be_deleted = [message for message in self._messages if message.id in raw.message_ids] self.dispatch('bulk_message_delete', found_messages)
for msg in to_be_deleted: for msg in found_messages:
self.dispatch('message_delete', msg) self._messages.remove(msg)
self._messages.remove(msg)
def parse_message_update(self, data): def parse_message_update(self, data):
raw = RawMessageUpdateEvent(data) raw = RawMessageUpdateEvent(data)

40
docs/api.rst

@ -227,25 +227,45 @@ to handle it, which defaults to print a traceback and ignoring the exception.
.. function:: on_message_delete(message) .. function:: on_message_delete(message)
Called when a message is deleted. If the message is not found in the Called when a message is deleted. If the message is not found in the
internal message cache, then these events will not be called. This internal message cache, then this event will not be called.
happens if the message is too old or the client is participating in high Messages might not be in cache if the message is too old
traffic guilds. To fix this, increase the ``max_messages`` option of or the client is participating in high traffic guilds.
:class:`Client`.
If this occurs increase the :attr:`Client.max_messages` attribute.
:param message: A :class:`Message` of the deleted message. :param message: A :class:`Message` of the deleted message.
.. function:: on_bulk_message_delete(messages)
Called when messages are bulk deleted. If none of the messages deleted
are found in the internal message cache, then this event will not be called.
If individual messages were not found in the internal message cache,
this event will still be called, but the messages not found will not be included in
the messages list. Messages might not be in cache if the message is too old
or the client is participating in high traffic guilds.
If this occurs increase the :attr:`Client.max_messages` attribute.
:param messages: A :class:`list` of :class:`Message` that have been deleted.
.. function:: on_raw_message_delete(payload) .. function:: on_raw_message_delete(payload)
Called when a message is deleted. Unlike :func:`on_message_delete`, this is Called when a message is deleted. Unlike :func:`on_message_delete`, this is
called regardless of the message being in the internal message cache or not. called regardless of the message being in the internal message cache or not.
If the message is found in the message cache,
it can be accessed via:attr:`RawMessageDeleteEvent.cached_message`
:param payload: The raw event payload data. :param payload: The raw event payload data.
:type payload: :class:`RawMessageDeleteEvent` :type payload: :class:`RawMessageDeleteEvent`
.. function:: on_raw_bulk_message_delete(payload) .. function:: on_raw_bulk_message_delete(payload)
Called when a bulk delete is triggered. This event is called regardless Called when a bulk delete is triggered. Unlike :func:`on_bulk_message_delete`, this is
of the message IDs being in the internal message cache or not. called regardless of the messages being in the internal message cache or not.
If the messages are found in the message cache,
they can be accessed via :attr:`RawBulkMessageDeleteEvent.cached_messages`
:param payload: The raw event payload data. :param payload: The raw event payload data.
:type payload: :class:`RawBulkMessageDeleteEvent` :type payload: :class:`RawBulkMessageDeleteEvent`
@ -254,8 +274,10 @@ to handle it, which defaults to print a traceback and ignoring the exception.
Called when a :class:`Message` receives an update event. If the message is not found Called when a :class:`Message` receives an update event. If the message is not found
in the internal message cache, then these events will not be called. in the internal message cache, then these events will not be called.
This happens if the message is too old or the client is participating in high Messages might not be in cache if the message is too old
traffic guilds. To fix this, increase the ``max_messages`` option of :class:`Client`. or the client is participating in high traffic guilds.
If this occurs increase the :attr:`Client.max_messages` attribute.
The following non-exhaustive cases trigger this event: The following non-exhaustive cases trigger this event:
@ -288,7 +310,7 @@ to handle it, which defaults to print a traceback and ignoring the exception.
.. function:: on_reaction_add(reaction, user) .. function:: on_reaction_add(reaction, user)
Called when a message has a reaction added to it. Similar to on_message_edit, Called when a message has a reaction added to it. Similar to :func:`on_message_edit`,
if the message is not found in the internal message cache, then this if the message is not found in the internal message cache, then this
event will not be called. event will not be called.

Loading…
Cancel
Save