mirror of
https://github.com/Rapptz/discord.py.git
synced 2025-10-24 18:13:00 +00:00
Add on_message_delete event and Client.messages attribute.
This commit is contained in:
@@ -27,8 +27,8 @@ DEALINGS IN THE SOFTWARE.
|
|||||||
import requests
|
import requests
|
||||||
import json, re
|
import json, re
|
||||||
import endpoints
|
import endpoints
|
||||||
|
from collections import deque
|
||||||
from ws4py.client.threadedclient import WebSocketClient
|
from ws4py.client.threadedclient import WebSocketClient
|
||||||
# from threading import Timer
|
|
||||||
from sys import platform as sys_platform
|
from sys import platform as sys_platform
|
||||||
from errors import InvalidEventName, InvalidDestination
|
from errors import InvalidEventName, InvalidDestination
|
||||||
from user import User
|
from user import User
|
||||||
@@ -43,6 +43,12 @@ class Client(object):
|
|||||||
"""Represents a client connection that connects to Discord.
|
"""Represents a client connection that connects to Discord.
|
||||||
This class is used to interact with the Discord WebSocket and API.
|
This class is used to interact with the Discord WebSocket and API.
|
||||||
|
|
||||||
|
A number of options can be passed to the :class:`Client` via keyword arguments.
|
||||||
|
|
||||||
|
:param int max_length: The maximum number of messages to store in :attr:`messages`. Defaults to 5000.
|
||||||
|
|
||||||
|
Instance attributes:
|
||||||
|
|
||||||
.. attribute:: user
|
.. attribute:: user
|
||||||
|
|
||||||
A :class:`User` that represents the connected client. None if not logged in.
|
A :class:`User` that represents the connected client. None if not logged in.
|
||||||
@@ -52,6 +58,11 @@ class Client(object):
|
|||||||
.. attribute:: private_channels
|
.. attribute:: private_channels
|
||||||
|
|
||||||
A list of :class:`PrivateChannel` that the connected client is participating on.
|
A list of :class:`PrivateChannel` that the connected client is participating on.
|
||||||
|
.. attribute:: messages
|
||||||
|
|
||||||
|
A deque_ of :class:`Message` that the client has received from all servers and private messages.
|
||||||
|
|
||||||
|
.. _deque: https://docs.python.org/3.4/library/collections.html#collections.deque
|
||||||
"""
|
"""
|
||||||
|
|
||||||
def __init__(self, **kwargs):
|
def __init__(self, **kwargs):
|
||||||
@@ -60,12 +71,14 @@ class Client(object):
|
|||||||
self.servers = []
|
self.servers = []
|
||||||
self.private_channels = []
|
self.private_channels = []
|
||||||
self.token = ''
|
self.token = ''
|
||||||
|
self.messages = deque([], maxlen=kwargs.get('max_length', 5000))
|
||||||
self.events = {
|
self.events = {
|
||||||
'on_ready': _null_event,
|
'on_ready': _null_event,
|
||||||
'on_disconnect': _null_event,
|
'on_disconnect': _null_event,
|
||||||
'on_error': _null_event,
|
'on_error': _null_event,
|
||||||
'on_response': _null_event,
|
'on_response': _null_event,
|
||||||
'on_message': _null_event
|
'on_message': _null_event,
|
||||||
|
'on_message_delete': _null_event
|
||||||
}
|
}
|
||||||
|
|
||||||
self.ws = WebSocketClient(endpoints.WEBSOCKET_HUB, protocols=['http-only', 'chat'])
|
self.ws = WebSocketClient(endpoints.WEBSOCKET_HUB, protocols=['http-only', 'chat'])
|
||||||
@@ -119,6 +132,14 @@ class Client(object):
|
|||||||
channel = self.get_channel(data.get('channel_id'))
|
channel = self.get_channel(data.get('channel_id'))
|
||||||
message = Message(channel=channel, **data)
|
message = Message(channel=channel, **data)
|
||||||
self.events['on_message'](message)
|
self.events['on_message'](message)
|
||||||
|
self.messages.append(message)
|
||||||
|
elif event == 'MESSAGE_DELETE':
|
||||||
|
channel = self.get_channel(data.get('channel_id'))
|
||||||
|
message_id = data.get('id')
|
||||||
|
found = next((m for m in self.messages if m.id == message_id), None)
|
||||||
|
if found is not None:
|
||||||
|
self.events['on_message_delete'](found)
|
||||||
|
self.messages.remove(found)
|
||||||
|
|
||||||
def _opened(self):
|
def _opened(self):
|
||||||
print('Opened!')
|
print('Opened!')
|
||||||
|
@@ -38,6 +38,12 @@ This page outlines the different types of events listened to by :meth:`Client.ev
|
|||||||
|
|
||||||
:param response: The received message response after gone through ``json.loads``.
|
:param response: The received message response after gone through ``json.loads``.
|
||||||
|
|
||||||
|
.. function:: on_message_delete(message)
|
||||||
|
|
||||||
|
Called when a message is deleted from any given server.
|
||||||
|
|
||||||
|
:param message: A :class:`Message` of the deleted message.
|
||||||
|
|
||||||
|
|
||||||
Data Classes
|
Data Classes
|
||||||
--------------
|
--------------
|
||||||
|
16
examples/deleted.py
Normal file
16
examples/deleted.py
Normal file
@@ -0,0 +1,16 @@
|
|||||||
|
import discord
|
||||||
|
|
||||||
|
client = discord.Client()
|
||||||
|
client.login('email', 'password')
|
||||||
|
|
||||||
|
@client.event
|
||||||
|
def on_ready():
|
||||||
|
print('Connected!')
|
||||||
|
print('Username: ' + client.user.name)
|
||||||
|
print('ID: ' + client.user.id)
|
||||||
|
|
||||||
|
@client.event
|
||||||
|
def on_message_delete(message):
|
||||||
|
client.send_message(message.channel, '{} has deleted the message:\n{}'.format(message.author.name, message.content))
|
||||||
|
|
||||||
|
client.run()
|
Reference in New Issue
Block a user