feat: add admin commands for managing guild and global command, testing..

This commit is contained in:
2025-09-23 23:06:15 -05:00
parent 40b7597a3e
commit acb41f8a46
6 changed files with 232 additions and 25 deletions

View File

@@ -0,0 +1,56 @@
// Comando de administración para sincronizar / limpiar comandos (solo dueño)
// @ts-ignore
import { CommandMessage } from "../../../core/types/commands";
const OWNER_ID = '327207082203938818';
export const command: CommandMessage = {
name: 'admin-comandos',
type: 'message',
aliases: ['cmdadmin', 'synccommands', 'comandos-admin'],
cooldown: 5,
run: async (message, _args, _client) => {
if (message.author.id !== OWNER_ID) {
await message.reply({ content: '❌ No tienes permisos para usar este panel.' });
return;
}
const panel = {
type: 17,
accent_color: 0x2b2d31,
components: [
{
type: 10,
content: '### 🛠️ Panel de Administración de Comandos\nGestiona el registro y limpieza de comandos **Slash**.'
},
{ type: 14, divider: true, spacing: 1 },
{
type: 10,
content: 'Acciones disponibles:\n• Registrar comandos de GUILD (testing)\n• Registrar comandos GLOBAL (propagación lenta)\n• Limpiar comandos de GUILD\n• Limpiar comandos GLOBAL\n\nUsa los botones de abajo. Se evita ejecución simultánea.'
}
]
};
const rows = [
{
type: 1,
components: [
{ type: 2, style: 1, label: 'Registrar GUILD', custom_id: 'cmd_reg_guild' },
{ type: 2, style: 1, label: 'Registrar GLOBAL', custom_id: 'cmd_reg_global' }
]
},
{
type: 1,
components: [
{ type: 2, style: 4, label: 'Limpiar GUILD', custom_id: 'cmd_clear_guild' },
{ type: 2, style: 4, label: 'Limpiar GLOBAL', custom_id: 'cmd_clear_global' }
]
}
];
await message.reply({
flags: 32768,
components: [panel, ...rows]
});
}
};

View File

@@ -0,0 +1,33 @@
import type { ButtonInteraction } from 'discord.js';
import { clearGlobalCommands } from '../../core/api/discordAPI';
const OWNER_ID = '327207082203938818';
let running = false;
export default {
customId: 'cmd_clear_global',
run: async (interaction: ButtonInteraction) => {
if (interaction.user.id !== OWNER_ID) {
return interaction.reply({ content: '❌ No autorizado.', ephemeral: true });
}
if (running) {
return interaction.reply({ content: '⏳ Limpieza GLOBAL en progreso, espera.', ephemeral: true });
}
running = true;
try {
await interaction.deferReply({ ephemeral: true });
await clearGlobalCommands();
await interaction.editReply('🧹 Comandos GLOBAL eliminados.');
} catch (e: any) {
console.error('Error limpiando comandos globales:', e);
if (interaction.deferred || interaction.replied) {
await interaction.editReply('❌ Error limpiando comandos globales.');
} else {
await interaction.reply({ content: '❌ Error limpiando comandos globales.', ephemeral: true });
}
} finally {
running = false;
}
}
};

View File

@@ -0,0 +1,33 @@
import type { ButtonInteraction } from 'discord.js';
import { clearAllCommands } from '../../core/api/discordAPI';
const OWNER_ID = '327207082203938818';
let running = false;
export default {
customId: 'cmd_clear_guild',
run: async (interaction: ButtonInteraction) => {
if (interaction.user.id !== OWNER_ID) {
return interaction.reply({ content: '❌ No autorizado.', ephemeral: true });
}
if (running) {
return interaction.reply({ content: '⏳ Limpieza GUILD en progreso, espera.', ephemeral: true });
}
running = true;
try {
await interaction.deferReply({ ephemeral: true });
await clearAllCommands();
await interaction.editReply('🧹 Comandos de GUILD eliminados.');
} catch (e: any) {
console.error('Error limpiando comandos guild:', e);
if (interaction.deferred || interaction.replied) {
await interaction.editReply('❌ Error limpiando comandos de guild.');
} else {
await interaction.reply({ content: '❌ Error limpiando comandos de guild.', ephemeral: true });
}
} finally {
running = false;
}
}
};

