Files
gestion/commands/gestion/changeall.js
T

58 lines
2.3 KiB
JavaScript

const fs = require('fs');
const path = require('path');
const sqlite3 = require('sqlite3').verbose();
module.exports = {
name: 'changeall',
aliases: ['permchangeall'],
description: 'Change le niveau de permission de toutes les commandes ayant un niveau de permission spécifié',
emote: '🔄',
utilisation: 'changeall <niveau actuel> <nouveau niveau>',
category: 'botcontrol',
async execute(message, args, client) {
const botId = client.user.id;
const unchangeableCommands = ['owner', 'unowner', 'buyer'];
if (args.length < 2) {
return message.reply('Veuillez spécifier un niveau de permission actuel et un nouveau niveau de permission.');
}
const currentPermissionLevel = parseInt(args[0]);
const newPermissionLevel = parseInt(args[1]);
if (isNaN(currentPermissionLevel) || isNaN(newPermissionLevel) || currentPermissionLevel < 0 || currentPermissionLevel > 9 || newPermissionLevel < 0 || newPermissionLevel > 9) {
return message.reply('Veuillez spécifier des niveaux de permission valides (entre 0 et 9).');
}
const db = new sqlite3.Database('myDatabase.db');
let permissions = await new Promise((resolve, reject) => {
db.get('SELECT value FROM gestion WHERE id = ?', [botId], (err, row) => {
if (err) {
console.error(err.message);
reject(err);
}
resolve(row ? JSON.parse(row.value) : {});
});
});
if (!permissions.permissions) {
permissions.permissions = {};
}
// Parcourir toutes les commandes et mettre à jour le niveau de permission
for (const commandName in permissions.permissions) {
if (permissions.permissions[commandName] === currentPermissionLevel) {
permissions.permissions[commandName] = newPermissionLevel;
}
}
db.run('INSERT OR REPLACE INTO gestion (id, value) VALUES (?, ?)', [botId, JSON.stringify(permissions)], (err) => {
if (err) {
console.error(err.message);
}
});
message.reply(`Le niveau de permission de toutes les commandes ayant le niveau ${currentPermissionLevel} a été changé à ${newPermissionLevel}.`);
},
};