This commit is contained in:
2026-03-15 12:22:42 +01:00
parent cd99275933
commit 311ba5e7f3
558 changed files with 55182 additions and 22981 deletions

View File

@@ -1,125 +1,114 @@
const { SlashCommandBuilder, PermissionFlagsBits, EmbedBuilder } = require('discord.js');
const { SlashCommandBuilder, PermissionFlagsBits, EmbedBuilder, MessageFlags } = require('discord.js');
const db = require('../../functions/database/db.js');
const { sendLog } = require('../../utils/helpers');
const { colors, emojis } = require('../../utils/constants');
module.exports = {
category: 'moderation',
data: new SlashCommandBuilder()
.setName('changesanction')
.setDescription('Changer la raison d\'une sanction.')
.addUserOption(option =>
option.setName('user')
.setDescription('L\'utilisateur concerné')
.setRequired(true))
.addIntegerOption(option =>
option.setName('sanction_id')
.setDescription('L\'ID DB de la sanction (visible dans /casier, ex: ID: 123)')
.setRequired(true))
.addStringOption(option =>
option.setName('new_reason')
.setDescription('La nouvelle raison')
.setRequired(true))
.setDefaultMemberPermissions(PermissionFlagsBits.ModerateMembers),
async execute(interaction) {
const target = interaction.options.getUser('user');
const sanctionId = interaction.options.getInteger('sanction_id');
const newReason = interaction.options.getString('new_reason');
category: 'moderation',
data: new SlashCommandBuilder()
.setName('changesanction')
.setDescription('Changer la raison d\'une sanction.')
.addUserOption(option =>
option.setName('user')
.setDescription('L\'utilisateur concerné')
.setRequired(true))
.addIntegerOption(option =>
option.setName('sanction_id')
.setDescription('L\'ID DB de la sanction (visible dans /casier, ex: ID: 123)')
.setRequired(true))
.addStringOption(option =>
option.setName('new_reason')
.setDescription('La nouvelle raison')
.setRequired(true))
.setDefaultMemberPermissions(PermissionFlagsBits.ModerateMembers),
await interaction.deferReply({ ephemeral: true });
async execute(interaction) {
const target = interaction.options.getUser('user');
const sanctionId = interaction.options.getInteger('sanction_id');
const newReason = interaction.options.getString('new_reason');
try {
console.log(`[changesanction] Recherche sanction ID: ${sanctionId}, userId: ${target.id}, guildId: ${interaction.guild.id}`);
// Récupérer directement la sanction par son ID DB (plus stable)
const [sanctionRows] = await db.query(
'SELECT * FROM logs WHERE id = ? AND userId = ? AND guildId = ?',
[sanctionId, target.id, interaction.guild.id]
);
await interaction.deferReply({ flags: MessageFlags.Ephemeral });
console.log(`[changesanction] Résultats trouvés: ${sanctionRows.length}`);
try {
const [sanctionRows] = await db.query(
'SELECT * FROM logs WHERE id = ? AND userId = ? AND guildId = ?',
[sanctionId, target.id, interaction.guild.id]
);
if (!sanctionRows.length) {
// Vérifier si l'ID existe pour cet utilisateur (peut-être mauvais serveur?)
const [allUserLogs] = await db.query(
'SELECT id, action, guildId FROM logs WHERE id = ? AND userId = ?',
[sanctionId, target.id]
);
if (allUserLogs.length > 0) {
const log = allUserLogs[0];
const guildName = interaction.client.guilds.cache.get(log.guildId)?.name || 'Serveur inconnu';
return interaction.editReply({
content: `❌ La sanction avec l'ID ${sanctionId} existe, mais elle appartient au serveur "${guildName}" (guildId: ${log.guildId}), pas à "${interaction.guild.name}" (guildId: ${interaction.guild.id}).`
});
}
return interaction.editReply({
content: `❌ Aucune sanction trouvée avec l'ID ${sanctionId} pour ${target.tag}.\n\n💡 **Astuce:** Utilise l'ID DB visible dans \`/casier\` (ex: \`#1 (ID: 123)\` → utilise \`123\`).`
});
}
if (!sanctionRows.length) {
const [allUserLogs] = await db.query(
'SELECT id, action, guildId FROM logs WHERE id = ? AND userId = ?',
[sanctionId, target.id]
);
if (allUserLogs.length > 0) {
const log = allUserLogs[0];
const guildName = interaction.client.guilds.cache.get(log.guildId)?.name || 'Serveur inconnu';
return interaction.editReply({
content: `❌ La sanction avec l'ID ${sanctionId} existe, mais elle appartient au serveur "${guildName}" (guildId: ${log.guildId}), pas à "${interaction.guild.name}" (guildId: ${interaction.guild.id}).`
});
}
return interaction.editReply({
content: `❌ Aucune sanction trouvée avec l'ID ${sanctionId} pour ${target.tag}.\n\n💡 **Astuce:** Utilise l'ID DB visible dans \`/casier\` (ex: \`#1 (ID: 123)\` → utilise \`123\`).`
});
}
const sanction = sanctionRows[0];
const sanction = sanctionRows[0];
// Vérifier que ce n'est pas une modification/révocation
if (sanction.action === 'Modification de sanction' ||
sanction.action === 'Révocation de sanction' ||
sanction.action === 'Modification de mute') {
return interaction.editReply({ content: `❌ Cette entrée est une modification, pas une sanction. Utilise l'ID d'une vraie sanction.` });
}
const oldReason = sanction.reason;
if (sanction.action === 'Modification de sanction' ||
sanction.action === 'Révocation de sanction' ||
sanction.action === 'Modification de mute') {
return interaction.editReply({ content: `❌ Cette entrée est une modification, pas une sanction. Utilise l'ID d'une vraie sanction.` });
}
const oldReason = sanction.reason;
// Mettre à jour la raison
await db.query(
'UPDATE logs SET reason = ?, modId = ?, modTag = ? WHERE id = ?',
[newReason, interaction.user.id, interaction.user.tag, sanction.id]
);
await db.query(
'UPDATE logs SET reason = ?, modId = ?, modTag = ? WHERE id = ?',
[newReason, interaction.user.id, interaction.user.tag, sanction.id]
);
// Log de la modification
await db.query(
`INSERT INTO logs (userId, userTag, modId, modTag, action, reason, type, guildId, timestamp)
VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?)`,
[target.id, target.tag, interaction.user.id, interaction.user.tag, 'Modification de sanction', `Ancienne raison: ${oldReason} → Nouvelle raison: ${newReason}`, null, interaction.guild.id, Date.now()]
);
await db.query(
`INSERT INTO logs (userId, userTag, modId, modTag, action, reason, type, guildId, timestamp)
VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?)`,
[target.id, target.tag, interaction.user.id, interaction.user.tag, 'Modification de sanction', `Ancienne raison: ${oldReason} → Nouvelle raison: ${newReason}`, null, interaction.guild.id, Date.now()]
);
const { colors, emojis } = require('../../utils/constants');
const { sendLog } = require('../../utils/helpers');
const embed = new EmbedBuilder()
.setTitle(`${emojis.success} Sanction Modifiée`)
.setColor(colors.success)
.setThumbnail(target.displayAvatarURL({ dynamic: true }))
.addFields(
{ name: '👤 Utilisateur', value: `<@${target.id}> (${target.tag})`, inline: true },
{ name: '🔧 Modérateur', value: `<@${interaction.user.id}> (${interaction.user.tag})`, inline: true },
{ name: '📝 Ancienne raison', value: oldReason || 'N/A', inline: false },
{ name: '📝 Nouvelle raison', value: newReason, inline: false },
{ name: '🆔 ID Sanction', value: `${sanction.id}`, inline: true },
{ name: '📅 Date', value: `<t:${Math.floor(Date.now() / 1000)}:F>`, inline: true }
)
.setFooter({ text: `ID: ${target.id}` })
.setTimestamp();
const embed = new EmbedBuilder()
.setTitle(`${emojis.success} Sanction Modifiée`)
.setColor(colors.success)
.setThumbnail(target.displayAvatarURL({ dynamic: true }))
.addFields(
{ name: '👤 Utilisateur', value: `<@${target.id}> (${target.tag})`, inline: true },
{ name: '🔧 Modérateur', value: `<@${interaction.user.id}> (${interaction.user.tag})`, inline: true },
{ name: '📝 Ancienne raison', value: oldReason || 'N/A', inline: false },
{ name: '📝 Nouvelle raison', value: newReason, inline: false },
{ name: '🆔 ID Sanction', value: `${sanction.id}`, inline: true },
{ name: '📅 Date', value: `<t:${Math.floor(Date.now() / 1000)}:F>`, inline: true }
)
.setFooter({ text: `ID: ${target.id}` })
.setTimestamp();
await interaction.editReply({ embeds: [embed] });
await interaction.editReply({ embeds: [embed] });
// Log dans le canal de logs
const logEmbed = new EmbedBuilder()
.setTitle(`${emojis.success} Modification de Sanction`)
.setColor(colors.success)
.addFields(
{ name: '👤 Utilisateur', value: `<@${target.id}> (${target.tag})`, inline: true },
{ name: '🔧 Modérateur', value: `<@${interaction.user.id}> (${interaction.user.tag})`, inline: true },
{ name: '📝 Ancienne raison', value: oldReason || 'N/A', inline: false },
{ name: '📝 Nouvelle raison', value: newReason, inline: false },
{ name: '🆔 ID Sanction', value: `${sanction.id}`, inline: true },
{ name: '📅 Date', value: `<t:${Math.floor(Date.now() / 1000)}:F>`, inline: true }
)
.setFooter({ text: `ID: ${target.id} | Serveur: ${interaction.guild.name}` })
.setTimestamp();
await sendLog(interaction.guild, { embeds: [logEmbed] });
} catch (err) {
console.error('Erreur lors de la modification de la sanction:', err);
await interaction.editReply({ content: `❌ Échec de la modification de la sanction: ${err.message}` });
}
},
};
const logEmbed = new EmbedBuilder()
.setTitle(`${emojis.success} Modification de Sanction`)
.setColor(colors.success)
.addFields(
{ name: '👤 Utilisateur', value: `<@${target.id}> (${target.tag})`, inline: true },
{ name: '🔧 Modérateur', value: `<@${interaction.user.id}> (${interaction.user.tag})`, inline: true },
{ name: '📝 Ancienne raison', value: oldReason || 'N/A', inline: false },
{ name: '📝 Nouvelle raison', value: newReason, inline: false },
{ name: '🆔 ID Sanction', value: `${sanction.id}`, inline: true },
{ name: '📅 Date', value: `<t:${Math.floor(Date.now() / 1000)}:F>`, inline: true }
)
.setFooter({ text: `ID: ${target.id} | Serveur: ${interaction.guild.name}` })
.setTimestamp();
await sendLog(interaction.guild, { embeds: [logEmbed] });
} catch (err) {
console.error('Erreur changesanction:', err);
await interaction.editReply({ content: `❌ Échec de la modification de la sanction: ${err.message}` });
}
},
};