mirror of
https://github.com/VCMP-SqMod/SqMod.git
synced 2025-01-19 12:07:13 +01:00
2524 lines
123 KiB
C
2524 lines
123 KiB
C
|
/************************************************************************************
|
||
|
*
|
||
|
* D++, A Lightweight C++ library for Discord
|
||
|
*
|
||
|
* Copyright 2022 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.
|
||
|
*
|
||
|
************************************************************************************/
|
||
|
|
||
|
|
||
|
/* Auto @generated by buildtools/make_sync_struct.php.
|
||
|
*
|
||
|
* DO NOT EDIT BY HAND!
|
||
|
*
|
||
|
* To re-generate this header file re-run the script!
|
||
|
*/
|
||
|
/**
|
||
|
* @brief Create/overwrite global slash commands.
|
||
|
* Any existing global slash commands will be deleted and replaced with these.
|
||
|
*
|
||
|
* @see dpp::cluster::global_bulk_command_create
|
||
|
* @see https://discord.com/developers/docs/interactions/application-commands#bulk-overwrite-global-application-commands
|
||
|
* @param commands Vector of slash commands to create/update.
|
||
|
* overwriting existing commands that are registered globally for this application. Updates will be available in all guilds after 1 hour.
|
||
|
* Commands that do not already exist will count toward daily application command create limits.
|
||
|
* @return slashcommand_map returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
slashcommand_map global_bulk_command_create_sync(const std::vector<slashcommand> &commands);
|
||
|
|
||
|
/**
|
||
|
* @brief Create a global slash command (a bot can have a maximum of 100 of these).
|
||
|
*
|
||
|
* @see dpp::cluster::global_command_create
|
||
|
* @see https://discord.com/developers/docs/interactions/application-commands#create-global-application-command
|
||
|
* @param s Slash command to create
|
||
|
* @return slashcommand returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
slashcommand global_command_create_sync(const slashcommand &s);
|
||
|
|
||
|
/**
|
||
|
* @brief Get a global slash command
|
||
|
*
|
||
|
* @see dpp::cluster::global_command_get
|
||
|
* @see https://discord.com/developers/docs/interactions/application-commands#get-global-application-command
|
||
|
* @param id The ID of the slash command
|
||
|
* @return slashcommand returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
slashcommand global_command_get_sync(snowflake id);
|
||
|
|
||
|
/**
|
||
|
* @brief Delete a global slash command (a bot can have a maximum of 100 of these)
|
||
|
*
|
||
|
* @see dpp::cluster::global_command_delete
|
||
|
* @see https://discord.com/developers/docs/interactions/application-commands#delete-global-application-command
|
||
|
* @param id Slash command to delete
|
||
|
* @return confirmation returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
confirmation global_command_delete_sync(snowflake id);
|
||
|
|
||
|
/**
|
||
|
* @brief Edit a global slash command (a bot can have a maximum of 100 of these)
|
||
|
*
|
||
|
* @see dpp::cluster::global_command_edit
|
||
|
* @see https://discord.com/developers/docs/interactions/application-commands#edit-global-application-command
|
||
|
* @param s Slash command to change
|
||
|
* @return confirmation returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
confirmation global_command_edit_sync(const slashcommand &s);
|
||
|
|
||
|
/**
|
||
|
* @brief Get the application's global slash commands
|
||
|
*
|
||
|
* @see dpp::cluster::global_commands_get
|
||
|
* @see https://discord.com/developers/docs/interactions/application-commands#get-global-application-commands
|
||
|
* @return slashcommand_map returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
slashcommand_map global_commands_get_sync();
|
||
|
|
||
|
/**
|
||
|
* @brief Create/overwrite guild slash commands.
|
||
|
* Any existing guild slash commands on this guild will be deleted and replaced with these.
|
||
|
*
|
||
|
* @see dpp::cluster::guild_bulk_command_create
|
||
|
* @see https://discord.com/developers/docs/interactions/application-commands#bulk-overwrite-guild-application-commands
|
||
|
* @param commands Vector of slash commands to create/update.
|
||
|
* New guild commands will be available in the guild immediately. If the command did not already exist, it will count toward daily application command create limits.
|
||
|
* @param guild_id Guild ID to create/update the slash commands in
|
||
|
* @return slashcommand_map returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
slashcommand_map guild_bulk_command_create_sync(const std::vector<slashcommand> &commands, snowflake guild_id);
|
||
|
|
||
|
/**
|
||
|
* @brief Get all slash command permissions of a guild
|
||
|
*
|
||
|
* @see dpp::cluster::guild_commands_get_permissions
|
||
|
* @see https://discord.com/developers/docs/interactions/application-commands#get-application-command-permissions
|
||
|
* @param guild_id Guild ID to get the slash commands permissions for
|
||
|
* @return guild_command_permissions_map returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
guild_command_permissions_map guild_commands_get_permissions_sync(snowflake guild_id);
|
||
|
|
||
|
/**
|
||
|
* @brief Edit/Overwrite the permissions of all existing slash commands in a guild
|
||
|
*
|
||
|
* @note You can only add up to 10 permission overwrites for a command
|
||
|
*
|
||
|
* @see dpp::cluster::guild_bulk_command_edit_permissions
|
||
|
* @see https://discord.com/developers/docs/interactions/application-commands#batch-edit-application-command-permissions
|
||
|
* @warning The endpoint will overwrite all existing permissions for all commands of the application in a guild, including slash commands, user commands, and message commands. Meaning that if you forgot to pass a slash command, the permissions of it might be removed.
|
||
|
* @param commands A vector of slash commands to edit/overwrite the permissions for
|
||
|
* @param guild_id Guild ID to edit permissions of the slash commands in
|
||
|
* @return guild_command_permissions_map returned object on completion
|
||
|
* @deprecated This has been disabled with updates to Permissions v2. You can use guild_command_edit_permissions instead
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
guild_command_permissions_map guild_bulk_command_edit_permissions_sync(const std::vector<slashcommand> &commands, snowflake guild_id);
|
||
|
|
||
|
/**
|
||
|
* @brief Create a slash command local to a guild
|
||
|
*
|
||
|
* @see dpp::cluster::guild_command_create
|
||
|
* @see https://discord.com/developers/docs/interactions/application-commands#create-guild-application-command
|
||
|
* @note Creating a command with the same name as an existing command for your application will overwrite the old command.
|
||
|
* @param s Slash command to create
|
||
|
* @param guild_id Guild ID to create the slash command in
|
||
|
* @return slashcommand returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
slashcommand guild_command_create_sync(const slashcommand &s, snowflake guild_id);
|
||
|
|
||
|
/**
|
||
|
* @brief Delete a slash command local to a guild
|
||
|
*
|
||
|
* @see dpp::cluster::guild_command_delete
|
||
|
* @see https://discord.com/developers/docs/interactions/application-commands#delete-guild-application-command
|
||
|
* @param id Slash command to delete
|
||
|
* @param guild_id Guild ID to delete the slash command in
|
||
|
* @return confirmation returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
confirmation guild_command_delete_sync(snowflake id, snowflake guild_id);
|
||
|
|
||
|
/**
|
||
|
* @brief Edit slash command permissions of a guild
|
||
|
*
|
||
|
* @see dpp::cluster::guild_command_edit_permissions
|
||
|
* @see https://discord.com/developers/docs/interactions/application-commands#edit-application-command-permissions
|
||
|
* @note You can only add up to 10 permission overwrites for a command
|
||
|
* @param s Slash command to edit the permissions for
|
||
|
* @param guild_id Guild ID to edit the slash command in
|
||
|
* @return confirmation returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
confirmation guild_command_edit_permissions_sync(const slashcommand &s, snowflake guild_id);
|
||
|
|
||
|
/**
|
||
|
* @brief Get a slash command of a guild
|
||
|
*
|
||
|
* @see dpp::cluster::guild_command_get
|
||
|
* @see https://discord.com/developers/docs/interactions/application-commands#get-guild-application-command
|
||
|
* @note The returned slash commands will not have permissions set, you need to use a permissions getter e.g. dpp::guild_commands_get_permissions to get the guild command permissions
|
||
|
* @param id The ID of the slash command
|
||
|
* @param guild_id Guild ID to get the slash command from
|
||
|
* @return slashcommand returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
slashcommand guild_command_get_sync(snowflake id, snowflake guild_id);
|
||
|
|
||
|
/**
|
||
|
* @brief Get the permissions for a slash command of a guild
|
||
|
*
|
||
|
* @see dpp::cluster::guild_command_get_permissions
|
||
|
* @see https://discord.com/developers/docs/interactions/application-commands#get-application-command-permissions
|
||
|
* @param id The ID of the slash command to get the permissions for
|
||
|
* @param guild_id Guild ID to get the permissions of
|
||
|
* @return guild_command_permissions returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
guild_command_permissions guild_command_get_permissions_sync(snowflake id, snowflake guild_id);
|
||
|
|
||
|
/**
|
||
|
* @brief Edit a slash command local to a guild
|
||
|
*
|
||
|
* @see dpp::cluster::guild_command_edit
|
||
|
* @see https://discord.com/developers/docs/interactions/application-commands#edit-guild-application-command
|
||
|
* @param s Slash command to edit
|
||
|
* @param guild_id Guild ID to edit the slash command in
|
||
|
* @return confirmation returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
confirmation guild_command_edit_sync(const slashcommand &s, snowflake guild_id);
|
||
|
|
||
|
/**
|
||
|
* @brief Get the application's slash commands for a guild
|
||
|
*
|
||
|
* @see dpp::cluster::guild_commands_get
|
||
|
* @see https://discord.com/developers/docs/interactions/application-commands#get-guild-application-commands
|
||
|
* @note The returned slash commands will not have permissions set, you need to use a permissions getter e.g. dpp::guild_commands_get_permissions to get the guild command permissions
|
||
|
* @param guild_id Guild ID to get the slash commands for
|
||
|
* @return slashcommand_map returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
slashcommand_map guild_commands_get_sync(snowflake guild_id);
|
||
|
|
||
|
/**
|
||
|
* @brief Respond to a slash command
|
||
|
*
|
||
|
* @see dpp::cluster::interaction_response_create
|
||
|
* @see https://discord.com/developers/docs/interactions/receiving-and-responding#create-interaction-response
|
||
|
* @param interaction_id Interaction id to respond to
|
||
|
* @param token Token for the interaction webhook
|
||
|
* @param r Response to send
|
||
|
* @return confirmation returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
confirmation interaction_response_create_sync(snowflake interaction_id, const std::string &token, const interaction_response &r);
|
||
|
|
||
|
/**
|
||
|
* @brief Edit response to a slash command
|
||
|
*
|
||
|
* @see dpp::cluster::interaction_response_edit
|
||
|
* @see https://discord.com/developers/docs/interactions/receiving-and-responding#edit-original-interaction-response
|
||
|
* @param token Token for the interaction webhook
|
||
|
* @param m Message to send
|
||
|
* @return confirmation returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
confirmation interaction_response_edit_sync(const std::string &token, const message &m);
|
||
|
|
||
|
/**
|
||
|
* @brief Create a followup message to a slash command
|
||
|
*
|
||
|
* @param token Token for the interaction webhook
|
||
|
* @param m followup message to create
|
||
|
* @return confirmation returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
confirmation interaction_followup_create_sync(const std::string &token, const message &m);
|
||
|
|
||
|
/**
|
||
|
* @brief Edit original followup message to a slash command
|
||
|
* This is an alias for cluster::interaction_response_edit
|
||
|
* @see dpp::cluster::interaction_followup_edit_original
|
||
|
* @see cluster::interaction_response_edit
|
||
|
*
|
||
|
* @param token Token for the interaction webhook
|
||
|
* @param m message to edit, the ID should be set
|
||
|
* @return confirmation returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
confirmation interaction_followup_edit_original_sync(const std::string &token, const message &m);
|
||
|
|
||
|
/**
|
||
|
* @brief
|
||
|
*
|
||
|
* @param token Token for the interaction webhook
|
||
|
* @return confirmation returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
confirmation interaction_followup_delete_sync(const std::string &token);
|
||
|
|
||
|
/**
|
||
|
* @brief Edit followup message to a slash command
|
||
|
* The message ID in the message you pass should be correctly set to that of a followup message you previously sent
|
||
|
* @param token Token for the interaction webhook
|
||
|
* @param m message to edit, the ID should be set
|
||
|
* @return confirmation returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
confirmation interaction_followup_edit_sync(const std::string &token, const message &m);
|
||
|
|
||
|
/**
|
||
|
* @brief Get the followup message to a slash command
|
||
|
* @param token Token for the interaction webhook
|
||
|
* @param message_id message to retrieve
|
||
|
* @return message returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
message interaction_followup_get_sync(const std::string &token, snowflake message_id);
|
||
|
|
||
|
/**
|
||
|
* @brief Get all auto moderation rules for a guild
|
||
|
*
|
||
|
* @param guild_id Guild id of the auto moderation rule
|
||
|
* @return automod_rule_map returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
automod_rule_map automod_rules_get_sync(snowflake guild_id);
|
||
|
|
||
|
/**
|
||
|
* @brief Get a single auto moderation rule
|
||
|
*
|
||
|
* @param guild_id Guild id of the auto moderation rule
|
||
|
* @param rule_id Rule id to retrieve
|
||
|
* @return automod_rule returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
automod_rule automod_rule_get_sync(snowflake guild_id, snowflake rule_id);
|
||
|
|
||
|
/**
|
||
|
* @brief Create an auto moderation rule
|
||
|
*
|
||
|
* @param guild_id Guild id of the auto moderation rule
|
||
|
* @param r Auto moderation rule to create
|
||
|
* @return automod_rule returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
automod_rule automod_rule_create_sync(snowflake guild_id, const automod_rule& r);
|
||
|
|
||
|
/**
|
||
|
* @brief Edit an auto moderation rule
|
||
|
*
|
||
|
* @param guild_id Guild id of the auto moderation rule
|
||
|
* @param r Auto moderation rule to edit. The rule's id must be set.
|
||
|
* @return automod_rule returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
automod_rule automod_rule_edit_sync(snowflake guild_id, const automod_rule& r);
|
||
|
|
||
|
/**
|
||
|
* @brief Delete an auto moderation rule
|
||
|
*
|
||
|
* @param guild_id Guild id of the auto moderation rule
|
||
|
* @param rule_id Auto moderation rule id to delete
|
||
|
* @return confirmation returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
confirmation automod_rule_delete_sync(snowflake guild_id, snowflake rule_id);
|
||
|
|
||
|
/**
|
||
|
* @brief Create a channel
|
||
|
*
|
||
|
* Create a new channel object for the guild. Requires the `MANAGE_CHANNELS` permission. If setting permission overwrites,
|
||
|
* only permissions your bot has in the guild can be allowed/denied. Setting `MANAGE_ROLES` permission in channels is only possible
|
||
|
* for guild administrators. Returns the new channel object on success. Fires a `Channel Create Gateway` event.
|
||
|
*
|
||
|
* All parameters to this endpoint are optional excluding `name`
|
||
|
*
|
||
|
* @note This method supports audit log reasons set by the cluster::set_audit_reason() method.
|
||
|
* @see dpp::cluster::channel_create
|
||
|
* @see https://discord.com/developers/docs/resources/channel#create-channel
|
||
|
* @param c Channel to create
|
||
|
* @return channel returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
channel channel_create_sync(const class channel &c);
|
||
|
|
||
|
/**
|
||
|
* @brief Remove a permission from a channel
|
||
|
* @note This method supports audit log reasons set by the cluster::set_audit_reason() method.
|
||
|
* @see dpp::cluster::channel_delete_permission
|
||
|
* @see https://discord.com/developers/docs/resources/channel#delete-channel-permission
|
||
|
* @param c Channel to remove permission from
|
||
|
* @param overwrite_id Overwrite to remove, user or channel ID
|
||
|
* @return confirmation returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
confirmation channel_delete_permission_sync(const class channel &c, snowflake overwrite_id);
|
||
|
|
||
|
/**
|
||
|
* @brief Delete a channel
|
||
|
* @note This method supports audit log reasons set by the cluster::set_audit_reason() method.
|
||
|
* @see dpp::cluster::channel_delete
|
||
|
* @see https://discord.com/developers/docs/resources/channel#deleteclose-channel
|
||
|
* @param channel_id Channel id to delete
|
||
|
* @return confirmation returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
confirmation channel_delete_sync(snowflake channel_id);
|
||
|
|
||
|
/**
|
||
|
* @brief Edit multiple channels positions
|
||
|
*
|
||
|
* Modify the positions of a set of channel objects for the guild.
|
||
|
* Requires `MANAGE_CHANNELS` permission. Fires multiple `Channel Update Gateway` events.
|
||
|
* Only channels to be modified are required.
|
||
|
*
|
||
|
* @see dpp::cluster::channel_edit_positions
|
||
|
* @see https://discord.com/developers/docs/resources/guild#modify-guild-channel-positions
|
||
|
* @param c Channel to change the position for
|
||
|
* @return confirmation returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
confirmation channel_edit_positions_sync(const std::vector<channel> &c);
|
||
|
|
||
|
/**
|
||
|
* @brief Edit a channel
|
||
|
* @note This method supports audit log reasons set by the cluster::set_audit_reason() method.
|
||
|
* @see dpp::cluster::channel_edit
|
||
|
* @see https://discord.com/developers/docs/resources/channel#modify-channel
|
||
|
* @param c Channel to edit/update
|
||
|
* @return channel returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
channel channel_edit_sync(const class channel &c);
|
||
|
|
||
|
/**
|
||
|
* @brief Follow an announcement (news) channel
|
||
|
* @see dpp::cluster::channel_follow_news
|
||
|
* @see https://discord.com/developers/docs/resources/channel#follow-news-channel
|
||
|
* @param c Channel id to follow
|
||
|
* @param target_channel_id Channel to subscribe the channel to
|
||
|
* @return confirmation returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
confirmation channel_follow_news_sync(const class channel &c, snowflake target_channel_id);
|
||
|
|
||
|
/**
|
||
|
* @brief Get a channel
|
||
|
*
|
||
|
* @see dpp::cluster::channel_get
|
||
|
* @see https://discord.com/developers/docs/resources/channel#get-channel
|
||
|
* @param c Channel ID to retrieve
|
||
|
* @return channel returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
channel channel_get_sync(snowflake c);
|
||
|
|
||
|
/**
|
||
|
* @brief Create invite for a channel
|
||
|
* @note This method supports audit log reasons set by the cluster::set_audit_reason() method.
|
||
|
* @see dpp::cluster::channel_invite_create
|
||
|
* @see https://discord.com/developers/docs/resources/channel#create-channel-invite
|
||
|
* @param c Channel to create an invite on
|
||
|
* @param i Invite to create
|
||
|
* @return confirmation returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
confirmation channel_invite_create_sync(const class channel &c, const class invite &i);
|
||
|
|
||
|
/**
|
||
|
* @brief Get invites for a channel
|
||
|
*
|
||
|
* @see dpp::cluster::channel_invites_get
|
||
|
* @see https://discord.com/developers/docs/resources/invite#get-invites
|
||
|
* @param c Channel to get invites for
|
||
|
* @return invite_map returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
invite_map channel_invites_get_sync(const class channel &c);
|
||
|
|
||
|
/**
|
||
|
* @brief Get all channels for a guild
|
||
|
*
|
||
|
* @see dpp::cluster::channels_get
|
||
|
* @see https://discord.com/developers/docs/resources/channel#get-channels
|
||
|
* @param guild_id Guild ID to retrieve channels for
|
||
|
* @return channel_map returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
channel_map channels_get_sync(snowflake guild_id);
|
||
|
|
||
|
/**
|
||
|
* @brief Create a dm channel
|
||
|
* @see dpp::cluster::create_dm_channel
|
||
|
* @see https://discord.com/developers/docs/resources/user#create-dm
|
||
|
* @param user_id User ID to create DM channel with
|
||
|
* @return channel returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
channel create_dm_channel_sync(snowflake user_id);
|
||
|
|
||
|
/**
|
||
|
* @brief Get current user DM channels
|
||
|
*
|
||
|
* @return channel_map returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
channel_map current_user_get_dms_sync();
|
||
|
|
||
|
/**
|
||
|
* @brief Create a direct message, also create the channel for the direct message if needed
|
||
|
*
|
||
|
* @see dpp::cluster::direct_message_create
|
||
|
* @see https://discord.com/developers/docs/resources/user#create-dm
|
||
|
* @see dpp::cluster::direct_message_create
|
||
|
* @see https://discord.com/developers/docs/resources/channel#create-message
|
||
|
* @param user_id User ID of user to send message to
|
||
|
* @param m Message object
|
||
|
* @return message returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
message direct_message_create_sync(snowflake user_id, const message &m);
|
||
|
|
||
|
/**
|
||
|
* @brief Adds a recipient to a Group DM using their access token
|
||
|
* @see dpp::cluster::gdm_add
|
||
|
* @see https://discord.com/developers/docs/resources/channel#group-dm-add-recipient
|
||
|
* @param channel_id Channel id to add group DM recipients to
|
||
|
* @param user_id User ID to add
|
||
|
* @param access_token Access token from OAuth2
|
||
|
* @param nick Nickname of user to apply to the chat
|
||
|
* @return confirmation returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
confirmation gdm_add_sync(snowflake channel_id, snowflake user_id, const std::string &access_token, const std::string &nick);
|
||
|
|
||
|
/**
|
||
|
* @brief Removes a recipient from a Group DM
|
||
|
* @see dpp::cluster::gdm_remove
|
||
|
* @see https://discord.com/developers/docs/resources/channel#group-dm-remove-recipient
|
||
|
* @param channel_id Channel ID of group DM
|
||
|
* @param user_id User ID to remove from group DM
|
||
|
* @return confirmation returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
confirmation gdm_remove_sync(snowflake channel_id, snowflake user_id);
|
||
|
|
||
|
/**
|
||
|
* @brief Create single emoji.
|
||
|
* You must ensure that the emoji passed contained image data using the emoji::load_image() method.
|
||
|
* @note This method supports audit log reasons set by the cluster::set_audit_reason() method.
|
||
|
*
|
||
|
* @see dpp::cluster::guild_emoji_create
|
||
|
* @see https://discord.com/developers/docs/resources/emoji#create-guild-emoji
|
||
|
* @param guild_id Guild ID to create emoji om
|
||
|
* @param newemoji Emoji to create
|
||
|
* @return emoji returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
emoji guild_emoji_create_sync(snowflake guild_id, const class emoji& newemoji);
|
||
|
|
||
|
/**
|
||
|
* @brief Delete a guild emoji
|
||
|
* @note This method supports audit log reasons set by the cluster::set_audit_reason() method.
|
||
|
*
|
||
|
* @see dpp::cluster::guild_emoji_delete
|
||
|
* @see https://discord.com/developers/docs/resources/emoji#delete-guild-emoji
|
||
|
* @param guild_id Guild ID to delete emoji on
|
||
|
* @param emoji_id Emoji ID to delete
|
||
|
* @return confirmation returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
confirmation guild_emoji_delete_sync(snowflake guild_id, snowflake emoji_id);
|
||
|
|
||
|
/**
|
||
|
* @brief Edit a single emoji.
|
||
|
*
|
||
|
* You must ensure that the emoji passed contained image data using the emoji::load_image() method.
|
||
|
* @see dpp::cluster::guild_emoji_edit
|
||
|
* @see https://discord.com/developers/docs/resources/emoji#get-guild-emoji
|
||
|
* @note This method supports audit log reasons set by the cluster::set_audit_reason() method.
|
||
|
* @param guild_id Guild ID to edit emoji on
|
||
|
* @param newemoji Emoji to edit
|
||
|
* @return emoji returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
emoji guild_emoji_edit_sync(snowflake guild_id, const class emoji& newemoji);
|
||
|
|
||
|
/**
|
||
|
* @brief Get a single emoji
|
||
|
*
|
||
|
* @see dpp::cluster::guild_emoji_get
|
||
|
* @see https://discord.com/developers/docs/resources/emoji#get-guild-emoji
|
||
|
* @param guild_id Guild ID to get emoji for
|
||
|
* @param emoji_id Emoji ID to get
|
||
|
* @return emoji returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
emoji guild_emoji_get_sync(snowflake guild_id, snowflake emoji_id);
|
||
|
|
||
|
/**
|
||
|
* @brief Get all emojis for a guild
|
||
|
*
|
||
|
* @see dpp::cluster::guild_emojis_get
|
||
|
* @see https://discord.com/developers/docs/resources/emoji#get-guild-emojis
|
||
|
* @param guild_id Guild ID to get emojis for
|
||
|
* @return emoji_map returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
emoji_map guild_emojis_get_sync(snowflake guild_id);
|
||
|
|
||
|
/**
|
||
|
* @brief Get the gateway information for the bot using the token
|
||
|
* @see dpp::cluster::get_gateway_bot
|
||
|
* @see https://discord.com/developers/docs/topics/gateway#get-gateway-bot
|
||
|
* @return gateway returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
gateway get_gateway_bot_sync();
|
||
|
|
||
|
/**
|
||
|
* @brief Modify current member
|
||
|
*
|
||
|
* Modifies the current member in a guild.
|
||
|
* Fires a `Guild Member Update` Gateway event.
|
||
|
*
|
||
|
* @note This method supports audit log reasons set by the cluster::set_audit_reason() method.
|
||
|
* @see dpp::cluster::guild_current_member_edit
|
||
|
* @see https://discord.com/developers/docs/resources/guild#modify-current-member
|
||
|
* @param guild_id Guild ID to change on
|
||
|
* @param nickname New nickname, or empty string to clear nickname
|
||
|
* @return confirmation returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
confirmation guild_current_member_edit_sync(snowflake guild_id, const std::string &nickname);
|
||
|
|
||
|
/**
|
||
|
* @brief Get the audit log for a guild
|
||
|
*
|
||
|
* @see dpp::cluster::guild_auditlog_get
|
||
|
* @see https://discord.com/developers/docs/resources/audit-log#get-guild-audit-log
|
||
|
* @param guild_id Guild to get the audit log of
|
||
|
* @param user_id Entries from a specific user ID. Set this to `0` will fetch any user
|
||
|
* @param action_type Entries for a specific dpp::audit_type. Set this to `0` will fetch any type
|
||
|
* @param before Entries with ID less than a specific audit log entry ID. Used for paginating
|
||
|
* @param after Entries with ID greater than a specific audit log entry ID. Used for paginating
|
||
|
* @param limit Maximum number of entries (between 1-100) to return
|
||
|
* @return auditlog returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
auditlog guild_auditlog_get_sync(snowflake guild_id, snowflake user_id, uint32_t action_type, snowflake before, snowflake after, uint32_t limit);
|
||
|
|
||
|
/**
|
||
|
* @brief Add guild ban
|
||
|
*
|
||
|
* Create a guild ban, and optionally delete previous messages sent by the banned user.
|
||
|
* Requires the `BAN_MEMBERS` permission. Fires a `Guild Ban Add` Gateway event.
|
||
|
* @see dpp::cluster::guild_ban_add
|
||
|
* @see https://discord.com/developers/docs/resources/guild#create-guild-ban
|
||
|
* @note This method supports audit log reasons set by the cluster::set_audit_reason() method.
|
||
|
* @param guild_id Guild ID to add ban to
|
||
|
* @param user_id User ID to ban
|
||
|
* @param delete_message_seconds How many seconds to delete messages for, between 0 and 604800 (7 days). Defaults to 0
|
||
|
* @return confirmation returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
confirmation guild_ban_add_sync(snowflake guild_id, snowflake user_id, uint32_t delete_message_seconds = 0);
|
||
|
|
||
|
/**
|
||
|
* @brief Delete guild ban
|
||
|
*
|
||
|
* Remove the ban for a user. Requires the `BAN_MEMBERS` permissions.
|
||
|
* Fires a Guild Ban Remove Gateway event.
|
||
|
* @see dpp::cluster::guild_ban_delete
|
||
|
* @see https://discord.com/developers/docs/resources/guild#remove-guild-ban
|
||
|
* @note This method supports audit log reasons set by the cluster::set_audit_reason() method.
|
||
|
* @param guild_id Guild to delete ban from
|
||
|
* @param user_id User ID to delete ban for
|
||
|
* @return confirmation returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
confirmation guild_ban_delete_sync(snowflake guild_id, snowflake user_id);
|
||
|
|
||
|
/**
|
||
|
* @brief Create a guild
|
||
|
*
|
||
|
* Create a new guild. Returns a guild object on success. `Fires a Guild Create Gateway` event.
|
||
|
*
|
||
|
* When using the roles parameter, the first member of the array is used to change properties of the guild's everyone role.
|
||
|
* If you are trying to bootstrap a guild with additional roles, keep this in mind. The required id field within each role object is an
|
||
|
* integer placeholder, and will be replaced by the API upon consumption. Its purpose is to allow you to overwrite a role's permissions
|
||
|
* in a channel when also passing in channels with the channels array.
|
||
|
* When using the channels parameter, the position field is ignored, and none of the default channels are created. The id field within
|
||
|
* each channel object may be set to an integer placeholder, and will be replaced by the API upon consumption. Its purpose is to
|
||
|
* allow you to create `GUILD_CATEGORY` channels by setting the `parent_id` field on any children to the category's id field.
|
||
|
* Category channels must be listed before any children.
|
||
|
*
|
||
|
* @see dpp::cluster::guild_create
|
||
|
* @see https://discord.com/developers/docs/resources/guild#create-guild
|
||
|
* @note The region field is deprecated and is replaced by channel.rtc_region. This endpoint can be used only by bots in less than 10 guilds.
|
||
|
* @param g Guild to create
|
||
|
* @return guild returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
guild guild_create_sync(const class guild &g);
|
||
|
|
||
|
/**
|
||
|
* @brief Delete a guild
|
||
|
*
|
||
|
* Delete a guild permanently. User must be owner. Fires a `Guild Delete Gateway` event.
|
||
|
*
|
||
|
* @see dpp::cluster::guild_delete
|
||
|
* @see https://discord.com/developers/docs/resources/guild#delete-guild
|
||
|
* @param guild_id Guild ID to delete
|
||
|
* @return confirmation returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
confirmation guild_delete_sync(snowflake guild_id);
|
||
|
|
||
|
/**
|
||
|
* @brief Delete guild integration
|
||
|
*
|
||
|
* Delete the attached integration object for the guild. Deletes any associated webhooks and kicks the associated bot if there is one.
|
||
|
* Requires the `MANAGE_GUILD` permission. Fires a Guild Integrations Update Gateway event.
|
||
|
*
|
||
|
* @see dpp::cluster::guild_delete_integration
|
||
|
* @see https://discord.com/developers/docs/resources/guild#delete-guild-integration
|
||
|
* @note This method supports audit log reasons set by the cluster::set_audit_reason() method.
|
||
|
* @param guild_id Guild ID to delete integration for
|
||
|
* @param integration_id Integration ID to delete
|
||
|
* @return confirmation returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
confirmation guild_delete_integration_sync(snowflake guild_id, snowflake integration_id);
|
||
|
|
||
|
/**
|
||
|
* @brief Edit a guild
|
||
|
*
|
||
|
* Modify a guild's settings. Requires the `MANAGE_GUILD` permission. Returns the updated guild object on success.
|
||
|
* Fires a `Guild Update Gateway` event.
|
||
|
*
|
||
|
* @see dpp::cluster::guild_edit
|
||
|
* @see https://discord.com/developers/docs/resources/guild#modify-guild
|
||
|
* @note This method supports audit log reasons set by the cluster::set_audit_reason() method.
|
||
|
* @param g Guild to edit
|
||
|
* @return guild returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
guild guild_edit_sync(const class guild &g);
|
||
|
|
||
|
/**
|
||
|
* @brief Edit guild widget
|
||
|
*
|
||
|
* Requires the `MANAGE_GUILD` permission.
|
||
|
*
|
||
|
* @see dpp::cluster::guild_edit_widget
|
||
|
* @see https://discord.com/developers/docs/resources/guild#modify-guild-widget
|
||
|
* @note This method supports audit log reasons set by the cluster::set_audit_reason() method.
|
||
|
* @param guild_id Guild ID to edit widget for
|
||
|
* @param gw New guild widget information
|
||
|
* @return guild_widget returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
guild_widget guild_edit_widget_sync(snowflake guild_id, const class guild_widget &gw);
|
||
|
|
||
|
/**
|
||
|
* @brief Get single guild ban
|
||
|
*
|
||
|
* Requires the `BAN_MEMBERS` permission.
|
||
|
* @see dpp::cluster::guild_get_ban
|
||
|
* @see https://discord.com/developers/docs/resources/guild#get-guild-ban
|
||
|
* @param guild_id Guild ID to get ban for
|
||
|
* @param user_id User ID of ban to retrieve
|
||
|
* @return ban returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
ban guild_get_ban_sync(snowflake guild_id, snowflake user_id);
|
||
|
|
||
|
/**
|
||
|
* @brief Get guild ban list
|
||
|
*
|
||
|
* Requires the `BAN_MEMBERS` permission.
|
||
|
* @see dpp::cluster::guild_get_bans
|
||
|
* @see https://discord.com/developers/docs/resources/guild#get-guild-bans
|
||
|
* @note Provide a user ID to `before` and `after` for pagination. Users will always be returned in ascending order by the user ID. If both before and after are provided, only before is respected.
|
||
|
* @param guild_id Guild ID to get bans for
|
||
|
* @param before If non-zero, all bans for user ids before this user id will be returned up to the limit
|
||
|
* @param after if non-zero, all bans for user ids after this user id will be returned up to the limit
|
||
|
* @param limit the maximum number of bans to retrieve in this call up to a maximum of 1000
|
||
|
* @return ban_map returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
ban_map guild_get_bans_sync(snowflake guild_id, snowflake before, snowflake after, snowflake limit);
|
||
|
|
||
|
|
||
|
guild guild_get_sync(snowflake guild_id);
|
||
|
|
||
|
/**
|
||
|
* @brief Get guild integrations
|
||
|
*
|
||
|
* Requires the `MANAGE_GUILD` permission.
|
||
|
*
|
||
|
* @see dpp::cluster::guild_get_integrations
|
||
|
* @see https://discord.com/developers/docs/resources/guild#get-guild-integrations
|
||
|
* @param guild_id Guild ID to get integrations for
|
||
|
* @return integration_map returned object on completion
|
||
|
*
|
||
|
* @note This endpoint returns a maximum of 50 integrations. If a guild has more integrations, they cannot be accessed.
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
integration_map guild_get_integrations_sync(snowflake guild_id);
|
||
|
|
||
|
|
||
|
guild guild_get_preview_sync(snowflake guild_id);
|
||
|
|
||
|
/**
|
||
|
* @brief Get guild vanity url, if enabled
|
||
|
*
|
||
|
* Returns a partial dpp::invite object for guilds with that feature enabled. Requires the `MANAGE_GUILD` permission. code will be null if a vanity url for the guild is not set.
|
||
|
* @see dpp::cluster::guild_get_vanity
|
||
|
* @see https://discord.com/developers/docs/resources/guild#get-guild-vanity-url
|
||
|
* @param guild_id Guild to get vanity URL for
|
||
|
* @return invite returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
invite guild_get_vanity_sync(snowflake guild_id);
|
||
|
|
||
|
/**
|
||
|
* @brief Get guild widget
|
||
|
*
|
||
|
* Requires the `MANAGE_GUILD` permission.
|
||
|
*
|
||
|
* @see dpp::cluster::guild_get_widget
|
||
|
* @see https://discord.com/developers/docs/resources/guild#get-guild-widget
|
||
|
* @param guild_id Guild ID to get widget for
|
||
|
* @return guild_widget returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
guild_widget guild_get_widget_sync(snowflake guild_id);
|
||
|
|
||
|
/**
|
||
|
* @brief Modify guild integration
|
||
|
* @note This method supports audit log reasons set by the cluster::set_audit_reason() method.
|
||
|
*
|
||
|
* @see dpp::cluster::guild_modify_integration
|
||
|
* @see https://discord.com/developers/docs/resources/guild#modify-guild-integration
|
||
|
* @param guild_id Guild ID to modify integration for
|
||
|
* @param i Integration to modify
|
||
|
* @return confirmation returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
confirmation guild_modify_integration_sync(snowflake guild_id, const class integration &i);
|
||
|
|
||
|
/**
|
||
|
* @brief Get prune counts
|
||
|
*
|
||
|
* Returns a prune object indicating the number of members that would be removed in a prune operation. Requires the `KICK_MEMBERS`
|
||
|
* permission. By default, prune will not remove users with roles. You can optionally include specific roles in your prune by providing the
|
||
|
* include_roles parameter. Any inactive user that has a subset of the provided role(s) will be counted in the prune and users with additional
|
||
|
* roles will not.
|
||
|
*
|
||
|
* @see dpp::cluster::guild_get_prune_counts
|
||
|
* @see https://discord.com/developers/docs/resources/guild#get-guild-prune-count
|
||
|
* @param guild_id Guild ID to count for pruning
|
||
|
* @param pruneinfo Pruning info
|
||
|
* @return prune returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
prune guild_get_prune_counts_sync(snowflake guild_id, const struct prune& pruneinfo);
|
||
|
|
||
|
/**
|
||
|
* @brief Begin guild prune
|
||
|
*
|
||
|
* Begin a prune operation. Requires the `KICK_MEMBERS` permission. Returns a prune object indicating the number of members
|
||
|
* that were removed in the prune operation. For large guilds it's recommended to set the `compute_prune_count` option to false, forcing
|
||
|
* 'pruned' to 0. Fires multiple `Guild Member Remove` Gateway events.
|
||
|
* By default, prune will not remove users with roles. You can optionally include specific roles in your prune by providing the `include_roles`
|
||
|
* parameter. Any inactive user that has a subset of the provided role(s) will be included in the prune and users with additional roles will not.
|
||
|
*
|
||
|
* @see dpp::cluster::guild_begin_prune
|
||
|
* @see https://discord.com/developers/docs/resources/guild#begin-guild-prune
|
||
|
* @note This method supports audit log reasons set by the cluster::set_audit_reason() method.
|
||
|
* @param guild_id Guild ID to prune
|
||
|
* @param pruneinfo Pruning info
|
||
|
* @return prune returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
prune guild_begin_prune_sync(snowflake guild_id, const struct prune& pruneinfo);
|
||
|
|
||
|
/**
|
||
|
* @brief Change current user nickname
|
||
|
*
|
||
|
* Modifies the nickname of the current user in a guild.
|
||
|
* Fires a `Guild Member Update` Gateway event.
|
||
|
*
|
||
|
* @deprecated Deprecated in favor of Modify Current Member. Will be replaced by dpp::cluster::guild_current_member_edit
|
||
|
* @note This method supports audit log reasons set by the cluster::set_audit_reason() method.
|
||
|
* @see dpp::cluster::guild_set_nickname
|
||
|
* @see https://discord.com/developers/docs/resources/guild#modify-current-user-nick
|
||
|
* @param guild_id Guild ID to change nickname on
|
||
|
* @param nickname New nickname, or empty string to clear nickname
|
||
|
* @return confirmation returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
confirmation guild_set_nickname_sync(snowflake guild_id, const std::string &nickname);
|
||
|
|
||
|
/**
|
||
|
* @brief Sync guild integration
|
||
|
*
|
||
|
* @see dpp::cluster::guild_sync_integration
|
||
|
* @see https://discord.com/developers/docs/resources/guild#sync-guild-integration
|
||
|
* @param guild_id Guild ID to sync integration on
|
||
|
* @param integration_id Integration ID to synchronise
|
||
|
* @return confirmation returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
confirmation guild_sync_integration_sync(snowflake guild_id, snowflake integration_id);
|
||
|
|
||
|
/**
|
||
|
* @brief Add guild member. Needs a specific oauth2 scope, from which you get the access_token.
|
||
|
*
|
||
|
* Adds a user to the guild, provided you have a valid oauth2 access token for the user with the guilds.join scope.
|
||
|
* Returns the guild_member, which is defaulted if the user is already a member of the guild. Fires a `Guild Member Add` Gateway event.
|
||
|
*
|
||
|
* For guilds with Membership Screening enabled, this endpoint will default to adding new members as pending in the guild member object.
|
||
|
* Members that are pending will have to complete membership screening before they become full members that can talk.
|
||
|
*
|
||
|
* @note All parameters to this endpoint except for access_token are optional.
|
||
|
* The bot must be a member of the guild with `CREATE_INSTANT_INVITE` permission.
|
||
|
* @see dpp::cluster::guild_add_member
|
||
|
* @see https://discord.com/developers/docs/resources/guild#add-guild-member
|
||
|
* @param gm Guild member to add
|
||
|
* @param access_token Access token from Oauth2 scope
|
||
|
* @return confirmation returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
confirmation guild_add_member_sync(const guild_member& gm, const std::string &access_token);
|
||
|
|
||
|
/**
|
||
|
* @brief Edit the properties of an existing guild member
|
||
|
*
|
||
|
* Modify attributes of a guild member. Returns the guild_member. Fires a `Guild Member Update` Gateway event.
|
||
|
* To remove a timeout, set the `communication_disabled_until` to a non-zero time in the past, e.g. 1.
|
||
|
* When moving members to channels, the API user must have permissions to both connect to the channel and have the `MOVE_MEMBERS` permission.
|
||
|
* For moving and disconnecting users from voice, use dpp::cluster::guild_member_move.
|
||
|
* @see dpp::cluster::guild_edit_member
|
||
|
* @see https://discord.com/developers/docs/resources/guild#modify-guild-member
|
||
|
* @note This method supports audit log reasons set by the cluster::set_audit_reason() method.
|
||
|
* @param gm Guild member to edit
|
||
|
* @return guild_member returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
guild_member guild_edit_member_sync(const guild_member& gm);
|
||
|
|
||
|
/**
|
||
|
* @brief Get a guild member
|
||
|
* @see dpp::cluster::guild_get_member
|
||
|
* @see https://discord.com/developers/docs/resources/guild#get-guild-member
|
||
|
* @param guild_id Guild ID to get member for
|
||
|
* @param user_id User ID of member to get
|
||
|
* @return guild_member returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
guild_member guild_get_member_sync(snowflake guild_id, snowflake user_id);
|
||
|
|
||
|
/**
|
||
|
* @brief Get all guild members
|
||
|
*
|
||
|
* @note This endpoint is restricted according to whether the `GUILD_MEMBERS` Privileged Intent is enabled for your application.
|
||
|
* @see dpp::cluster::guild_get_members
|
||
|
* @see https://discord.com/developers/docs/resources/guild#get-guild-members
|
||
|
* @param guild_id Guild ID to get all members for
|
||
|
* @param limit max number of members to return (1-1000)
|
||
|
* @param after the highest user id in the previous page
|
||
|
* @return guild_member_map returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
guild_member_map guild_get_members_sync(snowflake guild_id, uint16_t limit, snowflake after);
|
||
|
|
||
|
/**
|
||
|
* @brief Add role to guild member
|
||
|
*
|
||
|
* Adds a role to a guild member. Requires the `MANAGE_ROLES` permission.
|
||
|
* Fires a `Guild Member Update` Gateway event.
|
||
|
* @see dpp::cluster::guild_member_add_role
|
||
|
* @see https://discord.com/developers/docs/resources/guild#add-guild-member-role
|
||
|
* @note This method supports audit log reasons set by the cluster::set_audit_reason() method.
|
||
|
* @param guild_id Guild ID to add a role to
|
||
|
* @param user_id User ID to add role to
|
||
|
* @param role_id Role ID to add to the user
|
||
|
* @return confirmation returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
confirmation guild_member_add_role_sync(snowflake guild_id, snowflake user_id, snowflake role_id);
|
||
|
|
||
|
/**
|
||
|
* @brief Remove (kick) a guild member
|
||
|
*
|
||
|
* Remove a member from a guild. Requires `KICK_MEMBERS` permission.
|
||
|
* Fires a `Guild Member Remove` Gateway event.
|
||
|
* @see dpp::cluster::guild_member_delete
|
||
|
* @see https://discord.com/developers/docs/resources/guild#remove-guild-member
|
||
|
* @note This method supports audit log reasons set by the cluster::set_audit_reason() method.
|
||
|
* @deprecated Replaced by dpp::cluster::guild_member_kick
|
||
|
* @param guild_id Guild ID to kick member from
|
||
|
* @param user_id User ID to kick
|
||
|
* @return confirmation returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
confirmation guild_member_delete_sync(snowflake guild_id, snowflake user_id);
|
||
|
|
||
|
/**
|
||
|
* @brief Remove (kick) a guild member
|
||
|
*
|
||
|
* Remove a member from a guild. Requires `KICK_MEMBERS` permission.
|
||
|
* Fires a `Guild Member Remove` Gateway event.
|
||
|
* @see dpp::cluster::guild_member_kick
|
||
|
* @see https://discord.com/developers/docs/resources/guild#remove-guild-member
|
||
|
* @note This method supports audit log reasons set by the cluster::set_audit_reason() method.
|
||
|
* @param guild_id Guild ID to kick member from
|
||
|
* @param user_id User ID to kick
|
||
|
* @return confirmation returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
confirmation guild_member_kick_sync(snowflake guild_id, snowflake user_id);
|
||
|
|
||
|
/**
|
||
|
* @brief Set the timeout of a guild member
|
||
|
*
|
||
|
* Fires a `Guild Member Update` Gateway event.
|
||
|
* @see dpp::cluster::guild_member_timeout
|
||
|
* @see https://discord.com/developers/docs/resources/guild#modify-guild-member
|
||
|
* @note This method supports audit log reasons set by the cluster::set_audit_reason() method.
|
||
|
* @param guild_id Guild ID to timeout the member in
|
||
|
* @param user_id User ID to set the timeout for
|
||
|
* @param communication_disabled_until The timestamp when the user's timeout will expire (up to 28 days in the future). Set to 0 to remove the timeout
|
||
|
* @return confirmation returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
confirmation guild_member_timeout_sync(snowflake guild_id, snowflake user_id, time_t communication_disabled_until);
|
||
|
|
||
|
/**
|
||
|
* @brief Remove role from guild member
|
||
|
*
|
||
|
* Removes a role from a guild member. Requires the `MANAGE_ROLES` permission.
|
||
|
* Fires a `Guild Member Update` Gateway event.
|
||
|
* @see dpp::cluster::guild_member_delete_role
|
||
|
* @see https://discord.com/developers/docs/resources/guild#remove-guild-member-role
|
||
|
* @note This method supports audit log reasons set by the cluster::set_audit_reason() method.
|
||
|
* @param guild_id Guild ID to remove role from user on
|
||
|
* @param user_id User ID to remove role from
|
||
|
* @param role_id Role to remove
|
||
|
* @return confirmation returned object on completion
|
||
|
* @deprecated Use dpp::cluster::guild_member_remove_role instead
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
confirmation guild_member_delete_role_sync(snowflake guild_id, snowflake user_id, snowflake role_id);
|
||
|
|
||
|
/**
|
||
|
* @brief Remove role from guild member
|
||
|
*
|
||
|
* Removes a role from a guild member. Requires the `MANAGE_ROLES` permission.
|
||
|
* Fires a `Guild Member Update` Gateway event.
|
||
|
* @see dpp::cluster::guild_member_remove_role
|
||
|
* @see https://discord.com/developers/docs/resources/guild#remove-guild-member-role
|
||
|
* @note This method supports audit log reasons set by the cluster::set_audit_reason() method.
|
||
|
* @param guild_id Guild ID to remove role from user on
|
||
|
* @param user_id User ID to remove role from
|
||
|
* @param role_id Role to remove
|
||
|
* @return confirmation returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
confirmation guild_member_remove_role_sync(snowflake guild_id, snowflake user_id, snowflake role_id);
|
||
|
|
||
|
/**
|
||
|
* @brief Moves the guild member to a other voice channel, if member is connected to one.
|
||
|
* Set the `channel_id` to `0` to disconnect the user.
|
||
|
*
|
||
|
* Fires a `Guild Member Update` Gateway event.
|
||
|
* @note When moving members to channels, the API user __must__ have permissions to both connect to the channel and have the `MOVE_MEMBERS` permission.
|
||
|
* @note This method supports audit log reasons set by the cluster::set_audit_reason() method.
|
||
|
* @see dpp::cluster::guild_member_move
|
||
|
* @see https://discord.com/developers/docs/resources/guild#modify-guild-member
|
||
|
* @param channel_id Id of the channel to which the user is used. Set to `0` to disconnect the user
|
||
|
* @param guild_id Guild id to which the user is connected
|
||
|
* @param user_id User id, who should be moved
|
||
|
* @return guild_member returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
guild_member guild_member_move_sync(const snowflake channel_id, const snowflake guild_id, const snowflake user_id);
|
||
|
|
||
|
/**
|
||
|
* @brief Search for guild members based on whether their username or nickname starts with the given string.
|
||
|
*
|
||
|
* @note This endpoint is restricted according to whether the `GUILD_MEMBERS` Privileged Intent is enabled for your application.
|
||
|
* @see dpp::cluster::guild_search_members
|
||
|
* @see https://discord.com/developers/docs/resources/guild#search-guild-members
|
||
|
* @param guild_id Guild ID to search in
|
||
|
* @param query Query string to match username(s) and nickname(s) against
|
||
|
* @param limit max number of members to return (1-1000)
|
||
|
* @return guild_member_map returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
guild_member_map guild_search_members_sync(snowflake guild_id, const std::string& query, uint16_t limit);
|
||
|
|
||
|
/**
|
||
|
* @brief Get guild invites
|
||
|
*
|
||
|
* Returns a list of invite objects (with invite metadata) for the guild. Requires the `MANAGE_GUILD` permission.
|
||
|
*
|
||
|
* @see dpp::cluster::guild_get_invites
|
||
|
* @see https://discord.com/developers/docs/resources/guild#get-guild-invites
|
||
|
* @param guild_id Guild ID to get invites for
|
||
|
* @return invite_map returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
invite_map guild_get_invites_sync(snowflake guild_id);
|
||
|
|
||
|
|
||
|
invite invite_delete_sync(const std::string &invitecode);
|
||
|
|
||
|
|
||
|
invite invite_get_sync(const std::string &invitecode);
|
||
|
|
||
|
/**
|
||
|
* @brief Send a message to a channel. The callback function is called when the message has been sent
|
||
|
*
|
||
|
* @see dpp::cluster::message_create
|
||
|
* @see https://discord.com/developers/docs/resources/channel#create-message
|
||
|
* @param m Message to send
|
||
|
* @return message returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
message message_create_sync(const struct message &m);
|
||
|
|
||
|
/**
|
||
|
* @brief Crosspost a message. The callback function is called when the message has been sent
|
||
|
*
|
||
|
* @see dpp::cluster::message_crosspost
|
||
|
* @see https://discord.com/developers/docs/resources/channel#crosspost-message
|
||
|
* @param message_id Message to crosspost
|
||
|
* @param channel_id Channel ID to crosspost from
|
||
|
* @return message returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
message message_crosspost_sync(snowflake message_id, snowflake channel_id);
|
||
|
|
||
|
/**
|
||
|
* @brief Bulk delete messages from a channel. The callback function is called when the message has been edited
|
||
|
* @note This method supports audit log reasons set by the cluster::set_audit_reason() method.
|
||
|
*
|
||
|
* @note If any message provided older than 2 weeks or any duplicate message ID, it will fail.
|
||
|
*
|
||
|
* @see dpp::cluster::message_delete_bulk
|
||
|
* @see https://discord.com/developers/docs/resources/channel#bulk-delete-messages
|
||
|
* @param message_ids List of message IDs to delete (at least 2 and at most 100 message IDs)
|
||
|
* @param channel_id Channel to delete from
|
||
|
* @return confirmation returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
confirmation message_delete_bulk_sync(const std::vector<snowflake> &message_ids, snowflake channel_id);
|
||
|
|
||
|
/**
|
||
|
* @brief Delete a message from a channel. The callback function is called when the message has been edited
|
||
|
* @note This method supports audit log reasons set by the cluster::set_audit_reason() method.
|
||
|
*
|
||
|
* @see dpp::cluster::message_delete
|
||
|
* @see https://discord.com/developers/docs/resources/channel#delete-message
|
||
|
* @param message_id Message ID to delete
|
||
|
* @param channel_id Channel to delete from
|
||
|
* @return confirmation returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
confirmation message_delete_sync(snowflake message_id, snowflake channel_id);
|
||
|
|
||
|
/**
|
||
|
* @brief Edit a message on a channel. The callback function is called when the message has been edited
|
||
|
*
|
||
|
* @see dpp::cluster::message_edit
|
||
|
* @see https://discord.com/developers/docs/resources/channel#edit-message
|
||
|
* @param m Message to edit
|
||
|
* @return message returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
message message_edit_sync(const struct message &m);
|
||
|
|
||
|
/**
|
||
|
* @brief Get a message
|
||
|
*
|
||
|
* @see dpp::cluster::message_get
|
||
|
* @see https://discord.com/developers/docs/resources/channel#get-channel-message
|
||
|
* @param message_id Message ID
|
||
|
* @param channel_id Channel ID
|
||
|
* @return message returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
message message_get_sync(snowflake message_id, snowflake channel_id);
|
||
|
|
||
|
/**
|
||
|
* @brief Pin a message
|
||
|
* @note This method supports audit log reasons set by the cluster::set_audit_reason() method.
|
||
|
* @see dpp::cluster::message_pin
|
||
|
* @see https://discord.com/developers/docs/resources/channel#pin-message
|
||
|
* @param channel_id Channel id to pin message on
|
||
|
* @param message_id Message id to pin message on
|
||
|
* @return confirmation returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
confirmation message_pin_sync(snowflake channel_id, snowflake message_id);
|
||
|
|
||
|
/**
|
||
|
* @brief Get multiple messages.
|
||
|
*
|
||
|
* This function will attempt to fetch as many messages as possible using multiple API calls if needed.
|
||
|
*
|
||
|
* @see dpp::cluster::messages_get
|
||
|
* @see https://discord.com/developers/docs/resources/channel#get-channel-messages
|
||
|
* @param channel_id Channel ID to retrieve messages for
|
||
|
* @param around Messages should be retrieved around this ID if this is set to non-zero
|
||
|
* @param before Messages before this ID should be retrieved if this is set to non-zero
|
||
|
* @param after Messages after this ID should be retrieved if this is set to non-zero
|
||
|
* @param limit This number of messages maximum should be returned, up to a maximum of 100.
|
||
|
* @return message_map returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
message_map messages_get_sync(snowflake channel_id, snowflake around, snowflake before, snowflake after, uint64_t limit);
|
||
|
|
||
|
/**
|
||
|
* @brief Unpin a message
|
||
|
* @see dpp::cluster::message_unpin
|
||
|
* @see https://discord.com/developers/docs/resources/channel#unpin-message
|
||
|
* @note This method supports audit log reasons set by the cluster::set_audit_reason() method.
|
||
|
* @param channel_id Channel id to unpin message on
|
||
|
* @param message_id Message id to unpin message on
|
||
|
* @return confirmation returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
confirmation message_unpin_sync(snowflake channel_id, snowflake message_id);
|
||
|
|
||
|
/**
|
||
|
* @brief Get a channel's pins
|
||
|
* @see dpp::cluster::channel_pins_get
|
||
|
* @see https://discord.com/developers/docs/resources/channel#get-pinned-messages
|
||
|
* @param channel_id Channel ID to get pins for
|
||
|
* @return message_map returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
message_map channel_pins_get_sync(snowflake channel_id);
|
||
|
|
||
|
/**
|
||
|
* @brief Create a role on a guild
|
||
|
*
|
||
|
* Create a new role for the guild. Requires the `MANAGE_ROLES` permission. Returns the new role object on success.
|
||
|
* Fires a `Guild Role Create` Gateway event.
|
||
|
*
|
||
|
* @see dpp::cluster::role_create
|
||
|
* @see https://discord.com/developers/docs/resources/guild#create-guild-role
|
||
|
* @note This method supports audit log reasons set by the cluster::set_audit_reason() method.
|
||
|
* @param r Role to create (guild ID is encapsulated in the role object)
|
||
|
* @return role returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
role role_create_sync(const class role &r);
|
||
|
|
||
|
/**
|
||
|
* @brief Delete a role
|
||
|
*
|
||
|
* Requires the `MANAGE_ROLES` permission. Fires a `Guild Role Delete` Gateway event.
|
||
|
*
|
||
|
* @see dpp::cluster::role_delete
|
||
|
* @see https://discord.com/developers/docs/resources/guild#delete-guild-role
|
||
|
* @note This method supports audit log reasons set by the cluster::set_audit_reason() method.
|
||
|
* @param guild_id Guild ID to delete the role on
|
||
|
* @param role_id Role ID to delete
|
||
|
* @return confirmation returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
confirmation role_delete_sync(snowflake guild_id, snowflake role_id);
|
||
|
|
||
|
/**
|
||
|
* @brief Edit a role on a guild
|
||
|
*
|
||
|
* Requires the `MANAGE_ROLES` permission. Returns the updated role on success. Fires a `Guild Role Update` Gateway event.
|
||
|
*
|
||
|
* @see dpp::cluster::role_edit
|
||
|
* @see https://discord.com/developers/docs/resources/guild#modify-guild-role
|
||
|
* @note This method supports audit log reasons set by the cluster::set_audit_reason() method.
|
||
|
* @param r Role to edit
|
||
|
* @return role returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
role role_edit_sync(const class role &r);
|
||
|
|
||
|
/**
|
||
|
* @brief Edit multiple role's position in a guild. Returns a list of all roles of the guild on success.
|
||
|
*
|
||
|
* Modify the positions of a set of role objects for the guild. Requires the `MANAGE_ROLES` permission.
|
||
|
* Fires multiple `Guild Role Update` Gateway events.
|
||
|
*
|
||
|
* @see dpp::cluster::roles_edit_position
|
||
|
* @see https://discord.com/developers/docs/resources/guild#modify-guild-role-positions
|
||
|
* @note This method supports audit log reasons set by the cluster::set_audit_reason() method.
|
||
|
* @param guild_id Guild ID to change the roles position on
|
||
|
* @param roles Vector of roles to change the positions of
|
||
|
* @return role_map returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
role_map roles_edit_position_sync(snowflake guild_id, const std::vector<role> &roles);
|
||
|
|
||
|
/**
|
||
|
* @brief Get a role for a guild
|
||
|
*
|
||
|
* @see dpp::cluster::roles_get
|
||
|
* @see https://discord.com/developers/docs/resources/guild#get-guild-roles
|
||
|
* @param guild_id Guild ID to get role for
|
||
|
* @return role_map returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
role_map roles_get_sync(snowflake guild_id);
|
||
|
|
||
|
/**
|
||
|
* @brief Get user application role connection
|
||
|
*
|
||
|
* @see dpp::cluster::user_application_role_connection_get
|
||
|
* @see https://discord.com/developers/docs/resources/user#get-user-application-role-connection
|
||
|
* @param application_id The application ID
|
||
|
* @return application_role_connection returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
application_role_connection user_application_role_connection_get_sync(snowflake application_id);
|
||
|
|
||
|
/**
|
||
|
* @brief Update user application role connection
|
||
|
*
|
||
|
* @see dpp::cluster::user_application_role_connection_update
|
||
|
* @see https://discord.com/developers/docs/resources/user#update-user-application-role-connection
|
||
|
* @param application_id The application ID
|
||
|
* @param connection The application role connection to update
|
||
|
* @return application_role_connection returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
application_role_connection user_application_role_connection_update_sync(snowflake application_id, const application_role_connection &connection);
|
||
|
|
||
|
/**
|
||
|
* @brief Get all scheduled events for a guild
|
||
|
* @see dpp::cluster::guild_events_get
|
||
|
* @see https://discord.com/developers/docs/resources/guild-scheduled-event#list-scheduled-events-for-guild
|
||
|
* @param guild_id Guild to get events for
|
||
|
* @return scheduled_event_map returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
scheduled_event_map guild_events_get_sync(snowflake guild_id);
|
||
|
|
||
|
/**
|
||
|
* @brief Create a scheduled event on a guild
|
||
|
*
|
||
|
* @see dpp::cluster::guild_event_create
|
||
|
* @see https://discord.com/developers/docs/resources/guild-scheduled-event#create-guild-scheduled-event
|
||
|
* @param event Event to create (guild ID must be populated)
|
||
|
* @return scheduled_event returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
scheduled_event guild_event_create_sync(const scheduled_event& event);
|
||
|
|
||
|
/**
|
||
|
* @brief Delete a scheduled event from a guild
|
||
|
*
|
||
|
* @see dpp::cluster::guild_event_delete
|
||
|
* @see https://discord.com/developers/docs/resources/guild-scheduled-event#delete-guild-scheduled-event
|
||
|
* @param event_id Event ID to delete
|
||
|
* @param guild_id Guild ID of event to delete
|
||
|
* @return confirmation returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
confirmation guild_event_delete_sync(snowflake event_id, snowflake guild_id);
|
||
|
|
||
|
/**
|
||
|
* @brief Edit/modify a scheduled event on a guild
|
||
|
*
|
||
|
* @see dpp::cluster::guild_event_edit
|
||
|
* @see https://discord.com/developers/docs/resources/guild-scheduled-event#modify-guild-scheduled-event
|
||
|
* @param event Event to create (event ID and guild ID must be populated)
|
||
|
* @return scheduled_event returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
scheduled_event guild_event_edit_sync(const scheduled_event& event);
|
||
|
|
||
|
/**
|
||
|
* @brief Get a scheduled event for a guild
|
||
|
*
|
||
|
* @see dpp::cluster::guild_event_get
|
||
|
* @see https://discord.com/developers/docs/resources/guild-scheduled-event#get-guild-scheduled-event
|
||
|
* @param guild_id Guild to get event for
|
||
|
* @param event_id Event ID to get
|
||
|
* @return scheduled_event returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
scheduled_event guild_event_get_sync(snowflake guild_id, snowflake event_id);
|
||
|
|
||
|
|
||
|
stage_instance stage_instance_create_sync(const stage_instance& si);
|
||
|
|
||
|
/**
|
||
|
* @brief Get the stage instance associated with the channel id, if it exists.
|
||
|
* @see dpp::cluster::stage_instance_get
|
||
|
* @see https://discord.com/developers/docs/resources/stage-instance#get-stage-instance
|
||
|
* @param channel_id ID of the associated channel
|
||
|
* @return stage_instance returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
stage_instance stage_instance_get_sync(const snowflake channel_id);
|
||
|
|
||
|
|
||
|
stage_instance stage_instance_edit_sync(const stage_instance& si);
|
||
|
|
||
|
/**
|
||
|
* @brief Delete a stage instance.
|
||
|
* @see dpp::cluster::stage_instance_delete
|
||
|
* @see https://discord.com/developers/docs/resources/stage-instance#delete-stage-instance
|
||
|
* @param channel_id ID of the associated channel
|
||
|
* @return confirmation returned object on completion
|
||
|
* @note This method supports audit log reasons set by the cluster::set_audit_reason() method.
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
confirmation stage_instance_delete_sync(const snowflake channel_id);
|
||
|
|
||
|
/**
|
||
|
* @brief Create a sticker in a guild
|
||
|
* @note This method supports audit log reasons set by the cluster::set_audit_reason() method.
|
||
|
* @see dpp::cluster::guild_sticker_create
|
||
|
* @see https://discord.com/developers/docs/resources/sticker#create-guild-sticker
|
||
|
* @param s Sticker to create. Must have its guild ID set.
|
||
|
* @return sticker returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
sticker guild_sticker_create_sync(sticker &s);
|
||
|
|
||
|
/**
|
||
|
* @brief Delete a sticker from a guild
|
||
|
* @note This method supports audit log reasons set by the cluster::set_audit_reason() method.
|
||
|
* @see dpp::cluster::guild_sticker_delete
|
||
|
* @see https://discord.com/developers/docs/resources/sticker#delete-guild-sticker
|
||
|
* @param sticker_id sticker ID to delete
|
||
|
* @param guild_id guild ID to delete from
|
||
|
* @return confirmation returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
confirmation guild_sticker_delete_sync(snowflake sticker_id, snowflake guild_id);
|
||
|
|
||
|
/**
|
||
|
* @brief Get a guild sticker
|
||
|
* @see dpp::cluster::guild_sticker_get
|
||
|
* @see https://discord.com/developers/docs/resources/sticker#get-guild-sticker
|
||
|
* @param id Id of sticker to get.
|
||
|
* @param guild_id Guild ID of the guild where the sticker is
|
||
|
* @return sticker returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
sticker guild_sticker_get_sync(snowflake id, snowflake guild_id);
|
||
|
|
||
|
/**
|
||
|
* @brief Modify a sticker in a guild
|
||
|
* @note This method supports audit log reasons set by the cluster::set_audit_reason() method.
|
||
|
* @see dpp::cluster::guild_sticker_modify
|
||
|
* @see https://discord.com/developers/docs/resources/sticker#modify-guild-sticker
|
||
|
* @param s Sticker to modify. Must have its guild ID and sticker ID set.
|
||
|
* @return sticker returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
sticker guild_sticker_modify_sync(sticker &s);
|
||
|
|
||
|
/**
|
||
|
* @brief Get all guild stickers
|
||
|
* @see dpp::cluster::guild_stickers_get
|
||
|
* @see https://discord.com/developers/docs/resources/sticker#get-guild-stickers
|
||
|
* @param guild_id Guild ID of the guild where the sticker is
|
||
|
* @return sticker_map returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
sticker_map guild_stickers_get_sync(snowflake guild_id);
|
||
|
|
||
|
/**
|
||
|
* @brief Get a nitro sticker
|
||
|
* @see dpp::cluster::nitro_sticker_get
|
||
|
* @see https://discord.com/developers/docs/resources/sticker#get-sticker
|
||
|
* @param id Id of sticker to get.
|
||
|
* @return sticker returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
sticker nitro_sticker_get_sync(snowflake id);
|
||
|
|
||
|
/**
|
||
|
* @brief Get sticker packs
|
||
|
* @see dpp::cluster::sticker_packs_get
|
||
|
* @see https://discord.com/developers/docs/resources/sticker#list-nitro-sticker-packs
|
||
|
* @return sticker_pack_map returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
sticker_pack_map sticker_packs_get_sync();
|
||
|
|
||
|
/**
|
||
|
* @brief Create a new guild based on a template.
|
||
|
* @note This endpoint can be used only by bots in less than 10 guilds.
|
||
|
* @see dpp::cluster::guild_create_from_template
|
||
|
* @see https://discord.com/developers/docs/resources/guild-template#create-guild-from-guild-template
|
||
|
* @param code Template code to create guild from
|
||
|
* @param name Guild name to create
|
||
|
* @return guild returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
guild guild_create_from_template_sync(const std::string &code, const std::string &name);
|
||
|
|
||
|
/**
|
||
|
* @brief Creates a template for the guild
|
||
|
*
|
||
|
* @see dpp::cluster::guild_template_create
|
||
|
* @see https://discord.com/developers/docs/resources/guild-template#create-guild-template
|
||
|
* @param guild_id Guild to create template from
|
||
|
* @param name Template name to create
|
||
|
* @param description Description of template to create
|
||
|
* @return dtemplate returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
dtemplate guild_template_create_sync(snowflake guild_id, const std::string &name, const std::string &description);
|
||
|
|
||
|
/**
|
||
|
* @brief Deletes the template
|
||
|
*
|
||
|
* @see dpp::cluster::guild_template_delete
|
||
|
* @see https://discord.com/developers/docs/resources/guild-template#delete-guild-template
|
||
|
* @param guild_id Guild ID of template to delete
|
||
|
* @param code Template code to delete
|
||
|
* @return confirmation returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
confirmation guild_template_delete_sync(snowflake guild_id, const std::string &code);
|
||
|
|
||
|
/**
|
||
|
* @brief Modifies the template's metadata.
|
||
|
*
|
||
|
* @see dpp::cluster::guild_template_modify
|
||
|
* @see https://discord.com/developers/docs/resources/guild-template#modify-guild-template
|
||
|
* @param guild_id Guild ID of template to modify
|
||
|
* @param code Template code to modify
|
||
|
* @param name New name of template
|
||
|
* @param description New description of template
|
||
|
* @return dtemplate returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
dtemplate guild_template_modify_sync(snowflake guild_id, const std::string &code, const std::string &name, const std::string &description);
|
||
|
|
||
|
/**
|
||
|
* @brief Get guild templates
|
||
|
*
|
||
|
* @see dpp::cluster::guild_templates_get
|
||
|
* @see https://discord.com/developers/docs/resources/guild-template#get-guild-templates
|
||
|
* @param guild_id Guild ID to get templates for
|
||
|
* @return dtemplate_map returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
dtemplate_map guild_templates_get_sync(snowflake guild_id);
|
||
|
|
||
|
/**
|
||
|
* @brief Syncs the template to the guild's current state.
|
||
|
*
|
||
|
* @see dpp::cluster::guild_template_sync
|
||
|
* @see https://discord.com/developers/docs/resources/guild-template#sync-guild-template
|
||
|
* @param guild_id Guild to synchronise template for
|
||
|
* @param code Code of template to synchronise
|
||
|
* @return dtemplate returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
dtemplate guild_template_sync_sync(snowflake guild_id, const std::string &code);
|
||
|
|
||
|
/**
|
||
|
* @brief Get a template
|
||
|
* @see dpp::cluster::template_get
|
||
|
* @see https://discord.com/developers/docs/resources/guild-template#get-guild-template
|
||
|
* @param code Template code
|
||
|
* @return dtemplate returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
dtemplate template_get_sync(const std::string &code);
|
||
|
|
||
|
/**
|
||
|
* @brief Join a thread
|
||
|
* @see dpp::cluster::current_user_join_thread
|
||
|
* @see https://discord.com/developers/docs/topics/threads
|
||
|
* @param thread_id Thread ID to join
|
||
|
* @return confirmation returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
confirmation current_user_join_thread_sync(snowflake thread_id);
|
||
|
|
||
|
/**
|
||
|
* @brief Leave a thread
|
||
|
* @see dpp::cluster::current_user_leave_thread
|
||
|
* @see https://discord.com/developers/docs/topics/threads
|
||
|
* @param thread_id Thread ID to leave
|
||
|
* @return confirmation returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
confirmation current_user_leave_thread_sync(snowflake thread_id);
|
||
|
|
||
|
/**
|
||
|
* @brief Get active threads in a guild (Sorted by ID in descending order)
|
||
|
* @see dpp::cluster::threads_get_active
|
||
|
* @see https://discord.com/developers/docs/topics/threads
|
||
|
* @param guild_id Guild to get active threads for
|
||
|
* @return thread_map returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
thread_map threads_get_active_sync(snowflake guild_id);
|
||
|
|
||
|
/**
|
||
|
* @brief Get private archived threads in a channel which current user has joined (Sorted by ID in descending order)
|
||
|
* @see dpp::cluster::threads_get_joined_private_archived
|
||
|
* @see https://discord.com/developers/docs/topics/threads
|
||
|
* @param channel_id Channel to get public archived threads for
|
||
|
* @param before_id Get threads before this id
|
||
|
* @param limit Number of threads to get
|
||
|
* @return thread_map returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
thread_map threads_get_joined_private_archived_sync(snowflake channel_id, snowflake before_id, uint16_t limit);
|
||
|
|
||
|
/**
|
||
|
* @brief Get private archived threads in a channel (Sorted by archive_timestamp in descending order)
|
||
|
* @see dpp::cluster::threads_get_private_archived
|
||
|
* @see https://discord.com/developers/docs/topics/threads
|
||
|
* @param channel_id Channel to get public archived threads for
|
||
|
* @param before_timestamp Get threads before this timestamp
|
||
|
* @param limit Number of threads to get
|
||
|
* @return thread_map returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
thread_map threads_get_private_archived_sync(snowflake channel_id, time_t before_timestamp, uint16_t limit);
|
||
|
|
||
|
/**
|
||
|
* @brief Get public archived threads in a channel (Sorted by archive_timestamp in descending order)
|
||
|
* @see dpp::cluster::threads_get_public_archived
|
||
|
* @see https://discord.com/developers/docs/topics/threads
|
||
|
* @param channel_id Channel to get public archived threads for
|
||
|
* @param before_timestamp Get threads before this timestamp
|
||
|
* @param limit Number of threads to get
|
||
|
* @return thread_map returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
thread_map threads_get_public_archived_sync(snowflake channel_id, time_t before_timestamp, uint16_t limit);
|
||
|
|
||
|
/**
|
||
|
* @brief Get a thread member
|
||
|
* @see dpp::cluster::thread_member_get
|
||
|
* @see https://discord.com/developers/docs/topics/threads
|
||
|
* @param thread_id Thread to get member for
|
||
|
* @param user_id ID of the user to get
|
||
|
* @return thread_member returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
thread_member thread_member_get_sync(const snowflake thread_id, const snowflake user_id);
|
||
|
|
||
|
/**
|
||
|
* @brief Get members of a thread
|
||
|
* @see dpp::cluster::thread_members_get
|
||
|
* @see https://discord.com/developers/docs/topics/threads
|
||
|
* @param thread_id Thread to get members for
|
||
|
* @return thread_member_map returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
thread_member_map thread_members_get_sync(snowflake thread_id);
|
||
|
|
||
|
/**
|
||
|
* @brief Create a thread in forum channel
|
||
|
* @note This method supports audit log reasons set by the cluster::set_audit_reason() method.
|
||
|
*
|
||
|
* @see dpp::cluster::thread_create_in_forum
|
||
|
* @see https://discord.com/developers/docs/resources/channel#start-thread-in-forum-channel
|
||
|
* @param thread_name Name of the forum thread
|
||
|
* @param channel_id Forum channel in which thread to create
|
||
|
* @param msg The message to start the thread with
|
||
|
* @param auto_archive_duration Duration to automatically archive the thread after recent activity
|
||
|
* @param rate_limit_per_user amount of seconds a user has to wait before sending another message (0-21600); bots, as well as users with the permission manage_messages, manage_thread, or manage_channel, are unaffected
|
||
|
* @param applied_tags List of IDs of forum tags (dpp::forum_tag) to apply to this thread
|
||
|
* @return thread returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
thread thread_create_in_forum_sync(const std::string& thread_name, snowflake channel_id, const message& msg, auto_archive_duration_t auto_archive_duration, uint16_t rate_limit_per_user, std::vector<snowflake> applied_tags = {});
|
||
|
|
||
|
/**
|
||
|
* @brief Create a thread
|
||
|
* @note This method supports audit log reasons set by the cluster::set_audit_reason() method.
|
||
|
*
|
||
|
* @see dpp::cluster::thread_create
|
||
|
* @see https://discord.com/developers/docs/resources/guild#create-guild-channel
|
||
|
* @param thread_name Name of the thread
|
||
|
* @param channel_id Channel in which thread to create
|
||
|
* @param auto_archive_duration Duration after which thread auto-archives. Can be set to - 60, 1440 (for boosted guilds can also be: 4320, 10080)
|
||
|
* @param thread_type Type of thread - CHANNEL_PUBLIC_THREAD, CHANNEL_ANNOUNCEMENT_THREAD, CHANNEL_PRIVATE_THREAD
|
||
|
* @param invitable whether non-moderators can add other non-moderators to a thread; only available when creating a private thread
|
||
|
* @param rate_limit_per_user amount of seconds a user has to wait before sending another message (0-21600); bots, as well as users with the permission manage_messages, manage_thread, or manage_channel, are unaffected
|
||
|
* @return thread returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
thread thread_create_sync(const std::string& thread_name, snowflake channel_id, uint16_t auto_archive_duration, channel_type thread_type, bool invitable, uint16_t rate_limit_per_user);
|
||
|
|
||
|
/**
|
||
|
* @brief Create a thread with a message (Discord: ID of a thread is same as message ID)
|
||
|
* @note This method supports audit log reasons set by the cluster::set_audit_reason() method.
|
||
|
* @see dpp::cluster::thread_create_with_message
|
||
|
* @see https://discord.com/developers/docs/topics/threads
|
||
|
* @param thread_name Name of the thread
|
||
|
* @param channel_id Channel in which thread to create
|
||
|
* @param message_id message to start thread with
|
||
|
* @param auto_archive_duration Duration after which thread auto-archives. Can be set to - 60, 1440 (for boosted guilds can also be: 4320, 10080)
|
||
|
* @param rate_limit_per_user amount of seconds a user has to wait before sending another message (0-21600); bots, as well as users with the permission manage_messages, manage_thread, or manage_channel, are unaffected
|
||
|
* @return thread returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
thread thread_create_with_message_sync(const std::string& thread_name, snowflake channel_id, snowflake message_id, uint16_t auto_archive_duration, uint16_t rate_limit_per_user);
|
||
|
|
||
|
/**
|
||
|
* @brief Add a member to a thread
|
||
|
* @see dpp::cluster::thread_member_add
|
||
|
* @see https://discord.com/developers/docs/topics/threads
|
||
|
* @param thread_id Thread ID to add to
|
||
|
* @param user_id Member ID to add
|
||
|
* @return confirmation returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
confirmation thread_member_add_sync(snowflake thread_id, snowflake user_id);
|
||
|
|
||
|
/**
|
||
|
* @brief Remove a member from a thread
|
||
|
* @see dpp::cluster::thread_member_remove
|
||
|
* @see https://discord.com/developers/docs/topics/threads
|
||
|
* @param thread_id Thread ID to remove from
|
||
|
* @param user_id Member ID to remove
|
||
|
* @return confirmation returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
confirmation thread_member_remove_sync(snowflake thread_id, snowflake user_id);
|
||
|
|
||
|
/**
|
||
|
* @brief Edit current (bot) user
|
||
|
*
|
||
|
* Modifies the current member in a guild. Returns the updated guild_member object on success.
|
||
|
* Fires a `Guild Member Update` Gateway event.
|
||
|
* @see dpp::cluster::current_user_edit
|
||
|
* @see https://discord.com/developers/docs/resources/user#modify-current-user
|
||
|
* @param nickname Nickname to set
|
||
|
* @param image_blob Avatar data to upload (NOTE: Very heavily rate limited!)
|
||
|
* @param type Type of image for avatar. It can be one of `i_gif`, `i_jpg` or `i_png`.
|
||
|
* @return user returned object on completion
|
||
|
* @throw dpp::length_exception Image data is larger than the maximum size of 256 kilobytes
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
user current_user_edit_sync(const std::string &nickname, const std::string& image_blob = "", const image_type type = i_png);
|
||
|
|
||
|
/**
|
||
|
* @brief Get current (bot) application
|
||
|
*
|
||
|
* @see dpp::cluster::current_application_get
|
||
|
* @see https://discord.com/developers/docs/topics/oauth2#get-current-bot-application-information
|
||
|
* @return application returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
application current_application_get_sync();
|
||
|
|
||
|
/**
|
||
|
* @brief Get current (bot) user
|
||
|
*
|
||
|
* @see dpp::cluster::current_user_get
|
||
|
* @see https://discord.com/developers/docs/resources/user#get-current-user
|
||
|
* @return user_identified returned object on completion
|
||
|
* @note The user_identified object is a subclass of dpp::user which contains further details if you have the oauth2 identify or email scopes.
|
||
|
* If you do not have these scopes, these fields are empty. You can safely convert a user_identified to user with `dynamic_cast`.
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
user_identified current_user_get_sync();
|
||
|
|
||
|
/**
|
||
|
* @brief Set the bot's voice state on a stage channel
|
||
|
*
|
||
|
* **Caveats**
|
||
|
*
|
||
|
* There are currently several caveats for this endpoint:
|
||
|
*
|
||
|
* - `channel_id` must currently point to a stage channel.
|
||
|
* - current user must already have joined `channel_id`.
|
||
|
* - You must have the `MUTE_MEMBERS` permission to unsuppress yourself. You can always suppress yourself.
|
||
|
* - You must have the `REQUEST_TO_SPEAK` permission to request to speak. You can always clear your own request to speak.
|
||
|
* - You are able to set `request_to_speak_timestamp` to any present or future time.
|
||
|
*
|
||
|
* @see dpp::cluster::current_user_set_voice_state
|
||
|
* @see https://discord.com/developers/docs/resources/guild#modify-current-user-voice-state
|
||
|
* @param guild_id Guild to set voice state on
|
||
|
* @param channel_id Stage channel to set voice state on
|
||
|
* @return confirmation returned object on completion
|
||
|
* @param suppress True if the user's audio should be suppressed, false if it should not
|
||
|
* @param request_to_speak_timestamp The time at which we requested to speak, or 0 to clear the request. The time set here must be the current time or in the future.
|
||
|
* @throw std::logic_exception You attempted to set a request_to_speak_timestamp in the past which is not the value of 0.
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
confirmation current_user_set_voice_state_sync(snowflake guild_id, snowflake channel_id, bool suppress = false, time_t request_to_speak_timestamp = 0);
|
||
|
|
||
|
/**
|
||
|
* @brief Set a user's voice state on a stage channel
|
||
|
*
|
||
|
* **Caveats**
|
||
|
*
|
||
|
* There are currently several caveats for this endpoint:
|
||
|
*
|
||
|
* - `channel_id` must currently point to a stage channel.
|
||
|
* - User must already have joined `channel_id`.
|
||
|
* - You must have the `MUTE_MEMBERS` permission. (Since suppression is the only thing that is available currently)
|
||
|
* - When unsuppressed, non-bot users will have their `request_to_speak_timestamp` set to the current time. Bot users will not.
|
||
|
* - When suppressed, the user will have their `request_to_speak_timestamp` removed.
|
||
|
*
|
||
|
* @see dpp::cluster::user_set_voice_state
|
||
|
* @see https://discord.com/developers/docs/resources/guild#modify-user-voice-state
|
||
|
* @param user_id The user to set the voice state of
|
||
|
* @param guild_id Guild to set voice state on
|
||
|
* @param channel_id Stage channel to set voice state on
|
||
|
* @return confirmation returned object on completion
|
||
|
* @param suppress True if the user's audio should be suppressed, false if it should not
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
confirmation user_set_voice_state_sync(snowflake user_id, snowflake guild_id, snowflake channel_id, bool suppress = false);
|
||
|
|
||
|
/**
|
||
|
* @brief Get current user's connections (linked accounts, e.g. steam, xbox).
|
||
|
* This call requires the oauth2 `connections` scope and cannot be executed
|
||
|
* against a bot token.
|
||
|
* @see dpp::cluster::current_user_connections_get
|
||
|
* @see https://discord.com/developers/docs/resources/user#get-user-connections
|
||
|
* @return connection_map returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
connection_map current_user_connections_get_sync();
|
||
|
|
||
|
/**
|
||
|
* @brief Get current (bot) user guilds
|
||
|
* @see dpp::cluster::current_user_get_guilds
|
||
|
* @see https://discord.com/developers/docs/resources/user#get-current-user-guilds
|
||
|
* @return guild_map returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
guild_map current_user_get_guilds_sync();
|
||
|
|
||
|
/**
|
||
|
* @brief Leave a guild
|
||
|
* @see dpp::cluster::current_user_leave_guild
|
||
|
* @see https://discord.com/developers/docs/resources/user#leave-guild
|
||
|
* @param guild_id Guild ID to leave
|
||
|
* @return confirmation returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
confirmation current_user_leave_guild_sync(snowflake guild_id);
|
||
|
|
||
|
/**
|
||
|
* @brief Get a user by id, without using the cache
|
||
|
*
|
||
|
* @see dpp::cluster::user_get
|
||
|
* @see https://discord.com/developers/docs/resources/user#get-user
|
||
|
* @param user_id User ID to retrieve
|
||
|
* @return user_identified returned object on completion
|
||
|
* @note The user_identified object is a subclass of dpp::user which contains further details if you have the oauth2 identify or email scopes.
|
||
|
* If you do not have these scopes, these fields are empty. You can safely convert a user_identified to user with `dynamic_cast`.
|
||
|
* @note unless you want something special from `dpp::user_identified` or you've turned off caching, you have no need to call this.
|
||
|
* Call `dpp::find_user` instead that looks up the user in the cache rather than a REST call.
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
user_identified user_get_sync(snowflake user_id);
|
||
|
|
||
|
/**
|
||
|
* @brief Get a user by id, checking in the cache first
|
||
|
*
|
||
|
* @see dpp::cluster::user_get_cached
|
||
|
* @see https://discord.com/developers/docs/resources/user#get-user
|
||
|
* @param user_id User ID to retrieve
|
||
|
* @return user_identified returned object on completion
|
||
|
* @note The user_identified object is a subclass of dpp::user which contains further details if you have the oauth2 identify or email scopes.
|
||
|
* If you do not have these scopes, these fields are empty. You can safely convert a user_identified to user with `dynamic_cast`.
|
||
|
* @note If the user is found in the cache, special values set in `dpp::user_identified` will be undefined. This call should be used
|
||
|
* where you want to for example resolve a user who may no longer be in the bot's guilds, for something like a ban log message.
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
user_identified user_get_cached_sync(snowflake user_id);
|
||
|
|
||
|
/**
|
||
|
* @brief Get all voice regions
|
||
|
* @see dpp::cluster::get_voice_regions
|
||
|
* @see https://discord.com/developers/docs/resources/voice#list-voice-regions
|
||
|
* @return voiceregion_map returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
voiceregion_map get_voice_regions_sync();
|
||
|
|
||
|
/**
|
||
|
* @brief Get guild voice regions.
|
||
|
*
|
||
|
* Voice regions per guild are somewhat deprecated in preference of per-channel voice regions.
|
||
|
* Returns a list of voice region objects for the guild. Unlike the similar /voice route, this returns VIP servers when
|
||
|
* the guild is VIP-enabled.
|
||
|
*
|
||
|
* @see dpp::cluster::guild_get_voice_regions
|
||
|
* @see https://discord.com/developers/docs/resources/guild#get-guild-voice-regions
|
||
|
* @param guild_id Guild ID to get voice regions for
|
||
|
* @return voiceregion_map returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
voiceregion_map guild_get_voice_regions_sync(snowflake guild_id);
|
||
|
|
||
|
/**
|
||
|
* @brief Create a webhook
|
||
|
* @note This method supports audit log reasons set by the cluster::set_audit_reason() method.
|
||
|
* @see dpp::cluster::create_webhook
|
||
|
* @see https://discord.com/developers/docs/resources/webhook#create-webhook
|
||
|
* @param w Webhook to create
|
||
|
* @return webhook returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
webhook create_webhook_sync(const class webhook &w);
|
||
|
|
||
|
/**
|
||
|
* @brief Delete a webhook
|
||
|
* @note This method supports audit log reasons set by the cluster::set_audit_reason() method.
|
||
|
* @see dpp::cluster::delete_webhook
|
||
|
* @see https://discord.com/developers/docs/resources/webhook#delete-webhook
|
||
|
* @param webhook_id Webhook ID to delete
|
||
|
* @return confirmation returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
confirmation delete_webhook_sync(snowflake webhook_id);
|
||
|
|
||
|
/**
|
||
|
* @brief Delete webhook message
|
||
|
*
|
||
|
* @see dpp::cluster::delete_webhook_message
|
||
|
* @see https://discord.com/developers/docs/resources/webhook#delete-webhook-message
|
||
|
* @param wh Webhook to delete message for
|
||
|
* @param message_id Message ID to delete
|
||
|
* @param thread_id ID of the thread the message is in
|
||
|
* @return confirmation returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
confirmation delete_webhook_message_sync(const class webhook &wh, snowflake message_id, snowflake thread_id = 0);
|
||
|
|
||
|
/**
|
||
|
* @brief Delete webhook with token
|
||
|
* @see dpp::cluster::delete_webhook_with_token
|
||
|
* @see https://discord.com/developers/docs/resources/webhook#delete-webhook-with-token
|
||
|
* @param webhook_id Webhook ID to delete
|
||
|
* @param token Token of webhook to delete
|
||
|
* @return confirmation returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
confirmation delete_webhook_with_token_sync(snowflake webhook_id, const std::string &token);
|
||
|
|
||
|
/**
|
||
|
* @brief Edit webhook
|
||
|
* @note This method supports audit log reasons set by the cluster::set_audit_reason() method.
|
||
|
* @see dpp::cluster::edit_webhook
|
||
|
* @see https://discord.com/developers/docs/resources/webhook#modify-webhook
|
||
|
* @param wh Webhook to edit
|
||
|
* @return webhook returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
webhook edit_webhook_sync(const class webhook& wh);
|
||
|
|
||
|
/**
|
||
|
* @brief Edit webhook message
|
||
|
*
|
||
|
* When the content field is edited, the mentions array in the message object will be reconstructed from scratch based on
|
||
|
* the new content. The allowed_mentions field of the edit request controls how this happens. If there is no explicit
|
||
|
* allowed_mentions in the edit request, the content will be parsed with default allowances, that is, without regard to
|
||
|
* whether or not an allowed_mentions was present in the request that originally created the message.
|
||
|
*
|
||
|
* @see dpp::cluster::edit_webhook_message
|
||
|
* @see https://discord.com/developers/docs/resources/webhook#edit-webhook-message
|
||
|
* @note the attachments array must contain all attachments that should be present after edit, including retained and new attachments provided in the request body.
|
||
|
* @param wh Webhook to edit message for
|
||
|
* @param m New message
|
||
|
* @param thread_id ID of the thread the message is in
|
||
|
* @return message returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
message edit_webhook_message_sync(const class webhook &wh, const struct message &m, snowflake thread_id = 0);
|
||
|
|
||
|
/**
|
||
|
* @brief Edit webhook with token (token is encapsulated in the webhook object)
|
||
|
* @see dpp::cluster::edit_webhook_with_token
|
||
|
* @see https://discord.com/developers/docs/resources/webhook#modify-webhook-with-token
|
||
|
* @param wh Webhook to edit (should include token)
|
||
|
* @return webhook returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
webhook edit_webhook_with_token_sync(const class webhook& wh);
|
||
|
|
||
|
/**
|
||
|
* @brief Execute webhook
|
||
|
*
|
||
|
* @see dpp::cluster::execute_webhook
|
||
|
* @see https://discord.com/developers/docs/resources/webhook#execute-webhook
|
||
|
* @param wh Webhook to execute
|
||
|
* @param m Message to send
|
||
|
* @param wait waits for server confirmation of message send before response, and returns the created message body
|
||
|
* @param thread_id Send a message to the specified thread within a webhook's channel. The thread will automatically be unarchived
|
||
|
* @param thread_name Name of thread to create (requires the webhook channel to be a forum channel)
|
||
|
* @return message returned object on completion
|
||
|
* @note If the webhook channel is a forum channel, you must provide either `thread_id` or `thread_name`. If `thread_id` is provided, the message will send in that thread. If `thread_name` is provided, a thread with that name will be created in the forum channel.
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
message execute_webhook_sync(const class webhook &wh, const struct message &m, bool wait = false, snowflake thread_id = 0, const std::string& thread_name = "");
|
||
|
|
||
|
/**
|
||
|
* @brief Get channel webhooks
|
||
|
* @see dpp::cluster::get_channel_webhooks
|
||
|
* @see https://discord.com/developers/docs/resources/webhook#get-guild-webhooks
|
||
|
* @param channel_id Channel ID to get webhooks for
|
||
|
* @return webhook_map returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
webhook_map get_channel_webhooks_sync(snowflake channel_id);
|
||
|
|
||
|
/**
|
||
|
* @brief Get guild webhooks
|
||
|
* @see dpp::cluster::get_guild_webhooks
|
||
|
* @see https://discord.com/developers/docs/resources/webhook#get-guild-webhooks
|
||
|
* @param guild_id Guild ID to get webhooks for
|
||
|
* @return webhook_map returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
webhook_map get_guild_webhooks_sync(snowflake guild_id);
|
||
|
|
||
|
/**
|
||
|
* @brief Get webhook
|
||
|
* @see dpp::cluster::get_webhook
|
||
|
* @see https://discord.com/developers/docs/resources/webhook#get-webhook
|
||
|
* @param webhook_id Webhook ID to get
|
||
|
* @return webhook returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
webhook get_webhook_sync(snowflake webhook_id);
|
||
|
|
||
|
/**
|
||
|
* @brief Get webhook message
|
||
|
*
|
||
|
* @see dpp::cluster::get_webhook_message
|
||
|
* @see https://discord.com/developers/docs/resources/webhook#get-webhook-message
|
||
|
* @param wh Webhook to get the original message for
|
||
|
* @param message_id The message ID
|
||
|
* @param thread_id ID of the thread the message is in
|
||
|
* @return message returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
message get_webhook_message_sync(const class webhook &wh, snowflake message_id, snowflake thread_id = 0);
|
||
|
|
||
|
/**
|
||
|
* @brief Get webhook using token
|
||
|
* @see dpp::cluster::get_webhook_with_token
|
||
|
* @see https://discord.com/developers/docs/resources/webhook#get-webhook-with-token
|
||
|
* @param webhook_id Webhook ID to retrieve
|
||
|
* @param token Token of webhook
|
||
|
* @return webhook returned object on completion
|
||
|
* \memberof dpp::cluster
|
||
|
* @throw dpp::rest_exception upon failure to execute REST function
|
||
|
* @warning This function is a blocking (synchronous) call and should only be used from within a separate thread.
|
||
|
* Avoid direct use of this function inside an event handler.
|
||
|
*/
|
||
|
webhook get_webhook_with_token_sync(snowflake webhook_id, const std::string &token);
|
||
|
|
||
|
|
||
|
/* End of auto-generated definitions */
|