View File

@@ -0,0 +1,33 @@
import type { ButtonInteraction } from 'discord.js';
import { registeringGlobalCommands } from '../../core/api/discordAPI';
const OWNER_ID = '327207082203938818';
let running = false;
export default {
customId: 'cmd_reg_global',
run: async (interaction: ButtonInteraction) => {
if (interaction.user.id !== OWNER_ID) {
return interaction.reply({ content: '❌ No autorizado.', ephemeral: true });
}
if (running) {
return interaction.reply({ content: '⏳ Ya hay un registro GLOBAL en curso, espera.', ephemeral: true });
}
running = true;
try {
await interaction.deferReply({ ephemeral: true });
await registeringGlobalCommands();
await interaction.editReply('✅ Comandos GLOBAL registrados (propagación puede tardar).');
} catch (e: any) {
console.error('Error registrando comandos globales:', e);
if (interaction.deferred || interaction.replied) {
await interaction.editReply('❌ Error registrando comandos globales.');
} else {
await interaction.reply({ content: '❌ Error registrando comandos globales.', ephemeral: true });
}
} finally {
running = false;
}
}
};

View File

@@ -0,0 +1,33 @@
import type { ButtonInteraction } from 'discord.js';
import { registeringCommands } from '../../core/api/discordAPI';
const OWNER_ID = '327207082203938818';
let running = false;
export default {
customId: 'cmd_reg_guild',
run: async (interaction: ButtonInteraction) => {
if (interaction.user.id !== OWNER_ID) {
return interaction.reply({ content: '❌ No autorizado.', ephemeral: true });
}
if (running) {
return interaction.reply({ content: '⏳ Ya hay un registro de comandos guild en curso, espera.', ephemeral: true });
}
running = true;
try {
await interaction.deferReply({ ephemeral: true });
await registeringCommands();
await interaction.editReply('✅ Comandos de GUILD registrados correctamente.');
} catch (e: any) {
console.error('Error registrando comandos guild:', e);
if (interaction.deferred || interaction.replied) {
await interaction.editReply('❌ Error registrando comandos de guild. Revisa logs.');
} else {
await interaction.reply({ content: '❌ Error registrando comandos de guild.', ephemeral: true });
}
} finally {
running = false;
}
}
};

View File

