mirror of
https://github.com/discordjs/discord.js.git
synced 2026-03-16 19:43:29 +01:00
MessageDelete handling
This commit is contained in:
@@ -38,6 +38,7 @@ class WebSocketPacketManager {
|
|||||||
this.register(Constants.WSEvents.VOICE_STATE_UPDATE, 'VoiceStateUpdate');
|
this.register(Constants.WSEvents.VOICE_STATE_UPDATE, 'VoiceStateUpdate');
|
||||||
this.register(Constants.WSEvents.TYPING_START, 'TypingStart');
|
this.register(Constants.WSEvents.TYPING_START, 'TypingStart');
|
||||||
this.register(Constants.WSEvents.MESSAGE_CREATE, 'MessageCreate');
|
this.register(Constants.WSEvents.MESSAGE_CREATE, 'MessageCreate');
|
||||||
|
this.register(Constants.WSEvents.MESSAGE_DELETE, 'MessageDelete');
|
||||||
}
|
}
|
||||||
|
|
||||||
get client() {
|
get client() {
|
||||||
|
|||||||
32
src/client/websocket/packets/handlers/MessageDelete.js
Normal file
32
src/client/websocket/packets/handlers/MessageDelete.js
Normal file
@@ -0,0 +1,32 @@
|
|||||||
|
'use strict';
|
||||||
|
|
||||||
|
const AbstractHandler = require('./AbstractHandler');
|
||||||
|
const Structure = name => require(`../../../../structures/${name}`);
|
||||||
|
const Constants = require('../../../../util/Constants');
|
||||||
|
|
||||||
|
const Message = Structure('Message');
|
||||||
|
const Guild = Structure('Guild');
|
||||||
|
|
||||||
|
class MessageDeleteHandler extends AbstractHandler {
|
||||||
|
|
||||||
|
constructor(packetManager) {
|
||||||
|
super(packetManager);
|
||||||
|
}
|
||||||
|
|
||||||
|
handle(packet) {
|
||||||
|
let data = packet.d;
|
||||||
|
let client = this.packetManager.client;
|
||||||
|
let channel = client.store.get('channels', data.channel_id);
|
||||||
|
if (channel) {
|
||||||
|
let message = channel.store.get('messages', data.id);
|
||||||
|
if (message) {
|
||||||
|
channel.store.remove('messages', message.id);
|
||||||
|
client.emit(Constants.Events.MESSAGE_DELETE, message);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
module.exports = MessageDeleteHandler;
|
||||||
@@ -20,8 +20,9 @@ class DMChannel extends Channel{
|
|||||||
let storeKeys = Object.keys(this.store);
|
let storeKeys = Object.keys(this.store);
|
||||||
if (storeKeys.length >= maxSize) {
|
if (storeKeys.length >= maxSize) {
|
||||||
this.store.remove(storeKeys[0]);
|
this.store.remove(storeKeys[0]);
|
||||||
this.store.add('messages', message);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
this.store.add('messages', message);
|
||||||
}
|
}
|
||||||
|
|
||||||
setup(data) {
|
setup(data) {
|
||||||
|
|||||||
@@ -20,6 +20,7 @@ class Message {
|
|||||||
this.embeds = data.embeds;
|
this.embeds = data.embeds;
|
||||||
this.attachments = data.attachments;
|
this.attachments = data.attachments;
|
||||||
this.mentions = [];
|
this.mentions = [];
|
||||||
|
this.id = data.id;
|
||||||
for (let mention of data.mentions) {
|
for (let mention of data.mentions) {
|
||||||
let user = this.guild.client.store.get('users', mention.id);
|
let user = this.guild.client.store.get('users', mention.id);
|
||||||
if (user) {
|
if (user) {
|
||||||
|
|||||||
@@ -20,8 +20,9 @@ class TextChannel extends ServerChannel {
|
|||||||
let storeKeys = Object.keys(this.store);
|
let storeKeys = Object.keys(this.store);
|
||||||
if (storeKeys.length >= maxSize) {
|
if (storeKeys.length >= maxSize) {
|
||||||
this.store.remove(storeKeys[0]);
|
this.store.remove(storeKeys[0]);
|
||||||
this.store.add('messages', message);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
this.store.add('messages', message);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -100,6 +100,7 @@ const Events = exports.Events = {
|
|||||||
WARN: 'warn',
|
WARN: 'warn',
|
||||||
GUILD_MEMBERS_CHUNK: 'guildMembersChunk',
|
GUILD_MEMBERS_CHUNK: 'guildMembersChunk',
|
||||||
MESSAGE_CREATE: 'message',
|
MESSAGE_CREATE: 'message',
|
||||||
|
MESSAGE_DELETE: 'messageDelete',
|
||||||
};
|
};
|
||||||
|
|
||||||
const WSEvents = exports.WSEvents = {
|
const WSEvents = exports.WSEvents = {
|
||||||
|
|||||||
@@ -68,5 +68,10 @@ client.on('typingStop.', (channel, user, data) => {
|
|||||||
});
|
});
|
||||||
|
|
||||||
client.on('message', message => {
|
client.on('message', message => {
|
||||||
|
if (message.author.username === 'hydrabolt')
|
||||||
console.log(message.author.username, 'said', message.content, 'in', message.channel.name);
|
console.log(message.author.username, 'said', message.content, 'in', message.channel.name);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
client.on('messageDelete', message => {
|
||||||
|
console.log('Message deleted by', message.author.username);
|
||||||
|
});
|
||||||
|
|||||||
Reference in New Issue
Block a user