grand commit que tutur attend ( marche pas le raidmode en dev)

sinon il y a pleins de truc comme les anti raid , des coorectif ect
This commit is contained in:
VALOU3336
2024-04-22 18:30:33 +02:00
parent d8912855ff
commit 9bd39c69ca
178 changed files with 9241 additions and 480 deletions
+15 -15
View File
@@ -1,20 +1,20 @@
const sqlite3 = require('sqlite3').verbose();
const { EmbedBuilder } = require('discord.js');
const db = new sqlite3.Database('myDatabase.db');
module.exports = {
name: 'bl',
aliases: ['blacklist', 'blacklistlist', 'bliste'],
description: 'AJouter ou affiché la list des blacklist',
emote: '🚫',
utilisation: 'bl [@user]',
utilisation: 'bl [@user] [raison]',
category: 'gestion',
async execute(message, args, client) {
const db = new sqlite3.Database('myDatabase.db');
const botId = message.client.user.id;
const user = message.mentions.users.first() || (args[0] && client.users.cache.get(args[0]));
const userToBlacklist = message.mentions.users.first() || (args[0] && client.users.cache.get(args[0]));
const reason = args.slice(1).join(' ') || 'Aucune raison spécifiée';
if (user) {
if (userToBlacklist) {
let data = await new Promise((resolve, reject) => {
db.get('SELECT value FROM gestion WHERE id = ?', [botId], (err, row) => {
if (err) {
@@ -29,7 +29,11 @@ module.exports = {
data.blacklist = {};
}
data.blacklist[user.id] = true;
data.blacklist[userToBlacklist.id] = {
reason: reason,
blacklistedBy: message.author.id,
timestamp: Math.floor(Date.now() / 1000)
};
db.run('INSERT OR REPLACE INTO gestion (id, value) VALUES (?, ?)', [botId, JSON.stringify(data)], (err) => {
if (err) {
@@ -37,23 +41,22 @@ module.exports = {
}
});
let successfulBans = 0;
let successfulBans = 0;
try {
if (client.guilds && client.guilds.cache) {
for (const guild of client.guilds.cache.values()) {
const member = await guild.members.fetch(user.id).catch(() => null);
const member = await guild.members.fetch(userToBlacklist.id).catch(() => null);
if (member && !member.banned) {
await guild.members.ban(user.id, { reason: 'Blacklisted by bot owner' });
await guild.members.ban(userToBlacklist.id, { reason: `Blacklisted by ${message.author.tag} for: ${reason}` });
successfulBans++;
}
}
}
} catch (error) {
console.error(error);
}
// Informe l'utilisateur que l'opération a réussi
message.reply(`L'utilisateur <@${user.id}> a été ajouté à la blacklist et a été banni de ${successfulBans} serveurs.`);
message.reply(`L'utilisateur <@${userToBlacklist.id}> a été ajouté à la blacklist pour: ${reason} et a été banni de ${successfulBans} serveurs.`);
} else {
// Récupère les données existantes de la base de données
let data = await new Promise((resolve, reject) => {
@@ -65,14 +68,11 @@ module.exports = {
resolve(row ? JSON.parse(row.value) : {});
});
});
// Récupère la liste noire spécifique à partir des données
const blacklist = data.blacklist || {};
// Crée un embed pour afficher la liste noire
const embed = new EmbedBuilder()
.setTitle('Liste des blacklist')
.setDescription(Object.keys(blacklist).map(bllist => `<@${bllist}>`).join('\n') || "Aucun personne n'est blacklist")
.setDescription(Object.keys(blacklist).map(userId => `<@${userId}>`).join('\n') || "Aucun personne n'est blacklist")
.setColor('#0099ff');
// Envoie l'embed dans le canal