This commit is contained in:
parent
30c7fd171f
commit
99d6fc2401
4 changed files with 167 additions and 64 deletions
|
@ -2,55 +2,106 @@ const sqlite3 = require('sqlite3').verbose();
|
||||||
|
|
||||||
module.exports = {
|
module.exports = {
|
||||||
name: 'whitelist',
|
name: 'whitelist',
|
||||||
description: 'Whitelist a command in a specific server.',
|
description: 'Whitelist a command in a specific server, or for a user.',
|
||||||
admin: true,
|
admin: true,
|
||||||
async execute({message, args, prefix, client}) {
|
async execute({message, args, prefix, client}) {
|
||||||
if(args.length < 2){
|
if(args.length < 3){
|
||||||
message.channel.send(`You need to supply the command and channel that you want to whitelist\n\`${prefix}whitelist <command> <server_id>\``);
|
message.channel.send(`You need to supply the command and guild that you want to whitelist\n\`${prefix}whitelist <user|guild> <command> <user_id|guild_id>\``);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
let command = args[0];
|
let option = args[0];
|
||||||
let guild = args[1];
|
let command = args[1];
|
||||||
if(guild === "this") guild = message.guild.id;
|
let guildOrUser = args[2];
|
||||||
// TODO: Add ability to remove server from whitelist.
|
|
||||||
const whitelistedCommands = client.whitelist.get(guild);
|
if(option === "guild" || option === "server"){
|
||||||
if(whitelistedCommands && whitelistedCommands.includes(command)){
|
if(guildOrUser === "this") guildOrUser = message.guild.id;
|
||||||
message.channel.send("Command is already whitelisted in that server.")
|
const whitelistedCommands = client.whitelist.guild.get(guildOrUser);
|
||||||
|
if(whitelistedCommands && whitelistedCommands.includes(command)){
|
||||||
|
message.channel.send("Command is already whitelisted in that server.")
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
// TODO: First check if the bot has access to that guild before whitelisting.
|
||||||
|
const databasePath = 'data/database.db'
|
||||||
|
const db = new sqlite3.Database(databasePath)
|
||||||
|
let err = false;
|
||||||
|
await new Promise((resolve, reject)=>{
|
||||||
|
db.run(`INSERT INTO guild_whitelist (
|
||||||
|
guildId,
|
||||||
|
command,
|
||||||
|
dateAdded
|
||||||
|
) VALUES (?, ?, ?)`,
|
||||||
|
[
|
||||||
|
guildOrUser,
|
||||||
|
command,
|
||||||
|
new Date().getTime()
|
||||||
|
], function (error) {
|
||||||
|
if (error) {
|
||||||
|
console.error(error);
|
||||||
|
err = true;
|
||||||
|
resolve();
|
||||||
|
}else{
|
||||||
|
resolve();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
})
|
||||||
|
db.close();
|
||||||
|
if(!err){
|
||||||
|
if(whitelistedCommands){
|
||||||
|
whitelistedCommands.push(command);
|
||||||
|
client.whitelist.guild.set(guildOrUser, whitelistedCommands);
|
||||||
|
}else {
|
||||||
|
client.whitelist.guild.set(guildOrUser, command);
|
||||||
|
}
|
||||||
|
message.channel.send(`"${command}" has been whitelisted in that server.`)
|
||||||
|
|
||||||
|
} else message.channel.send("Could not whitelist the server with that command. Check the logs.")
|
||||||
|
return;
|
||||||
|
}else if (option === "user"){
|
||||||
|
const whitelistedCommands = client.whitelist.user.get(guildOrUser);
|
||||||
|
if(whitelistedCommands && whitelistedCommands.includes(command)){
|
||||||
|
message.channel.send("Command is already whitelisted for that user.")
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
const databasePath = 'data/database.db'
|
||||||
|
const db = new sqlite3.Database(databasePath)
|
||||||
|
let err = false;
|
||||||
|
await new Promise((resolve, reject)=>{
|
||||||
|
db.run(`INSERT INTO user_whitelist (
|
||||||
|
userId,
|
||||||
|
command,
|
||||||
|
dateAdded
|
||||||
|
) VALUES (?, ?, ?)`,
|
||||||
|
[
|
||||||
|
guildOrUser,
|
||||||
|
command,
|
||||||
|
new Date().getTime()
|
||||||
|
], function (error) {
|
||||||
|
if (error) {
|
||||||
|
console.error(error);
|
||||||
|
err = true;
|
||||||
|
resolve();
|
||||||
|
}else{
|
||||||
|
resolve();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
})
|
||||||
|
db.close();
|
||||||
|
if(!err){
|
||||||
|
if(whitelistedCommands){
|
||||||
|
whitelistedCommands.push(command);
|
||||||
|
client.whitelist.user.set(guildOrUser, whitelistedCommands);
|
||||||
|
}else {
|
||||||
|
client.whitelist.user.set(guildOrUser, command);
|
||||||
|
}
|
||||||
|
message.channel.send(`"${command}" has been whitelisted for ${guildOrUser}.`)
|
||||||
|
|
||||||
|
} else message.channel.send("Could not whitelist the server with that command. Check the logs.")
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
// TODO: First check if the bot has access to that guild before whitelisting.
|
|
||||||
const databasePath = 'data/database.db'
|
|
||||||
const db = new sqlite3.Database(databasePath)
|
|
||||||
let err = false;
|
|
||||||
await new Promise((resolve, reject)=>{
|
|
||||||
db.run(`INSERT INTO whitelist (
|
|
||||||
serverId,
|
|
||||||
command,
|
|
||||||
dateAdded
|
|
||||||
) VALUES (?, ?, ?)`,
|
|
||||||
[
|
|
||||||
guild,
|
|
||||||
command,
|
|
||||||
new Date().getTime()
|
|
||||||
], function (error) {
|
|
||||||
if (error) {
|
|
||||||
console.error(error);
|
|
||||||
err = true;
|
|
||||||
resolve();
|
|
||||||
}else{
|
|
||||||
resolve();
|
|
||||||
}
|
|
||||||
});
|
|
||||||
})
|
|
||||||
if(!err){
|
|
||||||
if(whitelistedCommands){
|
|
||||||
whitelistedCommands.push(command);
|
|
||||||
client.whitelist.set(guild, whitelistedCommands);
|
|
||||||
}else {
|
|
||||||
client.whitelist.set(guild, command);
|
|
||||||
}
|
|
||||||
message.channel.send("Command has been whitelisted in that server.")
|
|
||||||
|
|
||||||
} else message.channel.send("Could not whitelist the server with that command. Check the logs.")
|
|
||||||
|
|
||||||
|
// TODO: Add ability to remove server from whitelist.
|
||||||
}
|
}
|
||||||
|
|
||||||
};
|
};
|
|
@ -44,8 +44,10 @@ const {
|
||||||
client.settings = new Collection();
|
client.settings = new Collection();
|
||||||
client.commands = new Collection();
|
client.commands = new Collection();
|
||||||
client.serverPrefixes = new Collection();
|
client.serverPrefixes = new Collection();
|
||||||
client.whitelist = new Collection();
|
client.whitelist = {
|
||||||
|
guild: new Collection(),
|
||||||
|
user: new Collection()
|
||||||
|
}
|
||||||
|
|
||||||
createAndLoadWhitelistTable(client.whitelist);
|
createAndLoadWhitelistTable(client.whitelist);
|
||||||
|
|
||||||
|
|
|
@ -1,34 +1,61 @@
|
||||||
const sqlite3 = require('sqlite3').verbose();
|
const sqlite3 = require('sqlite3').verbose();
|
||||||
module.exports = async function (clientWhitelist) {
|
module.exports = async function (clientWhitelist) {
|
||||||
const db = new sqlite3.Database('data/database.db');
|
const db = new sqlite3.Database('data/database.db');
|
||||||
|
await createGuildWhitelist(db);
|
||||||
|
await createUserWhitelist(db);
|
||||||
|
db.close();
|
||||||
|
loadWhitelist(clientWhitelist);
|
||||||
|
}
|
||||||
|
|
||||||
|
async function createGuildWhitelist(db) {
|
||||||
await new Promise ((resolve, reject)=>{
|
await new Promise ((resolve, reject)=>{
|
||||||
db.run(
|
db.run(
|
||||||
`CREATE TABLE IF NOT EXISTS whitelist (
|
`CREATE TABLE IF NOT EXISTS guild_whitelist (
|
||||||
Id INTEGER PRIMARY KEY AUTOINCREMENT,
|
Id INTEGER PRIMARY KEY AUTOINCREMENT,
|
||||||
serverId TEXT,
|
guildId TEXT,
|
||||||
command TEXT,
|
command TEXT,
|
||||||
dateAdded INTEGER)`,
|
dateAdded INTEGER)`,
|
||||||
(err) => {
|
(err) => {
|
||||||
if (err) {
|
if (err) {
|
||||||
console.error(`Error while creating table 'whitelist': ${err}`);
|
db.close();
|
||||||
|
console.error(`Error while creating table 'guild_whitelist': ${err}`);
|
||||||
reject(err);
|
reject(err);
|
||||||
} else {
|
} else {
|
||||||
console.log("Table 'whitelist' created successfully.");
|
console.log("Table 'guild_whitelist' created successfully.");
|
||||||
resolve();
|
resolve();
|
||||||
}
|
}
|
||||||
db.close();
|
|
||||||
}
|
}
|
||||||
);
|
);
|
||||||
})
|
});
|
||||||
loadWhitelist(clientWhitelist);
|
}
|
||||||
|
async function createUserWhitelist(db) {
|
||||||
|
await new Promise ((resolve, reject)=>{
|
||||||
|
db.run(
|
||||||
|
`CREATE TABLE IF NOT EXISTS user_whitelist (
|
||||||
|
Id INTEGER PRIMARY KEY AUTOINCREMENT,
|
||||||
|
userId TEXT,
|
||||||
|
command TEXT,
|
||||||
|
dateAdded INTEGER)`,
|
||||||
|
(err) => {
|
||||||
|
if (err) {
|
||||||
|
db.close();
|
||||||
|
console.error(`Error while creating table 'user_whitelist': ${err}`);
|
||||||
|
reject(err);
|
||||||
|
} else {
|
||||||
|
console.log("Table 'user_whitelist' created successfully.");
|
||||||
|
resolve();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
);
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
async function loadWhitelist(clientWhitelist) {
|
async function loadWhitelist(clientWhitelist) {
|
||||||
const db = new sqlite3.Database('data/database.db');
|
const db = new sqlite3.Database('data/database.db');
|
||||||
let rows = await new Promise((resolve) => {
|
let guildRows = await new Promise((resolve) => {
|
||||||
db.all(`SELECT * FROM whitelist`, function (error, rows){
|
db.all(`SELECT * FROM guild_whitelist`, function (error, rows){
|
||||||
if(error){
|
if(error){
|
||||||
console.error("Failed to read whitelist table")
|
console.error("Failed to read guild_whitelist table")
|
||||||
console.error(error);
|
console.error(error);
|
||||||
resolve([]);
|
resolve([]);
|
||||||
}else{
|
}else{
|
||||||
|
@ -36,13 +63,33 @@ async function loadWhitelist(clientWhitelist) {
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
rows.forEach(row => {
|
let userRows = await new Promise((resolve) => {
|
||||||
if(clientWhitelist.has(row.serverId)){
|
db.all(`SELECT * FROM user_whitelist`, function (error, rows){
|
||||||
let oldEntry = clientWhitelist.get(row.serverId);
|
if(error){
|
||||||
|
console.error("Failed to read user_whitelist table")
|
||||||
|
console.error(error);
|
||||||
|
resolve([]);
|
||||||
|
}
|
||||||
|
})
|
||||||
|
})
|
||||||
|
guildRows.forEach(row => {
|
||||||
|
if(clientWhitelist.guild.has(row.guildId)){
|
||||||
|
let oldEntry = clientWhitelist.guild.get(row.guildId);
|
||||||
oldEntry.push(row.command)
|
oldEntry.push(row.command)
|
||||||
clientWhitelist.set(row.serverId, oldEntry)
|
clientWhitelist.guild.set(row.guildId, oldEntry)
|
||||||
}else {
|
}else {
|
||||||
clientWhitelist.set(row.serverId, [row.command])
|
clientWhitelist.guild.set(row.guildId, [row.command])
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
userRows.forEach(row => {
|
||||||
|
if(clientWhitelist.user.has(row.userId)){
|
||||||
|
let oldEntry = clientWhitelist.user.get(row.userId);
|
||||||
|
oldEntry.push(row.command)
|
||||||
|
clientWhitelist.user.set(row.userId, oldEntry)
|
||||||
|
}else {
|
||||||
|
clientWhitelist.user.set(row.userId, [row.command])
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
db.close();
|
||||||
}
|
}
|
|
@ -21,10 +21,13 @@ module.exports = function(client, owners, message, globalPrefix){
|
||||||
const command = client.commands.get(commandName);
|
const command = client.commands.get(commandName);
|
||||||
if(!command) return;
|
if(!command) return;
|
||||||
if(command.needsWhitelist){
|
if(command.needsWhitelist){
|
||||||
let isWhitelisted = client.whitelist.get(message.guild.id)?.includes(command.name);
|
let isGuildWhitelisted = client.whitelist.get(message.guild.id)?.includes(command.name);
|
||||||
if(!isWhitelisted){
|
if(!isGuildWhitelisted){
|
||||||
message.channel.send(`\`${command.name}\` is not whitelisted in this server. The bot admin needs to whitelist the command in this server for it to work`)
|
let isUserWhitelisted = client.whitelist.user.get(message.author.id)?.includes(command.name);
|
||||||
return;
|
if(!isUserWhitelisted){
|
||||||
|
message.channel.send(`\`${command.name}\` is not whitelisted in this server. The bot admin needs to whitelist the command in this server for it to work`)
|
||||||
|
return;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (command.admin && owners.indexOf(message.author.id.toString()) == -1) return;
|
if (command.admin && owners.indexOf(message.author.id.toString()) == -1) return;
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue