mirror of
https://github.com/VCMP-SqMod/SqMod.git
synced 2025-01-19 03:57:14 +01:00
9298065cef
CPR has features disabled and PCRE is fully disabled until updated to new code.
1226 lines
41 KiB
C++
1226 lines
41 KiB
C++
/************************************************************************************
|
|
*
|
|
* 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 <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 {
|
|
/** 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<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> {
|
|
std::string name; //!< Option name (1-32 chars)
|
|
command_value value; //!< Option value
|
|
std::map<std::string, std::string> 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/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> {
|
|
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<command_option_choice> choices; //!< List of choices for multiple choice command
|
|
bool autocomplete; //!< True if this option supports auto completion
|
|
std::vector<command_option> options; //!< Sub-commands
|
|
std::vector<channel_type> channel_types; //!< Allowed channel types for channel snowflake id options
|
|
// Combines the `min_length` and `max_length` field by storing its value in the int64_t of the command_option_range
|
|
command_option_range min_value; //!< Minimum value/length that can be entered, for dpp::co_number, dpp::co_integer and dpp::co_string types only
|
|
command_option_range max_value; //!< Maximum value/length that can be entered, for dpp::co_number, dpp::co_integer and dpp::co_string types only
|
|
std::map<std::string, std::string> name_localizations; //!< Localisations of command name
|
|
std::map<std::string, std::string> 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 (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 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<interaction_response> {
|
|
|
|
/**
|
|
* @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<command_option_choice> 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<interaction_modal_response> {
|
|
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<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 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<dpp::snowflake, dpp::user> users;
|
|
/**
|
|
* @brief Resolved guild members
|
|
*/
|
|
std::map<dpp::snowflake, dpp::guild_member> members;
|
|
/**
|
|
* @brief Resolved total guild member permissions in the channel, including overwrites
|
|
*/
|
|
std::map<dpp::snowflake, permission> member_permissions;
|
|
/**
|
|
* @brief Resolved roles
|
|
*/
|
|
std::map<dpp::snowflake, dpp::role> roles;
|
|
/**
|
|
* @brief Resolved channels
|
|
*/
|
|
std::map<dpp::snowflake, dpp::channel> channels;
|
|
/**
|
|
* @brief Resolved messages
|
|
*/
|
|
std::map<dpp::snowflake, dpp::message> messages;
|
|
/**
|
|
* @brief Resolved attachments
|
|
*/
|
|
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 {
|
|
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<command_data_option> 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<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 {
|
|
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<command_data_option> 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 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> {
|
|
|
|
/**
|
|
* @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;
|
|
}
|
|
|
|
public:
|
|
snowflake application_id; //!< id of the application this interaction is for
|
|
uint8_t type; //!< the type of interaction (dpp::interaction_type)
|
|
std::variant<command_interaction, component_interaction, autocomplete_interaction> 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
|
|
dpp::channel channel; //!< Optional: The partial channel object where 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. Filled when the interaction is invoked in a guild
|
|
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](https://discord.com/developers/docs/reference#locales) (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<command_permission> {
|
|
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<guild_command_permissions> {
|
|
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<command_permission> 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<slashcommand> {
|
|
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 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 (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 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<snowflake, slashcommand> slashcommand_map;
|
|
|
|
/**
|
|
* @brief A group of guild command permissions
|
|
*/
|
|
typedef std::unordered_map<snowflake, guild_command_permissions> guild_command_permissions_map;
|
|
|
|
};
|