Creating a Discord slash command bot

โœ๏ธ

Creating a discord bot that acts on slash commands in NodeJS

8 Jan, 2022 ยท 5 min read

You might have seen slash command bots on random discord servers. These commands start with a slash / and perform a specific action.

This article will create one of these bots that will listen to the /randomice command and return a random mouse. (See what I did there ๐Ÿ˜‚).

The bot will look like this once we finish.

Register the discord bot

The first thing we need to do is register a new discord bot. For this, we need to visit the discord developer portal.

Once you are there, we can register a new application by clicking the button in the top right corner.

Register new bot in discord

Once this step is done, you should automatically enter the new application and see the bot section on the left. Press this and add a new bot.

Adding a new bot

On the following screen, copy the token of this bot into a save place. We'll need this in a second.

Retrieving the bot token

While we are still in the developer portal, let's note down the application ID, as we also need to use this.

Retrieving the application ID

Adding the bot to your server

Now that our bot is set up, we can add this bot to our server. To do this, we can follow the following URL format.

https://discord.com/oauth2/authorize?client_id={APPLICATION_ID}&scope=applications.commands

Make sure to modify the APPLICATION_ID with the retrieved application id. Please open this link and follow the steps to add it to your desired server.

Authorize a new bot to your discord server

That's it. This bot can now access our server and act on the slash commands.

Register slash commands

This step wasn't clear to me initially, but slash commands need to be registered on a specific application!

Discords preferred way is to use guild commands, but we'll use a global one. (Downside: It can take an hour to refresh if you change commands)

You can either perform a CURL request or create a script that does this for us to register commands.

We will be using the discord.js package to leverage the registration part from there.

Let's quickly set up a new project and install all the packages.

# Create folder
mkdir discord-slash-bot && cd discord-slash-bot

# Initialise node
npm init

# Add packages
npm i discord.js @discordjs/rest discord-api-types dotenv

Now let's create a .env file to keep our two secret elements in a save spot.

APP_ID={APPLICATION_ID}
TOKEN={YOUR_BOT_TOKEN}

And then let's make a new file called register.js. This file will handle the command registration with discord.

const { REST } = require('@discordjs/rest');
const { Routes } = require('discord-api-types/v9');
const commands = [
  {
    name: 'randomice',
    description: 'Return a random mouse',
  },
];

const rest = new REST({ version: '9' }).setToken(process.env.TOKEN);

(async () => {
  try {
    console.log('Started refreshing application (/) commands.');

    await rest.put(Routes.applicationCommands(process.env.APP_ID), {
      body: commands,
    });

    console.log('Successfully reloaded application (/) commands.');
  } catch (error) {
    console.error(error);
  }
})();

As you can see, we define our command with a name and description. Then we perform a PUT request to Routes.applicationCommands and pass our APP_ID.

This will register the commands we defined for this app.

Let's add a new script to run this command quickly with our environment variables. Add the following in your package.json file.

"scripts": {
  "register": "node -r dotenv/config register.js",
},

Then you can execute npm run register, which should show an output like this.

Discord bot commands registered

Note: You can verify the registered commands by performing a GET request to this endpoint.

I quickly tested this in Insomnia. You can use a URL like so:

https://discord.com/api/v9/applications/{APP_ID}/commands

You can set an Authorization header like so:

Authorization: Bot {TOKEN}

Retrieving bot commands

The actual slash command handler

Alright, so far, we have our bot setup and added to our discord server, and we registered our command with discord. But the commands don't exist yet.

For this, we'll be creating an index.js file.

Let's start by loading the discord client.

const { Client, Intents } = require('discord.js');
const client = new Client({ intents: [Intents.FLAGS.GUILDS] });

Note: The intents flag is needed here to register a client.

Then we can listen and see when we are connected.

client.on('ready', () => {
  console.log(`Logged in as ${client.user.tag}!`);
});

Then I went ahead and created an array of random mouse things.

const options = [
  '๐Ÿญ',
  'https://media.giphy.com/media/wJZTbXayokOgbCfyQe/giphy.gif',
  'https://media.giphy.com/media/QXh9XnIJetPi0/giphy.gif',
  '๐Ÿ',
];

The next step is to listen to all interactions and fire an event when our action is met.

client.on('interactionCreate', async (interaction) => {
  if (!interaction.isCommand()) return;

  if (interaction.commandName === 'randomice') {
    await interaction.reply(
      options[Math.floor(Math.random() * options.length)]
    );
  }
});

If we hit the randomice command, you can see that we reply with one of our options in random order.

The last step is to call the login command with our bot token.

client.login(process.env.TOKEN);

And then let's also add a script in our package.json for this file.

"scripts": {
  "register": "node -r dotenv/config register.js",
  "start": "node -r dotenv/config index.js"
},

We can now run npm run start and spool up our bot.

And once it's ready, we can start typing our command, and it should appear as an action.

Discord slash command

And that's it! We created our very own slash command discord bot.

You can find the completed project on GitHub.

Thank you for reading, and let's connect!

Thank you for reading my blog. Feel free to subscribe to my email newsletter and connect on Facebook or Twitter

Spread the knowledge with fellow developers on Twitter
Tweet this tip
Powered by Webmentions - Learn more

Read next ๐Ÿ“–

NVM set default version

20 Jul, 2022 ยท 2 min read

NVM set default version

Managing multiple node versions with NVM

13 Jul, 2022 ยท 2 min read

Managing multiple node versions with NVM