diff --git a/commands/jobs/kill.js b/commands/jobs/kill.js new file mode 100644 index 0000000..b6471bb --- /dev/null +++ b/commands/jobs/kill.js @@ -0,0 +1,76 @@ +const { EmbedBuilder } = require('discord.js'); +const db = require('../../fonctions/database.js'); +const embedColor = require('../../fonctions/embedColor.js'); + +module.exports = { + aliases: [], + description: 'Vole les reputations d\'un membre.', + emote: '🦹', + utilisation: '<@membre>', + permission: 0, + + async execute(message, args, client) { + const member = message.mentions.users.first(); + if (!member) { + const embed = new EmbedBuilder() + .setTitle('Erreur') + .setDescription('❌ Vous devez mentionner un membre.') + .setColor(await embedColor(message.author.id, message.guild.id)) + .setTimestamp() + .setFooter({ text: `Demandé par ${message.author.tag}`, iconURL: message.author.displayAvatarURL() }); + + return message.reply({ embeds: [embed], allowedMentions: { repliedUser: false } }); + } + + const user = await new Promise((resolve, reject) => { + db.get(`SELECT * FROM users WHERE guildId = ? AND userId = ?`, [message.guild.id, message.author.id], (err, row) => { + if (err) reject(err); + resolve(row); + }); + }); + + if (user.lastKill + 7200000 > Date.now()) { + const embed = new EmbedBuilder() + .setTitle('Erreur') + .setDescription(`❌ Vous devez encore attendre ${Math.floor((user.lastKill + 7200000 - Date.now()) / 60000)} minutes avant de pouvoir voler à nouveau.`) + .setColor(await embedColor(message.author.id, message.guild.id)) + .setTimestamp() + .setFooter({ text: `Demandé par ${message.author.tag}`, iconURL: message.author.displayAvatarURL() }); + + return message.reply({ embeds: [embed], allowedMentions: { repliedUser: false } }); + } + + const memberInfo = await new Promise((resolve, reject) => { + db.get(`SELECT * FROM users WHERE guildId = ? AND userId = ?`, [message.guild.id, member.id], (err, row) => { + if (err) reject(err); + resolve(row); + }); + }); + + const memberRep = memberInfo.reputation; + + if (memberRep <= 0) { + const embed = new EmbedBuilder() + .setTitle('Erreur') + .setDescription(`❌ <@${member.id}> n'a pas de reputation.`) + .setColor(await embedColor(message.author.id, message.guild.id)) + .setTimestamp() + .setFooter({ text: `Demandé par ${message.author.tag}`, iconURL: message.author.displayAvatarURL() }); + + return message.reply({ embeds: [embed], allowedMentions: { repliedUser: false } }); + } + + const amount = Math.floor(Math.random() * memberRep) + 1; + db.run(`UPDATE users SET reputation = reputation - ? WHERE guildId = ? AND userId = ?`, [amount, message.guild.id, member.id]); + db.run(`UPDATE users SET reputation = reputation + ?, lastKill = ? WHERE guildId = ? AND userId = ?`, [amount, Date.now(), message.guild.id, message.author.id]); + + const embed = new EmbedBuilder() + .setTitle('Vol') + .setDescription(`💰 Vous avez volé **${amount}rep** à <@${member.id}>.`) + .setColor(await embedColor(message.author.id, message.guild.id)) + .setTimestamp() + .setFooter({ text: `Demandé par ${message.author.tag}`, iconURL: message.author.displayAvatarURL() }); + + message.reply({ embeds: [embed], allowedMentions: { repliedUser: false } }); + }, +}; \ No newline at end of file diff --git a/fonctions/database.js b/fonctions/database.js index d224f3c..f30b704 100644 --- a/fonctions/database.js +++ b/fonctions/database.js @@ -28,6 +28,7 @@ db.run(`CREATE TABLE IF NOT EXISTS users ( lastRep INTERGER DEFAULT 0, lastTrep INTERGER DEFAULT 0, lastHack INTERGER DEFAULT 0, + lastKill INTERGER DEFAULT 0, job TEXT, teamId TEXT, teamRole TEXT,