AeThex-Bot-Master/aethex-bot/commands/modlog.js
sirpiglr ca07d17417 Add new commands and improve bot functionality
Introduce several new slash commands including ban, kick, timeout, and userinfo. Enhance existing commands like config and rank with new features and configurations. Add new listeners for welcome and goodbye messages. Implement XP tracking for user leveling and integrate it with role rewards. Update documentation to reflect these changes.

Replit-Commit-Author: Agent
Replit-Commit-Session-Id: aed2e46d-25bb-4b73-81a1-bb9e8437c261
Replit-Commit-Checkpoint-Type: intermediate_checkpoint
Replit-Commit-Event-Id: 1be8d824-5029-4875-bed8-0bd1d810892d
Replit-Commit-Screenshot-Url: https://storage.googleapis.com/screenshot-production-us-central1/3bdfff67-975a-46ad-9845-fbb6b4a4c4b5/aed2e46d-25bb-4b73-81a1-bb9e8437c261/SQxsvtx
Replit-Helium-Checkpoint-Created: true
2025-12-08 04:09:56 +00:00

73 lines
2.6 KiB
JavaScript

const { SlashCommandBuilder, EmbedBuilder, PermissionFlagsBits } = require('discord.js');
module.exports = {
data: new SlashCommandBuilder()
.setName('modlog')
.setDescription('View moderation history for a user')
.setDefaultMemberPermissions(PermissionFlagsBits.ModerateMembers)
.addUserOption(option =>
option.setName('user')
.setDescription('User to check')
.setRequired(true)
),
async execute(interaction, supabase, client) {
if (!supabase) {
return interaction.reply({ content: 'Database not configured.', ephemeral: true });
}
const target = interaction.options.getUser('user');
await interaction.deferReply({ ephemeral: true });
try {
const { data: warnings } = await supabase
.from('warnings')
.select('*')
.eq('guild_id', interaction.guildId)
.eq('user_id', target.id)
.order('created_at', { ascending: false })
.limit(10);
const { data: actions } = await supabase
.from('mod_actions')
.select('*')
.eq('guild_id', interaction.guildId)
.eq('user_id', target.id)
.order('created_at', { ascending: false })
.limit(10);
const embed = new EmbedBuilder()
.setColor(0x7c3aed)
.setTitle(`Moderation Log: ${target.tag}`)
.setThumbnail(target.displayAvatarURL())
.setTimestamp();
if ((!warnings || warnings.length === 0) && (!actions || actions.length === 0)) {
embed.setDescription('No moderation history found for this user.');
} else {
if (warnings && warnings.length > 0) {
const warnText = warnings.map((w, i) => {
const date = new Date(w.created_at).toLocaleDateString();
return `**${i + 1}.** ${w.reason}\n By: ${w.moderator_tag} | ${date}`;
}).join('\n\n');
embed.addFields({ name: `Warnings (${warnings.length})`, value: warnText.slice(0, 1024) });
}
if (actions && actions.length > 0) {
const actionText = actions.map((a, i) => {
const date = new Date(a.created_at).toLocaleDateString();
const duration = a.duration_minutes ? ` (${a.duration_minutes}m)` : '';
return `**${a.action.toUpperCase()}${duration}** - ${a.reason}\n By: ${a.moderator_tag} | ${date}`;
}).join('\n\n');
embed.addFields({ name: `Actions (${actions.length})`, value: actionText.slice(0, 1024) });
}
}
await interaction.editReply({ embeds: [embed] });
} catch (error) {
console.error('Modlog error:', error);
await interaction.editReply({ content: 'Failed to fetch moderation log.' });
}
},
};