Some more logging options
Signed-off-by: loicbersier <loic.bersier1@gmail.com>
This commit is contained in:
parent
66314b5c79
commit
3d8f20f054
6 changed files with 122 additions and 3 deletions
|
@ -12,6 +12,13 @@ class channelCreateListener extends Listener {
|
||||||
async exec(GuildChannel) {
|
async exec(GuildChannel) {
|
||||||
const logStats = await LogStats.findOne({where: {guild: GuildChannel.guild.id}});
|
const logStats = await LogStats.findOne({where: {guild: GuildChannel.guild.id}});
|
||||||
if (logStats) {
|
if (logStats) {
|
||||||
|
const fetchedLogs = await GuildChannel.guild.fetchAuditLogs({
|
||||||
|
limit: 1,
|
||||||
|
type: 'CHANNEL_CREATE',
|
||||||
|
});
|
||||||
|
|
||||||
|
const creationLog = fetchedLogs.entries.first();
|
||||||
|
|
||||||
const channel = this.client.channels.resolve(await logStats.get('channel'));
|
const channel = this.client.channels.resolve(await logStats.get('channel'));
|
||||||
let Embed = this.client.util.embed()
|
let Embed = this.client.util.embed()
|
||||||
.setColor('NAVY')
|
.setColor('NAVY')
|
||||||
|
@ -20,6 +27,10 @@ class channelCreateListener extends Listener {
|
||||||
.setFooter(`Channel ID: ${GuildChannel.id}`)
|
.setFooter(`Channel ID: ${GuildChannel.id}`)
|
||||||
.setTimestamp();
|
.setTimestamp();
|
||||||
|
|
||||||
|
if (!creationLog) return channel.send(Embed);
|
||||||
|
|
||||||
|
Embed.setDescription(`${GuildChannel.type} channel ${GuildChannel} got created by ${creationLog.executor}`);
|
||||||
|
|
||||||
channel.send(Embed);
|
channel.send(Embed);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -12,13 +12,24 @@ class channelDeleteListener extends Listener {
|
||||||
async exec(GuildChannel) {
|
async exec(GuildChannel) {
|
||||||
const logStats = await LogStats.findOne({where: {guild: GuildChannel.guild.id}});
|
const logStats = await LogStats.findOne({where: {guild: GuildChannel.guild.id}});
|
||||||
if (logStats) {
|
if (logStats) {
|
||||||
|
const fetchedLogs = await GuildChannel.guild.fetchAuditLogs({
|
||||||
|
limit: 1,
|
||||||
|
type: 'CHANNEL_DELETE',
|
||||||
|
});
|
||||||
|
|
||||||
|
const deletionLog = fetchedLogs.entries.first();
|
||||||
|
|
||||||
const channel = this.client.channels.resolve(await logStats.get('channel'));
|
const channel = this.client.channels.resolve(await logStats.get('channel'));
|
||||||
let Embed = this.client.util.embed()
|
let Embed = this.client.util.embed()
|
||||||
.setColor('NAVY')
|
.setColor('NAVY')
|
||||||
.setTitle('Channel created!')
|
.setTitle('Channel created!')
|
||||||
.setDescription(`${GuildChannel.type} channel ${GuildChannel.name} got deleted!`)
|
.setDescription(`${GuildChannel.type} channel ${GuildChannel} got deleted!`)
|
||||||
.setTimestamp();
|
.setTimestamp();
|
||||||
|
|
||||||
|
if (!deletionLog) return channel.send(Embed);
|
||||||
|
|
||||||
|
Embed.setDescription(`${GuildChannel.type} channel ${GuildChannel} got deleted by ${deletionLog.executor}`);
|
||||||
|
|
||||||
channel.send(Embed);
|
channel.send(Embed);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -13,10 +13,17 @@ class channelUpdateListener extends Listener {
|
||||||
const logStats = await LogStats.findOne({where: {guild: newChannel.guild.id}});
|
const logStats = await LogStats.findOne({where: {guild: newChannel.guild.id}});
|
||||||
|
|
||||||
if (logStats) {
|
if (logStats) {
|
||||||
|
const fetchedLogs = await newChannel.guild.fetchAuditLogs({
|
||||||
|
limit: 1,
|
||||||
|
type: 'CHANNEL_CREATE',
|
||||||
|
});
|
||||||
|
|
||||||
|
const updateLog = fetchedLogs.entries.first();
|
||||||
|
|
||||||
const channel = this.client.channels.resolve(await logStats.get('channel'));
|
const channel = this.client.channels.resolve(await logStats.get('channel'));
|
||||||
let Embed = this.client.util.embed()
|
let Embed = this.client.util.embed()
|
||||||
.setColor('NAVY')
|
.setColor('NAVY')
|
||||||
.setTitle(`${newChannel.type} channel updated!`)
|
.setDescription(`**${newChannel} channel updated!**`)
|
||||||
.setTimestamp();
|
.setTimestamp();
|
||||||
|
|
||||||
if (oldChannel.name !== newChannel.name) {
|
if (oldChannel.name !== newChannel.name) {
|
||||||
|
@ -39,6 +46,10 @@ class channelUpdateListener extends Listener {
|
||||||
.addField('New channel slowmode', `${newChannel.rateLimitPerUser} seconds`, true);
|
.addField('New channel slowmode', `${newChannel.rateLimitPerUser} seconds`, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (!updateLog) return channel.send(Embed);
|
||||||
|
|
||||||
|
Embed.setDescription(`**${newChannel} channel updated by ${updateLog.executor}**`);
|
||||||
|
|
||||||
channel.send(Embed);
|
channel.send(Embed);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
37
event/listeners/log/guildBanAdd.js
Normal file
37
event/listeners/log/guildBanAdd.js
Normal file
|
@ -0,0 +1,37 @@
|
||||||
|
const { Listener } = require('discord-akairo');
|
||||||
|
const LogStats = require('../../../models/').LogStats;
|
||||||
|
|
||||||
|
class guildBanAddListener extends Listener {
|
||||||
|
constructor() {
|
||||||
|
super('guildBanAdd', {
|
||||||
|
emitter: 'client',
|
||||||
|
event: 'guildBanAdd'
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
async exec(guild, user) {
|
||||||
|
const logStats = await LogStats.findOne({where: {guild: guild.id}});
|
||||||
|
if (logStats) {
|
||||||
|
const fetchedLogs = await guild.fetchAuditLogs({
|
||||||
|
limit: 1,
|
||||||
|
type: 'MEMBER_BAN_ADD',
|
||||||
|
});
|
||||||
|
|
||||||
|
const banLog = fetchedLogs.entries.first();
|
||||||
|
|
||||||
|
const channel = this.client.channels.resolve(await logStats.get('channel'));
|
||||||
|
let Embed = this.client.util.embed()
|
||||||
|
.setColor('NAVY')
|
||||||
|
.setTitle('A user got banned!')
|
||||||
|
.setDescription(`${user.tag} got banned!`)
|
||||||
|
.setTimestamp();
|
||||||
|
|
||||||
|
if (!banLog) return channel.send(Embed);
|
||||||
|
|
||||||
|
Embed.setDescription(`${user.tag} got banned by ${banLog.executor}`);
|
||||||
|
|
||||||
|
channel.send(Embed);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
module.exports = guildBanAddListener;
|
37
event/listeners/log/guildBanRemove.js
Normal file
37
event/listeners/log/guildBanRemove.js
Normal file
|
@ -0,0 +1,37 @@
|
||||||
|
const { Listener } = require('discord-akairo');
|
||||||
|
const LogStats = require('../../../models/').LogStats;
|
||||||
|
|
||||||
|
class guildBanRemoveListener extends Listener {
|
||||||
|
constructor() {
|
||||||
|
super('guildBanRemove', {
|
||||||
|
emitter: 'client',
|
||||||
|
event: 'guildBanRemove'
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
async exec(guild, user) {
|
||||||
|
const logStats = await LogStats.findOne({where: {guild: guild.id}});
|
||||||
|
if (logStats) {
|
||||||
|
const fetchedLogs = await guild.fetchAuditLogs({
|
||||||
|
limit: 1,
|
||||||
|
type: 'MEMBER_BAN_REMOVE',
|
||||||
|
});
|
||||||
|
|
||||||
|
const unbanLog = fetchedLogs.entries.first();
|
||||||
|
|
||||||
|
const channel = this.client.channels.resolve(await logStats.get('channel'));
|
||||||
|
let Embed = this.client.util.embed()
|
||||||
|
.setColor('NAVY')
|
||||||
|
.setTitle('A user got unbanned!')
|
||||||
|
.setDescription(`${user.tag} got unbanned!`)
|
||||||
|
.setTimestamp();
|
||||||
|
|
||||||
|
if (!unbanLog) return channel.send(Embed);
|
||||||
|
|
||||||
|
Embed.setDescription(`${user.tag} got unbanned by ${unbanLog.executor}`);
|
||||||
|
|
||||||
|
channel.send(Embed);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
module.exports = guildBanRemoveListener;
|
|
@ -12,15 +12,27 @@ class messageDeleteListener extends Listener {
|
||||||
async exec(message) {
|
async exec(message) {
|
||||||
const logStats = await LogStats.findOne({where: {guild: message.guild.id}});
|
const logStats = await LogStats.findOne({where: {guild: message.guild.id}});
|
||||||
if (logStats) {
|
if (logStats) {
|
||||||
|
const fetchedLogs = await message.guild.fetchAuditLogs({
|
||||||
|
limit: 1,
|
||||||
|
type: 'MESSAGE_DELETE',
|
||||||
|
});
|
||||||
|
|
||||||
|
const deletionLog = fetchedLogs.entries.first();
|
||||||
|
|
||||||
const channel = this.client.channels.resolve(await logStats.get('channel'));
|
const channel = this.client.channels.resolve(await logStats.get('channel'));
|
||||||
let Embed = this.client.util.embed()
|
let Embed = this.client.util.embed()
|
||||||
.setColor('NAVY')
|
.setColor('NAVY')
|
||||||
.setAuthor(`${message.author.username}#${message.author.discriminator}`)
|
.setAuthor(`${message.author.username}#${message.author.discriminator}`)
|
||||||
.setDescription(`**${message.author} deleted their message in ${message.channel}**`)
|
.setDescription(`**${message.author} message got deleted in ${message.channel}**`)
|
||||||
.addField('Message deleted', message)
|
.addField('Message deleted', message)
|
||||||
.setFooter(`Author ID: ${message.author.id}`)
|
.setFooter(`Author ID: ${message.author.id}`)
|
||||||
.setTimestamp();
|
.setTimestamp();
|
||||||
|
|
||||||
|
if (!deletionLog) return channel.send(Embed);
|
||||||
|
else if (deletionLog.target === message.author) {
|
||||||
|
Embed.setDescription(`**${message.author} message was deleted by ${deletionLog.executor} in ${message.channel}**`);
|
||||||
|
}
|
||||||
|
|
||||||
channel.send(Embed);
|
channel.send(Embed);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue