Update Bot
This commit is contained in:
@@ -34,19 +34,45 @@ module.exports = {
|
||||
let unbanDate = null;
|
||||
|
||||
if (durationInput) {
|
||||
const regex = /^(\d+)([smhd])$/;
|
||||
const regex = /^(\d+)(s|m|h|d|mo|y)$/;
|
||||
const match = durationInput.match(regex);
|
||||
if (match) {
|
||||
const value = parseInt(match[1]);
|
||||
const unit = match[2];
|
||||
let multiplier = 1000;
|
||||
if (unit === 's') multiplier *= 60 / 60;
|
||||
if (unit === 'm') multiplier *= 60;
|
||||
if (unit === 'h') multiplier *= 60 * 60;
|
||||
if (unit === 'd') multiplier *= 60 * 60 * 24;
|
||||
if (unit === 'mo') multiplier *= 60 * 60 * 24 * 30;
|
||||
if (unit === 'y') multiplier *= 60 * 60 * 24 * 365;
|
||||
unbanDate = Date.now() + value * multiplier;
|
||||
type = 'Temporary';
|
||||
}
|
||||
}
|
||||
// juste avant la création de l'embed
|
||||
let durationText = type;
|
||||
if (type === 'Temporary' && unbanDate) {
|
||||
const initialDurationMs = unbanDate - Date.now() + (Date.now() - Date.now()); // ça reste l'unbanDate - timestamp original
|
||||
function formatInitialDuration(ms) {
|
||||
const seconds = Math.floor(ms / 1000) % 60;
|
||||
const minutes = Math.floor(ms / (1000 * 60)) % 60;
|
||||
const hours = Math.floor(ms / (1000 * 60 * 60)) % 24;
|
||||
const days = Math.floor(ms / (1000 * 60 * 60 * 24));
|
||||
const months = Math.floor(ms / (1000 * 60 * 60 * 24 * 30));
|
||||
const years = Math.floor(ms / (1000 * 60 * 60 * 24 * 365));
|
||||
|
||||
if (years) return `${years} Année${years > 1 ? 's' : ''}`;
|
||||
if (months) return `${months} Mois`;
|
||||
if (days) return `${days} Jour${days > 1 ? 's' : ''}`;
|
||||
if (hours) return `${hours} Heure${hours > 1 ? 's' : ''}`;
|
||||
if (minutes) return `${minutes} Minute${minutes > 1 ? 's' : ''}`;
|
||||
if (seconds) return `${seconds} Seconde${seconds > 1 ? 's' : ''}`;
|
||||
return 'Instantané';
|
||||
}
|
||||
|
||||
durationText = formatInitialDuration(initialDurationMs);
|
||||
}
|
||||
|
||||
try {
|
||||
// Bannissement
|
||||
@@ -54,17 +80,17 @@ module.exports = {
|
||||
|
||||
// Stockage dans MySQL (bans)
|
||||
await db.query(
|
||||
`INSERT INTO bans (userId, reason, modId, timestamp, type, unbanDate)
|
||||
VALUES (?, ?, ?, ?, ?, ?)
|
||||
`INSERT INTO bans (userId, reason, modId, timestamp, type, unbanDate, guildId)
|
||||
VALUES (?, ?, ?, ?, ?, ?, ?)
|
||||
ON DUPLICATE KEY UPDATE reason=VALUES(reason), modId=VALUES(modId), timestamp=VALUES(timestamp), type=VALUES(type), unbanDate=VALUES(unbanDate)`,
|
||||
[target.id, reason, interaction.user.id, Date.now(), type, unbanDate]
|
||||
[target.id, reason, interaction.user.id, Date.now(), type, unbanDate, interaction.guild.id]
|
||||
);
|
||||
|
||||
// Stockage dans logs (ajout guildId)
|
||||
|
||||
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, 'ban', reason, type, interaction.guild.id, Date.now()]
|
||||
[target.id, target.tag, interaction.user.id, interaction.user.tag, 'Bannissement', reason, type, interaction.guild.id, Date.now()]
|
||||
);
|
||||
|
||||
await interaction.editReply(`✅ Successfully banned ${target.tag} (${type})`);
|
||||
@@ -79,7 +105,7 @@ module.exports = {
|
||||
{ name: 'Banned User', value: `<@${target.id}> (${target.tag})`, inline: true },
|
||||
{ name: 'Banned By', value: `<@${interaction.user.id}> (${interaction.user.tag})`, inline: true },
|
||||
{ name: 'Reason', value: reason, inline: false },
|
||||
{ name: 'Type', value: type, inline: true },
|
||||
{ name: 'Duration', value: durationText, inline: true },
|
||||
{ name: 'Date', value: new Date().toLocaleString(), inline: true },
|
||||
{ name: 'Guild', value: interaction.guild.name, inline: true }
|
||||
)
|
||||
|
||||
Reference in New Issue
Block a user