@@ -10,7 +10,7 @@ export async function registeringCommands(): Promise<void> {
const commandsToRegister: any[] = []; const commandsToRegister: any[] = [];
// Recorremos la Collection que ya cargó loadCommands() // Recorremos la Collection que ya cargó loadCommands()
for (const [name, cmd] of commands) { for (const [_name, cmd] of commands) {
if (cmd.type === "slash") { if (cmd.type === "slash") {
commandsToRegister.push({ commandsToRegister.push({
name: cmd.name, name: cmd.name,
@@ -19,12 +19,12 @@ export async function registeringCommands(): Promise<void> {
options: cmd.options ?? [] options: cmd.options ?? []
}); });
console.log(`✅ Preparado para registrar: ${cmd.name}`); console.log(`✅ Preparado para registrar (guild): ${cmd.name}`);
} }
} }
try { try {
console.log(`🧹 Limpiando comandos antiguos/residuales...`); console.log(`🧹 Limpiando comandos antiguos/residuales (guild)...`);
// Primero eliminamos TODOS los comandos existentes // Primero eliminamos TODOS los comandos existentes
await rest.put( await rest.put(
@@ -35,12 +35,11 @@ export async function registeringCommands(): Promise<void> {
{ body: [] } // Array vacío elimina todos los comandos { body: [] } // Array vacío elimina todos los comandos
); );
console.log(`✅ Comandos antiguos eliminados correctamente.`); console.log(`✅ Comandos antiguos de guild eliminados.`);
// Pequeña pausa para asegurar que Discord procese la eliminación // Pequeña pausa para asegurar que Discord procese la eliminación
await new Promise(resolve => setTimeout(resolve, 1000)); await new Promise(r => setTimeout(r, 1000));
console.log(`🚀 Registrando ${commandsToRegister.length} comandos slash nuevos...`); console.log(`🚀 Registrando ${commandsToRegister.length} comandos slash nuevos (guild)...`);
// Ahora registramos los comandos actuales // Ahora registramos los comandos actuales
const data: any = await rest.put( const data: any = await rest.put(
@@ -51,20 +50,47 @@ export async function registeringCommands(): Promise<void> {
{ body: commandsToRegister } { body: commandsToRegister }
); );
console.log(`${data.length} comandos registrados correctamente.`); console.log(`${data.length} comandos de guild registrados.`);
console.log(`🎉 Proceso completado: comandos antiguos limpiados y nuevos registrados.`);
} catch (error) { } catch (error) {
console.error("❌ Error en el proceso de comandos:", error); console.error("❌ Error en el proceso de comandos de guild:", error);
}
}
export async function registeringGlobalCommands(): Promise<void> {
const commandsToRegister: any[] = [];
for (const [_name, cmd] of commands) {
if (cmd.type === "slash") {
commandsToRegister.push({
name: cmd.name,
description: cmd.description ?? "Sin descripción",
type: 1,
options: cmd.options ?? []
});
console.log(`🌍 Preparado para registrar global: ${cmd.name}`);
}
}
try {
console.log(`🧹 Limpiando comandos globales existentes...`);
await rest.put(
Routes.applicationCommands(process.env.CLIENT!),
{ body: [] }
);
console.log(`✅ Comandos globales previos eliminados.`);
await new Promise(r => setTimeout(r, 1500));
console.log(`🚀 Registrando ${commandsToRegister.length} comandos globales... (propagación puede tardar hasta 1h)`);
const data: any = await rest.put(
Routes.applicationCommands(process.env.CLIENT!),
{ body: commandsToRegister }
);
console.log(`${data.length} comandos globales enviados a la API.`);
} catch (error) {
console.error("❌ Error registrando comandos globales:", error);
} }
} }
/**
* Función específica para eliminar TODOS los comandos slash (útil para limpieza)
*/
export async function clearAllCommands(): Promise<void> { export async function clearAllCommands(): Promise<void> {
try { try {
console.log(`🧹 Eliminando TODOS los comandos slash...`); console.log(`🧹 Eliminando TODOS los comandos slash (guild)...`);
await rest.put( await rest.put(
Routes.applicationGuildCommands( Routes.applicationGuildCommands(
process.env.CLIENT!, process.env.CLIENT!,
@@ -72,28 +98,21 @@ export async function clearAllCommands(): Promise<void> {
), ),
{ body: [] } { body: [] }
); );
console.log(`✅ Todos los comandos de guild eliminados.`);
console.log(`✅ Todos los comandos han sido eliminados correctamente.`);
} catch (error) { } catch (error) {
console.error("❌ Error eliminando comandos:", error); console.error("❌ Error eliminando comandos de guild:", error);
} }
} }
/**
* Función para limpiar comandos globales (si los hay)
*/
export async function clearGlobalCommands(): Promise<void> { export async function clearGlobalCommands(): Promise<void> {
try { try {
console.log(`🌍 Eliminando comandos globales...`); console.log(`🌍 Eliminando comandos globales...`);
await rest.put( await rest.put(
Routes.applicationCommands(process.env.CLIENT!), Routes.applicationCommands(process.env.CLIENT!),
{ body: [] } { body: [] }
); );
console.log(`✅ Comandos globales eliminados.`);
console.log(`✅ Comandos globales eliminados correctamente.`);
} catch (error) { } catch (error) {
console.error("❌ Error eliminando comandos globales:", error); console.error("❌ Error eliminando comandos globales:", error);
} }
} }