Whitelist word
parent
a878ea977c
commit
63c10d758c
@ -0,0 +1,68 @@
|
|||||||
|
const { Command } = require('discord-akairo');
|
||||||
|
const whitelistWord = require('../../models').whitelistWord;
|
||||||
|
|
||||||
|
class whitelistWordCommand extends Command {
|
||||||
|
constructor() {
|
||||||
|
super('whitelistWord', {
|
||||||
|
aliases: ['whitelistWord'],
|
||||||
|
category: 'admin',
|
||||||
|
userPermissions: ['MANAGE_MESSAGES'],
|
||||||
|
clientPermissions: ['MANAGE_MESSAGES', 'SEND_MESSAGES'],
|
||||||
|
args: [
|
||||||
|
{
|
||||||
|
id: 'word',
|
||||||
|
type: 'string',
|
||||||
|
match: 'rest'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
id: 'remove',
|
||||||
|
match: 'flag',
|
||||||
|
flag: '--remove'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
id: 'removeall',
|
||||||
|
match: 'flag',
|
||||||
|
flag: '--removeall'
|
||||||
|
}
|
||||||
|
],
|
||||||
|
channelRestriction: 'guild',
|
||||||
|
description: {
|
||||||
|
content: 'Ban word on the server. use the unbanword alias to delete a banned word, unbanword alias and --removeaall to remove every banned word',
|
||||||
|
usage: '[word to ban]',
|
||||||
|
examples: ['owo']
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
async exec(message, args) {
|
||||||
|
if (!args.word) args.word = '';
|
||||||
|
args.word = args.word.replace(/[\u0250-\ue007]/g, '');
|
||||||
|
const WhitelistWord = await whitelistWord.findOne({where: {word: args.word.toLowerCase(), serverID: message.guild.id}});
|
||||||
|
|
||||||
|
if (message.util.parsed.alias == 'unbanword') {
|
||||||
|
if (args.removeall) {
|
||||||
|
whitelistWord.destroy({where: {serverID: message.guild.id}});
|
||||||
|
return message.channel.send('The whitelisted words has been reset.');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (WhitelistWord) {
|
||||||
|
whitelistWord.destroy({where: {word: args.word.toLowerCase(), serverID: message.guild.id}});
|
||||||
|
return message.channel.send(`The word ${args.word.toLowerCase()} is no longer whitelisted`);
|
||||||
|
} else {
|
||||||
|
return message.channel.send('There was no word to whiteliste');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!args.word) return message.channel.send('Please specify a word to whiteliste!');
|
||||||
|
|
||||||
|
if (!WhitelistWord) {
|
||||||
|
const body = {word: args.word.toLowerCase(), serverID: message.guild.id};
|
||||||
|
await whitelistWord.create(body);
|
||||||
|
return message.channel.send(`The word ${args.word.toLowerCase()} has been whitelisted`);
|
||||||
|
} else {
|
||||||
|
message.channel.send('This word is already whitelisted');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
module.exports = whitelistWordCommand;
|
@ -0,0 +1,30 @@
|
|||||||
|
'use strict';
|
||||||
|
module.exports = {
|
||||||
|
up: (queryInterface, Sequelize) => {
|
||||||
|
return queryInterface.createTable('whitelistWords', {
|
||||||
|
id: {
|
||||||
|
allowNull: false,
|
||||||
|
autoIncrement: true,
|
||||||
|
primaryKey: true,
|
||||||
|
type: Sequelize.INTEGER
|
||||||
|
},
|
||||||
|
word: {
|
||||||
|
type: Sequelize.STRING
|
||||||
|
},
|
||||||
|
serverID: {
|
||||||
|
type: Sequelize.BIGINT
|
||||||
|
},
|
||||||
|
createdAt: {
|
||||||
|
allowNull: false,
|
||||||
|
type: Sequelize.DATE
|
||||||
|
},
|
||||||
|
updatedAt: {
|
||||||
|
allowNull: false,
|
||||||
|
type: Sequelize.DATE
|
||||||
|
}
|
||||||
|
});
|
||||||
|
},
|
||||||
|
down: (queryInterface, Sequelize) => {
|
||||||
|
return queryInterface.dropTable('whitelistWords');
|
||||||
|
}
|
||||||
|
};
|
@ -0,0 +1,11 @@
|
|||||||
|
'use strict';
|
||||||
|
module.exports = (sequelize, DataTypes) => {
|
||||||
|
const whitelistWord = sequelize.define('whitelistWord', {
|
||||||
|
word: DataTypes.STRING,
|
||||||
|
serverID: DataTypes.BIGINT
|
||||||
|
}, {});
|
||||||
|
whitelistWord.associate = function(models) {
|
||||||
|
// associations can be defined here
|
||||||
|
};
|
||||||
|
return whitelistWord;
|
||||||
|
};
|
Loading…
Reference in New Issue