discord-bot/libs/DPP-10.0.29/include/dpp/appcommand.h

1592 lines
44 KiB
C++
Raw Normal View History

2024-02-22 16:09:56 -05:00
/************************************************************************************
*
* D++, A Lightweight C++ library for Discord
*
* Copyright 2021 Craig Edwards and D++ contributors
* (https://github.com/brainboxdotcc/DPP/graphs/contributors)
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*
************************************************************************************/
#pragma once
#include <dpp/export.h>
#include <dpp/snowflake.h>
#include <dpp/managed.h>
#include <dpp/message.h>
#include <dpp/channel.h>
#include <dpp/role.h>
#include <dpp/user.h>
#include <dpp/entitlement.h>
#include <variant>
#include <map>
#include <dpp/json_fwd.h>
#include <dpp/json_interface.h>
namespace dpp {
/**
* @brief Discord limits the maximum number of replies to an autocomplete interaction to 25.
* This value represents that maximum. interaction_response::add_autocomplete_choice does not allow
* adding more than this number of elements to the vector.
*/
#ifndef AUTOCOMPLETE_MAX_CHOICES
#define AUTOCOMPLETE_MAX_CHOICES 25
#endif
/**
* @brief Represents command option types.
* These are the possible parameter value types.
*/
enum command_option_type : uint8_t {
/**
* @brief A sub-command.
*/
co_sub_command = 1,
/**
* @brief A sub-command group.
*/
co_sub_command_group = 2,
/**
* @brief A string value.
*/
co_string = 3,
/**
* @brief An integer value.
*/
co_integer = 4,
/**
* @brief A boolean value.
*/
co_boolean = 5,
/**
* @brief A user snowflake id.
*/
co_user = 6,
/**
* @brief A channel snowflake id. Includes all channel types and categories.
*/
co_channel = 7,
/**
* @brief A role id (snowflake).
*/
co_role = 8,
/**
* @brief A mentionable (users and roles).
*/
co_mentionable = 9,
/**
* @brief Any double between -2^53 and 2^53.
*/
co_number = 10,
/**
* @brief File attachment type.
*/
co_attachment = 11,
};
/**
* @brief This type is a variant that can hold any of the potential
* native data types represented by the enum dpp::command_option_type.
* It is used in interactions.
*
* std::monostate indicates an invalid parameter value, e.g. an unfilled optional parameter.
* std::int64_t will be for all integer options, double for decimal numbers and dpp::snowflake for anything ID related.
*
* You can retrieve them with std::get().
*/
typedef std::variant<std::monostate, std::string, int64_t, bool, snowflake, double> command_value;
/**
* @brief This struct represents choices in a multiple choice option
* for a command parameter.
* It has both a string name, and a value parameter which is a variant,
* meaning it can hold different potential types (see dpp::command_value)
* that you can retrieve with std::get().
*/
struct DPP_EXPORT command_option_choice : public json_interface<command_option_choice> {
protected:
friend struct json_interface<command_option_choice>;
/**
* @brief Fill object properties from JSON
*
* @param j JSON to fill from
* @return command_option_choice& Reference to self
*/
command_option_choice& fill_from_json_impl(nlohmann::json* j);
public:
/**
* @brief Option name (1-32 chars).
*/
std::string name;
/**
* @brief Option value.
*/
command_value value;
/**
* @brief Localisations of command option name.
*/
std::map<std::string, std::string> name_localizations;
/**
* @brief Construct a new command option choice object
*/
command_option_choice() = default;
virtual ~command_option_choice() = default;
/**
* @brief Add a localisation for this command option choice
* @see https://discord.com/developers/docs/reference#locales
* @param language Name of language, see the list of locales linked to above
* @param _name name of command option choice in the specified language
* @return command_option_choice& reference to self for fluent chaining
*/
command_option_choice& add_localization(const std::string& language, const std::string& _name);
/**
* @brief Construct a new command option choice object
*
* @param n name to initialise with
* @param v value to initialise with
*/
command_option_choice(const std::string &n, command_value v);
};
/**
* @brief helper function to serialize a command_option_choice to json
*
* @see https://github.com/nlohmann/json#arbitrary-types-conversions
*
* @param j output json object
* @param choice command_option_choice to be serialized
*/
void to_json(nlohmann::json& j, const command_option_choice& choice);
/**
* @brief A minimum or maximum value/length for dpp::co_number, dpp::co_integer and dpp::co_string types of a dpp::command_option.
* The `int64_t` is for the integer range or string length that can be entered. The `double` is for the decimal range that can be entered
*/
typedef std::variant<std::monostate, int64_t, double> command_option_range;
/**
* @brief Each command option is a command line parameter.
* It can have a type (see dpp::command_option_type), a name,
* a description, can be required or optional, and can have
* zero or more choices (for multiple choice), plus options.
* Adding options acts like sub-commands and can contain more
* options.
*/
struct DPP_EXPORT command_option : public json_interface<command_option> {
protected:
friend struct json_interface<command_option>;
/**
* @brief Fill object properties from JSON. Fills options recursively.
*
* @param j JSON to fill from
* @return command_option& Reference to self
*/
command_option& fill_from_json_impl(nlohmann::json* j);
public:
/**
* @brief Option type (what type of value is accepted).
*/
command_option_type type;
/**
* @brief Option name (1-32 chars).
*/
std::string name;
/**
* @brief Option description (1-100 chars).
*/
std::string description;
/**
* @brief Is this a mandatory parameter?
*/
bool required;
/**
* @brief Is the user is typing in this field?
*
* @note This is sent via autocomplete.
*/
bool focused;
/**
* @brief Set only by autocomplete when sent as part of an interaction.
*/
command_value value;
/**
* @brief List of choices for multiple choice command.
*/
std::vector<command_option_choice> choices;
/**
* @brief Does this option supports auto completion?
*/
bool autocomplete;
/**
* @brief An array of sub-commands (options).
*/
std::vector<command_option> options;
/**
* @brief Allowed channel types for channel snowflake id options.
*/
std::vector<channel_type> channel_types;
// Combines the `min_length` and `max_length` field by storing its value in the int64_t of the command_option_range
/**
* @brief Minimum value/length that can be entered, for dpp::co_number, dpp::co_integer and dpp::co_string types only.
*/
command_option_range min_value;
/**
* @brief Maximum value/length that can be entered, for dpp::co_number, dpp::co_integer and dpp::co_string types only.
*/
command_option_range max_value;
/**
* @brief Localisations of command name.
*/
std::map<std::string, std::string> name_localizations;
/**
* @brief Localisations of command description.
*/
std::map<std::string, std::string> description_localizations;
/**
* @brief Construct a new command option object
*/
command_option() = default;
/**
* @brief Destroy the command option object
*/
virtual ~command_option() = default;
/**
* @brief Add a localisation for this slash command option
* @see https://discord.com/developers/docs/reference#locales
* @param language Name of language, see the list of locales linked to above
* @param _name name of slash command option in the specified language
* @param _description description of slash command option in the specified language (optional)
* @return command_option& reference to self for fluent chaining
*/
command_option& add_localization(const std::string& language, const std::string& _name, const std::string& _description = "");
/**
* @brief Construct a new command option object
*
* @param t Option type
* @param name Option name
* @param description Option description
* @param required True if this is a mandatory parameter
*/
command_option(command_option_type t, const std::string &name, const std::string &description, bool required = false);
/**
* @brief Add a multiple choice option
*
* @param o choice to add
* @return command_option& returns a reference to self for chaining of calls
* @throw dpp::logic_exception command_option is an autocomplete, so choices cannot be added
*/
command_option& add_choice(const command_option_choice &o);
/**
* @brief Set the minimum numeric value of the option.
* Only valid if the type is dpp::co_number or dpp::co_integer.
* @param min_v Minimum value
* @return command_option& returns a reference to self for chaining of calls
*/
command_option& set_min_value(command_option_range min_v);
/**
* @brief Set the maximum numeric value of the option.
* Only valid if the type is dpp::co_number or dpp::co_integer.
* @param max_v Maximum value
* @return command_option& returns a reference to self for chaining of calls
*/
command_option& set_max_value(command_option_range max_v);
/**
* @brief Set the minimum string length of the option. Must be between 0 and 6000 (inclusive).
* Only valid if the type is dpp::co_string
* @param min_v Minimum value
* @return command_option& returns a reference to self for chaining of calls
*/
command_option& set_min_length(command_option_range min_v);
/**
* @brief Set the maximum string length of the option. Must be between 1 and 6000 (inclusive).
* Only valid if the type is dpp::co_string
* @param max_v Maximum value
* @return command_option& returns a reference to self for chaining of calls
*/
command_option& set_max_length(command_option_range max_v);
/**
* @brief Add a sub-command option
*
* @param o Sub-command option to add
* @return command_option& return a reference to self for chaining of calls
*/
command_option& add_option(const command_option &o);
/**
* @brief Add channel type for option (only for co_channel type options)
*
* @param ch type to set
* @return command_option& return a reference to self for chaining of calls
*/
command_option& add_channel_type(const channel_type ch);
/**
* @brief Set the auto complete state
*
* @param autocomp True to enable auto completion for this option
* @return command_option& return a reference to self for chaining of calls
* @throw dpp::logic_exception You attempted to enable auto complete on a command_option that has choices added to it
*/
command_option& set_auto_complete(bool autocomp);
};
/**
* @brief helper function to serialize a command_option to json
*
* @see https://github.com/nlohmann/json#arbitrary-types-conversions
*
* @param j output json object
* @param opt command_option to be serialized
*/
void to_json(nlohmann::json& j, const command_option& opt);
/**
* @brief Response types when responding to an interaction within on_interaction_create.
*/
enum interaction_response_type {
/**
* @brief Acknowledge a Ping
*/
ir_pong = 1,
/**
* @brief Respond to an interaction with a message.
*/
ir_channel_message_with_source = 4,
/**
* @brief Acknowledge an interaction and edit a response later, the user sees a loading state
*/
ir_deferred_channel_message_with_source = 5,
/**
* @brief For components, acknowledge an interaction and edit the original message later; the user does not see a loading state.
*/
ir_deferred_update_message = 6,
/**
* @brief For components, edit the message the component was attached to.
*/
ir_update_message = 7,
/**
* @brief Reply to autocomplete interaction.
*
* @note Be sure to do this within 500ms of the interaction!
*/
ir_autocomplete_reply = 8,
/**
* @brief A modal dialog box
*
* @note Not available for modal submit and ping interactions.
*/
ir_modal_dialog = 9,
/**
* @brief Acknowledge a interaction with an upgrade button, only available for apps with monetization enabled.
*
* @see https://discord.com/developers/docs/monetization/entitlements#premiumrequired-interaction-response
* @note Not available for autocomplete and ping interactions.
* @warning This response does not support using `content`, `embeds`, or `attachments`, so reply with no data when using this!
*/
ir_premium_required = 10,
};
/**
* @brief A response to an interaction, used to reply to a command and initiate
* a message, which can be hidden from others (ephemeral) or visible to all.
*
* The dpp::interaction_response object wraps a dpp::message object. To set the
* message as 'ephemeral' (e.g. only the command issuer can see it) you should
* add the dpp::m_ephemeral flag to the dpp::message::flags field. e.g.:
*
* `mymessage.flags |= dpp::m_ephemeral;`
*/
struct DPP_EXPORT interaction_response : public json_interface<interaction_response> {
protected:
friend struct json_interface<interaction_response>;
/**
* @brief Fill object properties from JSON
*
* @param j JSON to fill from
* @return interaction_response& Reference to self
*/
virtual interaction_response& fill_from_json_impl(nlohmann::json* j);
/**
* @brief Build json for this object
*
* @return json JSON object
*/
virtual json to_json_impl(bool with_id = false) const;
public:
/**
* @brief Response type from dpp::interaction_response_type.
* Should be one of ir_pong, ir_channel_message_with_source,
* or ir_deferred_channel_message_with_source.
*/
interaction_response_type type{};
/**
* @brief Message tied to this response.
*/
message msg{};
/**
* @brief Array of up to 25 autocomplete choices
*/
std::vector<command_option_choice> autocomplete_choices{};
/**
* @brief Construct a new interaction response object
*/
interaction_response() = default;
/**
* @brief Construct a new interaction response object
*
* @param t Type of reply
*/
interaction_response(interaction_response_type t);
/**
* @brief Construct a new interaction response object
*
* @param t Type of reply
* @param m Message to reply with
*/
interaction_response(interaction_response_type t, const message& m);
/**
* @brief Construct a new interaction response object
*
* @param t Type of reply
* @param m Message to reply with
*/
interaction_response(interaction_response_type t, message&& m);
/**
* @brief Add a command option choice
*
* @param achoice command option choice to add
* @return interaction_response& Reference to self
*/
interaction_response& add_autocomplete_choice(const command_option_choice& achoice);
/**
* @brief Destroy the interaction response object
*/
virtual ~interaction_response() = default;
};
/**
* @brief Represents a modal dialog box response to an interaction.
*
* A dialog box is a modal popup which appears to the user instead of a message. One or more
* components are displayed on a form (the same component structure as within a dpp::message).
* When the user submits the form an on_form_submit event is dispatched to any listeners.
*/
struct DPP_EXPORT interaction_modal_response : public interaction_response, public json_interface<interaction_modal_response> {
protected:
friend struct json_interface<interaction_modal_response>;
size_t current_row;
/**
* @brief Fill object properties from JSON
*
* @param j JSON to fill from
* @return interaction_response& Reference to self
*/
virtual interaction_modal_response& fill_from_json_impl(nlohmann::json* j);
/**
* @brief Build a json for this object
* @param with_id include id in json output
*
* @return json JSON object
*/
virtual json to_json_impl(bool with_id = false) const;
public:
using json_interface<interaction_modal_response>::fill_from_json;
using json_interface<interaction_modal_response>::to_json;
using json_interface<interaction_modal_response>::build_json;
/**
* @brief Custom ID for the modal form
*/
std::string custom_id;
/**
* @brief Title of the modal form box (max 25 characters)
*/
std::string title;
/**
* @brief List of components. All components must be placed within
* an action row, each outer vector is the action row.
*/
std::vector<std::vector<component>> components;
/**
* @brief Construct a new interaction modal response object
*/
interaction_modal_response();
/**
* @brief Construct a new interaction modal response object
*
* @param _custom_id Custom ID of the modal form
* @param _title Title of the modal form. It will be truncated to the maximum length of 45 UTF-8 characters.
* @param _components Components to add to the modal form
*/
interaction_modal_response(const std::string& _custom_id, const std::string& _title, const std::vector<component> _components = {});
/**
* @brief Set the custom id
*
* @param _custom_id custom id to set
* @return interaction_modal_response& Reference to self
*/
interaction_modal_response& set_custom_id(const std::string& _custom_id);
/**
* @brief Set the title
*
* @param _title title to set
* @return interaction_modal_response& Reference to self
*/
interaction_modal_response& set_title(const std::string& _title);
/**
* @brief Add a component to an interaction modal response
*
* @param c component to add
* @return interaction_modal_response& Reference to self
*/
interaction_modal_response& add_component(const component& c);
/**
* @brief Add a new row to the interaction modal response.
* @note A modal response can have a maximum of five rows.
* @throw dpp::logic_exception if more than five rows are attempted to be added
* @return interaction_modal_response& Reference to self
*/
interaction_modal_response& add_row();
/**
* @brief Destroy the interaction modal response object
*/
virtual ~interaction_modal_response() = default;
};
/**
* @brief Resolved snowflake ids to users, guild members, roles and channels. You can use the `interaction::get_resolved_*` methods to easily get a resolved set
*/
struct DPP_EXPORT command_resolved {
/**
* @brief Resolved users
* @see interaction::get_resolved_user
*/
std::map<dpp::snowflake, dpp::user> users;
/**
* @brief Resolved guild members
* @see interaction::get_resolved_member
*/
std::map<dpp::snowflake, dpp::guild_member> members;
/**
* @brief Resolved total guild member permissions including channel overwrites, permissions from roles and administrator privileges
* @see interaction::get_resolved_permission
*/
std::map<dpp::snowflake, permission> member_permissions;
/**
* @brief Resolved roles
* @see interaction::get_resolved_role
*/
std::map<dpp::snowflake, dpp::role> roles;
/**
* @brief Resolved channels
* @see interaction::get_resolved_channel
*/
std::map<dpp::snowflake, dpp::channel> channels;
/**
* @brief Resolved messages
* @see interaction::get_resolved_message
*/
std::map<dpp::snowflake, dpp::message> messages;
/**
* @brief Resolved attachments
* @see interaction::get_resolved_attachment
*/
std::map<dpp::snowflake, dpp::attachment> attachments;
};
/**
* @brief Values in the command interaction.
* These are the values specified by the user when actually issuing
* the command on a channel or in DM.
*/
struct DPP_EXPORT command_data_option {
/**
* @brief The name of the parameter.
*/
std::string name;
/**
* @brief The type of option (value of ApplicationCommandOptionType).
*/
command_option_type type;
/**
* @brief Optional: the value of the pair
*/
command_value value;
/**
* @brief Optional: present if this option is a group or subcommand
*/
std::vector<command_data_option> options;
/**
* @brief Optional: true if this option is the currently focused option for autocomplete
*/
bool focused;
/**
* @brief Check if the value variant holds std::monostate and options vector is empty (i.e. the option wasn't supplied)
* @return bool true, if value variant holds std::monostate and options vector is empty
*/
bool empty() {
return std::holds_alternative<std::monostate>(value) && options.empty();
}
/**
* @brief Get an option value by index
*
* @tparam T Type to get from the parameter
* @param index index of the option
* @return T returned type
*/
template <typename T> T& get_value(size_t index) {
return std::get<T>(options.at(index).value);
}
};
/**
* @brief helper function to deserialize a command_data_option from json
*
* @see https://github.com/nlohmann/json#arbitrary-types-conversions
*
* @param j output json object
* @param cdo command_data_option to be deserialized
*/
void from_json(const nlohmann::json& j, command_data_option& cdo);
/** Types of interaction in the dpp::interaction class
*/
enum interaction_type {
/**
* @brief A ping interaction.
*/
it_ping = 1,
/**
* @brief Application command (slash command) interaction.
*/
it_application_command = 2,
/**
* @brief Button click or select menu chosen (component interaction)
*/
it_component_button = 3,
/**
* @brief Autocomplete interaction.
*/
it_autocomplete = 4,
/**
* @brief Modal form submission.
*/
it_modal_submit = 5,
};
/**
* @brief Right-click context menu types
*/
enum slashcommand_contextmenu_type {
/**
* @brief Undefined context menu type
*/
ctxm_none = 0,
/**
* @brief DEFAULT: these are the generic slash commands (e.g. /ping, /pong, etc)
*/
ctxm_chat_input = 1,
/**
* @brief A slashcommand that goes in the user context menu.
*/
ctxm_user = 2,
/**
* @brief A slashcommand that goes in the message context menu.
*/
ctxm_message = 3
};
/**
* @brief Details of a command within an interaction.
* This subobject represents the application command associated
* with the interaction.
*/
struct DPP_EXPORT command_interaction {
/**
* @brief The ID of the invoked command.
*/
snowflake id;
/**
* @brief The name of the invoked command.
*/
std::string name;
/**
* @brief Optional: the params + values from the user.
*/
std::vector<command_data_option> options;
/**
* @brief The type of command interaction.
*/
slashcommand_contextmenu_type type;
/**
* @brief Non-zero target ID for context menu actions (e.g. user id or message id whom clicked or tapped with the context menu).
*
* @see https://discord.com/developers/docs/interactions/application-commands#user-commands
*/
dpp::snowflake target_id;
/**
* @brief Get an option value by index
*
* @tparam T Type to get from the parameter
* @param index index of the option
* @return T returned type
*/
template <typename T> T& get_value(size_t index) {
return std::get<T>(options.at(index).value);
}
/**
* @brief Return a ping/mention for the slash command
*
* @return std::string mention. e.g. `</airhorn:816437322781949972>`
* @note If you want a mention for a subcommand or subcommand group, you can use dpp::utility::slashcommand_mention
*/
std::string get_mention() const;
};
/**
* @brief helper function to deserialize a command_interaction from json
*
* @see https://github.com/nlohmann/json#arbitrary-types-conversions
*
* @param j output json object
* @param ci command_interaction to be deserialized
*/
void from_json(const nlohmann::json& j, command_interaction& ci);
/**
* @brief A button click for a button component
*/
struct DPP_EXPORT component_interaction {
/**
* @brief Component type (dpp::component_type)
*/
uint8_t component_type;
/**
* @brief Custom ID set when created
*/
std::string custom_id;
/**
* @brief Possible values for a drop down list
*/
std::vector<std::string> values;
};
/**
* @brief An auto complete interaction
*/
struct DPP_EXPORT autocomplete_interaction : public command_interaction {
};
/**
* @brief helper function to deserialize a component_interaction from json
*
* @see https://github.com/nlohmann/json#arbitrary-types-conversions
*
* @param j output json object
* @param bi button_interaction to be deserialized
*/
void from_json(const nlohmann::json& j, component_interaction& bi);
/**
* @brief helper function to deserialize an autocomplete_interaction from json
*
* @see https://github.com/nlohmann/json#arbitrary-types-conversions
*
* @param j output json object
* @param ai autocomplete_interaction to be deserialized
*/
void from_json(const nlohmann::json& j, autocomplete_interaction& ai);
/**
* @brief An interaction represents a user running a command and arrives
* via the dpp::cluster::on_interaction_create event. This is further split
* into the events on_form_submit, on_slashcommand, on_user_context_menu,
* on_button_click, on_select_menu, etc.
*/
class DPP_EXPORT interaction : public managed, public json_interface<interaction> {
protected:
friend struct json_interface<interaction>;
/**
* @brief Get a resolved object from the resolved set
*
* @tparam T type of object to retrieve
* @tparam C container defintion for resolved container
* @param id Snowflake ID
* @param resolved_set container for the type
* @return const T& retrieved type
* @throws dpp::logic_exception on object not found in resolved set
*/
template<typename T, typename C> const T& get_resolved(snowflake id, const C& resolved_set) const {
auto i = resolved_set.find(id);
if (i == resolved_set.end()) {
throw dpp::logic_exception("ID not found in resolved properties of application command");
}
return i->second;
}
/**
* @brief Fill object properties from JSON
*
* @param j JSON to fill from
* @return interaction& Reference to self
*/
interaction& fill_from_json_impl(nlohmann::json* j);
/**
* @brief Build a json for this object
*
* @param with_id True if to include the ID in the JSON
* @return json JSON object
*/
virtual json to_json_impl(bool with_id = false) const;
public:
/**
* @brief ID of the application this interaction is for.
*/
snowflake application_id;
/**
* @brief The type of interaction from dpp::interaction_type.
*/
uint8_t type;
/**
* @brief Optional: the command data payload.
*/
std::variant<command_interaction, component_interaction, autocomplete_interaction> data;
/**
* @brief Optional: the guild it was sent from.
*/
snowflake guild_id;
/**
* @brief Optional: the channel it was sent from
*/
snowflake channel_id;
/**
* @brief Optional: The partial channel object where it was sent from.
*/
dpp::channel channel;
/**
* @brief Originating message id for context menu actions.
*/
snowflake message_id;
/**
* @brief Permissions of the bot in the channel/guild where this command was issued.
*/
permission app_permissions;
/**
* @brief Originating message for context menu actions.
*/
message msg;
/**
* @brief Optional: guild member data for the invoking user, including permissions. Filled when the interaction is invoked in a guild
*/
guild_member member;
/**
* @brief User object for the invoking user.
*/
user usr;
/**
* @brief A continuation token for responding to the interaction.
*/
std::string token;
/**
* @brief Read-only property, always 1.
*/
uint8_t version;
/**
* @brief Resolved data e.g. users, members, roles, channels, permissions, etc.
*/
command_resolved resolved;
/**
* @brief User's [locale](https://discord.com/developers/docs/reference#locales) (language).
*/
std::string locale;
/**
* @brief Guild's locale (language) - for guild interactions only.
*/
std::string guild_locale;
/**
* @brief Cache policy from cluster.
*/
cache_policy_t cache_policy;
/**
* @brief For monetized apps, any entitlements for the invoking user, representing access to premium SKUs.
*/
std::vector<entitlement> entitlements;
/**
* @brief Construct a new interaction object.
*/
interaction();
/**
* @brief Destroy the interaction object
*/
virtual ~interaction() = default;
/**
* @brief Get a user associated with the slash command from the resolved list.
* The resolved list contains associated structures for this command and does not
* use the cache or require any extra API calls.
*
* @param id User snowflake ID to find
* @return const dpp::user& user
* @throws dpp::logic_exception on object not found in resolved set
*/
const dpp::user& get_resolved_user(snowflake id) const;
/**
* @brief Get the channel this command originated on
*
* @return const dpp::channel& channel
* @throws dpp::logic_exception Command originated from a DM or channel not in cache
*/
const dpp::channel& get_channel() const;
/**
* @brief Get the guild this command originated on
*
* @return const dpp::guild& guild
* @throws dpp::logic_exception Command originated from a DM or guild not in cache
*/
const dpp::guild& get_guild() const;
/**
* @brief Get the user who issued this command
*
* @return const dpp::user& user
*/
const dpp::user& get_issuing_user() const;
/**
* @brief Get the message this action refers to if it is a context menu command
*
* @return const dpp::message& context menu message
*/
const dpp::message& get_context_message() const;
/**
* @brief Get a role associated with the slash command from the resolved list.
* The resolved list contains associated structures for this command and does not
* use the cache or require any extra API calls.
*
* @param id Role snowflake ID to find
* @return const dpp::role& role
* @throws dpp::logic_exception on object not found in resolved set
*/
const dpp::role& get_resolved_role(snowflake id) const;
/**
* @brief Get a channel associated with the slash command from the resolved list.
* The resolved list contains associated structures for this command and does not
* use the cache or require any extra API calls.
*
* @param id Channel snowflake ID to find
* @return const dpp::channel& channel
* @throws dpp::logic_exception on object not found in resolved set
*/
const dpp::channel& get_resolved_channel(snowflake id) const;
/**
* @brief Get a guild member associated with the slash command from the resolved list.
* The resolved list contains associated structures for this command and does not
* use the cache or require any extra API calls.
*
* @param id User snowflake ID to find
* @return const dpp::guild_member& guild member
* @throws dpp::logic_exception on object not found in resolved set
*/
const dpp::guild_member& get_resolved_member(snowflake id) const;
/**
* @brief Get a permission associated with the slash command from the resolved list.
* The resolved list contains associated structures for this command and does not
* use the cache or require any extra API calls.
*
* @param id User snowflake ID to find
* @return const dpp::permission& total permissions for the user including overrides on
* the channel where the command was issued.
* @throws dpp::logic_exception on object not found in resolved set
*/
const dpp::permission& get_resolved_permission(snowflake id) const;
/**
* @brief Get a message associated with the slash command from the resolved list.
* The resolved list contains associated structures for this command and does not
* use the cache or require any extra API calls.
*
* @param id Message snowflake ID to find
* @return const dpp::message& message
* @throws dpp::logic_exception on object not found in resolved set
*/
const dpp::message& get_resolved_message(snowflake id) const;
/**
* @brief Get an uploaded attachment associated with the slash command from the resolved list.
* The resolved list contains associated structures for this command and does not
* use the cache or require any extra API calls.
*
* @param id Attachment snowflake ID to find
* @return const dpp::attachment& file attachment
* @throws dpp::logic_exception on object not found in resolved set
*/
const dpp::attachment& get_resolved_attachment(snowflake id) const;
/**
* @brief Get the command interaction object
*
* @throw dpp::logic_exception if the interaction is not for a command
*
* @return command_interaction object
*/
command_interaction get_command_interaction() const;
/**
* @brief Get the component interaction object
*
* @throw dpp::logic_exception if the interaction is not for a component
*
* @return component_interaction object
*/
component_interaction get_component_interaction() const;
/**
* @brief Get the autocomplete interaction object
*
* @throw dpp::logic_exception if the interaction is not for an autocomplete
*
* @return autocomplete_interaction object
*/
autocomplete_interaction get_autocomplete_interaction() const;
/**
* @brief Get the command name for a command interaction
*
* @return std::string command interaction, or empty string if the interaction
* is not for a command.
*/
std::string get_command_name() const;
};
/**
* @brief helper function to deserialize an interaction from json
*
* @see https://github.com/nlohmann/json#arbitrary-types-conversions
*
* @param j output json object
* @param i interaction to be deserialized
*/
void from_json(const nlohmann::json& j, interaction& i);
/**
* @brief type of permission in the dpp::command_permission class
*/
enum command_permission_type {
/**
* @brief Role permission
*/
cpt_role = 1,
/**
* @brief User permission
*/
cpt_user = 2,
};
/**
* @brief Application command permissions allow you to enable or
* disable commands for specific users or roles within a guild
*/
class DPP_EXPORT command_permission : public json_interface<command_permission> {
protected:
friend struct json_interface<command_permission>;
/**
* @brief Fill object properties from JSON
*
* @param j JSON to fill from
* @return command_permission& Reference to self
*/
command_permission &fill_from_json_impl(nlohmann::json *j);
public:
/**
* @brief The ID of the role/user.
*/
snowflake id;
/**
* @brief The type of permission.
*/
command_permission_type type;
/**
* @brief True to allow, false to disallow.
*/
bool permission;
/**
* @brief Construct a new command permission object.
*/
command_permission() = default;
virtual ~command_permission() = default;
/**
* @brief Construct a new command permission object
*
* @param id The ID of the role or user
* @param t The permission type
* @param permission True to allow, false, to disallow
*/
command_permission(snowflake id, const command_permission_type t, bool permission);
};
/**
* @brief helper function to serialize a command_permission to json
*
* @see https://github.com/nlohmann/json#arbitrary-types-conversions
*
* @param j output json object
* @param cp command_permission to be serialized
*/
void to_json(nlohmann::json& j, const command_permission& cp);
/**
* @brief Returned when fetching the permissions for a command in a guild.
*/
class DPP_EXPORT guild_command_permissions : public json_interface<guild_command_permissions> {
protected:
friend struct json_interface<guild_command_permissions>;
/**
* @brief Fill object properties from JSON
*
* @param j JSON to fill from
* @return guild_command_permissions& Reference to self
*/
guild_command_permissions &fill_from_json_impl(nlohmann::json *j);
public:
/**
* @brief The id of the command.
*/
snowflake id;
/**
* @brief The id of the application the command belongs to.
*/
snowflake application_id;
/**
* @brief The id of the guild.
*/
snowflake guild_id;
/**
* @brief The permissions for the command, in the guild.
*/
std::vector<command_permission> permissions;
/**
* @brief Construct a new guild command permissions object
*/
guild_command_permissions();
virtual ~guild_command_permissions() = default;
};
/**
* @brief helper function to serialize a guild_command_permissions to json
*
* @see https://github.com/nlohmann/json#arbitrary-types-conversions
*
* @param j output json object
* @param gcp guild_command_permissions to be serialized
*/
void to_json(nlohmann::json& j, const guild_command_permissions& gcp);
/**
* @brief Represents an application command, created by your bot
* either globally, or on a guild.
*/
class DPP_EXPORT slashcommand : public managed, public json_interface<slashcommand> {
protected:
friend struct json_interface<slashcommand>;
/**
* @brief Fill object properties from JSON
*
* @param j JSON to fill from
* @return slashcommand& Reference to self
*/
slashcommand& fill_from_json_impl(nlohmann::json* j);
/**
* @brief Build a json for this object
*
* @param with_id True if to include the ID in the JSON
* @return json JSON object
*/
json to_json_impl(bool with_id = false) const;
public:
/**
* @brief Application id (usually matches your bots id)
*/
snowflake application_id;
/**
* @brief Context menu type, defaults to dpp::ctxm_chat_input
*/
slashcommand_contextmenu_type type;
/**
* @brief Command name (1-32 chars)
*/
std::string name;
/**
* @brief Command description (1-100 chars)
*/
std::string description;
/**
* @brief Command options (parameters)
*/
std::vector<command_option> options;
/**
* @brief Whether the command is enabled by default when the app is added to a guild.
* This has no effect as the default_member_permissions value is used instead.
* @deprecated Discord discourage use of this value and instead you should use slashcommand::default_member_permissions.
*/
bool default_permission;
/**
* @brief command permissions
* @deprecated Discord discourage use of this value and instead you should use default_member_permissions.
*/
std::vector<command_permission> permissions;
/**
* @brief autoincrementing version identifier updated during substantial record changes
*/
snowflake version;
/**
* @brief Localisations of command name
*/
std::map<std::string, std::string> name_localizations;
/**
* @brief Localisations of command description
*/
std::map<std::string, std::string> description_localizations;
/**
* @brief The default permissions of this command on a guild.
* D++ defaults this to dpp::p_use_application_commands.
* @note You can set it to 0 to disable the command for everyone except admins by default
*/
permission default_member_permissions;
/**
* @brief True if this command should be allowed in a DM
* D++ defaults this to false. Cannot be set to true in a guild
* command, only a global command.
*/
bool dm_permission;
/**
* @brief Indicates whether the command is [age-restricted](https://discord.com/developers/docs/interactions/application-commands#agerestricted-commands).
* Defaults to false
*/
bool nsfw;
/**
* @brief Construct a new slashcommand object
*/
slashcommand();
/**
* @brief Construct a new slashcommand object
*
* @param _name Command name
* @param _description Command description
* @param _application_id Application id (usually the bot's user id)
*/
slashcommand(const std::string &_name, const std::string &_description, const dpp::snowflake _application_id);
/**
* @brief Construct a new slashcommand object
*
* @param _name Command name
* @param _type Context menu type
* @param _application_id Application id (usually the bot's user id)
*/
slashcommand(const std::string &_name, const slashcommand_contextmenu_type _type, const dpp::snowflake _application_id);
/**
* @brief Destroy the slashcommand object
*/
virtual ~slashcommand() = default;
/**
* @brief Add a localisation for this slash command
* @see https://discord.com/developers/docs/reference#locales
* @param language Name of language, see the list of locales linked to above
* @param _name name of slash command in the specified language
* @param _description description of slash command in the specified language (optional)
* @return slashcommand& reference to self for chaining of calls
*/
slashcommand& add_localization(const std::string& language, const std::string& _name, const std::string& _description = "");
/**
* @brief Set the dm permission for the command
*
* @param dm true to allow this command in dms
* @return slashcommand& reference to self for chaining of calls
*/
slashcommand& set_dm_permission(bool dm);
/**
* @brief Set whether the command should be age-restricted or not
*
* @param is_nsfw true if the command should be age-restricted
* @return slashcommand& reference to self for chaining of calls
*/
slashcommand& set_nsfw(bool is_nsfw);
/**
* @brief Set the default permissions of the slash command
*
* @param defaults default permissions to set. This is a permission bitmask of bits from dpp::permissions
* @note You can set it to 0 to disable the command for everyone except admins by default
*
* @return slashcommand& reference to self for chaining of calls
*/
slashcommand& set_default_permissions(uint64_t defaults);
/**
* @brief Add an option (parameter)
*
* @param o option (parameter) to add
* @return slashcommand& reference to self for chaining of calls
*/
slashcommand& add_option(const command_option &o);
/**
* @brief Set the type of the slash command (only for context menu entries)
*
* @param _type Type of context menu entry this command represents
* @note If the type is dpp::ctxm_chat_input, the command name will be set to lowercase.
* @return slashcommand& reference to self for chaining of calls
*/
slashcommand& set_type(slashcommand_contextmenu_type _type);
/**
* @brief Set the name of the command
*
* @param n name of command
* @note The maximum length of a command name is 32 UTF-8 codepoints.
* If your command name is longer than this, it will be truncated.
* The command name will be set to lowercase when the type is the default dpp::ctxm_chat_input.
* @return slashcommand& reference to self for chaining of calls
*/
slashcommand& set_name(const std::string &n);
/**
* @brief Set the description of the command
*
* @param d description
* @note The maximum length of a command description is 100 UTF-8 codepoints.
* If your command description is longer than this, it will be truncated.
* @return slashcommand& reference to self for chaining of calls
*/
slashcommand& set_description(const std::string &d);
/**
* @brief Set the application id of the command
*
* @param i application id
* @return slashcommand& reference to self for chaining of calls
*/
slashcommand& set_application_id(snowflake i);
/**
* @brief Adds a permission to the command
*
* @param p permission to add
* @return slashcommand& reference to self for chaining of calls
* @deprecated Discord discourage use of this value and instead you should use default_member_permissions.
*/
slashcommand& add_permission(const command_permission& p);
/**
* @brief Disable default permissions, command will be unusable unless
* permissions are overridden with add_permission and
* dpp::guild_command_edit_permissions
*
* @return slashcommand& reference to self for chaining of calls
* @deprecated Discord discourage use of this value and instead you should use default_member_permissions.
*/
slashcommand& disable_default_permissions();
/**
* @brief Return a ping/mention for the slash command
*
* @return std::string mention. e.g. `</airhorn:816437322781949972>`
* @note If you want a mention for a subcommand or subcommand group, you can use dpp::utility::slashcommand_mention
*/
std::string get_mention() const;
};
/**
* @brief helper function to serialize a slashcommand to json
*
* @see https://github.com/nlohmann/json#arbitrary-types-conversions
*
* @param j output json object
* @param cmd slashcommand to be serialized
*/
void to_json(nlohmann::json& j, const slashcommand& cmd);
/**
* @brief A group of application slash commands
*/
typedef std::unordered_map<snowflake, slashcommand> slashcommand_map;
/**
* @brief A group of guild command permissions
*/
typedef std::unordered_map<snowflake, guild_command_permissions> guild_command_permissions_map;
} // namespace dpp