/************************************************************************************ * * 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 #include #include #include #include #include #include #include #include #include #include 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 { /** A sub-command */ co_sub_command = 1, /** A sub-command group */ co_sub_command_group = 2, /** A string value */ co_string = 3, /** An integer value */ co_integer = 4, /** A boolean value */ co_boolean = 5, /** A user snowflake id */ co_user = 6, /** A channel snowflake id. Includes all channel types and categories */ co_channel = 7, /** A role snowflake id */ co_role = 8, /** A mentionable. Includes users and roles */ co_mentionable = 9, /** Any double between -2^53 and 2^53 */ co_number = 10, /** 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 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 { std::string name; //!< Option name (1-32 chars) command_value value; //!< Option value std::map name_localizations; //!< Localisations of command option name /** * @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 Fill object properties from JSON * * @param j JSON to fill from * @return command_option_choice& Reference to self */ command_option_choice& fill_from_json(nlohmann::json* j); }; /** * @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 for co_number and co_integer dpp::command_option types */ typedef std::variant 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_type type; //!< Option type (what type of value is accepted) std::string name; //!< Option name (1-32 chars) std::string description; //!< Option description (1-100 chars) bool required; //!< True if this is a mandatory parameter bool focused; //!< True if the user is typing in this field, when sent via autocomplete command_value value; //!< Set only by autocomplete went sent as part of an interaction std::vector choices; //!< List of choices for multiple choice command bool autocomplete; //!< True if this option supports auto completion std::vector options; //!< Sub-commands std::vector channel_types; //!< Allowed channel types for channel snowflake id options command_option_range min_value; //!< Minimum value allowed, for co_number and co_integer types only command_option_range max_value; //!< Maximum value allowed, for co_number and co_integer types only std::map name_localizations; //!< Localisations of command name std::map description_localizations; //!< Localisations of command description /** * @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 * @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::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 co_number or co_integer. * @param min_v Minimum value * @return command_option& return a reference to sef 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 co_number or co_integer. * @param max_v Maximum value * @return command_option& return a reference to sef for chaining of calls */ command_option& set_max_value(command_option_range max_v); /** * @brief Set the minimum string length of the option. * Only valid if the type is co_string * @param min_v Minimum value * @return command_option& return a reference to sef for chaining of calls */ command_option& set_min_length(command_option_range min_v); /** * @brief Set the maximum string length of the option. * Only valid if the type is co_string * @param max_v Maximum value * @return command_option& return a reference to sef 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::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 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(nlohmann::json* j); }; /** * @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 { ir_pong = 1, //!< Acknowledge a Ping ir_channel_message_with_source = 4, //!< respond to an interaction with a message ir_deferred_channel_message_with_source = 5, //!< Acknowledge an interaction and edit a response later, the user sees a loading state ir_deferred_update_message = 6, //!< for components, acknowledge an interaction and edit the original message later; the user does not see a loading state ir_update_message = 7, //!< for components, edit the message the component was attached to ir_autocomplete_reply = 8, //!< Reply to autocomplete interaction. Be sure to do this within 500ms of the interaction! ir_modal_dialog = 9, //!< A modal dialog box }; /** * @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 { /** * @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 A message object. This pointer is always valid * while the containing interaction_response exists. */ struct message* msg; /** * @brief Array of up to 25 autocomplete choices */ std::vector autocomplete_choices; /** * @brief Construct a new interaction response object */ interaction_response(); /** * @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 struct message& m); /** * @brief Construct a new interaction response object * * @param t Type of reply */ interaction_response(interaction_response_type t); /** * @brief Fill object properties from JSON * * @param j JSON to fill from * @return interaction_response& Reference to self */ interaction_response& fill_from_json(nlohmann::json* j); /** * @brief Build a json string for this object * * @return std::string JSON string */ virtual std::string build_json(bool with_id = false) const; /** * @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(); }; /** * @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 { private: size_t current_row; public: /** * @brief Custom ID for the modal form */ std::string custom_id; /** * @brief Title of the modal form box */ 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> 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 _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 Fill object properties from JSON * * @param j JSON to fill from * @return interaction_response& Reference to self */ interaction_modal_response& fill_from_json(nlohmann::json* j); /** * @brief Build a json string for this object * @param with_id include id in json output * * @return std::string JSON string */ std::string build_json(bool with_id = false) const; /** * @brief Destroy the interaction modal response object */ virtual ~interaction_modal_response() = default; }; /** * @brief Resolved snowflake ids to users, guild members, roles and channels. */ struct DPP_EXPORT command_resolved { /** * @brief Resolved users */ std::map users; /** * @brief Resolved guild members */ std::map members; /** * @brief Resolved total guild member permissions in the channel, including overwrites */ std::map member_permissions; /** * @brief Resolved roles */ std::map roles; /** * @brief Resolved channels */ std::map channels; /** * @brief Resolved messages */ std::map messages; /** * @brief Resolved attachments */ std::map 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 { std::string name; //!< the name of the parameter command_option_type type; //!< value of ApplicationCommandOptionType command_value value; //!< Optional: the value of the pair std::vector options; //!< Optional: present if this option is a group or subcommand bool focused; //!< Optional: true if this option is the currently focused option for autocomplete /** * @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(value) && options.empty(); } /** * @brief Get an option value by index * * @tparam Type to get from the parameter * @param index index number of parameter * @return T returned type */ template T& get_value(size_t index) { return std::get(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 { it_ping = 1, //!< ping it_application_command = 2, //!< application command (slash command) it_component_button = 3, //!< button click or select menu chosen (component interaction) it_autocomplete = 4, //!< Autocomplete interaction it_modal_submit = 5, //!< Modal form submission }; /** * @brief Right-click context menu types */ enum slashcommand_contextmenu_type { ctxm_none = 0, //!< Undefined context menu type ctxm_chat_input = 1, //!< DEFAULT, these are the slash commands you're used to ctxm_user = 2, //!< Add command to user context menu ctxm_message = 3 //!< Add command to message context menu }; /** * @brief Details of a command within an interaction. * This subobject represents the application command associated * with the interaction. */ struct DPP_EXPORT command_interaction { snowflake id; //!< the ID of the invoked command std::string name; //!< the name of the invoked command std::vector options; //!< Optional: the params + values from the user slashcommand_contextmenu_type type; //!< type of the command interaction dpp::snowflake target_id; //!< Non-zero target ID for context menu actions. e.g. user id or message id whom clicked or tapped with the context menu https://discord.com/developers/docs/interactions/application-commands#user-commands /** * @brief Get an option value by index * * @tparam Type to get from the parameter * @param index index number of parameter * @return T returned type */ template T& get_value(size_t index) { return std::get(options.at(index).value); } /** * @brief Return a ping/mention for the slash command * * @return std::string mention. e.g. `` * @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 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 { /** * @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 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; } public: snowflake application_id; //!< id of the application this interaction is for uint8_t type; //!< the type of interaction (dpp::interaction_type) std::variant data; //!< Optional: the command data payload snowflake guild_id; //!< Optional: the guild it was sent from snowflake channel_id; //!< Optional: the channel it was sent from snowflake message_id; //!< Originating message id for context menu actions permission app_permissions; //!< Permissions of the bot in the channel/guild where this command was issued message msg; //!< Originating message for context menu actions guild_member member; //!< Optional: guild member data for the invoking user, including permissions user usr; //!< User object for the invoking user std::string token; //!< a continuation token for responding to the interaction uint8_t version; //!< read-only property, always 1 command_resolved resolved; //!< Resolved user/role etc std::string locale; //!< User's locale (language) std::string guild_locale; //!< Guild's locale (language) - for guild interactions only cache_policy_t cache_policy; //!< Cache policy from cluster /** * @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& 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 Fill object properties from JSON * * @param j JSON to fill from * @return interaction& Reference to self */ interaction& fill_from_json(nlohmann::json* j); /** * @brief Build a json string for this object * * @param with_id True if to include the ID in the JSON * @return std::string JSON string */ std::string build_json(bool with_id = false) 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 { public: snowflake id; //!< the ID of the role or user command_permission_type type; //!< the type of permission bool permission; //!< true to allow, false, to disallow /** * @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 Fill object properties from JSON * * @param j JSON to fill from * @return command_permission& Reference to self */ command_permission &fill_from_json(nlohmann::json *j); }; /** * @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 { public: snowflake id; //!< the id of the command snowflake application_id; //!< the id of the application the command belongs to snowflake guild_id; //!< the id of the guild std::vector permissions; //!< the permissions for the command in the guild /** * @brief Construct a new guild command permissions object */ guild_command_permissions(); virtual ~guild_command_permissions() = default; /** * @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(nlohmann::json *j); }; /** * @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 { 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 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 permissions; /** * @brief autoincrementing version identifier updated during substantial record changes */ snowflake version; /** * @brief Localisations of command name */ std::map name_localizations; /** * @brief Localisations of command description */ std::map 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 Destroy the slashcommand object */ virtual ~slashcommand(); /** * @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 * @return slashcommand& reference to self for fluent chaining */ 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. `` * @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 Fill object properties from JSON * * @param j JSON to fill from * @return slashcommand& Reference to self */ slashcommand& fill_from_json(nlohmann::json* j); /** * @brief Build a json string for this object * * @param with_id True if to include the ID in the JSON * @return std::string JSON string */ std::string build_json(bool with_id = false) 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 slashcommand_map; /** * @brief A group of guild command permissions */ typedef std::unordered_map guild_command_permissions_map; };