mirror of
https://github.com/ahmadk953/poixpixel-discord-bot.git
synced 2025-04-03 10:14:14 +00:00
Fixed deploy command script and made the commands work. The bot is working as expected.
This commit is contained in:
parent
ef298accc3
commit
4a9f5538a3
6 changed files with 77 additions and 62 deletions
|
@ -1,14 +1,16 @@
|
||||||
import { SlashCommandBuilder } from 'discord.js';
|
import { SlashCommandBuilder, CommandInteraction } from 'discord.js';
|
||||||
|
|
||||||
interface Command {
|
interface Command {
|
||||||
data: SlashCommandBuilder;
|
data: Omit<SlashCommandBuilder, "addSubcommand" | "addSubcommandGroup">;
|
||||||
execute: (interaction: any) => Promise<void>;
|
execute: (interaction: CommandInteraction) => Promise<void>;
|
||||||
}
|
}
|
||||||
|
|
||||||
export const command: Command = {
|
const command: Command = {
|
||||||
data: new SlashCommandBuilder().setName('ping').setDescription('Replies with Pong!'),
|
data: new SlashCommandBuilder()
|
||||||
|
.setName('ping')
|
||||||
|
.setDescription('Replies with Pong!'),
|
||||||
execute: async (interaction) => {
|
execute: async (interaction) => {
|
||||||
await interaction.reply('Pong!');
|
await interaction.reply(`Pong!`);
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -1,13 +1,17 @@
|
||||||
import { SlashCommandBuilder } from 'discord.js';
|
import { SlashCommandBuilder, CommandInteraction } from 'discord.js';
|
||||||
|
|
||||||
interface Command {
|
interface Command {
|
||||||
data: SlashCommandBuilder;
|
data: Omit<SlashCommandBuilder, "addSubcommand" | "addSubcommandGroup">;
|
||||||
execute: (interaction: any) => Promise<void>;
|
execute: (interaction: CommandInteraction) => Promise<void>;
|
||||||
}
|
}
|
||||||
|
|
||||||
export const command: Command = {
|
const command: Command = {
|
||||||
data: new SlashCommandBuilder().setName('server').setDescription('Provides information about the server.'),
|
data: new SlashCommandBuilder()
|
||||||
|
.setName('server')
|
||||||
|
.setDescription('Provides information about the server.'),
|
||||||
execute: async (interaction) => {
|
execute: async (interaction) => {
|
||||||
await interaction.reply(`This server is ${interaction.guild.name} and has ${interaction.guild.memberCount} members.`);
|
await interaction.reply(`This server is ${interaction?.guild?.name} and has ${interaction?.guild?.memberCount} members.`);
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
|
export default command;
|
|
@ -1,13 +1,21 @@
|
||||||
import { SlashCommandBuilder } from 'discord.js';
|
import { SlashCommandBuilder, CommandInteraction, GuildMember } from 'discord.js';
|
||||||
|
|
||||||
interface Command {
|
interface Command {
|
||||||
data: SlashCommandBuilder;
|
data: Omit<SlashCommandBuilder, "addSubcommand" | "addSubcommandGroup">;
|
||||||
execute: (interaction: any) => Promise<void>;
|
execute: (interaction: CommandInteraction) => Promise<void>;
|
||||||
}
|
}
|
||||||
|
|
||||||
export const command: Command = {
|
const command: Command = {
|
||||||
data: new SlashCommandBuilder().setName('user').setDescription('Provides information about the user.'),
|
data: new SlashCommandBuilder()
|
||||||
|
.setName('user')
|
||||||
|
.setDescription('Provides information about the user.'),
|
||||||
execute: async (interaction) => {
|
execute: async (interaction) => {
|
||||||
await interaction.reply(`This command was run by ${interaction.user.username}, who joined on ${interaction.member.joinedAt}.`);
|
if (interaction.member instanceof GuildMember) {
|
||||||
|
await interaction.reply(`This command was run by ${interaction.user.username}, who joined on ${interaction.member.joinedAt}.`);
|
||||||
|
} else {
|
||||||
|
await interaction.reply(`This command was run by ${interaction.user.username}.`);
|
||||||
|
}
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
|
export default command;
|
|
@ -1,5 +1,5 @@
|
||||||
{
|
{
|
||||||
"token": "DISCORD_BOT_API_KEY",
|
"token": "DISCORD_BOT_API_KEY",
|
||||||
"application_client_id": "DISCORD_BOT_ID",
|
"clientId": "DISCORD_BOT_ID",
|
||||||
"guild_id": "DISCORD_SERVER_ID"
|
"guildId": "DISCORD_SERVER_ID"
|
||||||
}
|
}
|
|
@ -5,7 +5,7 @@ import { Client, Collection, Events, GatewayIntentBits } from'discord.js';
|
||||||
import config from './config.json' assert { type: 'json' };
|
import config from './config.json' assert { type: 'json' };
|
||||||
import { deployCommands } from './util/deployCommand.js';
|
import { deployCommands } from './util/deployCommand.js';
|
||||||
|
|
||||||
const { token, application_client_id, guild_id } = config;
|
const { token } = config;
|
||||||
|
|
||||||
// Create a new client instance
|
// Create a new client instance
|
||||||
const client: any = new Client({ intents: [GatewayIntentBits.Guilds] });
|
const client: any = new Client({ intents: [GatewayIntentBits.Guilds] });
|
||||||
|
@ -33,7 +33,7 @@ try {
|
||||||
}
|
}
|
||||||
|
|
||||||
try {
|
try {
|
||||||
await deployCommands({token, guild_id, application_client_id});
|
await deployCommands();
|
||||||
} catch (error: any) {
|
} catch (error: any) {
|
||||||
console.log(`Error while registering commands: ${error}`)
|
console.log(`Error while registering commands: ${error}`)
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,44 +1,45 @@
|
||||||
import { REST, Routes } from 'discord.js';
|
import { REST, Routes } from 'discord.js';
|
||||||
import fs from 'node:fs';
|
import config from '../config.json' assert { type: 'json' };
|
||||||
import path from 'node:path';
|
import fs from 'fs';
|
||||||
|
import path from 'path';
|
||||||
|
|
||||||
export async function deployCommands({token, guildId, clientId}: any) {
|
const { token, clientId, guildId } = config;
|
||||||
const commands = [];
|
|
||||||
|
|
||||||
const __dirname = path.resolve();
|
const __dirname = path.resolve();
|
||||||
|
const commandsPath = path.join(__dirname, 'target', 'commands');
|
||||||
const commandsPath = path.join(__dirname, '/target/commands/');
|
const commandFiles = fs.readdirSync(commandsPath).filter(file => file.endsWith('.js'));
|
||||||
const commandFiles = fs.readdirSync(commandsPath).filter(file => file.endsWith('.js'));
|
|
||||||
|
|
||||||
// Grab the SlashCommandBuilder#toJSON() output of each command's data for deployment
|
const rest = new REST({ version: '9' }).setToken(token);
|
||||||
for (const file of commandFiles) {
|
|
||||||
const filePath = path.join('file://', commandsPath, file);
|
export const deployCommands = async () => {
|
||||||
const command = await import(filePath);
|
try {
|
||||||
if (command instanceof Object && 'data' in command && 'execute' in command) {
|
console.log(`Started refreshing ${commandFiles.length} application (/) commands.`);
|
||||||
commands.push(command.data.toJSON());
|
|
||||||
} else {
|
// Prepare the commands array
|
||||||
console.log(`[WARNING] The command at ${filePath} is missing a required "data" or "execute" property.`);
|
const commands = commandFiles.map(async (file) => {
|
||||||
}
|
const filePath = path.join('file://', commandsPath, file);
|
||||||
}
|
const commandModule = await import(filePath);
|
||||||
|
const command = commandModule.default;
|
||||||
// Construct and prepare an instance of the REST module
|
|
||||||
const rest = new REST().setToken(token);
|
if (command instanceof Object && 'data' in command) {
|
||||||
|
return command.data.toJSON();
|
||||||
// and deploy your commands!
|
} else {
|
||||||
(async () => {
|
console.log(`[WARNING] The command at ${filePath} is missing a required "data" property.`);
|
||||||
try {
|
return null;
|
||||||
console.log(`Started refreshing ${commands.length} application (/) commands.`);
|
}
|
||||||
|
});
|
||||||
// The put method is used to fully refresh all commands in the guild with the current set
|
|
||||||
const data: any = await rest.put(
|
// Filter out any null values from the commands array
|
||||||
Routes.applicationGuildCommands(clientId, guildId),
|
const validCommands = await Promise.all(commands.filter(command => command !== null));
|
||||||
{ body: commands },
|
|
||||||
);
|
// Use the provided way of registering commands
|
||||||
|
const data: any = await rest.put(
|
||||||
console.log(`Successfully reloaded ${data.length} application (/) commands.`);
|
Routes.applicationGuildCommands(clientId, guildId),
|
||||||
} catch (error) {
|
{ body: validCommands },
|
||||||
// And of course, make sure you catch and log any errors!
|
);
|
||||||
console.error(error);
|
|
||||||
}
|
console.log(`Successfully reloaded ${data.length} application (/) commands.`);
|
||||||
})();
|
} catch (error) {
|
||||||
}
|
console.error(error);
|
||||||
|
}
|
||||||
|
};
|
Loading…
Add table
Reference in a new issue