![]() |
D++ (DPP)
C++ Discord API Bot Library
|
Slash commands and interactions are a newer feature of Discord which allow a bot's commands to be registered centrally within the system and for users to easily explore and get help with available commands through the client itself.
To add a slash command you should use the dpp::cluster::global_command_create method for global commands (available to all guilds) or dpp::cluster::guild_command_create to create a local command (available only to one guild). If you want to add many commands, it is advised to use the dpp::cluster::global_bulk_command_create method for global commands or the dpp::cluster::guild_bulk_command_create method for local commands.
When a user issues these commands the reply will arrive via the on_slashcommand
event which you can hook into, and take action when you see your commands. It is possible to reply to an interaction by using either the dpp::interaction_create_t::reply method, or by manually instantiating an object of type dpp::interaction_response and attaching a dpp::message object to it.
dpp::interaction_create_t::reply has two overloaded versions of the method, one of which accepts simple std::string
replies, for basic text-only messages (if your message is 'ephemeral' you must use this) and one which accepts a dpp::message for more advanced replies. Please note that at present, Discord only supports a small subset of message and embed features within an interaction response object.
This first example goes over creating a single command globally.
#include <dpp/dpp.h> int main() { dpp::cluster bot("token"); bot.on_log(dpp::utility::cout_logger()); /* The event is fired when someone issues your commands */ bot.on_slashcommand([&bot](const dpp::slashcommand_t & event) { /* Check which command they ran */ if (event.command.get_command_name() == "blep") { /* Fetch a parameter value from the command parameters */ std::string animal = std::get<std::string>(event.get_parameter("animal")); /* Reply to the command. There is an overloaded version of this * call that accepts a dpp::message so you can send embeds. */ event.reply(std::string("Blep! You chose") + animal); } }); bot.on_ready([&bot](const dpp::ready_t & event) { if (dpp::run_once<struct register_bot_commands>()) { /* Create a new global command on ready event */ dpp::slashcommand newcommand("blep", "Send a random adorable animal photo", bot.me.id); newcommand.add_option( dpp::command_option(dpp::co_string, "animal", "The type of animal", true) .add_choice(dpp::command_option_choice("Dog", std::string("animal_dog"))) .add_choice(dpp::command_option_choice("Cat", std::string("animal_cat"))) .add_choice(dpp::command_option_choice("Penguin", std::string("animal_penguin"))) ); /* Register the command */ bot.global_command_create(newcommand); } }); bot.start(dpp::st_wait); return 0; }
This second example goes over creating a single command but only for a guild, this means that the command can not be accessed anywhere else but the guild specified.
#include <dpp/dpp.h> int main() { dpp::cluster bot("token"); bot.on_log(dpp::utility::cout_logger()); /* The event is fired when someone issues your commands */ bot.on_slashcommand([&bot](const dpp::slashcommand_t & event) { /* Check which command they ran */ if (event.command.get_command_name() == "blep") { /* Fetch a parameter value from the command parameters */ std::string animal = std::get<std::string>(event.get_parameter("animal")); /* Reply to the command. There is an overloaded version of this * call that accepts a dpp::message so you can send embeds. */ event.reply(std::string("Blep! You chose") + animal); } }); bot.on_ready([&bot](const dpp::ready_t & event) { if (dpp::run_once<struct register_bot_commands>()) { /* Create a new global command on ready event */ dpp::slashcommand newcommand("blep", "Send a random adorable animal photo", bot.me.id); newcommand.add_option( dpp::command_option(dpp::co_string, "animal", "The type of animal", true) .add_choice(dpp::command_option_choice("Dog", std::string("animal_dog"))) .add_choice(dpp::command_option_choice("Cat", std::string("animal_cat"))) .add_choice(dpp::command_option_choice("Penguin", std::string("animal_penguin"))) ); /* Register the command */ bot.guild_command_create(newcommand, 857692897221033129); /* Replace this with the guild id you want */ } }); bot.start(dpp::st_wait); return 0; }
This third example goes over creating four commands globally, using the bulk create method.
#include <dpp/dpp.h> int main() { dpp::cluster bot("token"); bot.on_log(dpp::utility::cout_logger()); /* The event is fired when someone issues your commands */ bot.on_slashcommand([&bot](const dpp::slashcommand_t & event) { /* Check which command they ran */ if (event.command.get_command_name() == "ping") { event.reply("Pong!"); } else if (event.command.get_command_name() == "pong") { event.reply("Ping!"); } else if (event.command.get_command_name() == "ding") { event.reply("Dong!"); } else if (event.command.get_command_name() == "dong") { event.reply("Ding!"); } }); bot.on_ready([&bot](const dpp::ready_t & event) { if (dpp::run_once<struct register_bot_commands>()) { /* Create some commands */ dpp::slashcommand pingcommand("ping", "Pong!", bot.me.id); dpp::slashcommand pongcommand("pong", "Ping!", bot.me.id); dpp::slashcommand dingcommand("ding", "Dong!", bot.me.id); dpp::slashcommand dongcommand("dong", "Ding!", bot.me.id); /* Register our commands in a list using bulk */ bot.global_bulk_command_create({ pingcommand, pongcommand, dingcommand, dongcommand }); } }); bot.start(dpp::st_wait); return 0; }
This fourth example goes over creating four commands but only for a guild.
#include <dpp/dpp.h> int main() { dpp::cluster bot("token"); bot.on_log(dpp::utility::cout_logger()); /* The event is fired when someone issues your commands */ bot.on_slashcommand([&bot](const dpp::slashcommand_t & event) { /* Check which command they ran */ if (event.command.get_command_name() == "ping") { event.reply("Pong!"); } else if (event.command.get_command_name() == "pong") { event.reply("Ping!"); } else if (event.command.get_command_name() == "ding") { event.reply("Dong!"); } else if (event.command.get_command_name() == "dong") { event.reply("Ding!"); } }); bot.on_ready([&bot](const dpp::ready_t & event) { if (dpp::run_once<struct register_bot_commands>()) { /* Create some commands */ dpp::slashcommand pingcommand("ping", "Pong!", bot.me.id); dpp::slashcommand pongcommand("pong", "Ping!", bot.me.id); dpp::slashcommand dingcommand("ding", "Dong!", bot.me.id); dpp::slashcommand dongcommand("dong", "Ding!", bot.me.id); /* Register our commands in a list using bulk */ bot.guild_bulk_command_create({ pingcommand, pongcommand, dingcommand, dongcommand }, 857692897221033129); } }); bot.start(dpp::st_wait); return 0; }
on_ready
event even when it's inside dpp::run_once as, if you re-run your bot multiple times or start multiple clusters, you will quickly get rate-limited! You could, for example, add a commandline parameter to your bot (argc
, argv
) so that if you want the bot to register commands it must be launched with a specific command line argument.