Some channel logging (W.I.P)

Signed-off-by: loicbersier <loic.bersier1@gmail.com>
This commit is contained in:
loicbersier 2020-04-30 22:34:54 +02:00
parent b8105f2f1d
commit 320ac3a3f0
6 changed files with 195 additions and 0 deletions

50
commands/admin/log.js Normal file
View file

@ -0,0 +1,50 @@
const { Command } = require('discord-akairo');
const LogStats = require('../../models').LogStats;
class logCommand extends Command {
constructor() {
super('log', {
aliases: ['log', 'logging'],
category: 'admin',
userPermissions: ['MANAGE_MESSAGES'],
channel: 'guild',
description: {
content: 'Setup logging in current channel (W.I.P)',
usage: '',
examples: ['']
}
});
}
async exec(message, args) {
const logStats = await LogStats.findOne({where: {guild: message.guild.id}});
const ownerID = this.client.ownerID;
if (!logStats) {
const body = {guild: message.guild.id, channel: message.channel.id};
await LogStats.create(body);
return message.channel.send('Logging has been enabled on this channel');
} else if (logStats.get('ownerID') == message.author.id || message.member.hasPermission('ADMINISTRATOR') || message.author.id == ownerID) {
message.channel.send('The log channel is already setup, do you want to delete it? y/n');
const filter = m => m.content && m.author.id == message.author.id;
message.channel.awaitMessages(filter, {time: 5000, max: 1, errors: ['time'] })
.then(async messages => {
let messageContent = messages.map(messages => messages.content.toLowerCase());
if (messageContent == 'y' || messageContent == 'yes') {
await LogStats.destroy({where: {guild: message.guild.id}});
return message.channel.send('Log channel has been disabled!');
} else {
return message.channel.send('Not updating.');
}
})
.catch(err => {
console.error(err);
return message.channel.send('Took too long to answer. didin\'t change anything.');
});
} else {
return message.channel.send(`You are not the owner of this tag, if you think it is problematic ask an admin to remove it by doing ${this.client.commandHandler.prefix[0]}tag ${args.trigger} --remove`);
}
}
}
module.exports = logCommand;

View file

@ -0,0 +1,27 @@
const { Listener } = require('discord-akairo');
const LogStats = require('../../../models/').LogStats;
class channelCreateListener extends Listener {
constructor() {
super('channelCreate', {
emitter: 'client',
event: 'channelCreate'
});
}
async exec(GuildChannel) {
const logStats = await LogStats.findOne({where: {guild: GuildChannel.guild.id}});
if (logStats) {
const channel = this.client.channels.resolve(await logStats.get('channel'));
let Embed = this.client.util.embed()
.setColor('NAVY')
.setTitle('Channel created!')
.setDescription(`${GuildChannel.type} channel ${GuildChannel} got created!`)
.setFooter(`Channel ID: ${GuildChannel.id}`)
.setTimestamp();
channel.send(Embed);
}
}
}
module.exports = channelCreateListener;

View file

@ -0,0 +1,27 @@
const { Listener } = require('discord-akairo');
const LogStats = require('../../../models/').LogStats;
class channelDeleteListener extends Listener {
constructor() {
super('channelDelete', {
emitter: 'client',
event: 'channelDelete'
});
}
async exec(GuildChannel) {
const logStats = await LogStats.findOne({where: {guild: GuildChannel.guild.id}});
if (logStats) {
console.log(GuildChannel);
const channel = this.client.channels.resolve(await logStats.get('channel'));
let Embed = this.client.util.embed()
.setColor('NAVY')
.setTitle('Channel created!')
.setDescription(`${GuildChannel.type} channel ${GuildChannel.name} got deleted!`)
.setTimestamp();
channel.send(Embed);
}
}
}
module.exports = channelDeleteListener;

View file

@ -0,0 +1,50 @@
const { Listener } = require('discord-akairo');
const LogStats = require('../../../models/').LogStats;
class channelUpdateListener extends Listener {
constructor() {
super('channelUpdate', {
emitter: 'client',
event: 'channelUpdate'
});
}
async exec(oldChannel, newChannel) {
const logStats = await LogStats.findOne({where: {guild: newChannel.guild.id}});
if (logStats) {
const channel = this.client.channels.resolve(await logStats.get('channel'));
let Embed = this.client.util.embed()
.setColor('NAVY')
.setTitle(`${newChannel.type} channel updated!`)
.setTimestamp();
if (oldChannel.name !== newChannel.name) {
Embed.addField('', '')
.addField('Previous channel', oldChannel.name, true)
.addField('New channel', newChannel.name, true);
}
if (oldChannel.topic !== newChannel.topic) {
Embed.addField('', '')
.addField('Previous channel topic', oldChannel.topic, true)
.addField('New channel topic', newChannel.topic, true);
}
if (oldChannel.nsfw !== newChannel.nsfw) {
Embed.addField('', '')
.addField('Previous channel nsfw', oldChannel.nsfw, true)
.addField('New channel nsfw', newChannel.nsfw, true);
}
if (oldChannel.rateLimitPerUser !== newChannel.rateLimitPerUser) {
Embed.addField('', '')
.addField('Previous channel slowmode', `${oldChannel.rateLimitPerUser} seconds`, true)
.addField('New channel slowmode', `${newChannel.rateLimitPerUser} seconds`, true);
}
channel.send(Embed);
}
}
}
module.exports = channelUpdateListener;

View file

@ -0,0 +1,30 @@
'use strict';
module.exports = {
up: (queryInterface, Sequelize) => {
return queryInterface.createTable('LogStats', {
id: {
allowNull: false,
autoIncrement: true,
primaryKey: true,
type: Sequelize.INTEGER
},
guild: {
type: Sequelize.BIGINT
},
channel: {
type: Sequelize.BIGINT
},
createdAt: {
allowNull: false,
type: Sequelize.DATE
},
updatedAt: {
allowNull: false,
type: Sequelize.DATE
}
});
},
down: (queryInterface, Sequelize) => {
return queryInterface.dropTable('LogStats');
}
};

11
models/logstats.js Normal file
View file

@ -0,0 +1,11 @@
'use strict';
module.exports = (sequelize, DataTypes) => {
const LogStats = sequelize.define('LogStats', {
guild: DataTypes.BIGINT,
channel: DataTypes.BIGINT
}, {});
LogStats.associate = function(models) {
// associations can be defined here
};
return LogStats;
};