D++ (DPP)  10.0.30
C++ Discord API Bot Library
dpp::cluster Class Reference

The cluster class represents a group of shards and a command queue for sending and receiving commands from discord via HTTP. More...

#include "cluster.h"

Collaboration diagram for dpp::cluster:

Public Member Functions

 cluster (const cluster &&)=delete
 dpp::cluster is non-moveable More...
 
 cluster (const cluster &)=delete
 dpp::cluster is non-copyable More...
 
 cluster (const std::string &token, uint32_t intents=i_default_intents, uint32_t shards=0, uint32_t cluster_id=0, uint32_t maxclusters=1, bool compressed=true, cache_policy_t policy=cache_policy::cpol_default, uint32_t request_threads=12, uint32_t request_threads_raw=1)
 Constructor for creating a cluster. More...
 
virtual ~cluster ()
 Destroy the cluster object. More...
 
void application_role_connection_get (snowflake application_id, command_completion_event_t callback)
 Get the application's role connection metadata records. More...
 
application_role_connection application_role_connection_get_sync (snowflake application_id)
 Get the application's role connection metadata records. More...
 
void application_role_connection_update (snowflake application_id, const std::vector< application_role_connection_metadata > &connection_metadata, command_completion_event_t callback=utility::log_error())
 Update the application's role connection metadata records. More...
 
application_role_connection application_role_connection_update_sync (snowflake application_id, const std::vector< application_role_connection_metadata > &connection_metadata)
 Update the application's role connection metadata records. More...
 
void automod_rule_create (snowflake guild_id, const automod_rule &r, command_completion_event_t callback=utility::log_error())
 Create an auto moderation rule. More...
 
automod_rule automod_rule_create_sync (snowflake guild_id, const automod_rule &r)
 Create an auto moderation rule. More...
 
void automod_rule_delete (snowflake guild_id, snowflake rule_id, command_completion_event_t callback=utility::log_error())
 Delete an auto moderation rule. More...
 
confirmation automod_rule_delete_sync (snowflake guild_id, snowflake rule_id)
 Delete an auto moderation rule. More...
 
void automod_rule_edit (snowflake guild_id, const automod_rule &r, command_completion_event_t callback=utility::log_error())
 Edit an auto moderation rule. More...
 
automod_rule automod_rule_edit_sync (snowflake guild_id, const automod_rule &r)
 Edit an auto moderation rule. More...
 
void automod_rule_get (snowflake guild_id, snowflake rule_id, command_completion_event_t callback)
 Get a single auto moderation rule. More...
 
automod_rule automod_rule_get_sync (snowflake guild_id, snowflake rule_id)
 Get a single auto moderation rule. More...
 
void automod_rules_get (snowflake guild_id, command_completion_event_t callback)
 Get all auto moderation rules for a guild. More...
 
automod_rule_map automod_rules_get_sync (snowflake guild_id)
 Get all auto moderation rules for a guild. More...
 
void channel_create (const class channel &c, command_completion_event_t callback=utility::log_error())
 Create a channel. More...
 
channel channel_create_sync (const class channel &c)
 Create a channel. More...
 
void channel_delete (snowflake channel_id, command_completion_event_t callback=utility::log_error())
 Delete a channel. More...
 
void channel_delete_permission (const class channel &c, snowflake overwrite_id, command_completion_event_t callback=utility::log_error())
 Remove a permission from a channel. More...
 
confirmation channel_delete_permission_sync (const class channel &c, snowflake overwrite_id)
 Remove a permission from a channel. More...
 
confirmation channel_delete_sync (snowflake channel_id)
 Delete a channel. More...
 
void channel_edit (const class channel &c, command_completion_event_t callback=utility::log_error())
 Edit a channel. More...
 
void channel_edit_permissions (const class channel &c, const snowflake overwrite_id, const uint64_t allow, const uint64_t deny, const bool member, command_completion_event_t callback=utility::log_error())
 Edit a channel's permissions. More...
 
void channel_edit_permissions (const snowflake channel_id, const snowflake overwrite_id, const uint64_t allow, const uint64_t deny, const bool member, command_completion_event_t callback=utility::log_error())
 Edit a channel's permissions. More...
 
confirmation channel_edit_permissions_sync (const class channel &c, const snowflake overwrite_id, const uint64_t allow, const uint64_t deny, const bool member)
 Edit a channel's permissions. More...
 
confirmation channel_edit_permissions_sync (const snowflake channel_id, const snowflake overwrite_id, const uint64_t allow, const uint64_t deny, const bool member)
 Edit a channel's permissions. More...
 
void channel_edit_positions (const std::vector< channel > &c, command_completion_event_t callback=utility::log_error())
 Edit multiple channels positions. More...
 
confirmation channel_edit_positions_sync (const std::vector< channel > &c)
 Edit multiple channels positions. More...
 
channel channel_edit_sync (const class channel &c)
 Edit a channel. More...
 
void channel_follow_news (const class channel &c, snowflake target_channel_id, command_completion_event_t callback=utility::log_error())
 Follow an announcement (news) channel. More...
 
confirmation channel_follow_news_sync (const class channel &c, snowflake target_channel_id)
 Follow an announcement (news) channel. More...
 
void channel_get (snowflake c, command_completion_event_t callback)
 Get a channel. More...
 
channel channel_get_sync (snowflake c)
 Get a channel. More...
 
void channel_invite_create (const class channel &c, const class invite &i, command_completion_event_t callback=utility::log_error())
 Create invite for a channel. More...
 
invite channel_invite_create_sync (const class channel &c, const class invite &i)
 Create invite for a channel. More...
 
void channel_invites_get (const class channel &c, command_completion_event_t callback)
 Get invites for a channel. More...
 
invite_map channel_invites_get_sync (const class channel &c)
 Get invites for a channel. More...
 
void channel_pins_get (snowflake channel_id, command_completion_event_t callback)
 Get a channel's pins. More...
 
message_map channel_pins_get_sync (snowflake channel_id)
 Get a channel's pins. More...
 
void channel_set_voice_status (snowflake channel_id, const std::string &status, command_completion_event_t callback=utility::log_error())
 Set the status of a voice channel. More...
 
confirmation channel_set_voice_status_sync (snowflake channel_id, const std::string &status)
 Set the status of a voice channel. More...
 
void channel_typing (const class channel &c, command_completion_event_t callback=utility::log_error())
 Trigger channel typing indicator. More...
 
void channel_typing (snowflake cid, command_completion_event_t callback=utility::log_error())
 Trigger channel typing indicator. More...
 
confirmation channel_typing_sync (const class channel &c)
 Trigger channel typing indicator. More...
 
confirmation channel_typing_sync (snowflake cid)
 Trigger channel typing indicator. More...
 
void channels_get (snowflake guild_id, command_completion_event_t callback)
 Get all channels for a guild. More...
 
channel_map channels_get_sync (snowflake guild_id)
 Get all channels for a guild. More...
 
clusterclear_audit_reason ()
 Clear the audit log reason for the next REST call to be made. More...
 
async< confirmation_callback_tco_application_role_connection_get (snowflake application_id)
 Get the application's role connection metadata records. More...
 
async< confirmation_callback_tco_application_role_connection_update (snowflake application_id, const std::vector< application_role_connection_metadata > &connection_metadata)
 Update the application's role connection metadata records. More...
 
async< confirmation_callback_tco_automod_rule_create (snowflake guild_id, const automod_rule &r)
 Create an auto moderation rule. More...
 
async< confirmation_callback_tco_automod_rule_delete (snowflake guild_id, snowflake rule_id)
 Delete an auto moderation rule. More...
 
async< confirmation_callback_tco_automod_rule_edit (snowflake guild_id, const automod_rule &r)
 Edit an auto moderation rule. More...
 
async< confirmation_callback_tco_automod_rule_get (snowflake guild_id, snowflake rule_id)
 Get a single auto moderation rule. More...
 
async< confirmation_callback_tco_automod_rules_get (snowflake guild_id)
 Get all auto moderation rules for a guild. More...
 
async< confirmation_callback_tco_channel_create (const class channel &c)
 Create a channel. More...
 
async< confirmation_callback_tco_channel_delete (snowflake channel_id)
 Delete a channel. More...
 
async< confirmation_callback_tco_channel_delete_permission (const class channel &c, snowflake overwrite_id)
 Remove a permission from a channel. More...
 
async< confirmation_callback_tco_channel_edit (const class channel &c)
 Edit a channel. More...
 
async< confirmation_callback_tco_channel_edit_permissions (const class channel &c, const snowflake overwrite_id, const uint64_t allow, const uint64_t deny, const bool member)
 Edit a channel's permissions. More...
 
async< confirmation_callback_tco_channel_edit_permissions (const snowflake channel_id, const snowflake overwrite_id, const uint64_t allow, const uint64_t deny, const bool member)
 Edit a channel's permissions. More...
 
async< confirmation_callback_tco_channel_edit_positions (const std::vector< channel > &c)
 Edit multiple channels positions. More...
 
async< confirmation_callback_tco_channel_follow_news (const class channel &c, snowflake target_channel_id)
 Follow an announcement (news) channel. More...
 
async< confirmation_callback_tco_channel_get (snowflake c)
 Get a channel. More...
 
async< confirmation_callback_tco_channel_invite_create (const class channel &c, const class invite &i)
 Create invite for a channel. More...
 
async< confirmation_callback_tco_channel_invites_get (const class channel &c)
 Get invites for a channel. More...
 
async< confirmation_callback_tco_channel_pins_get (snowflake channel_id)
 Get a channel's pins. More...
 
async< confirmation_callback_tco_channel_set_voice_status (snowflake channel_id, const std::string &status)
 Set the status of a voice channel. More...
 
async< confirmation_callback_tco_channel_typing (const class channel &c)
 Trigger channel typing indicator. More...
 
async< confirmation_callback_tco_channel_typing (snowflake cid)
 Trigger channel typing indicator. More...
 
async< confirmation_callback_tco_channels_get (snowflake guild_id)
 Get all channels for a guild. More...
 
async< confirmation_callback_tco_create_dm_channel (snowflake user_id)
 Create a dm channel. More...
 
async< confirmation_callback_tco_current_application_get ()
 Get current (bot) application. More...
 
async< confirmation_callback_tco_current_user_connections_get ()
 Get current user's connections (linked accounts, e.g. More...
 
async< confirmation_callback_tco_current_user_edit (const std::string &nickname, const std::string &image_blob="", const image_type type=i_png)
 Edit current (bot) user. More...
 
async< confirmation_callback_tco_current_user_get ()
 Get current (bot) user. More...
 
async< confirmation_callback_tco_current_user_get_dms ()
 Get current user DM channels. More...
 
async< confirmation_callback_tco_current_user_get_guilds ()
 Get current (bot) user guilds. More...
 
async< confirmation_callback_tco_current_user_join_thread (snowflake thread_id)
 Join a thread. More...
 
async< confirmation_callback_tco_current_user_leave_guild (snowflake guild_id)
 Leave a guild. More...
 
async< confirmation_callback_tco_current_user_leave_thread (snowflake thread_id)
 Leave a thread. More...
 
async< confirmation_callback_tco_current_user_set_voice_state (snowflake guild_id, snowflake channel_id, bool suppress=false, time_t request_to_speak_timestamp=0)
 Set the bot's voice state on a stage channel. More...
 
async< confirmation_callback_tco_delete_webhook (snowflake webhook_id)
 Delete a webhook. More...
 
async< confirmation_callback_tco_delete_webhook_message (const class webhook &wh, snowflake message_id, snowflake thread_id=0)
 Delete webhook message. More...
 
async< confirmation_callback_tco_delete_webhook_with_token (snowflake webhook_id, const std::string &token)
 Delete webhook with token. More...
 
async< confirmation_callback_tco_direct_message_create (snowflake user_id, const message &m)
 Create a direct message, also create the channel for the direct message if needed. More...
 
async< confirmation_callback_tco_edit_webhook (const class webhook &wh)
 Edit webhook. More...
 
async< confirmation_callback_tco_edit_webhook_message (const class webhook &wh, const struct message &m, snowflake thread_id=0)
 Edit webhook message. More...
 
async< confirmation_callback_tco_edit_webhook_with_token (const class webhook &wh)
 Edit webhook with token (token is encapsulated in the webhook object) More...
 
async< confirmation_callback_tco_entitlement_test_create (const class entitlement &new_entitlement)
 Creates a test entitlement to a given SKU for a given guild or user. More...
 
async< confirmation_callback_tco_entitlement_test_delete (snowflake entitlement_id)
 Deletes a currently-active test entitlement. More...
 
async< confirmation_callback_tco_entitlements_get (snowflake user_id=0, const std::vector< snowflake > &sku_ids={}, snowflake before_id=0, snowflake after_id=0, uint8_t limit=100, snowflake guild_id=0, bool exclude_ended=false)
 Returns all entitlements for a given app, active and expired. More...
 
async< confirmation_callback_tco_execute_webhook (const class webhook &wh, const struct message &m, bool wait=false, snowflake thread_id=0, const std::string &thread_name="")
 Execute webhook. More...
 
async< confirmation_callback_tco_gdm_add (snowflake channel_id, snowflake user_id, const std::string &access_token, const std::string &nick)
 Adds a recipient to a Group DM using their access token. More...
 
async< confirmation_callback_tco_gdm_remove (snowflake channel_id, snowflake user_id)
 Removes a recipient from a Group DM. More...
 
async< confirmation_callback_tco_get_channel_webhooks (snowflake channel_id)
 Get channel webhooks. More...
 
async< confirmation_callback_tco_get_gateway_bot ()
 Get the gateway information for the bot using the token. More...
 
async< confirmation_callback_tco_get_guild_webhooks (snowflake guild_id)
 Get guild webhooks. More...
 
async< confirmation_callback_tco_get_voice_regions ()
 Get all voice regions. More...
 
async< confirmation_callback_tco_get_webhook (snowflake webhook_id)
 Get webhook. More...
 
async< confirmation_callback_tco_get_webhook_message (const class webhook &wh, snowflake message_id, snowflake thread_id=0)
 Get webhook message. More...
 
async< confirmation_callback_tco_get_webhook_with_token (snowflake webhook_id, const std::string &token)
 Get webhook using token. More...
 
async< confirmation_callback_tco_global_bulk_command_create (const std::vector< slashcommand > &commands)
 Create/overwrite global slash commands. More...
 
async< confirmation_callback_tco_global_bulk_command_delete ()
 Delete all existing global slash commands. More...
 
async< confirmation_callback_tco_global_command_create (const slashcommand &s)
 Create a global slash command (a bot can have a maximum of 100 of these). More...
 
async< confirmation_callback_tco_global_command_delete (snowflake id)
 Delete a global slash command (a bot can have a maximum of 100 of these) More...
 
async< confirmation_callback_tco_global_command_edit (const slashcommand &s)
 Edit a global slash command (a bot can have a maximum of 100 of these) More...
 
async< confirmation_callback_tco_global_command_get (snowflake id)
 Get a global slash command. More...
 
async< confirmation_callback_tco_global_commands_get ()
 Get the application's global slash commands. More...
 
async< confirmation_callback_tco_guild_add_member (const guild_member &gm, const std::string &access_token)
 Add guild member. More...
 
async< confirmation_callback_tco_guild_auditlog_get (snowflake guild_id, snowflake user_id, uint32_t action_type, snowflake before, snowflake after, uint32_t limit)
 Get the audit log for a guild. More...
 
async< confirmation_callback_tco_guild_ban_add (snowflake guild_id, snowflake user_id, uint32_t delete_message_seconds=0)
 Add guild ban. More...
 
async< confirmation_callback_tco_guild_ban_delete (snowflake guild_id, snowflake user_id)
 Delete guild ban. More...
 
async< confirmation_callback_tco_guild_begin_prune (snowflake guild_id, const struct prune &pruneinfo)
 Begin guild prune. More...
 
async< confirmation_callback_tco_guild_bulk_command_create (const std::vector< slashcommand > &commands, snowflake guild_id)
 Create/overwrite guild slash commands. More...
 
async< confirmation_callback_tco_guild_bulk_command_delete (snowflake guild_id)
 Delete all existing guild slash commands. More...
 
async< confirmation_callback_tco_guild_bulk_command_edit_permissions (const std::vector< slashcommand > &commands, snowflake guild_id)
 Edit/Overwrite the permissions of all existing slash commands in a guild. More...
 
async< confirmation_callback_tco_guild_command_create (const slashcommand &s, snowflake guild_id)
 Create a slash command local to a guild. More...
 
async< confirmation_callback_tco_guild_command_delete (snowflake id, snowflake guild_id)
 Delete a slash command local to a guild. More...
 
async< confirmation_callback_tco_guild_command_edit (const slashcommand &s, snowflake guild_id)
 Edit a slash command local to a guild. More...
 
async< confirmation_callback_tco_guild_command_edit_permissions (const slashcommand &s, snowflake guild_id)
 Edit slash command permissions of a guild. More...
 
async< confirmation_callback_tco_guild_command_get (snowflake id, snowflake guild_id)
 Get a slash command of a guild. More...
 
async< confirmation_callback_tco_guild_command_get_permissions (snowflake id, snowflake guild_id)
 Get the permissions for a slash command of a guild. More...
 
async< confirmation_callback_tco_guild_commands_get (snowflake guild_id)
 Get the application's slash commands for a guild. More...
 
async< confirmation_callback_tco_guild_commands_get_permissions (snowflake guild_id)
 Get all slash command permissions of a guild. More...
 
async< confirmation_callback_tco_guild_create (const class guild &g)
 Create a guild. More...
 
async< confirmation_callback_tco_guild_create_from_template (const std::string &code, const std::string &name)
 Create a new guild based on a template. More...
 
async< confirmation_callback_tco_guild_current_member_edit (snowflake guild_id, const std::string &nickname)
 Modify current member. More...
 
async< confirmation_callback_tco_guild_delete (snowflake guild_id)
 Delete a guild. More...
 
async< confirmation_callback_tco_guild_delete_integration (snowflake guild_id, snowflake integration_id)
 Delete guild integration. More...
 
async< confirmation_callback_tco_guild_edit (const class guild &g)
 Edit a guild. More...
 
async< confirmation_callback_tco_guild_edit_member (const guild_member &gm)
 Edit the properties of an existing guild member. More...
 
async< confirmation_callback_tco_guild_edit_onboarding (const struct onboarding &o)
 Edit the guild's onboarding configuration. More...
 
async< confirmation_callback_tco_guild_edit_welcome_screen (snowflake guild_id, const struct welcome_screen &welcome_screen, bool enabled)
 Edit the guild's welcome screen. More...
 
async< confirmation_callback_tco_guild_edit_widget (snowflake guild_id, const class guild_widget &gw)
 Edit guild widget. More...
 
async< confirmation_callback_tco_guild_emoji_create (snowflake guild_id, const class emoji &newemoji)
 Create single emoji. More...
 
async< confirmation_callback_tco_guild_emoji_delete (snowflake guild_id, snowflake emoji_id)
 Delete a guild emoji. More...
 
async< confirmation_callback_tco_guild_emoji_edit (snowflake guild_id, const class emoji &newemoji)
 Edit a single emoji. More...
 
async< confirmation_callback_tco_guild_emoji_get (snowflake guild_id, snowflake emoji_id)
 Get a single emoji. More...
 
async< confirmation_callback_tco_guild_emojis_get (snowflake guild_id)
 Get all emojis for a guild. More...
 
async< confirmation_callback_tco_guild_event_create (const scheduled_event &event)
 Create a scheduled event on a guild. More...
 
async< confirmation_callback_tco_guild_event_delete (snowflake event_id, snowflake guild_id)
 Delete a scheduled event from a guild. More...
 
async< confirmation_callback_tco_guild_event_edit (const scheduled_event &event)
 Edit/modify a scheduled event on a guild. More...
 
async< confirmation_callback_tco_guild_event_get (snowflake guild_id, snowflake event_id)
 Get a scheduled event for a guild. More...
 
async< confirmation_callback_tco_guild_events_get (snowflake guild_id)
 Get all scheduled events for a guild. More...
 
async< confirmation_callback_tco_guild_get_ban (snowflake guild_id, snowflake user_id)
 Get single guild ban. More...
 
async< confirmation_callback_tco_guild_get_bans (snowflake guild_id, snowflake before, snowflake after, snowflake limit)
 Get guild ban list. More...
 
async< confirmation_callback_tco_guild_get_integrations (snowflake guild_id)
 Get guild integrations. More...
 
async< confirmation_callback_tco_guild_get_invites (snowflake guild_id)
 Get guild invites. More...
 
async< confirmation_callback_tco_guild_get_member (snowflake guild_id, snowflake user_id)
 Get a guild member. More...
 
async< confirmation_callback_tco_guild_get_members (snowflake guild_id, uint16_t limit, snowflake after)
 Get all guild members. More...
 
async< confirmation_callback_tco_guild_get_onboarding (snowflake guild_id)
 Get the guild's onboarding configuration. More...
 
async< confirmation_callback_tco_guild_get_prune_counts (snowflake guild_id, const struct prune &pruneinfo)
 Get prune counts. More...
 
async< confirmation_callback_tco_guild_get_vanity (snowflake guild_id)
 Get guild vanity url, if enabled. More...
 
async< confirmation_callback_tco_guild_get_voice_regions (snowflake guild_id)
 Get guild voice regions. More...
 
async< confirmation_callback_tco_guild_get_welcome_screen (snowflake guild_id)
 Get the guild's welcome screen. More...
 
async< confirmation_callback_tco_guild_get_widget (snowflake guild_id)
 Get guild widget. More...
 
async< confirmation_callback_tco_guild_member_add_role (snowflake guild_id, snowflake user_id, snowflake role_id)
 Add role to guild member. More...
 
async< confirmation_callback_tco_guild_member_delete (snowflake guild_id, snowflake user_id)
 Remove (kick) a guild member. More...
 
async< confirmation_callback_tco_guild_member_delete_role (snowflake guild_id, snowflake user_id, snowflake role_id)
 Remove role from guild member. More...
 
async< confirmation_callback_tco_guild_member_kick (snowflake guild_id, snowflake user_id)
 Remove (kick) a guild member. More...
 
async< confirmation_callback_tco_guild_member_move (const snowflake channel_id, const snowflake guild_id, const snowflake user_id)
 Moves the guild member to a other voice channel, if member is connected to one. More...
 
async< confirmation_callback_tco_guild_member_remove_role (snowflake guild_id, snowflake user_id, snowflake role_id)
 Remove role from guild member. More...
 
async< confirmation_callback_tco_guild_member_timeout (snowflake guild_id, snowflake user_id, time_t communication_disabled_until)
 Set the timeout of a guild member. More...
 
async< confirmation_callback_tco_guild_member_timeout_remove (snowflake guild_id, snowflake user_id)
 Remove the timeout of a guild member. More...
 
async< confirmation_callback_tco_guild_modify_integration (snowflake guild_id, const class integration &i)
 Modify guild integration. More...
 
async< confirmation_callback_tco_guild_search_members (snowflake guild_id, const std::string &query, uint16_t limit)
 Search for guild members based on whether their username or nickname starts with the given string. More...
 
async< confirmation_callback_tco_guild_set_nickname (snowflake guild_id, const std::string &nickname)
 Change current user nickname. More...
 
async< confirmation_callback_tco_guild_sticker_create (const sticker &s)
 Create a sticker in a guild. More...
 
async< confirmation_callback_tco_guild_sticker_delete (snowflake sticker_id, snowflake guild_id)
 Delete a sticker from a guild. More...
 
async< confirmation_callback_tco_guild_sticker_get (snowflake id, snowflake guild_id)
 Get a guild sticker. More...
 
async< confirmation_callback_tco_guild_sticker_modify (const sticker &s)
 Modify a sticker in a guild. More...
 
async< confirmation_callback_tco_guild_stickers_get (snowflake guild_id)
 Get all guild stickers. More...
 
async< confirmation_callback_tco_guild_sync_integration (snowflake guild_id, snowflake integration_id)
 Sync guild integration. More...
 
async< confirmation_callback_tco_guild_template_create (snowflake guild_id, const std::string &name, const std::string &description)
 Creates a template for the guild. More...
 
async< confirmation_callback_tco_guild_template_delete (snowflake guild_id, const std::string &code)
 Deletes the template. More...
 
async< confirmation_callback_tco_guild_template_modify (snowflake guild_id, const std::string &code, const std::string &name, const std::string &description)
 Modifies the template's metadata. More...
 
async< confirmation_callback_tco_guild_template_sync (snowflake guild_id, const std::string &code)
 Syncs the template to the guild's current state. More...
 
async< confirmation_callback_tco_guild_templates_get (snowflake guild_id)
 Get guild templates. More...
 
async< confirmation_callback_tco_interaction_followup_create (const std::string &token, const message &m)
 Create a followup message to a slash command. More...
 
async< confirmation_callback_tco_interaction_followup_delete (const std::string &token)
 Delete the initial interaction response. More...
 
async< confirmation_callback_tco_interaction_followup_edit (const std::string &token, const message &m)
 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. More...
 
async< confirmation_callback_tco_interaction_followup_edit_original (const std::string &token, const message &m)
 Edit original followup message to a slash command This is an alias for cluster::interaction_response_edit. More...
 
async< confirmation_callback_tco_interaction_followup_get (const std::string &token, snowflake message_id)
 Get the followup message to a slash command. More...
 
async< confirmation_callback_tco_interaction_followup_get_original (const std::string &token)
 Get the original followup message to a slash command This is an alias for cluster::interaction_response_get_original. More...
 
async< confirmation_callback_tco_interaction_response_create (snowflake interaction_id, const std::string &token, const interaction_response &r)
 Respond to a slash command. More...
 
async< confirmation_callback_tco_interaction_response_edit (const std::string &token, const message &m)
 Edit response to a slash command. More...
 
async< confirmation_callback_tco_interaction_response_get_original (const std::string &token)
 Get the original response to a slash command. More...
 
async< confirmation_callback_tco_invite_get (const std::string &invite_code)
 Get details about an invite. More...
 
async< confirmation_callback_tco_message_add_reaction (const struct message &m, const std::string &reaction)
 Add a reaction to a message. More...
 
async< confirmation_callback_tco_message_add_reaction (snowflake message_id, snowflake channel_id, const std::string &reaction)
 Add a reaction to a message by id. More...
 
async< confirmation_callback_tco_message_create (const struct message &m)
 Send a message to a channel. More...
 
async< confirmation_callback_tco_message_crosspost (snowflake message_id, snowflake channel_id)
 Crosspost a message. More...
 
async< confirmation_callback_tco_message_delete (snowflake message_id, snowflake channel_id)
 Delete a message from a channel. More...
 
async< confirmation_callback_tco_message_delete_all_reactions (const struct message &m)
 Delete all reactions on a message. More...
 
async< confirmation_callback_tco_message_delete_all_reactions (snowflake message_id, snowflake channel_id)
 Delete all reactions on a message by id. More...
 
async< confirmation_callback_tco_message_delete_bulk (const std::vector< snowflake > &message_ids, snowflake channel_id)
 Bulk delete messages from a channel. More...
 
async< confirmation_callback_tco_message_delete_own_reaction (const struct message &m, const std::string &reaction)
 Delete own reaction from a message. More...
 
async< confirmation_callback_tco_message_delete_own_reaction (snowflake message_id, snowflake channel_id, const std::string &reaction)
 Delete own reaction from a message by id. More...
 
async< confirmation_callback_tco_message_delete_reaction (const struct message &m, snowflake user_id, const std::string &reaction)
 Delete a user's reaction from a message. More...
 
async< confirmation_callback_tco_message_delete_reaction (snowflake message_id, snowflake channel_id, snowflake user_id, const std::string &reaction)
 Delete a user's reaction from a message by id. More...
 
async< confirmation_callback_tco_message_delete_reaction_emoji (const struct message &m, const std::string &reaction)
 Delete all reactions on a message using a particular emoji. More...
 
async< confirmation_callback_tco_message_delete_reaction_emoji (snowflake message_id, snowflake channel_id, const std::string &reaction)
 Delete all reactions on a message using a particular emoji by id. More...
 
async< confirmation_callback_tco_message_edit (const struct message &m)
 Edit a message on a channel. More...
 
async< confirmation_callback_tco_message_edit_flags (const struct message &m)
 Edit the flags of a message on a channel. More...
 
async< confirmation_callback_tco_message_get (snowflake message_id, snowflake channel_id)
 Get a message. More...
 
async< confirmation_callback_tco_message_get_reactions (const struct message &m, const std::string &reaction, snowflake before, snowflake after, snowflake limit)
 Get reactions on a message for a particular emoji. More...
 
async< confirmation_callback_tco_message_get_reactions (snowflake message_id, snowflake channel_id, const std::string &reaction, snowflake before, snowflake after, snowflake limit)
 Get reactions on a message for a particular emoji by id. More...
 
async< confirmation_callback_tco_message_pin (snowflake channel_id, snowflake message_id)
 Pin a message. More...
 
async< confirmation_callback_tco_message_unpin (snowflake channel_id, snowflake message_id)
 Unpin a message. More...
 
async< confirmation_callback_tco_messages_get (snowflake channel_id, snowflake around, snowflake before, snowflake after, uint64_t limit)
 Get multiple messages. More...
 
async< confirmation_callback_tco_nitro_sticker_get (snowflake id)
 Get a nitro sticker. More...
 
async< confirmation_callback_tco_poll_end (const message &m)
 Immediately end a poll. More...
 
async< confirmation_callback_tco_poll_end (snowflake message_id, snowflake channel_id)
 Immediately end a poll. More...
 
async< confirmation_callback_tco_poll_get_answer_voters (const message &m, uint32_t answer_id, snowflake after, uint64_t limit)
 Get a list of users that voted for this specific answer. More...
 
async< confirmation_callback_tco_poll_get_answer_voters (snowflake message_id, snowflake channel_id, uint32_t answer_id, snowflake after, uint64_t limit)
 Get a list of users that voted for this specific answer. More...
 
async< confirmation_callback_tco_role_create (const class role &r)
 Create a role on a guild. More...
 
async< confirmation_callback_tco_role_delete (snowflake guild_id, snowflake role_id)
 Delete a role. More...
 
async< confirmation_callback_tco_role_edit (const class role &r)
 Edit a role on a guild. More...
 
async< confirmation_callback_tco_roles_edit_position (snowflake guild_id, const std::vector< role > &roles)
 Edit multiple role's position in a guild. More...
 
async< confirmation_callback_tco_roles_get (snowflake guild_id)
 Get a role for a guild. More...
 
async< confirmation_callback_tco_skus_get ()
 Returns all SKUs for a given application. More...
 
async< timerco_sleep (uint64_t seconds)
 Get an awaitable to wait a certain amount of seconds. More...
 
async< confirmation_callback_tco_stage_instance_delete (const snowflake channel_id)
 Delete a stage instance. More...
 
async< confirmation_callback_tco_stage_instance_get (const snowflake channel_id)
 Get the stage instance associated with the channel id, if it exists. More...
 
async< confirmation_callback_tco_sticker_packs_get ()
 Get a list of available sticker packs. More...
 
async< confirmation_callback_tco_template_get (const std::string &code)
 Get a template. More...
 
async< confirmation_callback_tco_thread_create (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)
 Create a thread. More...
 
async< confirmation_callback_tco_thread_create_in_forum (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={})
 Create a thread in a forum or media channel. More...
 
async< confirmation_callback_tco_thread_create_with_message (const std::string &thread_name, snowflake channel_id, snowflake message_id, uint16_t auto_archive_duration, uint16_t rate_limit_per_user)
 Create a thread with a message (Discord: ID of a thread is same as message ID) More...
 
async< confirmation_callback_tco_thread_edit (const thread &t)
 Edit a thread. More...
 
async< confirmation_callback_tco_thread_get (snowflake thread_id)
 Get the thread specified by thread_id. More...
 
async< confirmation_callback_tco_thread_member_add (snowflake thread_id, snowflake user_id)
 Add a member to a thread. More...
 
async< confirmation_callback_tco_thread_member_get (const snowflake thread_id, const snowflake user_id)
 Get a thread member. More...
 
async< confirmation_callback_tco_thread_member_remove (snowflake thread_id, snowflake user_id)
 Remove a member from a thread. More...
 
async< confirmation_callback_tco_thread_members_get (snowflake thread_id)
 Get members of a thread. More...
 
async< confirmation_callback_tco_threads_get_active (snowflake guild_id)
 Get all active threads in the guild, including public and private threads. More...
 
async< confirmation_callback_tco_threads_get_joined_private_archived (snowflake channel_id, snowflake before_id, uint16_t limit)
 Get private archived threads in a channel which current user has joined (Sorted by ID in descending order) More...
 
async< confirmation_callback_tco_threads_get_private_archived (snowflake channel_id, time_t before_timestamp, uint16_t limit)
 Get private archived threads in a channel (Sorted by archive_timestamp in descending order) More...
 
async< confirmation_callback_tco_threads_get_public_archived (snowflake channel_id, time_t before_timestamp, uint16_t limit)
 Get public archived threads in a channel (Sorted by archive_timestamp in descending order) More...
 
async< confirmation_callback_tco_user_application_role_connection_get (snowflake application_id)
 Get user application role connection. More...
 
async< confirmation_callback_tco_user_application_role_connection_update (snowflake application_id, const application_role_connection &connection)
 Update user application role connection. More...
 
async< confirmation_callback_tco_user_get (snowflake user_id)
 Get a user by id, without using the cache. More...
 
async< confirmation_callback_tco_user_get_cached (snowflake user_id)
 Get a user by id, checking in the cache first. More...
 
async< confirmation_callback_tco_user_set_voice_state (snowflake user_id, snowflake guild_id, snowflake channel_id, bool suppress=false)
 Set a user's voice state on a stage channel. More...
 
void create_dm_channel (snowflake user_id, command_completion_event_t callback=utility::log_error())
 Create a dm channel. More...
 
channel create_dm_channel_sync (snowflake user_id)
 Create a dm channel. More...
 
void create_webhook (const class webhook &w, command_completion_event_t callback=utility::log_error())
 Create a webhook. More...
 
void current_application_get (command_completion_event_t callback)
 Get current (bot) application. More...
 
application current_application_get_sync ()
 Get current (bot) application. More...
 
void current_user_connections_get (command_completion_event_t callback)
 Get current user's connections (linked accounts, e.g. More...
 
connection_map current_user_connections_get_sync ()
 Get current user's connections (linked accounts, e.g. More...
 
void current_user_edit (const std::string &nickname, const std::string &image_blob="", const image_type type=i_png, command_completion_event_t callback=utility::log_error())
 Edit current (bot) user. More...
 
user current_user_edit_sync (const std::string &nickname, const std::string &image_blob="", const image_type type=i_png)
 Edit current (bot) user. More...
 
void current_user_get (command_completion_event_t callback)
 Get current (bot) user. More...
 
void current_user_get_dms (command_completion_event_t callback)
 Get current user DM channels. More...
 
channel_map current_user_get_dms_sync ()
 Get current user DM channels. More...
 
void current_user_get_guilds (command_completion_event_t callback)
 Get current (bot) user guilds. More...
 
guild_map current_user_get_guilds_sync ()
 Get current (bot) user guilds. More...
 
user_identified current_user_get_sync ()
 Get current (bot) user. More...
 
void current_user_join_thread (snowflake thread_id, command_completion_event_t callback=utility::log_error())
 Join a thread. More...
 
confirmation current_user_join_thread_sync (snowflake thread_id)
 Join a thread. More...
 
void current_user_leave_guild (snowflake guild_id, command_completion_event_t callback=utility::log_error())
 Leave a guild. More...
 
confirmation current_user_leave_guild_sync (snowflake guild_id)
 Leave a guild. More...
 
void current_user_leave_thread (snowflake thread_id, command_completion_event_t callback=utility::log_error())
 Leave a thread. More...
 
confirmation current_user_leave_thread_sync (snowflake thread_id)
 Leave a thread. More...
 
void current_user_set_voice_state (snowflake guild_id, snowflake channel_id, bool suppress=false, time_t request_to_speak_timestamp=0, command_completion_event_t callback=utility::log_error())
 Set the bot's voice state on a stage channel. More...
 
confirmation current_user_set_voice_state_sync (snowflake guild_id, snowflake channel_id, bool suppress=false, time_t request_to_speak_timestamp=0)
 Set the bot's voice state on a stage channel. More...
 
void delete_webhook (snowflake webhook_id, command_completion_event_t callback=utility::log_error())
 Delete a webhook. More...
 
void delete_webhook_message (const class webhook &wh, snowflake message_id, snowflake thread_id=0, command_completion_event_t callback=utility::log_error())
 Delete webhook message. More...
 
confirmation delete_webhook_message_sync (const class webhook &wh, snowflake message_id, snowflake thread_id=0)
 Delete webhook message. More...
 
confirmation delete_webhook_sync (snowflake webhook_id)
 Delete a webhook. More...
 
void delete_webhook_with_token (snowflake webhook_id, const std::string &token, command_completion_event_t callback=utility::log_error())
 Delete webhook with token. More...
 
confirmation delete_webhook_with_token_sync (snowflake webhook_id, const std::string &token)
 Delete webhook with token. More...
 
void direct_message_create (snowflake user_id, const message &m, command_completion_event_t callback=utility::log_error())
 Create a direct message, also create the channel for the direct message if needed. More...
 
message direct_message_create_sync (snowflake user_id, const message &m)
 Create a direct message, also create the channel for the direct message if needed. More...
 
void edit_webhook (const class webhook &wh, command_completion_event_t callback=utility::log_error())
 Edit webhook. More...
 
void edit_webhook_message (const class webhook &wh, const struct message &m, snowflake thread_id=0, command_completion_event_t callback=utility::log_error())
 Edit webhook message. More...
 
message edit_webhook_message_sync (const class webhook &wh, const struct message &m, snowflake thread_id=0)
 Edit webhook message. More...
 
webhook edit_webhook_sync (const class webhook &wh)
 Edit webhook. More...
 
void edit_webhook_with_token (const class webhook &wh, command_completion_event_t callback=utility::log_error())
 Edit webhook with token (token is encapsulated in the webhook object) More...
 
webhook edit_webhook_with_token_sync (const class webhook &wh)
 Edit webhook with token (token is encapsulated in the webhook object) More...
 
void entitlement_test_create (const class entitlement &new_entitlement, command_completion_event_t callback=utility::log_error())
 Creates a test entitlement to a given SKU for a given guild or user. More...
 
entitlement entitlement_test_create_sync (const class entitlement &new_entitlement)
 Creates a test entitlement to a given SKU for a given guild or user. More...
 
void entitlement_test_delete (snowflake entitlement_id, command_completion_event_t callback=utility::log_error())
 Deletes a currently-active test entitlement. More...
 
confirmation entitlement_test_delete_sync (snowflake entitlement_id)
 Deletes a currently-active test entitlement. More...
 
void entitlements_get (snowflake user_id=0, const std::vector< snowflake > &sku_ids={}, snowflake before_id=0, snowflake after_id=0, uint8_t limit=100, snowflake guild_id=0, bool exclude_ended=false, command_completion_event_t callback=utility::log_error())
 Returns all entitlements for a given app, active and expired. More...
 
entitlement_map entitlements_get_sync (snowflake user_id=0, const std::vector< snowflake > &sku_ids={}, snowflake before_id=0, snowflake after_id=0, uint8_t limit=100, snowflake guild_id=0, bool exclude_ended=false)
 Returns all entitlements for a given app, active and expired. More...
 
void execute_webhook (const class webhook &wh, const struct message &m, bool wait=false, snowflake thread_id=0, const std::string &thread_name="", command_completion_event_t callback=utility::log_error())
 Execute webhook. More...
 
message execute_webhook_sync (const class webhook &wh, const struct message &m, bool wait=false, snowflake thread_id=0, const std::string &thread_name="")
 Execute webhook. More...
 
void gdm_add (snowflake channel_id, snowflake user_id, const std::string &access_token, const std::string &nick, command_completion_event_t callback=utility::log_error())
 Adds a recipient to a Group DM using their access token. More...
 
confirmation gdm_add_sync (snowflake channel_id, snowflake user_id, const std::string &access_token, const std::string &nick)
 Adds a recipient to a Group DM using their access token. More...
 
void gdm_remove (snowflake channel_id, snowflake user_id, command_completion_event_t callback=utility::log_error())
 Removes a recipient from a Group DM. More...
 
confirmation gdm_remove_sync (snowflake channel_id, snowflake user_id)
 Removes a recipient from a Group DM. More...
 
std::string get_audit_reason ()
 Get the audit reason set for the next REST call to be made on this thread. More...
 
void get_channel_webhooks (snowflake channel_id, command_completion_event_t callback)
 Get channel webhooks. More...
 
webhook_map get_channel_webhooks_sync (snowflake channel_id)
 Get channel webhooks. More...
 
snowflake get_dm_channel (snowflake user_id)
 Get the dm channel for a user id. More...
 
void get_gateway_bot (command_completion_event_t callback)
 Get the gateway information for the bot using the token. More...
 
gateway get_gateway_bot_sync ()
 Get the gateway information for the bot using the token. More...
 
void get_guild_webhooks (snowflake guild_id, command_completion_event_t callback)
 Get guild webhooks. More...
 
webhook_map get_guild_webhooks_sync (snowflake guild_id)
 Get guild webhooks. More...
 
request_queueget_raw_rest ()
 Get the raw rest_queue object which handles all HTTP(S) requests that are not directed at Discord. More...
 
request_queueget_rest ()
 Get the rest_queue object which handles HTTPS requests to Discord. More...
 
discord_clientget_shard (uint32_t id)
 Get a shard by id, returning the discord_client. More...
 
const shard_listget_shards ()
 Get the list of shards. More...
 
void get_voice_regions (command_completion_event_t callback)
 Get all voice regions. More...
 
voiceregion_map get_voice_regions_sync ()
 Get all voice regions. More...
 
void get_webhook (snowflake webhook_id, command_completion_event_t callback)
 Get webhook. More...
 
void get_webhook_message (const class webhook &wh, snowflake message_id, snowflake thread_id=0, command_completion_event_t callback=utility::log_error())
 Get webhook message. More...
 
message get_webhook_message_sync (const class webhook &wh, snowflake message_id, snowflake thread_id=0)
 Get webhook message. More...
 
webhook get_webhook_sync (snowflake webhook_id)
 Get webhook. More...
 
void get_webhook_with_token (snowflake webhook_id, const std::string &token, command_completion_event_t callback)
 Get webhook using token. More...
 
webhook get_webhook_with_token_sync (snowflake webhook_id, const std::string &token)
 Get webhook using token. More...
 
void global_bulk_command_create (const std::vector< slashcommand > &commands, command_completion_event_t callback=utility::log_error())
 Create/overwrite global slash commands. More...
 
slashcommand_map global_bulk_command_create_sync (const std::vector< slashcommand > &commands)
 Create/overwrite global slash commands. More...
 
void global_bulk_command_delete (command_completion_event_t callback=utility::log_error())
 Delete all existing global slash commands. More...
 
slashcommand_map global_bulk_command_delete_sync ()
 Delete all existing global slash commands. More...
 
void global_command_create (const slashcommand &s, command_completion_event_t callback=utility::log_error())
 Create a global slash command (a bot can have a maximum of 100 of these). More...
 
slashcommand global_command_create_sync (const slashcommand &s)
 Create a global slash command (a bot can have a maximum of 100 of these). More...
 
void global_command_delete (snowflake id, command_completion_event_t callback=utility::log_error())
 Delete a global slash command (a bot can have a maximum of 100 of these) More...
 
confirmation global_command_delete_sync (snowflake id)
 Delete a global slash command (a bot can have a maximum of 100 of these) More...
 
void global_command_edit (const slashcommand &s, command_completion_event_t callback=utility::log_error())
 Edit a global slash command (a bot can have a maximum of 100 of these) More...
 
confirmation global_command_edit_sync (const slashcommand &s)
 Edit a global slash command (a bot can have a maximum of 100 of these) More...
 
void global_command_get (snowflake id, command_completion_event_t callback=utility::log_error())
 Get a global slash command. More...
 
slashcommand global_command_get_sync (snowflake id)
 Get a global slash command. More...
 
void global_commands_get (command_completion_event_t callback)
 Get the application's global slash commands. More...
 
slashcommand_map global_commands_get_sync ()
 Get the application's global slash commands. More...
 
void guild_add_member (const guild_member &gm, const std::string &access_token, command_completion_event_t callback=utility::log_error())
 Add guild member. More...
 
confirmation guild_add_member_sync (const guild_member &gm, const std::string &access_token)
 Add guild member. More...
 
void guild_auditlog_get (snowflake guild_id, snowflake user_id, uint32_t action_type, snowflake before, snowflake after, uint32_t limit, command_completion_event_t callback)
 Get the audit log for a guild. More...
 
auditlog guild_auditlog_get_sync (snowflake guild_id, snowflake user_id, uint32_t action_type, snowflake before, snowflake after, uint32_t limit)
 Get the audit log for a guild. More...
 
void guild_ban_add (snowflake guild_id, snowflake user_id, uint32_t delete_message_seconds=0, command_completion_event_t callback=utility::log_error())
 Add guild ban. More...
 
confirmation guild_ban_add_sync (snowflake guild_id, snowflake user_id, uint32_t delete_message_seconds=0)
 Add guild ban. More...
 
void guild_ban_delete (snowflake guild_id, snowflake user_id, command_completion_event_t callback=utility::log_error())
 Delete guild ban. More...
 
confirmation guild_ban_delete_sync (snowflake guild_id, snowflake user_id)
 Delete guild ban. More...
 
void guild_begin_prune (snowflake guild_id, const struct prune &pruneinfo, command_completion_event_t callback=utility::log_error())
 Begin guild prune. More...
 
prune guild_begin_prune_sync (snowflake guild_id, const struct prune &pruneinfo)
 Begin guild prune. More...
 
void guild_bulk_command_create (const std::vector< slashcommand > &commands, snowflake guild_id, command_completion_event_t callback=utility::log_error())
 Create/overwrite guild slash commands. More...
 
slashcommand_map guild_bulk_command_create_sync (const std::vector< slashcommand > &commands, snowflake guild_id)
 Create/overwrite guild slash commands. More...
 
void guild_bulk_command_delete (snowflake guild_id, command_completion_event_t callback=utility::log_error())
 Delete all existing guild slash commands. More...
 
slashcommand_map guild_bulk_command_delete_sync (snowflake guild_id)
 Delete all existing guild slash commands. More...
 
void guild_bulk_command_edit_permissions (const std::vector< slashcommand > &commands, snowflake guild_id, command_completion_event_t callback=utility::log_error())
 Edit/Overwrite the permissions of all existing slash commands in a guild. More...
 
guild_command_permissions_map guild_bulk_command_edit_permissions_sync (const std::vector< slashcommand > &commands, snowflake guild_id)
 Edit/Overwrite the permissions of all existing slash commands in a guild. More...
 
void guild_command_create (const slashcommand &s, snowflake guild_id, command_completion_event_t callback=utility::log_error())
 Create a slash command local to a guild. More...
 
slashcommand guild_command_create_sync (const slashcommand &s, snowflake guild_id)
 Create a slash command local to a guild. More...
 
void guild_command_delete (snowflake id, snowflake guild_id, command_completion_event_t callback=utility::log_error())
 Delete a slash command local to a guild. More...
 
confirmation guild_command_delete_sync (snowflake id, snowflake guild_id)
 Delete a slash command local to a guild. More...
 
void guild_command_edit (const slashcommand &s, snowflake guild_id, command_completion_event_t callback=utility::log_error())
 Edit a slash command local to a guild. More...
 
void guild_command_edit_permissions (const slashcommand &s, snowflake guild_id, command_completion_event_t callback=utility::log_error())
 Edit slash command permissions of a guild. More...
 
confirmation guild_command_edit_permissions_sync (const slashcommand &s, snowflake guild_id)
 Edit slash command permissions of a guild. More...
 
confirmation guild_command_edit_sync (const slashcommand &s, snowflake guild_id)
 Edit a slash command local to a guild. More...
 
void guild_command_get (snowflake id, snowflake guild_id, command_completion_event_t callback=utility::log_error())
 Get a slash command of a guild. More...
 
void guild_command_get_permissions (snowflake id, snowflake guild_id, command_completion_event_t callback=utility::log_error())
 Get the permissions for a slash command of a guild. More...
 
guild_command_permissions guild_command_get_permissions_sync (snowflake id, snowflake guild_id)
 Get the permissions for a slash command of a guild. More...
 
slashcommand guild_command_get_sync (snowflake id, snowflake guild_id)
 Get a slash command of a guild. More...
 
void guild_commands_get (snowflake guild_id, command_completion_event_t callback)
 Get the application's slash commands for a guild. More...
 
void guild_commands_get_permissions (snowflake guild_id, command_completion_event_t callback)
 Get all slash command permissions of a guild. More...
 
guild_command_permissions_map guild_commands_get_permissions_sync (snowflake guild_id)
 Get all slash command permissions of a guild. More...
 
slashcommand_map guild_commands_get_sync (snowflake guild_id)
 Get the application's slash commands for a guild. More...
 
void guild_create (const class guild &g, command_completion_event_t callback=utility::log_error())
 Create a guild. More...
 
void guild_create_from_template (const std::string &code, const std::string &name, command_completion_event_t callback=utility::log_error())
 Create a new guild based on a template. More...
 
guild guild_create_from_template_sync (const std::string &code, const std::string &name)
 Create a new guild based on a template. More...
 
guild guild_create_sync (const class guild &g)
 Create a guild. More...
 
void guild_current_member_edit (snowflake guild_id, const std::string &nickname, command_completion_event_t callback=utility::log_error())
 Modify current member. More...
 
confirmation guild_current_member_edit_sync (snowflake guild_id, const std::string &nickname)
 Modify current member. More...
 
void guild_delete (snowflake guild_id, command_completion_event_t callback=utility::log_error())
 Delete a guild. More...
 
void guild_delete_integration (snowflake guild_id, snowflake integration_id, command_completion_event_t callback=utility::log_error())
 Delete guild integration. More...
 
confirmation guild_delete_integration_sync (snowflake guild_id, snowflake integration_id)
 Delete guild integration. More...
 
confirmation guild_delete_sync (snowflake guild_id)
 Delete a guild. More...
 
void guild_edit (const class guild &g, command_completion_event_t callback=utility::log_error())
 Edit a guild. More...
 
void guild_edit_member (const guild_member &gm, command_completion_event_t callback=utility::log_error())
 Edit the properties of an existing guild member. More...
 
guild_member guild_edit_member_sync (const guild_member &gm)
 Edit the properties of an existing guild member. More...
 
void guild_edit_onboarding (const struct onboarding &o, command_completion_event_t callback=utility::log_error())
 Edit the guild's onboarding configuration. More...
 
onboarding guild_edit_onboarding_sync (const struct onboarding &o)
 Edit the guild's onboarding configuration. More...
 
guild guild_edit_sync (const class guild &g)
 Edit a guild. More...
 
void guild_edit_welcome_screen (snowflake guild_id, const struct welcome_screen &welcome_screen, bool enabled, command_completion_event_t callback=utility::log_error())
 Edit the guild's welcome screen. More...
 
dpp::welcome_screen guild_edit_welcome_screen_sync (snowflake guild_id, const struct welcome_screen &welcome_screen, bool enabled)
 Edit the guild's welcome screen. More...
 
void guild_edit_widget (snowflake guild_id, const class guild_widget &gw, command_completion_event_t callback=utility::log_error())
 Edit guild widget. More...
 
guild_widget guild_edit_widget_sync (snowflake guild_id, const class guild_widget &gw)
 Edit guild widget. More...
 
void guild_emoji_create (snowflake guild_id, const class emoji &newemoji, command_completion_event_t callback=utility::log_error())
 Create single emoji. More...
 
emoji guild_emoji_create_sync (snowflake guild_id, const class emoji &newemoji)
 Create single emoji. More...
 
void guild_emoji_delete (snowflake guild_id, snowflake emoji_id, command_completion_event_t callback=utility::log_error())
 Delete a guild emoji. More...
 
confirmation guild_emoji_delete_sync (snowflake guild_id, snowflake emoji_id)
 Delete a guild emoji. More...
 
void guild_emoji_edit (snowflake guild_id, const class emoji &newemoji, command_completion_event_t callback=utility::log_error())
 Edit a single emoji. More...
 
emoji guild_emoji_edit_sync (snowflake guild_id, const class emoji &newemoji)
 Edit a single emoji. More...
 
void guild_emoji_get (snowflake guild_id, snowflake emoji_id, command_completion_event_t callback)
 Get a single emoji. More...
 
emoji guild_emoji_get_sync (snowflake guild_id, snowflake emoji_id)
 Get a single emoji. More...
 
void guild_emojis_get (snowflake guild_id, command_completion_event_t callback)
 Get all emojis for a guild. More...
 
emoji_map guild_emojis_get_sync (snowflake guild_id)
 Get all emojis for a guild. More...
 
void guild_event_create (const scheduled_event &event, command_completion_event_t callback=utility::log_error())
 Create a scheduled event on a guild. More...
 
scheduled_event guild_event_create_sync (const scheduled_event &event)
 Create a scheduled event on a guild. More...
 
void guild_event_delete (snowflake event_id, snowflake guild_id, command_completion_event_t callback=utility::log_error())
 Delete a scheduled event from a guild. More...
 
confirmation guild_event_delete_sync (snowflake event_id, snowflake guild_id)
 Delete a scheduled event from a guild. More...
 
void guild_event_edit (const scheduled_event &event, command_completion_event_t callback=utility::log_error())
 Edit/modify a scheduled event on a guild. More...
 
scheduled_event guild_event_edit_sync (const scheduled_event &event)
 Edit/modify a scheduled event on a guild. More...
 
void guild_event_get (snowflake guild_id, snowflake event_id, command_completion_event_t callback)
 Get a scheduled event for a guild. More...
 
scheduled_event guild_event_get_sync (snowflake guild_id, snowflake event_id)
 Get a scheduled event for a guild. More...
 
void guild_event_users_get (snowflake guild_id, snowflake event_id, command_completion_event_t callback, uint8_t limit=100, snowflake before=0, snowflake after=0)
 Get users RSVP'd to an event. More...
 
void guild_events_get (snowflake guild_id, command_completion_event_t callback)
 Get all scheduled events for a guild. More...
 
scheduled_event_map guild_events_get_sync (snowflake guild_id)
 Get all scheduled events for a guild. More...
 
void guild_get (snowflake g, command_completion_event_t callback)
 Get a guild. More...
 
void guild_get_ban (snowflake guild_id, snowflake user_id, command_completion_event_t callback)
 Get single guild ban. More...
 
ban guild_get_ban_sync (snowflake guild_id, snowflake user_id)
 Get single guild ban. More...
 
void guild_get_bans (snowflake guild_id, snowflake before, snowflake after, snowflake limit, command_completion_event_t callback)
 Get guild ban list. More...
 
ban_map guild_get_bans_sync (snowflake guild_id, snowflake before, snowflake after, snowflake limit)
 Get guild ban list. More...
 
void guild_get_integrations (snowflake guild_id, command_completion_event_t callback)
 Get guild integrations. More...
 
integration_map guild_get_integrations_sync (snowflake guild_id)
 Get guild integrations. More...
 
void guild_get_invites (snowflake guild_id, command_completion_event_t callback)
 Get guild invites. More...
 
invite_map guild_get_invites_sync (snowflake guild_id)
 Get guild invites. More...
 
void guild_get_member (snowflake guild_id, snowflake user_id, command_completion_event_t callback)
 Get a guild member. More...
 
guild_member guild_get_member_sync (snowflake guild_id, snowflake user_id)
 Get a guild member. More...
 
void guild_get_members (snowflake guild_id, uint16_t limit, snowflake after, command_completion_event_t callback)
 Get all guild members. More...
 
guild_member_map guild_get_members_sync (snowflake guild_id, uint16_t limit, snowflake after)
 Get all guild members. More...
 
void guild_get_onboarding (snowflake guild_id, command_completion_event_t callback)
 Get the guild's onboarding configuration. More...
 
onboarding guild_get_onboarding_sync (snowflake guild_id)
 Get the guild's onboarding configuration. More...
 
void guild_get_preview (snowflake g, command_completion_event_t callback)
 Get a guild preview. More...
 
void guild_get_prune_counts (snowflake guild_id, const struct prune &pruneinfo, command_completion_event_t callback)
 Get prune counts. More...
 
prune guild_get_prune_counts_sync (snowflake guild_id, const struct prune &pruneinfo)
 Get prune counts. More...
 
void guild_get_vanity (snowflake guild_id, command_completion_event_t callback)
 Get guild vanity url, if enabled. More...
 
invite guild_get_vanity_sync (snowflake guild_id)
 Get guild vanity url, if enabled. More...
 
void guild_get_voice_regions (snowflake guild_id, command_completion_event_t callback)
 Get guild voice regions. More...
 
voiceregion_map guild_get_voice_regions_sync (snowflake guild_id)
 Get guild voice regions. More...
 
void guild_get_welcome_screen (snowflake guild_id, command_completion_event_t callback)
 Get the guild's welcome screen. More...
 
dpp::welcome_screen guild_get_welcome_screen_sync (snowflake guild_id)
 Get the guild's welcome screen. More...
 
void guild_get_widget (snowflake guild_id, command_completion_event_t callback)
 Get guild widget. More...
 
guild_widget guild_get_widget_sync (snowflake guild_id)
 Get guild widget. More...
 
void guild_member_add_role (snowflake guild_id, snowflake user_id, snowflake role_id, command_completion_event_t callback=utility::log_error())
 Add role to guild member. More...
 
confirmation guild_member_add_role_sync (snowflake guild_id, snowflake user_id, snowflake role_id)
 Add role to guild member. More...
 
void guild_member_delete (snowflake guild_id, snowflake user_id, command_completion_event_t callback=utility::log_error())
 Remove (kick) a guild member. More...
 
void guild_member_delete_role (snowflake guild_id, snowflake user_id, snowflake role_id, command_completion_event_t callback=utility::log_error())
 Remove role from guild member. More...
 
confirmation guild_member_delete_role_sync (snowflake guild_id, snowflake user_id, snowflake role_id)
 Remove role from guild member. More...
 
confirmation guild_member_delete_sync (snowflake guild_id, snowflake user_id)
 Remove (kick) a guild member. More...
 
void guild_member_kick (snowflake guild_id, snowflake user_id, command_completion_event_t callback=utility::log_error())
 Remove (kick) a guild member. More...
 
confirmation guild_member_kick_sync (snowflake guild_id, snowflake user_id)
 Remove (kick) a guild member. More...
 
void guild_member_move (const snowflake channel_id, const snowflake guild_id, const snowflake user_id, command_completion_event_t callback=utility::log_error())
 Moves the guild member to a other voice channel, if member is connected to one. More...
 
guild_member guild_member_move_sync (const snowflake channel_id, const snowflake guild_id, const snowflake user_id)
 Moves the guild member to a other voice channel, if member is connected to one. More...
 
void guild_member_remove_role (snowflake guild_id, snowflake user_id, snowflake role_id, command_completion_event_t callback=utility::log_error())
 Remove role from guild member. More...
 
confirmation guild_member_remove_role_sync (snowflake guild_id, snowflake user_id, snowflake role_id)
 Remove role from guild member. More...
 
void guild_member_timeout (snowflake guild_id, snowflake user_id, time_t communication_disabled_until, command_completion_event_t callback=utility::log_error())
 Set the timeout of a guild member. More...
 
void guild_member_timeout_remove (snowflake guild_id, snowflake user_id, command_completion_event_t callback=utility::log_error())
 Remove the timeout of a guild member. More...
 
confirmation guild_member_timeout_remove_sync (snowflake guild_id, snowflake user_id)
 Remove the timeout of a guild member. More...
 
confirmation guild_member_timeout_sync (snowflake guild_id, snowflake user_id, time_t communication_disabled_until)
 Set the timeout of a guild member. More...
 
void guild_modify_integration (snowflake guild_id, const class integration &i, command_completion_event_t callback=utility::log_error())
 Modify guild integration. More...
 
confirmation guild_modify_integration_sync (snowflake guild_id, const class integration &i)
 Modify guild integration. More...
 
void guild_search_members (snowflake guild_id, const std::string &query, uint16_t limit, command_completion_event_t callback)
 Search for guild members based on whether their username or nickname starts with the given string. More...
 
guild_member_map guild_search_members_sync (snowflake guild_id, const std::string &query, uint16_t limit)
 Search for guild members based on whether their username or nickname starts with the given string. More...
 
void guild_set_nickname (snowflake guild_id, const std::string &nickname, command_completion_event_t callback=utility::log_error())
 Change current user nickname. More...
 
confirmation guild_set_nickname_sync (snowflake guild_id, const std::string &nickname)
 Change current user nickname. More...
 
void guild_sticker_create (const sticker &s, command_completion_event_t callback=utility::log_error())
 Create a sticker in a guild. More...
 
sticker guild_sticker_create_sync (const sticker &s)
 Create a sticker in a guild. More...
 
void guild_sticker_delete (snowflake sticker_id, snowflake guild_id, command_completion_event_t callback=utility::log_error())
 Delete a sticker from a guild. More...
 
confirmation guild_sticker_delete_sync (snowflake sticker_id, snowflake guild_id)
 Delete a sticker from a guild. More...
 
void guild_sticker_get (snowflake id, snowflake guild_id, command_completion_event_t callback)
 Get a guild sticker. More...
 
sticker guild_sticker_get_sync (snowflake id, snowflake guild_id)
 Get a guild sticker. More...
 
void guild_sticker_modify (const sticker &s, command_completion_event_t callback=utility::log_error())
 Modify a sticker in a guild. More...
 
sticker guild_sticker_modify_sync (const sticker &s)
 Modify a sticker in a guild. More...
 
void guild_stickers_get (snowflake guild_id, command_completion_event_t callback)
 Get all guild stickers. More...
 
sticker_map guild_stickers_get_sync (snowflake guild_id)
 Get all guild stickers. More...
 
void guild_sync_integration (snowflake guild_id, snowflake integration_id, command_completion_event_t callback=utility::log_error())
 Sync guild integration. More...
 
confirmation guild_sync_integration_sync (snowflake guild_id, snowflake integration_id)
 Sync guild integration. More...
 
void guild_template_create (snowflake guild_id, const std::string &name, const std::string &description, command_completion_event_t callback=utility::log_error())
 Creates a template for the guild. More...
 
dtemplate guild_template_create_sync (snowflake guild_id, const std::string &name, const std::string &description)
 Creates a template for the guild. More...
 
void guild_template_delete (snowflake guild_id, const std::string &code, command_completion_event_t callback=utility::log_error())
 Deletes the template. More...
 
confirmation guild_template_delete_sync (snowflake guild_id, const std::string &code)
 Deletes the template. More...
 
void guild_template_modify (snowflake guild_id, const std::string &code, const std::string &name, const std::string &description, command_completion_event_t callback=utility::log_error())
 Modifies the template's metadata. More...
 
dtemplate guild_template_modify_sync (snowflake guild_id, const std::string &code, const std::string &name, const std::string &description)
 Modifies the template's metadata. More...
 
void guild_template_sync (snowflake guild_id, const std::string &code, command_completion_event_t callback=utility::log_error())
 Syncs the template to the guild's current state. More...
 
dtemplate guild_template_sync_sync (snowflake guild_id, const std::string &code)
 Syncs the template to the guild's current state. More...
 
void guild_templates_get (snowflake guild_id, command_completion_event_t callback)
 Get guild templates. More...
 
dtemplate_map guild_templates_get_sync (snowflake guild_id)
 Get guild templates. More...
 
void interaction_followup_create (const std::string &token, const message &m, command_completion_event_t callback=utility::log_error())
 Create a followup message to a slash command. More...
 
confirmation interaction_followup_create_sync (const std::string &token, const message &m)
 Create a followup message to a slash command. More...
 
void interaction_followup_delete (const std::string &token, command_completion_event_t callback=utility::log_error())
 Delete the initial interaction response. More...
 
confirmation interaction_followup_delete_sync (const std::string &token)
 Delete the initial interaction response. More...
 
void interaction_followup_edit (const std::string &token, const message &m, command_completion_event_t callback=utility::log_error())
 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. More...
 
void interaction_followup_edit_original (const std::string &token, const message &m, command_completion_event_t callback=utility::log_error())
 Edit original followup message to a slash command This is an alias for cluster::interaction_response_edit. More...
 
confirmation interaction_followup_edit_original_sync (const std::string &token, const message &m)
 Edit original followup message to a slash command This is an alias for cluster::interaction_response_edit. More...
 
confirmation interaction_followup_edit_sync (const std::string &token, const message &m)
 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. More...
 
void interaction_followup_get (const std::string &token, snowflake message_id, command_completion_event_t callback)
 Get the followup message to a slash command. More...
 
void interaction_followup_get_original (const std::string &token, command_completion_event_t callback=utility::log_error())
 Get the original followup message to a slash command This is an alias for cluster::interaction_response_get_original. More...
 
message interaction_followup_get_original_sync (const std::string &token)
 Get the original followup message to a slash command This is an alias for cluster::interaction_response_get_original. More...
 
message interaction_followup_get_sync (const std::string &token, snowflake message_id)
 Get the followup message to a slash command. More...
 
void interaction_response_create (snowflake interaction_id, const std::string &token, const interaction_response &r, command_completion_event_t callback=utility::log_error())
 Respond to a slash command. More...
 
confirmation interaction_response_create_sync (snowflake interaction_id, const std::string &token, const interaction_response &r)
 Respond to a slash command. More...
 
void interaction_response_edit (const std::string &token, const message &m, command_completion_event_t callback=utility::log_error())
 Edit response to a slash command. More...
 
confirmation interaction_response_edit_sync (const std::string &token, const message &m)
 Edit response to a slash command. More...
 
void interaction_response_get_original (const std::string &token, command_completion_event_t callback=utility::log_error())
 Get the original response to a slash command. More...
 
message interaction_response_get_original_sync (const std::string &token)
 Get the original response to a slash command. More...
 
void invite_delete (const std::string &invite, command_completion_event_t callback=utility::log_error())
 Delete an invite. More...
 
void invite_get (const std::string &invite_code, command_completion_event_t callback)
 Get details about an invite. More...
 
invite invite_get_sync (const std::string &invite_code)
 Get details about an invite. More...
 
void log (dpp::loglevel severity, const std::string &msg) const
 Log a message to whatever log the user is using. More...
 
void message_add_reaction (const struct message &m, const std::string &reaction, command_completion_event_t callback=utility::log_error())
 Add a reaction to a message. More...
 
void message_add_reaction (snowflake message_id, snowflake channel_id, const std::string &reaction, command_completion_event_t callback=utility::log_error())
 Add a reaction to a message by id. More...
 
confirmation message_add_reaction_sync (const struct message &m, const std::string &reaction)
 Add a reaction to a message. More...
 
confirmation message_add_reaction_sync (snowflake message_id, snowflake channel_id, const std::string &reaction)
 Add a reaction to a message by id. More...
 
void message_create (const struct message &m, command_completion_event_t callback=utility::log_error())
 Send a message to a channel. More...
 
message message_create_sync (const struct message &m)
 Send a message to a channel. More...
 
void message_crosspost (snowflake message_id, snowflake channel_id, command_completion_event_t callback=utility::log_error())
 Crosspost a message. More...
 
message message_crosspost_sync (snowflake message_id, snowflake channel_id)
 Crosspost a message. More...
 
void message_delete (snowflake message_id, snowflake channel_id, command_completion_event_t callback=utility::log_error())
 Delete a message from a channel. More...
 
void message_delete_all_reactions (const struct message &m, command_completion_event_t callback=utility::log_error())
 Delete all reactions on a message. More...
 
void message_delete_all_reactions (snowflake message_id, snowflake channel_id, command_completion_event_t callback=utility::log_error())
 Delete all reactions on a message by id. More...
 
confirmation message_delete_all_reactions_sync (const struct message &m)
 Delete all reactions on a message. More...
 
confirmation message_delete_all_reactions_sync (snowflake message_id, snowflake channel_id)
 Delete all reactions on a message by id. More...
 
void message_delete_bulk (const std::vector< snowflake > &message_ids, snowflake channel_id, command_completion_event_t callback=utility::log_error())
 Bulk delete messages from a channel. More...
 
confirmation message_delete_bulk_sync (const std::vector< snowflake > &message_ids, snowflake channel_id)
 Bulk delete messages from a channel. More...
 
void message_delete_own_reaction (const struct message &m, const std::string &reaction, command_completion_event_t callback=utility::log_error())
 Delete own reaction from a message. More...
 
void message_delete_own_reaction (snowflake message_id, snowflake channel_id, const std::string &reaction, command_completion_event_t callback=utility::log_error())
 Delete own reaction from a message by id. More...
 
confirmation message_delete_own_reaction_sync (const struct message &m, const std::string &reaction)
 Delete own reaction from a message. More...
 
confirmation message_delete_own_reaction_sync (snowflake message_id, snowflake channel_id, const std::string &reaction)
 Delete own reaction from a message by id. More...
 
void message_delete_reaction (const struct message &m, snowflake user_id, const std::string &reaction, command_completion_event_t callback=utility::log_error())
 Delete a user's reaction from a message. More...
 
void message_delete_reaction (snowflake message_id, snowflake channel_id, snowflake user_id, const std::string &reaction, command_completion_event_t callback=utility::log_error())
 Delete a user's reaction from a message by id. More...
 
void message_delete_reaction_emoji (const struct message &m, const std::string &reaction, command_completion_event_t callback=utility::log_error())
 Delete all reactions on a message using a particular emoji. More...
 
void message_delete_reaction_emoji (snowflake message_id, snowflake channel_id, const std::string &reaction, command_completion_event_t callback=utility::log_error())
 Delete all reactions on a message using a particular emoji by id. More...
 
confirmation message_delete_reaction_emoji_sync (const struct message &m, const std::string &reaction)
 Delete all reactions on a message using a particular emoji. More...
 
confirmation message_delete_reaction_emoji_sync (snowflake message_id, snowflake channel_id, const std::string &reaction)
 Delete all reactions on a message using a particular emoji by id. More...
 
confirmation message_delete_reaction_sync (const struct message &m, snowflake user_id, const std::string &reaction)
 Delete a user's reaction from a message. More...
 
confirmation message_delete_reaction_sync (snowflake message_id, snowflake channel_id, snowflake user_id, const std::string &reaction)
 Delete a user's reaction from a message by id. More...
 
confirmation message_delete_sync (snowflake message_id, snowflake channel_id)
 Delete a message from a channel. More...
 
void message_edit (const struct message &m, command_completion_event_t callback=utility::log_error())
 Edit a message on a channel. More...
 
void message_edit_flags (const struct message &m, command_completion_event_t callback=utility::log_error())
 Edit the flags of a message on a channel. More...
 
message message_edit_flags_sync (const struct message &m)
 Edit the flags of a message on a channel. More...
 
message message_edit_sync (const struct message &m)
 Edit a message on a channel. More...
 
void message_get (snowflake message_id, snowflake channel_id, command_completion_event_t callback)
 Get a message. More...
 
void message_get_reactions (const struct message &m, const std::string &reaction, snowflake before, snowflake after, snowflake limit, command_completion_event_t callback)
 Get reactions on a message for a particular emoji. More...
 
void message_get_reactions (snowflake message_id, snowflake channel_id, const std::string &reaction, snowflake before, snowflake after, snowflake limit, command_completion_event_t callback)
 Get reactions on a message for a particular emoji by id. More...
 
user_map message_get_reactions_sync (const struct message &m, const std::string &reaction, snowflake before, snowflake after, snowflake limit)
 Get reactions on a message for a particular emoji. More...
 
emoji_map message_get_reactions_sync (snowflake message_id, snowflake channel_id, const std::string &reaction, snowflake before, snowflake after, snowflake limit)
 Get reactions on a message for a particular emoji by id. More...
 
message message_get_sync (snowflake message_id, snowflake channel_id)
 Get a message. More...
 
void message_pin (snowflake channel_id, snowflake message_id, command_completion_event_t callback=utility::log_error())
 Pin a message. More...
 
confirmation message_pin_sync (snowflake channel_id, snowflake message_id)
 Pin a message. More...
 
void message_unpin (snowflake channel_id, snowflake message_id, command_completion_event_t callback=utility::log_error())
 Unpin a message. More...
 
confirmation message_unpin_sync (snowflake channel_id, snowflake message_id)
 Unpin a message. More...
 
void messages_get (snowflake channel_id, snowflake around, snowflake before, snowflake after, uint64_t limit, command_completion_event_t callback)
 Get multiple messages. More...
 
message_map messages_get_sync (snowflake channel_id, snowflake around, snowflake before, snowflake after, uint64_t limit)
 Get multiple messages. More...
 
void nitro_sticker_get (snowflake id, command_completion_event_t callback)
 Get a nitro sticker. More...
 
sticker nitro_sticker_get_sync (snowflake id)
 Get a nitro sticker. More...
 
clusteroperator= (const cluster &&)=delete
 dpp::cluster is non-moveable More...
 
clusteroperator= (const cluster &)=delete
 dpp::cluster is non-copyable More...
 
void poll_end (const message &m, command_completion_event_t callback=utility::log_error())
 Immediately end a poll. More...
 
void poll_end (snowflake message_id, snowflake channel_id, command_completion_event_t callback=utility::log_error())
 Immediately end a poll. More...
 
message poll_end_sync (const message &m)
 Immediately end a poll. More...
 
message poll_end_sync (snowflake message_id, snowflake channel_id)
 Immediately end a poll. More...
 
void poll_get_answer_voters (const message &m, uint32_t answer_id, snowflake after, uint64_t limit, command_completion_event_t callback=utility::log_error())
 Get a list of users that voted for this specific answer. More...
 
void poll_get_answer_voters (snowflake message_id, snowflake channel_id, uint32_t answer_id, snowflake after, uint64_t limit, command_completion_event_t callback=utility::log_error())
 Get a list of users that voted for this specific answer. More...
 
user_map poll_get_answer_voters_sync (const message &m, uint32_t answer_id, snowflake after, uint64_t limit)
 Get a list of users that voted for this specific answer. More...
 
user_map poll_get_answer_voters_sync (snowflake message_id, snowflake channel_id, uint32_t answer_id, snowflake after, uint64_t limit)
 Get a list of users that voted for this specific answer. More...
 
void post_rest (const std::string &endpoint, const std::string &major_parameters, const std::string &parameters, http_method method, const std::string &postdata, json_encode_t callback, const std::string &filename="", const std::string &filecontent="", const std::string &filemimetype="", const std::string &protocol="1.1")
 Post a REST request. More...
 
void post_rest_multipart (const std::string &endpoint, const std::string &major_parameters, const std::string &parameters, http_method method, const std::string &postdata, json_encode_t callback, const std::vector< message_file_data > &file_data={})
 Post a multipart REST request. More...
 
void request (const std::string &url, http_method method, http_completion_event callback, const std::string &postdata="", const std::string &mimetype="text/plain", const std::multimap< std::string, std::string > &headers={}, const std::string &protocol="1.1")
 Make a HTTP(S) request. More...
 
void role_create (const class role &r, command_completion_event_t callback=utility::log_error())
 Create a role on a guild. More...
 
role role_create_sync (const class role &r)
 Create a role on a guild. More...
 
void role_delete (snowflake guild_id, snowflake role_id, command_completion_event_t callback=utility::log_error())
 Delete a role. More...
 
confirmation role_delete_sync (snowflake guild_id, snowflake role_id)
 Delete a role. More...
 
void role_edit (const class role &r, command_completion_event_t callback=utility::log_error())
 Edit a role on a guild. More...
 
role role_edit_sync (const class role &r)
 Edit a role on a guild. More...
 
void roles_edit_position (snowflake guild_id, const std::vector< role > &roles, command_completion_event_t callback=utility::log_error())
 Edit multiple role's position in a guild. More...
 
role_map roles_edit_position_sync (snowflake guild_id, const std::vector< role > &roles)
 Edit multiple role's position in a guild. More...
 
void roles_get (snowflake guild_id, command_completion_event_t callback)
 Get a role for a guild. More...
 
role_map roles_get_sync (snowflake guild_id)
 Get a role for a guild. More...
 
clusterset_audit_reason (const std::string &reason)
 Set the audit log reason for the next REST call to be made. More...
 
clusterset_default_gateway (std::string &default_gateway)
 Sets the address of the default gateway, for connecting the websockets. More...
 
void set_dm_channel (snowflake user_id, snowflake channel_id)
 Set the dm channel id for a user id. More...
 
void set_presence (const class dpp::presence &p)
 Set the presence for all shards on the cluster. More...
 
clusterset_websocket_protocol (websocket_protocol_t mode)
 Set the websocket protocol for all shards on this cluster. More...
 
void shutdown ()
 End cluster execution without destructing it. More...
 
void skus_get (command_completion_event_t callback=utility::log_error())
 Returns all SKUs for a given application. More...
 
sku_map skus_get_sync ()
 Returns all SKUs for a given application. More...
 
void stage_instance_create (const stage_instance &instance, command_completion_event_t callback=utility::log_error())
 Create a stage instance on a stage channel. More...
 
void stage_instance_delete (const snowflake channel_id, command_completion_event_t callback=utility::log_error())
 Delete a stage instance. More...
 
confirmation stage_instance_delete_sync (const snowflake channel_id)
 Delete a stage instance. More...
 
void stage_instance_edit (const stage_instance &instance, command_completion_event_t callback=utility::log_error())
 Edit a stage instance. More...
 
void stage_instance_get (const snowflake channel_id, command_completion_event_t callback)
 Get the stage instance associated with the channel id, if it exists. More...
 
stage_instance stage_instance_get_sync (const snowflake channel_id)
 Get the stage instance associated with the channel id, if it exists. More...
 
void start (bool return_after=true)
 Start the cluster, connecting all its shards. More...
 
timer start_timer (timer_callback_t on_tick, uint64_t frequency, timer_callback_t on_stop={})
 Start a timer. More...
 
void sticker_packs_get (command_completion_event_t callback)
 Get a list of available sticker packs. More...
 
sticker_pack_map sticker_packs_get_sync ()
 Get a list of available sticker packs. More...
 
bool stop_timer (timer t)
 Stop a ticking timer. More...
 
void template_get (const std::string &code, command_completion_event_t callback)
 Get a template. More...
 
dtemplate template_get_sync (const std::string &code)
 Get a template. More...
 
void thread_create (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, command_completion_event_t callback=utility::log_error())
 Create a thread. More...
 
void thread_create_in_forum (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={}, command_completion_event_t callback=utility::log_error())
 Create a thread in a forum or media channel. More...
 
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={})
 Create a thread in a forum or media channel. More...
 
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)
 Create a thread. More...
 
void thread_create_with_message (const std::string &thread_name, snowflake channel_id, snowflake message_id, uint16_t auto_archive_duration, uint16_t rate_limit_per_user, command_completion_event_t callback=utility::log_error())
 Create a thread with a message (Discord: ID of a thread is same as message ID) More...
 
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)
 Create a thread with a message (Discord: ID of a thread is same as message ID) More...
 
void thread_edit (const thread &t, command_completion_event_t callback=utility::log_error())
 Edit a thread. More...
 
thread thread_edit_sync (const thread &t)
 Edit a thread. More...
 
void thread_get (snowflake thread_id, command_completion_event_t callback)
 Get the thread specified by thread_id. More...
 
thread thread_get_sync (snowflake thread_id)
 Get the thread specified by thread_id. More...
 
void thread_member_add (snowflake thread_id, snowflake user_id, command_completion_event_t callback=utility::log_error())
 Add a member to a thread. More...
 
confirmation thread_member_add_sync (snowflake thread_id, snowflake user_id)
 Add a member to a thread. More...
 
void thread_member_get (const snowflake thread_id, const snowflake user_id, command_completion_event_t callback)
 Get a thread member. More...
 
thread_member thread_member_get_sync (const snowflake thread_id, const snowflake user_id)
 Get a thread member. More...
 
void thread_member_remove (snowflake thread_id, snowflake user_id, command_completion_event_t callback=utility::log_error())
 Remove a member from a thread. More...
 
confirmation thread_member_remove_sync (snowflake thread_id, snowflake user_id)
 Remove a member from a thread. More...
 
void thread_members_get (snowflake thread_id, command_completion_event_t callback)
 Get members of a thread. More...
 
thread_member_map thread_members_get_sync (snowflake thread_id)
 Get members of a thread. More...
 
void threads_get_active (snowflake guild_id, command_completion_event_t callback)
 Get all active threads in the guild, including public and private threads. More...
 
active_threads threads_get_active_sync (snowflake guild_id)
 Get all active threads in the guild, including public and private threads. More...
 
void threads_get_joined_private_archived (snowflake channel_id, snowflake before_id, uint16_t limit, command_completion_event_t callback)
 Get private archived threads in a channel which current user has joined (Sorted by ID in descending order) More...
 
thread_map threads_get_joined_private_archived_sync (snowflake channel_id, snowflake before_id, uint16_t limit)
 Get private archived threads in a channel which current user has joined (Sorted by ID in descending order) More...
 
void threads_get_private_archived (snowflake channel_id, time_t before_timestamp, uint16_t limit, command_completion_event_t callback)
 Get private archived threads in a channel (Sorted by archive_timestamp in descending order) More...
 
thread_map threads_get_private_archived_sync (snowflake channel_id, time_t before_timestamp, uint16_t limit)
 Get private archived threads in a channel (Sorted by archive_timestamp in descending order) More...
 
void threads_get_public_archived (snowflake channel_id, time_t before_timestamp, uint16_t limit, command_completion_event_t callback)
 Get public archived threads in a channel (Sorted by archive_timestamp in descending order) More...
 
thread_map threads_get_public_archived_sync (snowflake channel_id, time_t before_timestamp, uint16_t limit)
 Get public archived threads in a channel (Sorted by archive_timestamp in descending order) More...
 
dpp::utility::uptime uptime ()
 Returns the uptime of the cluster. More...
 
void user_application_role_connection_get (snowflake application_id, command_completion_event_t callback)
 Get user application role connection. More...
 
application_role_connection user_application_role_connection_get_sync (snowflake application_id)
 Get user application role connection. More...
 
void user_application_role_connection_update (snowflake application_id, const application_role_connection &connection, command_completion_event_t callback=utility::log_error())
 Update user application role connection. More...
 
application_role_connection user_application_role_connection_update_sync (snowflake application_id, const application_role_connection &connection)
 Update user application role connection. More...
 
void user_get (snowflake user_id, command_completion_event_t callback)
 Get a user by id, without using the cache. More...
 
void user_get_cached (snowflake user_id, command_completion_event_t callback)
 Get a user by id, checking in the cache first. More...
 
user_identified user_get_cached_sync (snowflake user_id)
 Get a user by id, checking in the cache first. More...
 
user_identified user_get_sync (snowflake user_id)
 Get a user by id, without using the cache. More...
 
void user_set_voice_state (snowflake user_id, snowflake guild_id, snowflake channel_id, bool suppress=false, command_completion_event_t callback=utility::log_error())
 Set a user's voice state on a stage channel. More...
 
confirmation user_set_voice_state_sync (snowflake user_id, snowflake guild_id, snowflake channel_id, bool suppress=false)
 Set a user's voice state on a stage channel. More...
 

Public Attributes

cache_policy_t cache_policy
 Current cache policy for the cluster. More...
 
uint32_t cluster_id
 ID of this cluster, between 0 and MAXCLUSTERS-1 inclusive. More...
 
uint32_t intents
 Current bitmask of gateway intents. More...
 
time_t last_identify
 Last time the bot sent an IDENTIFY. More...
 
uint32_t maxclusters
 Total number of clusters that are active. More...
 
dpp::user me
 The details of the bot user. More...
 
uint32_t numshards
 Total number of shards across all clusters. More...
 
event_router_t< autocomplete_ton_autocomplete
 Called when an auto completed field needs suggestions to present to the user This is triggered by discord when option choices have auto completion enabled which you have associated with a dpp::slashcommand. More...
 
event_router_t< automod_rule_create_ton_automod_rule_create
 Called when a new automod rule is created. More...
 
event_router_t< automod_rule_delete_ton_automod_rule_delete
 Called when an automod rule is deleted. More...
 
event_router_t< automod_rule_execute_ton_automod_rule_execute
 Called when an automod rule is triggered/executed. More...
 
event_router_t< automod_rule_update_ton_automod_rule_update
 Called when an automod rule is updated. More...
 
event_router_t< button_click_ton_button_click
 Called when a button is clicked attached to a message. More...
 
event_router_t< channel_create_ton_channel_create
 Called when a new channel is created on a guild. More...
 
event_router_t< channel_delete_ton_channel_delete
 Called when a channel is deleted from a guild. More...
 
event_router_t< channel_pins_update_ton_channel_pins_update
 Called when a message is pinned. More...
 
event_router_t< channel_update_ton_channel_update
 Called when a channel is edited on a guild. More...
 
event_router_t< entitlement_create_ton_entitlement_create
 Called when a user subscribes to an SKU. More...
 
event_router_t< entitlement_delete_ton_entitlement_delete
 Called when a user's entitlement is deleted. More...
 
event_router_t< entitlement_update_ton_entitlement_update
 Called when a user's subscription renews for the next billing period. More...
 
event_router_t< form_submit_ton_form_submit
 Called when a modal dialog is submitted. More...
 
event_router_t< guild_audit_log_entry_create_ton_guild_audit_log_entry_create
 Called when a guild audit log entry is created. More...
 
event_router_t< guild_ban_add_ton_guild_ban_add
 Called when a ban is added to a guild. More...
 
event_router_t< guild_ban_remove_ton_guild_ban_remove
 Called when a ban is removed from a guild. More...
 
event_router_t< guild_create_ton_guild_create
 Called when a new guild is created. More...
 
event_router_t< guild_delete_ton_guild_delete
 Called when a guild is deleted. More...
 
event_router_t< guild_emojis_update_ton_guild_emojis_update
 Called when new emojis are added to a guild. More...
 
event_router_t< guild_integrations_update_ton_guild_integrations_update
 Called when an integration is updated for a guild. More...
 
event_router_t< guild_join_request_delete_ton_guild_join_request_delete
 on guild join request delete. More...
 
event_router_t< guild_member_add_ton_guild_member_add
 Called when a new member joins a guild. More...
 
event_router_t< guild_member_remove_ton_guild_member_remove
 Called when a user leaves a guild (either through being kicked, or choosing to leave) More...
 
event_router_t< guild_member_update_ton_guild_member_update
 Called when details of a guild member (e.g. More...
 
event_router_t< guild_members_chunk_ton_guild_members_chunk
 Called when a set of members is received for a guild. More...
 
event_router_t< guild_role_create_ton_guild_role_create
 Called when a new role is created on a guild. More...
 
event_router_t< guild_role_delete_ton_guild_role_delete
 Called when a role is deleted in a guild. More...
 
event_router_t< guild_role_update_ton_guild_role_update
 Called when an existing role is updated on a guild. More...
 
event_router_t< guild_scheduled_event_create_ton_guild_scheduled_event_create
 Called when a new scheduled event is created. More...
 
event_router_t< guild_scheduled_event_delete_ton_guild_scheduled_event_delete
 Called when a new scheduled event is deleted. More...
 
event_router_t< guild_scheduled_event_update_ton_guild_scheduled_event_update
 Called when a new scheduled event is updated. More...
 
event_router_t< guild_scheduled_event_user_add_ton_guild_scheduled_event_user_add
 Called when a user is added to a scheduled event. More...
 
event_router_t< guild_scheduled_event_user_remove_ton_guild_scheduled_event_user_remove
 Called when a user is removed from a scheduled event. More...
 
event_router_t< guild_stickers_update_ton_guild_stickers_update
 Called when new stickers are added to a guild. More...
 
event_router_t< guild_update_ton_guild_update
 Called when details of a guild are updated. More...
 
event_router_t< integration_create_ton_integration_create
 Called when a new integration is attached to a guild by a user. More...
 
event_router_t< integration_delete_ton_integration_delete
 Called when an integration is removed by a user. More...
 
event_router_t< integration_update_ton_integration_update
 Called when an integration is updated by a user. More...
 
event_router_t< interaction_create_ton_interaction_create
 Called when a new interaction is created. More...
 
event_router_t< invite_create_ton_invite_create
 Called when a new invite is created for a guild. More...
 
event_router_t< invite_delete_ton_invite_delete
 Called when an invite is deleted from a guild. More...
 
event_router_t< log_ton_log
 Called when a log message is to be written to the log. More...
 
event_router_t< message_context_menu_ton_message_context_menu
 Called when a user right-clicks or long-presses on a message, where a slash command is bound to the dpp::ctxm_message command type. More...
 
event_router_t< message_create_ton_message_create
 Called when a new message arrives from discord. More...
 
event_router_t< message_delete_ton_message_delete
 Called when a message is deleted. More...
 
event_router_t< message_delete_bulk_ton_message_delete_bulk
 Called when multiple messages are deleted from a channel or DM. More...
 
event_router_t< message_poll_vote_add_ton_message_poll_vote_add
 Called when a vote is added to a message poll. More...
 
event_router_t< message_poll_vote_remove_ton_message_poll_vote_remove
 Called when a vote is removed from a message poll. More...
 
event_router_t< message_reaction_add_ton_message_reaction_add
 Called when a new reaction is added to a message. More...
 
event_router_t< message_reaction_remove_ton_message_reaction_remove
 Called when a single reaction is removed from a message. More...
 
event_router_t< message_reaction_remove_all_ton_message_reaction_remove_all
 Called when all reactions are removed from a message. More...
 
event_router_t< message_reaction_remove_emoji_ton_message_reaction_remove_emoji
 Called when all reactions for a particular emoji are removed from a message. More...
 
event_router_t< message_update_ton_message_update
 Called when a message is updated (edited). More...
 
event_router_t< presence_update_ton_presence_update
 Called when a user's presence is updated. More...
 
event_router_t< ready_ton_ready
 Called when a shard is connected and ready. More...
 
event_router_t< resumed_ton_resumed
 Called when a connection to a shard successfully resumes. More...
 
event_router_t< select_click_ton_select_click
 Called when a select menu is clicked attached to a message. More...
 
event_router_t< slashcommand_ton_slashcommand
 Called when a slash command is issued. More...
 
event_router_t< stage_instance_create_ton_stage_instance_create
 Called when a new stage instance is created on a stage channel. More...
 
event_router_t< stage_instance_delete_ton_stage_instance_delete
 Called when an existing stage instance is deleted from a stage channel. More...
 
event_router_t< stage_instance_update_ton_stage_instance_update
 Called when a stage instance is updated. More...
 
event_router_t< thread_create_ton_thread_create
 Called when a thread is created. More...
 
event_router_t< thread_delete_ton_thread_delete
 Called when a thread is deleted. More...
 
event_router_t< thread_list_sync_ton_thread_list_sync
 Called when thread list is synced (upon gaining access to a channel). More...
 
event_router_t< thread_member_update_ton_thread_member_update
 Called when current user's thread member object is updated. More...
 
event_router_t< thread_members_update_ton_thread_members_update
 Called when a thread's member list is updated (without GUILD_MEMBERS intent, is only called for current user) More...
 
event_router_t< thread_update_ton_thread_update
 Called when a thread is updated. More...
 
event_router_t< typing_start_ton_typing_start
 Called when a user is typing on a channel. More...
 
event_router_t< user_context_menu_ton_user_context_menu
 Called when a user right-clicks or long-presses on a user, where a slash command is bound to the dpp::ctxm_user command type. More...
 
event_router_t< user_update_ton_user_update
 Called when a user is updated. More...
 
event_router_t< voice_buffer_send_ton_voice_buffer_send
 Called when packets are sent from the voice buffer. More...
 
event_router_t< voice_client_disconnect_ton_voice_client_disconnect
 on voice client disconnect event More...
 
event_router_t< voice_client_speaking_ton_voice_client_speaking
 on voice client speaking event More...
 
event_router_t< voice_ready_ton_voice_ready
 Called when a voice channel is connected and ready to send audio. More...
 
event_router_t< voice_receive_ton_voice_receive
 Called when new audio data is received. More...
 
event_router_t< voice_receive_ton_voice_receive_combined
 Called when new audio data is received, combined and mixed for all speaking users. More...
 
event_router_t< voice_server_update_ton_voice_server_update
 Called when we are told which voice server we can use. More...
 
event_router_t< voice_state_update_ton_voice_state_update
 on voice state update event More...
 
event_router_t< voice_track_marker_ton_voice_track_marker
 Called when sending of audio passes over a track marker. More...
 
event_router_t< voice_user_talking_ton_voice_user_talking
 Called when a user is talking on a voice channel. More...
 
event_router_t< webhooks_update_ton_webhooks_update
 Called when the webhooks for a guild are updated. More...
 
double rest_ping
 REST latency (HTTPS ping) in seconds. More...
 
std::condition_variable terminating
 Condition variable notified when the cluster is terminating. More...
 
std::string token
 Current bot token for all shards on this cluster and all commands sent via HTTP. More...
 
websocket_protocol_t ws_mode
 Websocket mode for all shards in the cluster, either ws_json or ws_etf. More...
 

Friends

class discord_client
 
class discord_voice_client
 

Detailed Description

The cluster class represents a group of shards and a command queue for sending and receiving commands from discord via HTTP.

You should usually instantiate a cluster object at the very least to make use of the library.

Constructor & Destructor Documentation

◆ cluster() [1/3]

dpp::cluster::cluster ( const std::string &  token,
uint32_t  intents = i_default_intents,
uint32_t  shards = 0,
uint32_t  cluster_id = 0,
uint32_t  maxclusters = 1,
bool  compressed = true,
cache_policy_t  policy = cache_policy::cpol_default,
uint32_t  request_threads = 12,
uint32_t  request_threads_raw = 1 
)

Constructor for creating a cluster.

All but the token are optional.

Parameters
tokenThe bot token to use for all HTTP commands and websocket connections
intentsA bitmask of dpd::intents values for all shards on this cluster. This is required to be sent for all bots with over 100 servers.
shardsThe total number of shards on this bot. If there are multiple clusters, then (shards / clusters) actual shards will run on this cluster. If you omit this value, the library will attempt to query the Discord API for the correct number of shards to start.
cluster_idThe ID of this cluster, should be between 0 and MAXCLUSTERS-1
maxclustersThe total number of clusters that are active, which may be on separate processes or even separate machines.
compressedWhether or not to use compression for shards on this cluster. Saves a ton of bandwidth at the cost of some CPU
policySet the caching policy for the cluster, either lazy (only cache users/members when they message the bot) or aggressive (request whole member lists on seeing new guilds too)
request_threadsThe number of threads to allocate for making HTTP requests to Discord. This defaults to 12. You can increase this at runtime via the object returned from get_rest().
request_threads_rawThe number of threads to allocate for making HTTP requests to sites outside of Discord. This defaults to 1. You can increase this at runtime via the object returned from get_raw_rest().
Exceptions
dpp::exceptionThrown on windows, if WinSock fails to initialise, or on any other system if a dpp::request_queue fails to construct

◆ cluster() [2/3]

dpp::cluster::cluster ( const cluster )
delete

dpp::cluster is non-copyable

◆ cluster() [3/3]

dpp::cluster::cluster ( const cluster &&  )
delete

dpp::cluster is non-moveable

◆ ~cluster()

dpp::cluster::~cluster ( )
virtual

Destroy the cluster object.

References dpp::err_websocket_proto_already_set.

Member Function Documentation

◆ application_role_connection_get()

void dpp::cluster::application_role_connection_get ( snowflake  application_id,
command_completion_event_t  callback 
)

Get the application's role connection metadata records.

See also
https://discord.com/developers/docs/resources/application-role-connection-metadata#get-application-role-connection-metadata-records
Parameters
application_idThe application ID
callbackFunction to call when the API call completes. On success the callback will contain a dpp::application_role_connection_metadata_list object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_role_create(), and role_create_sync().

Here is the caller graph for this function:

◆ application_role_connection_get_sync()

application_role_connection dpp::cluster::application_role_connection_get_sync ( snowflake  application_id)

Get the application's role connection metadata records.

See also
dpp::cluster::application_role_connection_get
https://discord.com/developers/docs/resources/application-role-connection-metadata#get-application-role-connection-metadata-records
Parameters
application_idThe application ID
Returns
application_role_connection returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References guild_event_create().

Here is the call graph for this function:

◆ application_role_connection_update()

void dpp::cluster::application_role_connection_update ( snowflake  application_id,
const std::vector< application_role_connection_metadata > &  connection_metadata,
command_completion_event_t  callback = utility::log_error() 
)

Update the application's role connection metadata records.

See also
https://discord.com/developers/docs/resources/application-role-connection-metadata#update-application-role-connection-metadata-records
Parameters
application_idThe application ID
connection_metadataThe application role connection metadata to update
callbackFunction to call when the API call completes. On success the callback will contain a dpp::application_role_connection_metadata_list object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().
Note
An application can have a maximum of 5 metadata records.

Referenced by co_role_delete(), and role_delete_sync().

Here is the caller graph for this function:

◆ application_role_connection_update_sync()

application_role_connection dpp::cluster::application_role_connection_update_sync ( snowflake  application_id,
const std::vector< application_role_connection_metadata > &  connection_metadata 
)

Update the application's role connection metadata records.

See also
dpp::cluster::application_role_connection_update
https://discord.com/developers/docs/resources/application-role-connection-metadata#update-application-role-connection-metadata-records
Parameters
application_idThe application ID
connection_metadataThe application role connection metadata to update
Returns
application_role_connection returned object on completion
Note
An application can have a maximum of 5 metadata records.
Exceptions
dpp::rest_exceptionupon 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.

References guild_event_delete().

Here is the call graph for this function:

◆ automod_rule_create()

void dpp::cluster::automod_rule_create ( snowflake  guild_id,
const automod_rule r,
command_completion_event_t  callback = utility::log_error() 
)

Create an auto moderation rule.

Parameters
guild_idGuild id of the auto moderation rule
rAuto moderation rule to create
callbackFunction to call when the API call completes. On success the callback will contain a dpp::automod_rule object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_interaction_followup_edit(), and interaction_followup_edit_sync().

Here is the caller graph for this function:

◆ automod_rule_create_sync()

automod_rule dpp::cluster::automod_rule_create_sync ( snowflake  guild_id,
const automod_rule r 
)

Create an auto moderation rule.

Parameters
guild_idGuild id of the auto moderation rule
rAuto moderation rule to create
Returns
automod_rule returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References channel_delete().

Here is the call graph for this function:

◆ automod_rule_delete()

void dpp::cluster::automod_rule_delete ( snowflake  guild_id,
snowflake  rule_id,
command_completion_event_t  callback = utility::log_error() 
)

Delete an auto moderation rule.

Parameters
guild_idGuild id of the auto moderation rule
rule_idAuto moderation rule id to delete
callbackFunction to call when the API call completes. On success the callback will contain a dpp::confirmation object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_interaction_followup_get_original(), and interaction_followup_get_original_sync().

Here is the caller graph for this function:

◆ automod_rule_delete_sync()

confirmation dpp::cluster::automod_rule_delete_sync ( snowflake  guild_id,
snowflake  rule_id 
)

Delete an auto moderation rule.

Parameters
guild_idGuild id of the auto moderation rule
rule_idAuto moderation rule id to delete
Returns
confirmation returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References channel_edit_permissions().

Here is the call graph for this function:

◆ automod_rule_edit()

void dpp::cluster::automod_rule_edit ( snowflake  guild_id,
const automod_rule r,
command_completion_event_t  callback = utility::log_error() 
)

Edit an auto moderation rule.

Parameters
guild_idGuild id of the auto moderation rule
rAuto moderation rule to edit. The rule's id must be set.
callbackFunction to call when the API call completes. On success the callback will contain a dpp::automod_rule object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_interaction_followup_get(), and interaction_followup_get_sync().

Here is the caller graph for this function:

◆ automod_rule_edit_sync()

automod_rule dpp::cluster::automod_rule_edit_sync ( snowflake  guild_id,
const automod_rule r 
)

Edit an auto moderation rule.

Parameters
guild_idGuild id of the auto moderation rule
rAuto moderation rule to edit. The rule's id must be set.
Returns
automod_rule returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References channel_edit_permissions().

Here is the call graph for this function:

◆ automod_rule_get()

void dpp::cluster::automod_rule_get ( snowflake  guild_id,
snowflake  rule_id,
command_completion_event_t  callback 
)

Get a single auto moderation rule.

Parameters
guild_idGuild id of the auto moderation rule
rule_idRule id to retrieve
callbackFunction to call when the API call completes. On success the callback will contain a dpp::automod_rule object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_interaction_followup_delete(), and interaction_followup_delete_sync().

Here is the caller graph for this function:

◆ automod_rule_get_sync()

automod_rule dpp::cluster::automod_rule_get_sync ( snowflake  guild_id,
snowflake  rule_id 
)

Get a single auto moderation rule.

Parameters
guild_idGuild id of the auto moderation rule
rule_idRule id to retrieve
Returns
automod_rule returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References channel_delete_permission().

Here is the call graph for this function:

◆ automod_rules_get()

void dpp::cluster::automod_rules_get ( snowflake  guild_id,
command_completion_event_t  callback 
)

Get all auto moderation rules for a guild.

Parameters
guild_idGuild id of the auto moderation rule
callbackFunction to call when the API call completes. On success the callback will contain a dpp::automod_rule_map object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_interaction_followup_edit_original(), and interaction_followup_edit_original_sync().

Here is the caller graph for this function:

◆ automod_rules_get_sync()

automod_rule_map dpp::cluster::automod_rules_get_sync ( snowflake  guild_id)

Get all auto moderation rules for a guild.

Parameters
guild_idGuild id of the auto moderation rule
Returns
automod_rule_map returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References channel_create().

Here is the call graph for this function:

◆ channel_create()

void dpp::cluster::channel_create ( const class channel c,
command_completion_event_t  callback = utility::log_error() 
)

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 also
https://discord.com/developers/docs/resources/channel#create-channel
Parameters
cChannel to create
callbackFunction to call when the API call completes. On success the callback will contain a dpp::channel object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by automod_rules_get_sync(), and co_automod_rules_get().

Here is the caller graph for this function:

◆ channel_create_sync()

channel dpp::cluster::channel_create_sync ( const class channel c)

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 also
dpp::cluster::channel_create
https://discord.com/developers/docs/resources/channel#create-channel
Parameters
cChannel to create
Returns
channel returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References channel_edit_positions().

Here is the call graph for this function:

◆ channel_delete()

void dpp::cluster::channel_delete ( snowflake  channel_id,
command_completion_event_t  callback = utility::log_error() 
)

Delete a channel.

Note
This method supports audit log reasons set by the cluster::set_audit_reason() method.
See also
https://discord.com/developers/docs/resources/channel#deleteclose-channel
Parameters
channel_idChannel id to delete
callbackFunction to call when the API call completes. On success the callback will contain a dpp::confirmation object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by automod_rule_create_sync(), and co_automod_rule_create().

Here is the caller graph for this function:

◆ channel_delete_permission()

void dpp::cluster::channel_delete_permission ( const class channel c,
snowflake  overwrite_id,
command_completion_event_t  callback = utility::log_error() 
)

Remove a permission from a channel.

Note
This method supports audit log reasons set by the cluster::set_audit_reason() method.
See also
https://discord.com/developers/docs/resources/channel#delete-channel-permission
Parameters
cChannel to remove permission from
overwrite_idOverwrite to remove, user or channel ID
callbackFunction to call when the API call completes. On success the callback will contain a dpp::confirmation object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by automod_rule_get_sync(), and co_automod_rule_get().

Here is the caller graph for this function:

◆ channel_delete_permission_sync()

confirmation dpp::cluster::channel_delete_permission_sync ( const class channel c,
snowflake  overwrite_id 
)

Remove a permission from a channel.

Note
This method supports audit log reasons set by the cluster::set_audit_reason() method.
See also
dpp::cluster::channel_delete_permission
https://discord.com/developers/docs/resources/channel#delete-channel-permission
Parameters
cChannel to remove permission from
overwrite_idOverwrite to remove, user or channel ID
Returns
confirmation returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References channel_edit().

Here is the call graph for this function:

◆ channel_delete_sync()

confirmation dpp::cluster::channel_delete_sync ( snowflake  channel_id)

Delete a channel.

Note
This method supports audit log reasons set by the cluster::set_audit_reason() method.
See also
dpp::cluster::channel_delete
https://discord.com/developers/docs/resources/channel#deleteclose-channel
Parameters
channel_idChannel id to delete
Returns
confirmation returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References channel_follow_news().

Here is the call graph for this function:

◆ channel_edit()

void dpp::cluster::channel_edit ( const class channel c,
command_completion_event_t  callback = utility::log_error() 
)

Edit a channel.

Note
This method supports audit log reasons set by the cluster::set_audit_reason() method.
See also
https://discord.com/developers/docs/resources/channel#modify-channel
Parameters
cChannel to edit/update
callbackFunction to call when the API call completes. On success the callback will contain a dpp::channel object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by channel_delete_permission_sync(), and co_channel_delete_permission().

Here is the caller graph for this function:

◆ channel_edit_permissions() [1/2]

void dpp::cluster::channel_edit_permissions ( const class channel c,
const snowflake  overwrite_id,
const uint64_t  allow,
const uint64_t  deny,
const bool  member,
command_completion_event_t  callback = utility::log_error() 
)

Edit a channel's permissions.

See also
https://discord.com/developers/docs/resources/channel#edit-channel-permissions
Note
This method supports audit log reasons set by the cluster::set_audit_reason() method.
Parameters
cChannel to set permissions for
overwrite_idOverwrite to change (a user or role ID)
allowallow permissions bitmask
denydeny permissions bitmask
membertrue if the overwrite_id is a user id, false if it is a channel id
callbackFunction to call when the API call completes. On success the callback will contain a dpp::confirmation object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by automod_rule_delete_sync(), automod_rule_edit_sync(), co_automod_rule_delete(), and co_automod_rule_edit().

Here is the caller graph for this function:

◆ channel_edit_permissions() [2/2]

void dpp::cluster::channel_edit_permissions ( const snowflake  channel_id,
const snowflake  overwrite_id,
const uint64_t  allow,
const uint64_t  deny,
const bool  member,
command_completion_event_t  callback = utility::log_error() 
)

Edit a channel's permissions.

See also
https://discord.com/developers/docs/resources/channel#edit-channel-permissions
Note
This method supports audit log reasons set by the cluster::set_audit_reason() method.
Parameters
channel_idID of the channel to set permissions for
overwrite_idOverwrite to change (a user or role ID)
allowallow permissions bitmask
denydeny permissions bitmask
membertrue if the overwrite_id is a user id, false if it is a channel id
callbackFunction to call when the API call completes. On success the callback will contain a dpp::confirmation object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

◆ channel_edit_permissions_sync() [1/2]

confirmation dpp::cluster::channel_edit_permissions_sync ( const class channel c,
const snowflake  overwrite_id,
const uint64_t  allow,
const uint64_t  deny,
const bool  member 
)

Edit a channel's permissions.

See also
dpp::cluster::channel_edit_permissions
https://discord.com/developers/docs/resources/channel#edit-channel-permissions
Note
This method supports audit log reasons set by the cluster::set_audit_reason() method.
Parameters
cChannel to set permissions for
overwrite_idOverwrite to change (a user or role ID)
allowallow permissions bitmask
denydeny permissions bitmask
membertrue if the overwrite_id is a user id, false if it is a channel id
Returns
confirmation returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References channel_get().

Here is the call graph for this function:

◆ channel_edit_permissions_sync() [2/2]

confirmation dpp::cluster::channel_edit_permissions_sync ( const snowflake  channel_id,
const snowflake  overwrite_id,
const uint64_t  allow,
const uint64_t  deny,
const bool  member 
)

Edit a channel's permissions.

See also
dpp::cluster::channel_edit_permissions
https://discord.com/developers/docs/resources/channel#edit-channel-permissions
Note
This method supports audit log reasons set by the cluster::set_audit_reason() method.
Parameters
channel_idID of the channel to set permissions for
overwrite_idOverwrite to change (a user or role ID)
allowallow permissions bitmask
denydeny permissions bitmask
membertrue if the overwrite_id is a user id, false if it is a channel id
Returns
confirmation returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References channel_invite_create().

Here is the call graph for this function:

◆ channel_edit_positions()

void dpp::cluster::channel_edit_positions ( const std::vector< channel > &  c,
command_completion_event_t  callback = utility::log_error() 
)

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 also
https://discord.com/developers/docs/resources/guild#modify-guild-channel-positions
Parameters
cChannel to change the position for
callbackFunction to call when the API call completes. On success the callback will contain a dpp::confirmation object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by channel_create_sync(), and co_channel_create().

Here is the caller graph for this function:

◆ channel_edit_positions_sync()

confirmation dpp::cluster::channel_edit_positions_sync ( const std::vector< channel > &  c)

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 also
dpp::cluster::channel_edit_positions
https://discord.com/developers/docs/resources/guild#modify-guild-channel-positions
Parameters
cChannel to change the position for
Returns
confirmation returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References channel_invites_get().

Here is the call graph for this function:

◆ channel_edit_sync()

channel dpp::cluster::channel_edit_sync ( const class channel c)

Edit a channel.

Note
This method supports audit log reasons set by the cluster::set_audit_reason() method.
See also
dpp::cluster::channel_edit
https://discord.com/developers/docs/resources/channel#modify-channel
Parameters
cChannel to edit/update
Returns
channel returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References channel_typing().

Here is the call graph for this function:

◆ channel_follow_news()

void dpp::cluster::channel_follow_news ( const class channel c,
snowflake  target_channel_id,
command_completion_event_t  callback = utility::log_error() 
)

Follow an announcement (news) channel.

See also
https://discord.com/developers/docs/resources/channel#follow-news-channel
Parameters
cChannel id to follow
target_channel_idChannel to subscribe the channel to
callbackFunction to call when the API call completes. On success the callback will contain a dpp::confirmation object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by channel_delete_sync(), and co_channel_delete().

Here is the caller graph for this function:

◆ channel_follow_news_sync()

confirmation dpp::cluster::channel_follow_news_sync ( const class channel c,
snowflake  target_channel_id 
)

Follow an announcement (news) channel.

See also
dpp::cluster::channel_follow_news
https://discord.com/developers/docs/resources/channel#follow-news-channel
Parameters
cChannel id to follow
target_channel_idChannel to subscribe the channel to
Returns
confirmation returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References channel_typing().

Here is the call graph for this function:

◆ channel_get()

void dpp::cluster::channel_get ( snowflake  c,
command_completion_event_t  callback 
)

Get a channel.

See also
https://discord.com/developers/docs/resources/channel#get-channel
Parameters
cChannel ID to retrieve
callbackFunction to call when the API call completes. On success the callback will contain a dpp::channel object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

References API_PATH, and dpp::m_get.

Referenced by channel_edit_permissions_sync(), and co_channel_edit_permissions().

Here is the caller graph for this function:

◆ channel_get_sync()

channel dpp::cluster::channel_get_sync ( snowflake  c)

Get a channel.

See also
dpp::cluster::channel_get
https://discord.com/developers/docs/resources/channel#get-channel
Parameters
cChannel ID to retrieve
Returns
channel returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References channels_get().

Here is the call graph for this function:

◆ channel_invite_create()

void dpp::cluster::channel_invite_create ( const class channel c,
const class invite i,
command_completion_event_t  callback = utility::log_error() 
)

Create invite for a channel.

Note
This method supports audit log reasons set by the cluster::set_audit_reason() method.
See also
https://discord.com/developers/docs/resources/channel#create-channel-invite
Parameters
cChannel to create an invite on
iInvite to create
callbackFunction to call when the API call completes. On success the callback will contain a dpp::invite object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by channel_edit_permissions_sync(), and co_channel_edit_permissions().

Here is the caller graph for this function:

◆ channel_invite_create_sync()

invite dpp::cluster::channel_invite_create_sync ( const class channel c,
const class invite i 
)

Create invite for a channel.

Note
This method supports audit log reasons set by the cluster::set_audit_reason() method.
See also
dpp::cluster::channel_invite_create
https://discord.com/developers/docs/resources/channel#create-channel-invite
Parameters
cChannel to create an invite on
iInvite to create
Returns
invite returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References channel_set_voice_status().

Here is the call graph for this function:

◆ channel_invites_get()

void dpp::cluster::channel_invites_get ( const class channel c,
command_completion_event_t  callback 
)

Get invites for a channel.

See also
https://discord.com/developers/docs/resources/invite#get-invites
Parameters
cChannel to get invites for
callbackFunction to call when the API call completes. On success the callback will contain a dpp::invite_map object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by channel_edit_positions_sync(), and co_channel_edit_positions().

Here is the caller graph for this function:

◆ channel_invites_get_sync()

invite_map dpp::cluster::channel_invites_get_sync ( const class channel c)

Get invites for a channel.

See also
dpp::cluster::channel_invites_get
https://discord.com/developers/docs/resources/invite#get-invites
Parameters
cChannel to get invites for
Returns
invite_map returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References create_dm_channel().

Here is the call graph for this function:

◆ channel_pins_get()

void dpp::cluster::channel_pins_get ( snowflake  channel_id,
command_completion_event_t  callback 
)

Get a channel's pins.

See also
https://discord.com/developers/docs/resources/channel#get-pinned-messages
Parameters
channel_idChannel ID to get pins for
callbackFunction to call when the API call completes. On success the callback will contain a dpp::message_map object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_message_unpin(), and message_unpin_sync().

Here is the caller graph for this function:

◆ channel_pins_get_sync()

message_map dpp::cluster::channel_pins_get_sync ( snowflake  channel_id)

Get a channel's pins.

See also
dpp::cluster::channel_pins_get
https://discord.com/developers/docs/resources/channel#get-pinned-messages
Parameters
channel_idChannel ID to get pins for
Returns
message_map returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References roles_get().

Here is the call graph for this function:

◆ channel_set_voice_status()

void dpp::cluster::channel_set_voice_status ( snowflake  channel_id,
const std::string &  status,
command_completion_event_t  callback = utility::log_error() 
)

Set the status of a voice channel.

See also
https://github.com/discord/discord-api-docs/pull/6400 (please replace soon).
Parameters
channel_idThe channel to update.
statusThe new status for the channel.
callbackFunction to call when the API call completes. On success the callback will contain a dpp::confirmation object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by channel_invite_create_sync(), and co_channel_invite_create().

Here is the caller graph for this function:

◆ channel_set_voice_status_sync()

confirmation dpp::cluster::channel_set_voice_status_sync ( snowflake  channel_id,
const std::string &  status 
)

Set the status of a voice channel.

See also
dpp::cluster::channel_set_voice_status
https://github.com/discord/discord-api-docs/pull/6400 (please replace soon).
Parameters
channel_idThe channel to update.
statusThe new status for the channel.
Returns
confirmation returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References gdm_remove().

Here is the call graph for this function:

◆ channel_typing() [1/2]

void dpp::cluster::channel_typing ( const class channel c,
command_completion_event_t  callback = utility::log_error() 
)

Trigger channel typing indicator.

See also
https://discord.com/developers/docs/resources/channel#trigger-typing-indicator
Parameters
cChannel to set as typing on
callbackFunction to call when the API call completes. On success the callback will contain a dpp::confirmation object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by channel_edit_sync(), channel_follow_news_sync(), co_channel_edit(), and co_channel_follow_news().

Here is the caller graph for this function:

◆ channel_typing() [2/2]

void dpp::cluster::channel_typing ( snowflake  cid,
command_completion_event_t  callback = utility::log_error() 
)

Trigger channel typing indicator.

See also
https://discord.com/developers/docs/resources/channel#trigger-typing-indicator
Parameters
cidChannel ID to set as typing on
callbackFunction to call when the API call completes. On success the callback will contain a dpp::confirmation object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

◆ channel_typing_sync() [1/2]

confirmation dpp::cluster::channel_typing_sync ( const class channel c)

Trigger channel typing indicator.

See also
dpp::cluster::channel_typing
https://discord.com/developers/docs/resources/channel#trigger-typing-indicator
Parameters
cChannel to set as typing on
Returns
confirmation returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References current_user_get_dms().

Here is the call graph for this function:

◆ channel_typing_sync() [2/2]

confirmation dpp::cluster::channel_typing_sync ( snowflake  cid)

Trigger channel typing indicator.

See also
dpp::cluster::channel_typing
https://discord.com/developers/docs/resources/channel#trigger-typing-indicator
Parameters
cidChannel ID to set as typing on
Returns
confirmation returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References direct_message_create(), and dpp::unicode_emoji::m.

Here is the call graph for this function:

◆ channels_get()

void dpp::cluster::channels_get ( snowflake  guild_id,
command_completion_event_t  callback 
)

Get all channels for a guild.

See also
https://discord.com/developers/docs/resources/channel#get-channels
Parameters
guild_idGuild ID to retrieve channels for
callbackFunction to call when the API call completes. On success the callback will contain a dpp::channel_map object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by channel_get_sync(), and co_channel_get().

Here is the caller graph for this function:

◆ channels_get_sync()

channel_map dpp::cluster::channels_get_sync ( snowflake  guild_id)

Get all channels for a guild.

See also
dpp::cluster::channels_get
https://discord.com/developers/docs/resources/channel#get-channels
Parameters
guild_idGuild ID to retrieve channels for
Returns
channel_map returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References gdm_add().

Here is the call graph for this function:

◆ clear_audit_reason()

cluster & dpp::cluster::clear_audit_reason ( )

Clear the audit log reason for the next REST call to be made.

This is set per-thread, so you must ensure that if you call this method, your request that is associated with the reason happens on the same thread where you set the reason. Once the next call is made, the audit log reason is cleared for this thread automatically.

Example:

bot.set_audit_reason("Won't be sent")
.clear_audit_reason()
.channel_delete(my_channel_id);
Returns
cluster& Reference to self for chaining.

◆ co_application_role_connection_get()

async< confirmation_callback_t > dpp::cluster::co_application_role_connection_get ( snowflake  application_id)

Get the application's role connection metadata records.

See also
dpp::cluster::application_role_connection_get
https://discord.com/developers/docs/resources/application-role-connection-metadata#get-application-role-connection-metadata-records
Parameters
application_idThe application ID
Returns
application_role_connection returned object on completion

References guild_event_create().

Here is the call graph for this function:

◆ co_application_role_connection_update()

async< confirmation_callback_t > dpp::cluster::co_application_role_connection_update ( snowflake  application_id,
const std::vector< application_role_connection_metadata > &  connection_metadata 
)

Update the application's role connection metadata records.

See also
dpp::cluster::application_role_connection_update
https://discord.com/developers/docs/resources/application-role-connection-metadata#update-application-role-connection-metadata-records
Parameters
application_idThe application ID
connection_metadataThe application role connection metadata to update
Returns
application_role_connection returned object on completion
Note
An application can have a maximum of 5 metadata records.

References guild_event_delete().

Here is the call graph for this function:

◆ co_automod_rule_create()

async< confirmation_callback_t > dpp::cluster::co_automod_rule_create ( snowflake  guild_id,
const automod_rule r 
)

Create an auto moderation rule.

Parameters
guild_idGuild id of the auto moderation rule
rAuto moderation rule to create
Returns
automod_rule returned object on completion

References channel_delete().

Here is the call graph for this function:

◆ co_automod_rule_delete()

async< confirmation_callback_t > dpp::cluster::co_automod_rule_delete ( snowflake  guild_id,
snowflake  rule_id 
)

Delete an auto moderation rule.

Parameters
guild_idGuild id of the auto moderation rule
rule_idAuto moderation rule id to delete
Returns
confirmation returned object on completion

References channel_edit_permissions().

Here is the call graph for this function:

◆ co_automod_rule_edit()

async< confirmation_callback_t > dpp::cluster::co_automod_rule_edit ( snowflake  guild_id,
const automod_rule r 
)

Edit an auto moderation rule.

Parameters
guild_idGuild id of the auto moderation rule
rAuto moderation rule to edit. The rule's id must be set.
Returns
automod_rule returned object on completion

References channel_edit_permissions().

Here is the call graph for this function:

◆ co_automod_rule_get()

async< confirmation_callback_t > dpp::cluster::co_automod_rule_get ( snowflake  guild_id,
snowflake  rule_id 
)

Get a single auto moderation rule.

Parameters
guild_idGuild id of the auto moderation rule
rule_idRule id to retrieve
Returns
automod_rule returned object on completion

References channel_delete_permission().

Here is the call graph for this function:

◆ co_automod_rules_get()

async< confirmation_callback_t > dpp::cluster::co_automod_rules_get ( snowflake  guild_id)

Get all auto moderation rules for a guild.

Parameters
guild_idGuild id of the auto moderation rule
Returns
automod_rule_map returned object on completion

References channel_create().

Here is the call graph for this function:

◆ co_channel_create()

async< confirmation_callback_t > dpp::cluster::co_channel_create ( const class channel c)

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 also
dpp::cluster::channel_create
https://discord.com/developers/docs/resources/channel#create-channel
Parameters
cChannel to create
Returns
channel returned object on completion

References channel_edit_positions().

Here is the call graph for this function:

◆ co_channel_delete()

async< confirmation_callback_t > dpp::cluster::co_channel_delete ( snowflake  channel_id)

Delete a channel.

Note
This method supports audit log reasons set by the cluster::set_audit_reason() method.
See also
dpp::cluster::channel_delete
https://discord.com/developers/docs/resources/channel#deleteclose-channel
Parameters
channel_idChannel id to delete
Returns
confirmation returned object on completion

References channel_follow_news().

Here is the call graph for this function:

◆ co_channel_delete_permission()

async< confirmation_callback_t > dpp::cluster::co_channel_delete_permission ( const class channel c,
snowflake  overwrite_id 
)

Remove a permission from a channel.

Note
This method supports audit log reasons set by the cluster::set_audit_reason() method.
See also
dpp::cluster::channel_delete_permission
https://discord.com/developers/docs/resources/channel#delete-channel-permission
Parameters
cChannel to remove permission from
overwrite_idOverwrite to remove, user or channel ID
Returns
confirmation returned object on completion

References channel_edit().

Here is the call graph for this function:

◆ co_channel_edit()

async< confirmation_callback_t > dpp::cluster::co_channel_edit ( const class channel c)

Edit a channel.

Note
This method supports audit log reasons set by the cluster::set_audit_reason() method.
See also
dpp::cluster::channel_edit
https://discord.com/developers/docs/resources/channel#modify-channel
Parameters
cChannel to edit/update
Returns
channel returned object on completion

References channel_typing().

Here is the call graph for this function:

◆ co_channel_edit_permissions() [1/2]

async< confirmation_callback_t > dpp::cluster::co_channel_edit_permissions ( const class channel c,
const snowflake  overwrite_id,
const uint64_t  allow,
const uint64_t  deny,
const bool  member 
)

Edit a channel's permissions.

See also
dpp::cluster::channel_edit_permissions
https://discord.com/developers/docs/resources/channel#edit-channel-permissions
Note
This method supports audit log reasons set by the cluster::set_audit_reason() method.
Parameters
cChannel to set permissions for
overwrite_idOverwrite to change (a user or role ID)
allowallow permissions bitmask
denydeny permissions bitmask
membertrue if the overwrite_id is a user id, false if it is a channel id
Returns
confirmation returned object on completion

References channel_get().

Here is the call graph for this function:

◆ co_channel_edit_permissions() [2/2]

async< confirmation_callback_t > dpp::cluster::co_channel_edit_permissions ( const snowflake  channel_id,
const snowflake  overwrite_id,
const uint64_t  allow,
const uint64_t  deny,
const bool  member 
)

Edit a channel's permissions.

See also
dpp::cluster::channel_edit_permissions
https://discord.com/developers/docs/resources/channel#edit-channel-permissions
Note
This method supports audit log reasons set by the cluster::set_audit_reason() method.
Parameters
channel_idID of the channel to set permissions for
overwrite_idOverwrite to change (a user or role ID)
allowallow permissions bitmask
denydeny permissions bitmask
membertrue if the overwrite_id is a user id, false if it is a channel id
Returns
confirmation returned object on completion

References channel_invite_create().

Here is the call graph for this function:

◆ co_channel_edit_positions()

async< confirmation_callback_t > dpp::cluster::co_channel_edit_positions ( const std::vector< channel > &  c)

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 also
dpp::cluster::channel_edit_positions
https://discord.com/developers/docs/resources/guild#modify-guild-channel-positions
Parameters
cChannel to change the position for
Returns
confirmation returned object on completion

References channel_invites_get().

Here is the call graph for this function:

◆ co_channel_follow_news()

async< confirmation_callback_t > dpp::cluster::co_channel_follow_news ( const class channel c,
snowflake  target_channel_id 
)

Follow an announcement (news) channel.

See also
dpp::cluster::channel_follow_news
https://discord.com/developers/docs/resources/channel#follow-news-channel
Parameters
cChannel id to follow
target_channel_idChannel to subscribe the channel to
Returns
confirmation returned object on completion

References channel_typing().

Here is the call graph for this function:

◆ co_channel_get()

async< confirmation_callback_t > dpp::cluster::co_channel_get ( snowflake  c)

Get a channel.

See also
dpp::cluster::channel_get
https://discord.com/developers/docs/resources/channel#get-channel
Parameters
cChannel ID to retrieve
Returns
channel returned object on completion

References channels_get().

Here is the call graph for this function:

◆ co_channel_invite_create()

async< confirmation_callback_t > dpp::cluster::co_channel_invite_create ( const class channel c,
const class invite i 
)

Create invite for a channel.

Note
This method supports audit log reasons set by the cluster::set_audit_reason() method.
See also
dpp::cluster::channel_invite_create
https://discord.com/developers/docs/resources/channel#create-channel-invite
Parameters
cChannel to create an invite on
iInvite to create
Returns
invite returned object on completion

References channel_set_voice_status().

Here is the call graph for this function:

◆ co_channel_invites_get()

async< confirmation_callback_t > dpp::cluster::co_channel_invites_get ( const class channel c)

Get invites for a channel.

See also
dpp::cluster::channel_invites_get
https://discord.com/developers/docs/resources/invite#get-invites
Parameters
cChannel to get invites for
Returns
invite_map returned object on completion

References create_dm_channel().

Here is the call graph for this function:

◆ co_channel_pins_get()

async< confirmation_callback_t > dpp::cluster::co_channel_pins_get ( snowflake  channel_id)

Get a channel's pins.

See also
dpp::cluster::channel_pins_get
https://discord.com/developers/docs/resources/channel#get-pinned-messages
Parameters
channel_idChannel ID to get pins for
Returns
message_map returned object on completion

References roles_get().

Here is the call graph for this function:

◆ co_channel_set_voice_status()

async< confirmation_callback_t > dpp::cluster::co_channel_set_voice_status ( snowflake  channel_id,
const std::string &  status 
)

Set the status of a voice channel.

See also
dpp::cluster::channel_set_voice_status
https://github.com/discord/discord-api-docs/pull/6400 (please replace soon).
Parameters
channel_idThe channel to update.
statusThe new status for the channel.
Returns
confirmation returned object on completion

References gdm_remove().

Here is the call graph for this function:

◆ co_channel_typing() [1/2]

async< confirmation_callback_t > dpp::cluster::co_channel_typing ( const class channel c)

Trigger channel typing indicator.

See also
dpp::cluster::channel_typing
https://discord.com/developers/docs/resources/channel#trigger-typing-indicator
Parameters
cChannel to set as typing on
Returns
confirmation returned object on completion

References current_user_get_dms().

Here is the call graph for this function:

◆ co_channel_typing() [2/2]

async< confirmation_callback_t > dpp::cluster::co_channel_typing ( snowflake  cid)

Trigger channel typing indicator.

See also
dpp::cluster::channel_typing
https://discord.com/developers/docs/resources/channel#trigger-typing-indicator
Parameters
cidChannel ID to set as typing on
Returns
confirmation returned object on completion

References direct_message_create(), and dpp::unicode_emoji::m.

Here is the call graph for this function:

◆ co_channels_get()

async< confirmation_callback_t > dpp::cluster::co_channels_get ( snowflake  guild_id)

Get all channels for a guild.

See also
dpp::cluster::channels_get
https://discord.com/developers/docs/resources/channel#get-channels
Parameters
guild_idGuild ID to retrieve channels for
Returns
channel_map returned object on completion

References gdm_add().

Here is the call graph for this function:

◆ co_create_dm_channel()

async< confirmation_callback_t > dpp::cluster::co_create_dm_channel ( snowflake  user_id)

Create a dm channel.

See also
dpp::cluster::create_dm_channel
https://discord.com/developers/docs/resources/user#create-dm
Parameters
user_idUser ID to create DM channel with
Returns
channel returned object on completion

References guild_emoji_create().

Here is the call graph for this function:

◆ co_current_application_get()

async< confirmation_callback_t > dpp::cluster::co_current_application_get ( )

Get current (bot) application.

See also
dpp::cluster::current_application_get
https://discord.com/developers/docs/topics/oauth2#get-current-bot-application-information
Returns
application returned object on completion

References current_user_get_guilds().

Here is the call graph for this function:

◆ co_current_user_connections_get()

async< confirmation_callback_t > dpp::cluster::co_current_user_connections_get ( )

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 also
dpp::cluster::current_user_connections_get
https://discord.com/developers/docs/resources/user#get-user-connections
Returns
connection_map returned object on completion

References get_voice_regions().

Here is the call graph for this function:

◆ co_current_user_edit()

async< confirmation_callback_t > dpp::cluster::co_current_user_edit ( const std::string &  nickname,
const std::string &  image_blob = "",
const image_type  type = i_png 
)

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 also
dpp::cluster::current_user_edit
https://discord.com/developers/docs/resources/user#modify-current-user
Parameters
nicknameNickname to set
image_blobAvatar data to upload (NOTE: Very heavily rate limited!)
typeType of image for avatar. It can be one of i_gif, i_jpg or i_png.
Returns
user returned object on completion
Exceptions
dpp::length_exceptionImage data is larger than the maximum size of 256 kilobytes

References current_user_connections_get().

Here is the call graph for this function:

◆ co_current_user_get()

async< confirmation_callback_t > dpp::cluster::co_current_user_get ( )

Get current (bot) user.

See also
dpp::cluster::current_user_get
https://discord.com/developers/docs/resources/user#get-current-user
Returns
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.

References current_user_leave_guild().

Here is the call graph for this function:

◆ co_current_user_get_dms()

async< confirmation_callback_t > dpp::cluster::co_current_user_get_dms ( )

Get current user DM channels.

Returns
channel_map returned object on completion

References guild_emoji_delete().

Here is the call graph for this function:

◆ co_current_user_get_guilds()

async< confirmation_callback_t > dpp::cluster::co_current_user_get_guilds ( )

Get current (bot) user guilds.

See also
dpp::cluster::current_user_get_guilds
https://discord.com/developers/docs/resources/user#get-current-user-guilds
Returns
guild_map returned object on completion

References guild_get_voice_regions().

Here is the call graph for this function:

◆ co_current_user_join_thread()

async< confirmation_callback_t > dpp::cluster::co_current_user_join_thread ( snowflake  thread_id)

Join a thread.

See also
dpp::cluster::current_user_join_thread
https://discord.com/developers/docs/resources/channel#join-thread
Parameters
thread_idThread ID to join
Returns
confirmation returned object on completion

References threads_get_public_archived().

Here is the call graph for this function:

◆ co_current_user_leave_guild()

async< confirmation_callback_t > dpp::cluster::co_current_user_leave_guild ( snowflake  guild_id)

Leave a guild.

See also
dpp::cluster::current_user_leave_guild
https://discord.com/developers/docs/resources/user#leave-guild
Parameters
guild_idGuild ID to leave
Returns
confirmation returned object on completion

References create_webhook().

Here is the call graph for this function:

◆ co_current_user_leave_thread()

async< confirmation_callback_t > dpp::cluster::co_current_user_leave_thread ( snowflake  thread_id)

Leave a thread.

See also
dpp::cluster::current_user_leave_thread
https://discord.com/developers/docs/resources/channel#leave-thread
Parameters
thread_idThread ID to leave
Returns
confirmation returned object on completion

References thread_member_get().

Here is the call graph for this function:

◆ co_current_user_set_voice_state()

async< confirmation_callback_t > dpp::cluster::co_current_user_set_voice_state ( snowflake  guild_id,
snowflake  channel_id,
bool  suppress = false,
time_t  request_to_speak_timestamp = 0 
)

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 also
dpp::cluster::current_user_set_voice_state
https://discord.com/developers/docs/resources/guild#modify-current-user-voice-state
Parameters
guild_idGuild to set voice state on
channel_idStage channel to set voice state on
Returns
confirmation returned object on completion
Parameters
suppressTrue if the user's audio should be suppressed, false if it should not
request_to_speak_timestampThe 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.
Exceptions
std::logic_exceptionYou attempted to set a request_to_speak_timestamp in the past which is not the value of 0.

References user_get().

Here is the call graph for this function:

◆ co_delete_webhook()

async< confirmation_callback_t > dpp::cluster::co_delete_webhook ( snowflake  webhook_id)

Delete a webhook.

Note
This method supports audit log reasons set by the cluster::set_audit_reason() method.
See also
dpp::cluster::delete_webhook
https://discord.com/developers/docs/resources/webhook#delete-webhook
Parameters
webhook_idWebhook ID to delete
Returns
confirmation returned object on completion

References edit_webhook_with_token().

Here is the call graph for this function:

◆ co_delete_webhook_message()

async< confirmation_callback_t > dpp::cluster::co_delete_webhook_message ( const class webhook wh,
snowflake  message_id,
snowflake  thread_id = 0 
)

Delete webhook message.

See also
dpp::cluster::delete_webhook_message
https://discord.com/developers/docs/resources/webhook#delete-webhook-message
Parameters
whWebhook to delete message for
message_idMessage ID to delete
thread_idID of the thread the message is in
Returns
confirmation returned object on completion

References execute_webhook(), and dpp::unicode_emoji::m.

Here is the call graph for this function:

◆ co_delete_webhook_with_token()

async< confirmation_callback_t > dpp::cluster::co_delete_webhook_with_token ( snowflake  webhook_id,
const std::string &  token 
)

Delete webhook with token.

See also
dpp::cluster::delete_webhook_with_token
https://discord.com/developers/docs/resources/webhook#delete-webhook-with-token
Parameters
webhook_idWebhook ID to delete
tokenToken of webhook to delete
Returns
confirmation returned object on completion

References get_channel_webhooks().

Here is the call graph for this function:

◆ co_direct_message_create()

async< confirmation_callback_t > dpp::cluster::co_direct_message_create ( snowflake  user_id,
const message m 
)

Create a direct message, also create the channel for the direct message if needed.

See also
dpp::cluster::direct_message_create
https://discord.com/developers/docs/resources/user#create-dm
dpp::cluster::direct_message_create
https://discord.com/developers/docs/resources/channel#create-message
Parameters
user_idUser ID of user to send message to
mMessage object
Returns
message returned object on completion

References guild_emoji_edit().

Here is the call graph for this function:

◆ co_edit_webhook()

async< confirmation_callback_t > dpp::cluster::co_edit_webhook ( const class webhook wh)

Edit webhook.

Note
This method supports audit log reasons set by the cluster::set_audit_reason() method.
See also
dpp::cluster::edit_webhook
https://discord.com/developers/docs/resources/webhook#modify-webhook
Parameters
whWebhook to edit
Returns
webhook returned object on completion

References get_guild_webhooks().

Here is the call graph for this function:

◆ co_edit_webhook_message()

async< confirmation_callback_t > dpp::cluster::co_edit_webhook_message ( const class webhook wh,
const struct message m,
snowflake  thread_id = 0 
)

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 also
dpp::cluster::edit_webhook_message
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.
Parameters
whWebhook to edit message for
mNew message
thread_idID of the thread the message is in
Returns
message returned object on completion

References get_webhook().

Here is the call graph for this function:

◆ co_edit_webhook_with_token()

async< confirmation_callback_t > dpp::cluster::co_edit_webhook_with_token ( const class webhook wh)

Edit webhook with token (token is encapsulated in the webhook object)

See also
dpp::cluster::edit_webhook_with_token
https://discord.com/developers/docs/resources/webhook#modify-webhook-with-token
Parameters
whWebhook to edit (should include token)
Returns
webhook returned object on completion

References get_webhook_message().

Here is the call graph for this function:

◆ co_entitlement_test_create()

async< confirmation_callback_t > dpp::cluster::co_entitlement_test_create ( const class entitlement new_entitlement)

Creates a test entitlement to a given SKU for a given guild or user.

Discord will act as though that user or guild has entitlement to your premium offering.

See also
dpp::cluster::entitlement_test_create
https://discord.com/developers/docs/monetization/entitlements#create-test-entitlement
Parameters
new_entitlementThe entitlement to create. Make sure your dpp::entitlement_type (inside your dpp::entitlement object) matches the type of the owner_id (if type is guild, owner_id is a guild id), otherwise it won't work!
Returns
entitlement returned object on completion

References guild_ban_add().

Here is the call graph for this function:

◆ co_entitlement_test_delete()

async< confirmation_callback_t > dpp::cluster::co_entitlement_test_delete ( snowflake  entitlement_id)

Deletes a currently-active test entitlement.

Discord will act as though that user or guild no longer has entitlement to your premium offering.

See also
dpp::cluster::entitlement_test_delete
https://discord.com/developers/docs/monetization/entitlements#delete-test-entitlement
Parameters
entitlement_idThe test entitlement to delete.
Returns
confirmation returned object on completion

References guild_ban_delete().

Here is the call graph for this function:

◆ co_entitlements_get()

async< confirmation_callback_t > dpp::cluster::co_entitlements_get ( snowflake  user_id = 0,
const std::vector< snowflake > &  sku_ids = {},
snowflake  before_id = 0,
snowflake  after_id = 0,
uint8_t  limit = 100,
snowflake  guild_id = 0,
bool  exclude_ended = false 
)

Returns all entitlements for a given app, active and expired.

See also
dpp::cluster::entitlements_get
https://discord.com/developers/docs/monetization/entitlements#list-entitlements
Parameters
user_idUser ID to look up entitlements for.
sku_idsList of SKU IDs to check entitlements for.
before_idRetrieve entitlements before this entitlement ID.
after_idRetrieve entitlements after this entitlement ID.
limitNumber of entitlements to return, 1-100 (default 100).
guild_idGuild ID to look up entitlements for.
exclude_endedWhether ended entitlements should be excluded from the search.
Returns
entitlement_map returned object on completion

References guild_auditlog_get().

Here is the call graph for this function:

◆ co_execute_webhook()

async< confirmation_callback_t > dpp::cluster::co_execute_webhook ( const class webhook wh,
const struct message m,
bool  wait = false,
snowflake  thread_id = 0,
const std::string &  thread_name = "" 
)

Execute webhook.

See also
dpp::cluster::execute_webhook
https://discord.com/developers/docs/resources/webhook#execute-webhook
Parameters
whWebhook to execute
mMessage to send
waitwaits for server confirmation of message send before response, and returns the created message body
thread_idSend a message to the specified thread within a webhook's channel. The thread will automatically be unarchived
thread_nameName of thread to create (requires the webhook channel to be a forum channel)
Returns
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.

References get_webhook_with_token(), and token.

Here is the call graph for this function:

◆ co_gdm_add()

async< confirmation_callback_t > dpp::cluster::co_gdm_add ( snowflake  channel_id,
snowflake  user_id,
const std::string &  access_token,
const std::string &  nick 
)

Adds a recipient to a Group DM using their access token.

See also
dpp::cluster::gdm_add
https://discord.com/developers/docs/resources/channel#group-dm-add-recipient
Parameters
channel_idChannel id to add group DM recipients to
user_idUser ID to add
access_tokenAccess token from OAuth2
nickNickname of user to apply to the chat
Returns
confirmation returned object on completion

References guild_emoji_get().

Here is the call graph for this function:

◆ co_gdm_remove()

async< confirmation_callback_t > dpp::cluster::co_gdm_remove ( snowflake  channel_id,
snowflake  user_id 
)

Removes a recipient from a Group DM.

See also
dpp::cluster::gdm_remove
https://discord.com/developers/docs/resources/channel#group-dm-remove-recipient
Parameters
channel_idChannel ID of group DM
user_idUser ID to remove from group DM
Returns
confirmation returned object on completion

References guild_emojis_get().

Here is the call graph for this function:

◆ co_get_channel_webhooks()

async< confirmation_callback_t > dpp::cluster::co_get_channel_webhooks ( snowflake  channel_id)

Get channel webhooks.

See also
dpp::cluster::get_channel_webhooks
https://discord.com/developers/docs/resources/webhook#get-guild-webhooks
Parameters
channel_idChannel ID to get webhooks for
Returns
webhook_map returned object on completion

◆ co_get_gateway_bot()

async< confirmation_callback_t > dpp::cluster::co_get_gateway_bot ( )

Get the gateway information for the bot using the token.

See also
dpp::cluster::get_gateway_bot
https://discord.com/developers/docs/topics/gateway#get-gateway-bot
Returns
gateway returned object on completion

References guild_create().

Here is the call graph for this function:

◆ co_get_guild_webhooks()

async< confirmation_callback_t > dpp::cluster::co_get_guild_webhooks ( snowflake  guild_id)

Get guild webhooks.

See also
dpp::cluster::get_guild_webhooks
https://discord.com/developers/docs/resources/webhook#get-guild-webhooks
Parameters
guild_idGuild ID to get webhooks for
Returns
webhook_map returned object on completion

References request().

Here is the call graph for this function:

◆ co_get_voice_regions()

async< confirmation_callback_t > dpp::cluster::co_get_voice_regions ( )

Get all voice regions.

See also
dpp::cluster::get_voice_regions
https://discord.com/developers/docs/resources/voice#list-voice-regions
Returns
voiceregion_map returned object on completion

References delete_webhook_with_token(), and token.

Here is the call graph for this function:

◆ co_get_webhook()

async< confirmation_callback_t > dpp::cluster::co_get_webhook ( snowflake  webhook_id)

Get webhook.

See also
dpp::cluster::get_webhook
https://discord.com/developers/docs/resources/webhook#get-webhook
Parameters
webhook_idWebhook ID to get
Returns
webhook returned object on completion

◆ co_get_webhook_message()

async< confirmation_callback_t > dpp::cluster::co_get_webhook_message ( const class webhook wh,
snowflake  message_id,
snowflake  thread_id = 0 
)

Get webhook message.

See also
dpp::cluster::get_webhook_message
https://discord.com/developers/docs/resources/webhook#get-webhook-message
Parameters
whWebhook to get the original message for
message_idThe message ID
thread_idID of the thread the message is in
Returns
message returned object on completion

◆ co_get_webhook_with_token()

async< confirmation_callback_t > dpp::cluster::co_get_webhook_with_token ( snowflake  webhook_id,
const std::string &  token 
)

Get webhook using token.

See also
dpp::cluster::get_webhook_with_token
https://discord.com/developers/docs/resources/webhook#get-webhook-with-token
Parameters
webhook_idWebhook ID to retrieve
tokenToken of webhook
Returns
webhook returned object on completion

◆ co_global_bulk_command_create()

async< confirmation_callback_t > dpp::cluster::co_global_bulk_command_create ( const std::vector< slashcommand > &  commands)

Create/overwrite global slash commands.

Any existing global slash commands will be deleted and replaced with these.

See also
dpp::cluster::global_bulk_command_create
https://discord.com/developers/docs/interactions/application-commands#bulk-overwrite-global-application-commands
Parameters
commandsVector of slash commands to create/update. overwriting existing commands that are registered globally for this application. Commands that do not already exist will count toward daily application command create limits.
Returns
slashcommand_map returned object on completion

References global_command_edit().

Here is the call graph for this function:

◆ co_global_bulk_command_delete()

async< confirmation_callback_t > dpp::cluster::co_global_bulk_command_delete ( )

Delete all existing global slash commands.

See also
dpp::cluster::global_bulk_command_delete
https://discord.com/developers/docs/interactions/application-commands#bulk-overwrite-global-application-commands
Returns
slashcommand_map returned object on completion

References global_commands_get().

Here is the call graph for this function:

◆ co_global_command_create()

async< confirmation_callback_t > dpp::cluster::co_global_command_create ( const slashcommand s)

Create a global slash command (a bot can have a maximum of 100 of these).

See also
dpp::cluster::global_command_create
https://discord.com/developers/docs/interactions/application-commands#create-global-application-command
Parameters
sSlash command to create
Returns
slashcommand returned object on completion

References guild_bulk_command_create().

Here is the call graph for this function:

◆ co_global_command_delete()

async< confirmation_callback_t > dpp::cluster::co_global_command_delete ( snowflake  id)

Delete a global slash command (a bot can have a maximum of 100 of these)

See also
dpp::cluster::global_command_delete
https://discord.com/developers/docs/interactions/application-commands#delete-global-application-command
Parameters
idSlash command to delete
Returns
confirmation returned object on completion

References guild_commands_get_permissions().

Here is the call graph for this function:

◆ co_global_command_edit()

async< confirmation_callback_t > dpp::cluster::co_global_command_edit ( const slashcommand s)

Edit a global slash command (a bot can have a maximum of 100 of these)

See also
dpp::cluster::global_command_edit
https://discord.com/developers/docs/interactions/application-commands#edit-global-application-command
Parameters
sSlash command to change
Returns
confirmation returned object on completion

References guild_bulk_command_edit_permissions().

Here is the call graph for this function:

◆ co_global_command_get()

async< confirmation_callback_t > dpp::cluster::co_global_command_get ( snowflake  id)

Get a global slash command.

See also
dpp::cluster::global_command_get
https://discord.com/developers/docs/interactions/application-commands#get-global-application-command
Parameters
idThe ID of the slash command
Returns
slashcommand returned object on completion

References guild_bulk_command_delete().

Here is the call graph for this function:

◆ co_global_commands_get()

async< confirmation_callback_t > dpp::cluster::co_global_commands_get ( )

Get the application's global slash commands.

See also
dpp::cluster::global_commands_get
https://discord.com/developers/docs/interactions/application-commands#get-global-application-commands
Returns
slashcommand_map returned object on completion

References guild_command_create().

Here is the call graph for this function:

◆ co_guild_add_member()

async< confirmation_callback_t > dpp::cluster::co_guild_add_member ( const guild_member gm,
const std::string &  access_token 
)

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 also
dpp::cluster::guild_add_member
https://discord.com/developers/docs/resources/guild#add-guild-member
Parameters
gmGuild member to add
access_tokenAccess token from Oauth2 scope
Returns
confirmation returned object on completion

References guild_member_delete().

Here is the call graph for this function:

◆ co_guild_auditlog_get()

async< confirmation_callback_t > dpp::cluster::co_guild_auditlog_get ( snowflake  guild_id,
snowflake  user_id,
uint32_t  action_type,
snowflake  before,
snowflake  after,
uint32_t  limit 
)

Get the audit log for a guild.

See also
dpp::cluster::guild_auditlog_get
https://discord.com/developers/docs/resources/audit-log#get-guild-audit-log
Parameters
guild_idGuild to get the audit log of
user_idEntries from a specific user ID. Set this to 0 will fetch any user
action_typeEntries for a specific dpp::audit_type. Set this to 0 will fetch any type
beforeEntries with ID less than a specific audit log entry ID. Used for paginating
afterEntries with ID greater than a specific audit log entry ID. Used for paginating
limitMaximum number of entries (between 1-100) to return
Returns
auditlog returned object on completion

References guild_delete_integration().

Here is the call graph for this function:

◆ co_guild_ban_add()

async< confirmation_callback_t > dpp::cluster::co_guild_ban_add ( snowflake  guild_id,
snowflake  user_id,
uint32_t  delete_message_seconds = 0 
)

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 also
dpp::cluster::guild_ban_add
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.
Parameters
guild_idGuild ID to add ban to
user_idUser ID to ban
delete_message_secondsHow many seconds to delete messages for, between 0 and 604800 (7 days). Defaults to 0
Returns
confirmation returned object on completion

References guild_edit().

Here is the call graph for this function:

◆ co_guild_ban_delete()

async< confirmation_callback_t > dpp::cluster::co_guild_ban_delete ( snowflake  guild_id,
snowflake  user_id 
)

Delete guild ban.

Remove the ban for a user. Requires the BAN_MEMBERS permissions. Fires a Guild Ban Remove Gateway event.

See also
dpp::cluster::guild_ban_delete
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.
Parameters
guild_idGuild to delete ban from
user_idUser ID to delete ban for
Returns
confirmation returned object on completion

References guild_edit_widget().

Here is the call graph for this function:

◆ co_guild_begin_prune()

async< confirmation_callback_t > dpp::cluster::co_guild_begin_prune ( snowflake  guild_id,
const struct prune pruneinfo 
)

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 also
dpp::cluster::guild_begin_prune
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.
Parameters
guild_idGuild ID to prune
pruneinfoPruning info
Returns
prune returned object on completion

References guild_get_welcome_screen().

Here is the call graph for this function:

◆ co_guild_bulk_command_create()

async< confirmation_callback_t > dpp::cluster::co_guild_bulk_command_create ( const std::vector< slashcommand > &  commands,
snowflake  guild_id 
)

Create/overwrite guild slash commands.

Any existing guild slash commands on this guild will be deleted and replaced with these.

See also
dpp::cluster::guild_bulk_command_create
https://discord.com/developers/docs/interactions/application-commands#bulk-overwrite-guild-application-commands
Parameters
commandsVector 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.
guild_idGuild ID to create/update the slash commands in
Returns
slashcommand_map returned object on completion

References guild_command_delete().

Here is the call graph for this function:

◆ co_guild_bulk_command_delete()

async< confirmation_callback_t > dpp::cluster::co_guild_bulk_command_delete ( snowflake  guild_id)

Delete all existing guild slash commands.

See also
dpp::cluster::guild_bulk_command_delete
https://discord.com/developers/docs/interactions/application-commands#bulk-overwrite-global-application-commands
Parameters
guild_idGuild ID to delete the slash commands in.
Returns
slashcommand_map returned object on completion

References guild_command_edit_permissions().

Here is the call graph for this function:

◆ co_guild_bulk_command_edit_permissions()

async< confirmation_callback_t > dpp::cluster::co_guild_bulk_command_edit_permissions ( const std::vector< slashcommand > &  commands,
snowflake  guild_id 
)

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 also
dpp::cluster::guild_bulk_command_edit_permissions
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.
Parameters
commandsA vector of slash commands to edit/overwrite the permissions for
guild_idGuild ID to edit permissions of the slash commands in
Returns
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

References guild_command_get_permissions().

Here is the call graph for this function:

◆ co_guild_command_create()

async< confirmation_callback_t > dpp::cluster::co_guild_command_create ( const slashcommand s,
snowflake  guild_id 
)

Create a slash command local to a guild.

See also
dpp::cluster::guild_command_create
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.
Parameters
sSlash command to create
guild_idGuild ID to create the slash command in
Returns
slashcommand returned object on completion

References guild_command_edit().

Here is the call graph for this function:

◆ co_guild_command_delete()

async< confirmation_callback_t > dpp::cluster::co_guild_command_delete ( snowflake  id,
snowflake  guild_id 
)

Delete a slash command local to a guild.

See also
dpp::cluster::guild_command_delete
https://discord.com/developers/docs/interactions/application-commands#delete-guild-application-command
Parameters
idSlash command to delete
guild_idGuild ID to delete the slash command in
Returns
confirmation returned object on completion

References guild_commands_get().

Here is the call graph for this function:

◆ co_guild_command_edit()

async< confirmation_callback_t > dpp::cluster::co_guild_command_edit ( const slashcommand s,
snowflake  guild_id 
)

Edit a slash command local to a guild.

See also
dpp::cluster::guild_command_edit
https://discord.com/developers/docs/interactions/application-commands#edit-guild-application-command
Parameters
sSlash command to edit
guild_idGuild ID to edit the slash command in
Returns
confirmation returned object on completion

References interaction_followup_create(), dpp::unicode_emoji::m, and token.

Here is the call graph for this function:

◆ co_guild_command_edit_permissions()

async< confirmation_callback_t > dpp::cluster::co_guild_command_edit_permissions ( const slashcommand s,
snowflake  guild_id 
)

Edit slash command permissions of a guild.

See also
dpp::cluster::guild_command_edit_permissions
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
Parameters
sSlash command to edit the permissions for
guild_idGuild ID to edit the slash command in
Returns
confirmation returned object on completion

References interaction_response_create(), and token.

Here is the call graph for this function:

◆ co_guild_command_get()

async< confirmation_callback_t > dpp::cluster::co_guild_command_get ( snowflake  id,
snowflake  guild_id 
)

Get a slash command of a guild.

See also
dpp::cluster::guild_command_get
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
Parameters
idThe ID of the slash command
guild_idGuild ID to get the slash command from
Returns
slashcommand returned object on completion

References interaction_response_edit(), dpp::unicode_emoji::m, and token.

Here is the call graph for this function:

◆ co_guild_command_get_permissions()

async< confirmation_callback_t > dpp::cluster::co_guild_command_get_permissions ( snowflake  id,
snowflake  guild_id 
)

Get the permissions for a slash command of a guild.

See also
dpp::cluster::guild_command_get_permissions
https://discord.com/developers/docs/interactions/application-commands#get-application-command-permissions
Parameters
idThe ID of the slash command to get the permissions for
guild_idGuild ID to get the permissions of
Returns
guild_command_permissions returned object on completion

References interaction_response_get_original(), and token.

Here is the call graph for this function:

◆ co_guild_commands_get()

async< confirmation_callback_t > dpp::cluster::co_guild_commands_get ( snowflake  guild_id)

Get the application's slash commands for a guild.

See also
dpp::cluster::guild_commands_get
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
Parameters
guild_idGuild ID to get the slash commands for
Returns
slashcommand_map returned object on completion

References interaction_followup_edit_original(), dpp::unicode_emoji::m, and token.

Here is the call graph for this function:

◆ co_guild_commands_get_permissions()

async< confirmation_callback_t > dpp::cluster::co_guild_commands_get_permissions ( snowflake  guild_id)

Get all slash command permissions of a guild.

See also
dpp::cluster::guild_commands_get_permissions
https://discord.com/developers/docs/interactions/application-commands#get-application-command-permissions
Parameters
guild_idGuild ID to get the slash commands permissions for
Returns
guild_command_permissions_map returned object on completion

References guild_command_get().

Here is the call graph for this function:

◆ co_guild_create()

async< confirmation_callback_t > dpp::cluster::co_guild_create ( const class guild g)

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 also
dpp::cluster::guild_create
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.
Parameters
gGuild to create
Returns
guild returned object on completion

References guild_get_ban().

Here is the call graph for this function:

◆ co_guild_create_from_template()

async< confirmation_callback_t > dpp::cluster::co_guild_create_from_template ( const std::string &  code,
const std::string &  name 
)

Create a new guild based on a template.

Note
This endpoint can be used only by bots in less than 10 guilds.
See also
dpp::cluster::guild_create_from_template
https://discord.com/developers/docs/resources/guild-template#create-guild-from-guild-template
Parameters
codeTemplate code to create guild from
nameGuild name to create
Returns
guild returned object on completion

References guild_template_sync().

Here is the call graph for this function:

◆ co_guild_current_member_edit()

async< confirmation_callback_t > dpp::cluster::co_guild_current_member_edit ( snowflake  guild_id,
const std::string &  nickname 
)

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 also
dpp::cluster::guild_current_member_edit
https://discord.com/developers/docs/resources/guild#modify-current-member
Parameters
guild_idGuild ID to change on
nicknameNew nickname, or empty string to clear nickname
Returns
confirmation returned object on completion

References guild_delete().

Here is the call graph for this function:

◆ co_guild_delete()

async< confirmation_callback_t > dpp::cluster::co_guild_delete ( snowflake  guild_id)

Delete a guild.

Delete a guild permanently. User must be owner. Fires a Guild Delete Gateway event.

See also
dpp::cluster::guild_delete
https://discord.com/developers/docs/resources/guild#delete-guild
Parameters
guild_idGuild ID to delete
Returns
confirmation returned object on completion

References guild_get_bans().

Here is the call graph for this function:

◆ co_guild_delete_integration()

async< confirmation_callback_t > dpp::cluster::co_guild_delete_integration ( snowflake  guild_id,
snowflake  integration_id 
)

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 also
dpp::cluster::guild_delete_integration
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.
Parameters
guild_idGuild ID to delete integration for
integration_idIntegration ID to delete
Returns
confirmation returned object on completion

References guild_get().

Here is the call graph for this function:

◆ co_guild_edit()

async< confirmation_callback_t > dpp::cluster::co_guild_edit ( const class guild g)

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 also
dpp::cluster::guild_edit
https://discord.com/developers/docs/resources/guild#modify-guild
Note
This method supports audit log reasons set by the cluster::set_audit_reason() method.
Parameters
gGuild to edit
Returns
guild returned object on completion

References guild_get_integrations().

Here is the call graph for this function:

◆ co_guild_edit_member()

async< confirmation_callback_t > dpp::cluster::co_guild_edit_member ( const guild_member gm)

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 also
dpp::cluster::guild_edit_member
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.
Parameters
gmGuild member to edit
Returns
guild_member returned object on completion

References guild_member_kick().

Here is the call graph for this function:

◆ co_guild_edit_onboarding()

async< confirmation_callback_t > dpp::cluster::co_guild_edit_onboarding ( const struct onboarding o)

Edit the guild's onboarding configuration.

Requires the MANAGE_GUILD and MANAGE_ROLES permissions.

Note
Onboarding enforces constraints when enabled. These constraints are that there must be at least 7 Default Channels and at least 5 of them must allow sending messages to the @everyone role. The onboarding::mode field modifies what is considered when enforcing these constraints.
See also
dpp::cluster::guild_edit_onboarding
https://discord.com/developers/docs/resources/guild#modify-guild-onboarding
Note
This method supports audit log reasons set by the cluster::set_audit_reason() method.
Parameters
oThe onboarding object
Returns
onboarding returned object on completion

References guild_get_member().

Here is the call graph for this function:

◆ co_guild_edit_welcome_screen()

async< confirmation_callback_t > dpp::cluster::co_guild_edit_welcome_screen ( snowflake  guild_id,
const struct welcome_screen welcome_screen,
bool  enabled 
)

Edit the guild's welcome screen.

Requires the MANAGE_GUILD permission. May fire a Guild Update Gateway event.

See also
dpp::cluster::guild_edit_welcome_screen
https://discord.com/developers/docs/resources/guild#modify-guild-welcome-screen
Parameters
guild_idThe guild ID to edit the welcome screen for
welcome_screenThe welcome screen
enabledWhether the welcome screen should be enabled or disabled
Returns
dpp::welcome_screen returned object on completion

References guild_member_add_role().

Here is the call graph for this function:

◆ co_guild_edit_widget()

async< confirmation_callback_t > dpp::cluster::co_guild_edit_widget ( snowflake  guild_id,
const class guild_widget gw 
)

Edit guild widget.

Requires the MANAGE_GUILD permission.

See also
dpp::cluster::guild_edit_widget
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.
Parameters
guild_idGuild ID to edit widget for
gwNew guild widget information
Returns
guild_widget returned object on completion

References guild_get_preview().

Here is the call graph for this function:

◆ co_guild_emoji_create()

async< confirmation_callback_t > dpp::cluster::co_guild_emoji_create ( snowflake  guild_id,
const class emoji newemoji 
)

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 also
dpp::cluster::guild_emoji_create
https://discord.com/developers/docs/resources/emoji#create-guild-emoji
Parameters
guild_idGuild ID to create emoji om
newemojiEmoji to create
Returns
emoji returned object on completion

References entitlements_get().

Here is the call graph for this function:

◆ co_guild_emoji_delete()

async< confirmation_callback_t > dpp::cluster::co_guild_emoji_delete ( snowflake  guild_id,
snowflake  emoji_id 
)

Delete a guild emoji.

Note
This method supports audit log reasons set by the cluster::set_audit_reason() method.
See also
dpp::cluster::guild_emoji_delete
https://discord.com/developers/docs/resources/emoji#delete-guild-emoji
Parameters
guild_idGuild ID to delete emoji on
emoji_idEmoji ID to delete
Returns
confirmation returned object on completion

References entitlement_test_create().

Here is the call graph for this function:

◆ co_guild_emoji_edit()

async< confirmation_callback_t > dpp::cluster::co_guild_emoji_edit ( snowflake  guild_id,
const class emoji newemoji 
)

Edit a single emoji.

You must ensure that the emoji passed contained image data using the emoji::load_image() method.

See also
dpp::cluster::guild_emoji_edit
https://discord.com/developers/docs/resources/emoji#modify-guild-emoji
Note
This method supports audit log reasons set by the cluster::set_audit_reason() method.
Parameters
guild_idGuild ID to edit emoji on
newemojiEmoji to edit
Returns
emoji returned object on completion

References entitlement_test_delete().

Here is the call graph for this function:

◆ co_guild_emoji_get()

async< confirmation_callback_t > dpp::cluster::co_guild_emoji_get ( snowflake  guild_id,
snowflake  emoji_id 
)

Get a single emoji.

See also
dpp::cluster::guild_emoji_get
https://discord.com/developers/docs/resources/emoji#get-guild-emoji
Parameters
guild_idGuild ID to get emoji for
emoji_idEmoji ID to get
Returns
emoji returned object on completion

References get_gateway_bot().

Here is the call graph for this function:

◆ co_guild_emojis_get()

async< confirmation_callback_t > dpp::cluster::co_guild_emojis_get ( snowflake  guild_id)

Get all emojis for a guild.

See also
dpp::cluster::guild_emojis_get
https://discord.com/developers/docs/resources/emoji#list-guild-emojis
Parameters
guild_idGuild ID to get emojis for
Returns
emoji_map returned object on completion

References guild_current_member_edit().

Here is the call graph for this function:

◆ co_guild_event_create()

async< confirmation_callback_t > dpp::cluster::co_guild_event_create ( const scheduled_event event)

Create a scheduled event on a guild.

See also
dpp::cluster::guild_event_create
https://discord.com/developers/docs/resources/guild-scheduled-event#create-guild-scheduled-event
Parameters
eventEvent to create (guild ID must be populated)
Returns
scheduled_event returned object on completion

References stage_instance_create().

Here is the call graph for this function:

◆ co_guild_event_delete()

async< confirmation_callback_t > dpp::cluster::co_guild_event_delete ( snowflake  event_id,
snowflake  guild_id 
)

Delete a scheduled event from a guild.

See also
dpp::cluster::guild_event_delete
https://discord.com/developers/docs/resources/guild-scheduled-event#delete-guild-scheduled-event
Parameters
event_idEvent ID to delete
guild_idGuild ID of event to delete
Returns
confirmation returned object on completion

References stage_instance_get().

Here is the call graph for this function:

◆ co_guild_event_edit()

async< confirmation_callback_t > dpp::cluster::co_guild_event_edit ( const scheduled_event event)

Edit/modify a scheduled event on a guild.

See also
dpp::cluster::guild_event_edit
https://discord.com/developers/docs/resources/guild-scheduled-event#modify-guild-scheduled-event
Parameters
eventEvent to create (event ID and guild ID must be populated)
Returns
scheduled_event returned object on completion

References stage_instance_edit().

Here is the call graph for this function:

◆ co_guild_event_get()

async< confirmation_callback_t > dpp::cluster::co_guild_event_get ( snowflake  guild_id,
snowflake  event_id 
)

Get a scheduled event for a guild.

See also
dpp::cluster::guild_event_get
https://discord.com/developers/docs/resources/guild-scheduled-event#get-guild-scheduled-event
Parameters
guild_idGuild to get event for
event_idEvent ID to get
Returns
scheduled_event returned object on completion

References stage_instance_delete().

Here is the call graph for this function:

◆ co_guild_events_get()

async< confirmation_callback_t > dpp::cluster::co_guild_events_get ( snowflake  guild_id)

Get all scheduled events for a guild.

See also
dpp::cluster::guild_events_get
https://discord.com/developers/docs/resources/guild-scheduled-event#list-scheduled-events-for-guild
Parameters
guild_idGuild to get events for
Returns
scheduled_event_map returned object on completion

References skus_get().

Here is the call graph for this function:

◆ co_guild_get_ban()

async< confirmation_callback_t > dpp::cluster::co_guild_get_ban ( snowflake  guild_id,
snowflake  user_id 
)

Get single guild ban.

Requires the BAN_MEMBERS permission.

See also
dpp::cluster::guild_get_ban
https://discord.com/developers/docs/resources/guild#get-guild-ban
Parameters
guild_idGuild ID to get ban for
user_idUser ID of ban to retrieve
Returns
ban returned object on completion

References guild_get_vanity().

Here is the call graph for this function:

◆ co_guild_get_bans()

async< confirmation_callback_t > dpp::cluster::co_guild_get_bans ( snowflake  guild_id,
snowflake  before,
snowflake  after,
snowflake  limit 
)

Get guild ban list.

Requires the BAN_MEMBERS permission.

See also
dpp::cluster::guild_get_bans
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.
Parameters
guild_idGuild ID to get bans for
beforeIf non-zero, all bans for user ids before this user id will be returned up to the limit
afterif non-zero, all bans for user ids after this user id will be returned up to the limit
limitthe maximum number of bans to retrieve in this call up to a maximum of 1000
Returns
ban_map returned object on completion

References guild_get_widget().

Here is the call graph for this function:

◆ co_guild_get_integrations()

async< confirmation_callback_t > dpp::cluster::co_guild_get_integrations ( snowflake  guild_id)

Get guild integrations.

Requires the MANAGE_GUILD permission.

See also
dpp::cluster::guild_get_integrations
https://discord.com/developers/docs/resources/guild#get-guild-integrations
Parameters
guild_idGuild ID to get integrations for
Returns
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.

References guild_get_prune_counts().

Here is the call graph for this function:

◆ co_guild_get_invites()

async< confirmation_callback_t > dpp::cluster::co_guild_get_invites ( snowflake  guild_id)

Get guild invites.

Returns a list of invite objects (with invite metadata) for the guild. Requires the MANAGE_GUILD permission.

See also
dpp::cluster::guild_get_invites
https://discord.com/developers/docs/resources/guild#get-guild-invites
Parameters
guild_idGuild ID to get invites for
Returns
invite_map returned object on completion

References dpp::unicode_emoji::m, and message_create().

Here is the call graph for this function:

◆ co_guild_get_member()

async< confirmation_callback_t > dpp::cluster::co_guild_get_member ( snowflake  guild_id,
snowflake  user_id 
)

Get a guild member.

See also
dpp::cluster::guild_get_member
https://discord.com/developers/docs/resources/guild#get-guild-member
Parameters
guild_idGuild ID to get member for
user_idUser ID of member to get
Returns
guild_member returned object on completion

References guild_member_timeout().

Referenced by event_handler_test().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ co_guild_get_members()

async< confirmation_callback_t > dpp::cluster::co_guild_get_members ( snowflake  guild_id,
uint16_t  limit,
snowflake  after 
)

Get all guild members.

Note
This endpoint is restricted according to whether the GUILD_MEMBERS Privileged Intent is enabled for your application.
See also
dpp::cluster::guild_get_members
https://discord.com/developers/docs/resources/guild#get-guild-members
Parameters
guild_idGuild ID to get all members for
limitmax number of members to return (1-1000)
afterthe highest user id in the previous page
Returns
guild_member_map returned object on completion

References guild_member_timeout_remove().

Here is the call graph for this function:

◆ co_guild_get_onboarding()

async< confirmation_callback_t > dpp::cluster::co_guild_get_onboarding ( snowflake  guild_id)

Get the guild's onboarding configuration.

See also
dpp::cluster::guild_get_onboarding
https://discord.com/developers/docs/resources/guild#get-guild-onboarding
Parameters
guild_idThe guild to pull the onboarding configuration from.
Returns
onboarding returned object on completion

References guild_edit_member().

Here is the call graph for this function:

◆ co_guild_get_prune_counts()

async< confirmation_callback_t > dpp::cluster::co_guild_get_prune_counts ( snowflake  guild_id,
const struct prune pruneinfo 
)

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 also
dpp::cluster::guild_get_prune_counts
https://discord.com/developers/docs/resources/guild#get-guild-prune-count
Parameters
guild_idGuild ID to count for pruning
pruneinfoPruning info
Returns
prune returned object on completion

References guild_edit_onboarding(), and dpp::unicode_emoji::o.

Here is the call graph for this function:

◆ co_guild_get_vanity()

async< confirmation_callback_t > dpp::cluster::co_guild_get_vanity ( snowflake  guild_id)

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 also
dpp::cluster::guild_get_vanity
https://discord.com/developers/docs/resources/guild#get-guild-vanity-url
Parameters
guild_idGuild to get vanity URL for
Returns
invite returned object on completion

References guild_set_nickname().

Here is the call graph for this function:

◆ co_guild_get_voice_regions()

async< confirmation_callback_t > dpp::cluster::co_guild_get_voice_regions ( snowflake  guild_id)

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 also
dpp::cluster::guild_get_voice_regions
https://discord.com/developers/docs/resources/guild#get-guild-voice-regions
Parameters
guild_idGuild ID to get voice regions for
Returns
voiceregion_map returned object on completion

References edit_webhook().

Here is the call graph for this function:

◆ co_guild_get_welcome_screen()

async< confirmation_callback_t > dpp::cluster::co_guild_get_welcome_screen ( snowflake  guild_id)

Get the guild's welcome screen.

If the welcome screen is not enabled, the MANAGE_GUILD permission is required.

See also
dpp::cluster::guild_get_welcome_screen
https://discord.com/developers/docs/resources/guild#get-guild-welcome-screen
Parameters
guild_idThe guild ID to get the welcome screen from
Returns
dpp::welcome_screen returned object on completion

References guild_get_members().

Here is the call graph for this function:

◆ co_guild_get_widget()

async< confirmation_callback_t > dpp::cluster::co_guild_get_widget ( snowflake  guild_id)

Get guild widget.

Requires the MANAGE_GUILD permission.

See also
dpp::cluster::guild_get_widget
https://discord.com/developers/docs/resources/guild#get-guild-widget
Parameters
guild_idGuild ID to get widget for
Returns
guild_widget returned object on completion

References guild_sync_integration().

Here is the call graph for this function:

◆ co_guild_member_add_role()

async< confirmation_callback_t > dpp::cluster::co_guild_member_add_role ( snowflake  guild_id,
snowflake  user_id,
snowflake  role_id 
)

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 also
dpp::cluster::guild_member_add_role
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.
Parameters
guild_idGuild ID to add a role to
user_idUser ID to add role to
role_idRole ID to add to the user
Returns
confirmation returned object on completion

References guild_member_delete_role().

Here is the call graph for this function:

◆ co_guild_member_delete()

async< confirmation_callback_t > dpp::cluster::co_guild_member_delete ( snowflake  guild_id,
snowflake  user_id 
)

Remove (kick) a guild member.

Remove a member from a guild. Requires KICK_MEMBERS permission. Fires a Guild Member Remove Gateway event.

See also
dpp::cluster::guild_member_delete
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
Parameters
guild_idGuild ID to kick member from
user_idUser ID to kick
Returns
confirmation returned object on completion

References guild_member_remove_role().

Here is the call graph for this function:

◆ co_guild_member_delete_role()

async< confirmation_callback_t > dpp::cluster::co_guild_member_delete_role ( snowflake  guild_id,
snowflake  user_id,
snowflake  role_id 
)

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 also
dpp::cluster::guild_member_delete_role
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.
Parameters
guild_idGuild ID to remove role from user on
user_idUser ID to remove role from
role_idRole to remove
Returns
confirmation returned object on completion
Deprecated:
Use dpp::cluster::guild_member_remove_role instead

References invite_delete().

Here is the call graph for this function:

◆ co_guild_member_kick()

async< confirmation_callback_t > dpp::cluster::co_guild_member_kick ( snowflake  guild_id,
snowflake  user_id 
)

Remove (kick) a guild member.

Remove a member from a guild. Requires KICK_MEMBERS permission. Fires a Guild Member Remove Gateway event.

See also
dpp::cluster::guild_member_kick
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.
Parameters
guild_idGuild ID to kick member from
user_idUser ID to kick
Returns
confirmation returned object on completion

References guild_member_move().

Here is the call graph for this function:

◆ co_guild_member_move()

async< confirmation_callback_t > dpp::cluster::co_guild_member_move ( const snowflake  channel_id,
const snowflake  guild_id,
const snowflake  user_id 
)

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.
This method supports audit log reasons set by the cluster::set_audit_reason() method.
See also
dpp::cluster::guild_member_move
https://discord.com/developers/docs/resources/guild#modify-guild-member
Parameters
channel_idId of the channel to which the user is used. Set to 0 to disconnect the user
guild_idGuild id to which the user is connected
user_idUser id, who should be moved
Returns
guild_member returned object on completion

References dpp::unicode_emoji::m, and message_add_reaction().

Here is the call graph for this function:

◆ co_guild_member_remove_role()

async< confirmation_callback_t > dpp::cluster::co_guild_member_remove_role ( snowflake  guild_id,
snowflake  user_id,
snowflake  role_id 
)

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 also
dpp::cluster::guild_member_remove_role
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.
Parameters
guild_idGuild ID to remove role from user on
user_idUser ID to remove role from
role_idRole to remove
Returns
confirmation returned object on completion

References invite_get().

Here is the call graph for this function:

◆ co_guild_member_timeout()

async< confirmation_callback_t > dpp::cluster::co_guild_member_timeout ( snowflake  guild_id,
snowflake  user_id,
time_t  communication_disabled_until 
)

Set the timeout of a guild member.

Fires a Guild Member Update Gateway event.

See also
dpp::cluster::guild_member_timeout
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.
Parameters
guild_idGuild ID to timeout the member in
user_idUser ID to set the timeout for
communication_disabled_untilThe timestamp when the user's timeout will expire (up to 28 days in the future). Set to 0 to remove the timeout
Returns
confirmation returned object on completion

References guild_search_members().

Here is the call graph for this function:

◆ co_guild_member_timeout_remove()

async< confirmation_callback_t > dpp::cluster::co_guild_member_timeout_remove ( snowflake  guild_id,
snowflake  user_id 
)

Remove the timeout of a guild member.

A shortcut for guild_member_timeout(guild_id, user_id, 0, callback) Fires a Guild Member Update Gateway event.

See also
dpp::cluster::guild_member_timeout_remove
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.
Parameters
guild_idGuild ID to remove the member timeout from
user_idUser ID to remove the timeout for
Returns
confirmation returned object on completion

References guild_get_invites().

Here is the call graph for this function:

◆ co_guild_modify_integration()

async< confirmation_callback_t > dpp::cluster::co_guild_modify_integration ( snowflake  guild_id,
const class integration i 
)

Modify guild integration.

Note
This method supports audit log reasons set by the cluster::set_audit_reason() method.
See also
dpp::cluster::guild_modify_integration
https://discord.com/developers/docs/resources/guild#modify-guild-integration
Parameters
guild_idGuild ID to modify integration for
iIntegration to modify
Returns
confirmation returned object on completion

References guild_get_onboarding().

Here is the call graph for this function:

◆ co_guild_search_members()

async< confirmation_callback_t > dpp::cluster::co_guild_search_members ( snowflake  guild_id,
const std::string &  query,
uint16_t  limit 
)

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 also
dpp::cluster::guild_search_members
https://discord.com/developers/docs/resources/guild#search-guild-members
Parameters
guild_idGuild ID to search in
queryQuery string to match username(s) and nickname(s) against
limitmax number of members to return (1-1000)
Returns
guild_member_map returned object on completion

References message_add_reaction().

Here is the call graph for this function:

◆ co_guild_set_nickname()

async< confirmation_callback_t > dpp::cluster::co_guild_set_nickname ( snowflake  guild_id,
const std::string &  nickname 
)

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 also
dpp::cluster::guild_set_nickname
https://discord.com/developers/docs/resources/guild#modify-current-user-nick
Parameters
guild_idGuild ID to change nickname on
nicknameNew nickname, or empty string to clear nickname
Returns
confirmation returned object on completion

References guild_edit_welcome_screen().

Here is the call graph for this function:

◆ co_guild_sticker_create()

async< confirmation_callback_t > dpp::cluster::co_guild_sticker_create ( const sticker s)

Create a sticker in a guild.

Note
This method supports audit log reasons set by the cluster::set_audit_reason() method.
See also
dpp::cluster::guild_sticker_create
https://discord.com/developers/docs/resources/sticker#create-guild-sticker
Parameters
sSticker to create. Must have its guild ID set.
Returns
sticker returned object on completion

References nitro_sticker_get().

Here is the call graph for this function:

◆ co_guild_sticker_delete()

async< confirmation_callback_t > dpp::cluster::co_guild_sticker_delete ( snowflake  sticker_id,
snowflake  guild_id 
)

Delete a sticker from a guild.

Note
This method supports audit log reasons set by the cluster::set_audit_reason() method.
See also
dpp::cluster::guild_sticker_delete
https://discord.com/developers/docs/resources/sticker#delete-guild-sticker
Parameters
sticker_idsticker ID to delete
guild_idguild ID to delete from
Returns
confirmation returned object on completion

References sticker_packs_get().

Here is the call graph for this function:

◆ co_guild_sticker_get()

async< confirmation_callback_t > dpp::cluster::co_guild_sticker_get ( snowflake  id,
snowflake  guild_id 
)

Get a guild sticker.

See also
dpp::cluster::guild_sticker_get
https://discord.com/developers/docs/resources/sticker#get-guild-sticker
Parameters
idId of sticker to get.
guild_idGuild ID of the guild where the sticker is
Returns
sticker returned object on completion

References guild_create_from_template().

Here is the call graph for this function:

◆ co_guild_sticker_modify()

async< confirmation_callback_t > dpp::cluster::co_guild_sticker_modify ( const sticker s)

Modify a sticker in a guild.

Note
This method supports audit log reasons set by the cluster::set_audit_reason() method.
See also
dpp::cluster::guild_sticker_modify
https://discord.com/developers/docs/resources/sticker#modify-guild-sticker
Parameters
sSticker to modify. Must have its guild ID and sticker ID set.
Returns
sticker returned object on completion

References guild_template_create().

Here is the call graph for this function:

◆ co_guild_stickers_get()

async< confirmation_callback_t > dpp::cluster::co_guild_stickers_get ( snowflake  guild_id)

Get all guild stickers.

See also
dpp::cluster::guild_stickers_get
https://discord.com/developers/docs/resources/sticker#get-guild-stickers
Parameters
guild_idGuild ID of the guild where the sticker is
Returns
sticker_map returned object on completion

References guild_template_delete().

Here is the call graph for this function:

◆ co_guild_sync_integration()

async< confirmation_callback_t > dpp::cluster::co_guild_sync_integration ( snowflake  guild_id,
snowflake  integration_id 
)

Sync guild integration.

See also
dpp::cluster::guild_sync_integration
https://discord.com/developers/docs/resources/guild#sync-guild-integration
Parameters
guild_idGuild ID to sync integration on
integration_idIntegration ID to synchronise
Returns
confirmation returned object on completion

References guild_add_member().

Here is the call graph for this function:

◆ co_guild_template_create()

async< confirmation_callback_t > dpp::cluster::co_guild_template_create ( snowflake  guild_id,
const std::string &  name,
const std::string &  description 
)

Creates a template for the guild.

See also
dpp::cluster::guild_template_create
https://discord.com/developers/docs/resources/guild-template#create-guild-template
Parameters
guild_idGuild to create template from
nameTemplate name to create
descriptionDescription of template to create
Returns
dtemplate returned object on completion

References template_get().

Here is the call graph for this function:

◆ co_guild_template_delete()

async< confirmation_callback_t > dpp::cluster::co_guild_template_delete ( snowflake  guild_id,
const std::string &  code 
)

Deletes the template.

See also
dpp::cluster::guild_template_delete
https://discord.com/developers/docs/resources/guild-template#delete-guild-template
Parameters
guild_idGuild ID of template to delete
codeTemplate code to delete
Returns
confirmation returned object on completion

References current_user_join_thread().

Here is the call graph for this function:

◆ co_guild_template_modify()

async< confirmation_callback_t > dpp::cluster::co_guild_template_modify ( snowflake  guild_id,
const std::string &  code,
const std::string &  name,
const std::string &  description 
)

Modifies the template's metadata.

See also
dpp::cluster::guild_template_modify
https://discord.com/developers/docs/resources/guild-template#modify-guild-template
Parameters
guild_idGuild ID of template to modify
codeTemplate code to modify
nameNew name of template
descriptionNew description of template
Returns
dtemplate returned object on completion

References current_user_leave_thread().

Here is the call graph for this function:

◆ co_guild_template_sync()

async< confirmation_callback_t > dpp::cluster::co_guild_template_sync ( snowflake  guild_id,
const std::string &  code 
)

Syncs the template to the guild's current state.

See also
dpp::cluster::guild_template_sync
https://discord.com/developers/docs/resources/guild-template#sync-guild-template
Parameters
guild_idGuild to synchronise template for
codeCode of template to synchronise
Returns
dtemplate returned object on completion

References threads_get_joined_private_archived().

Here is the call graph for this function:

◆ co_guild_templates_get()

async< confirmation_callback_t > dpp::cluster::co_guild_templates_get ( snowflake  guild_id)

Get guild templates.

See also
dpp::cluster::guild_templates_get
https://discord.com/developers/docs/resources/guild-template#get-guild-templates
Parameters
guild_idGuild ID to get templates for
Returns
dtemplate_map returned object on completion

References threads_get_active().

Here is the call graph for this function:

◆ co_interaction_followup_create()

async< confirmation_callback_t > dpp::cluster::co_interaction_followup_create ( const std::string &  token,
const message m 
)

Create a followup message to a slash command.

See also
dpp::cluster::interaction_followup_create
https://discord.com/developers/docs/interactions/receiving-and-responding#create-interaction-response
Parameters
tokenToken for the interaction webhook
mfollowup message to create
Returns
confirmation returned object on completion

References interaction_followup_get_original(), and token.

Here is the call graph for this function:

◆ co_interaction_followup_delete()

async< confirmation_callback_t > dpp::cluster::co_interaction_followup_delete ( const std::string &  token)

Delete the initial interaction response.

See also
dpp::cluster::interaction_followup_delete
https://discord.com/developers/docs/interactions/receiving-and-responding#delete-original-interaction-response
Parameters
tokenToken for the interaction webhook
Returns
confirmation returned object on completion

References automod_rule_get().

Here is the call graph for this function:

◆ co_interaction_followup_edit()

async< confirmation_callback_t > dpp::cluster::co_interaction_followup_edit ( const std::string &  token,
const message m 
)

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.

See also
dpp::cluster::interaction_followup_edit
https://discord.com/developers/docs/interactions/receiving-and-responding#edit-followup-message
Parameters
tokenToken for the interaction webhook
mmessage to edit, the ID should be set
Returns
confirmation returned object on completion

References automod_rule_create().

Here is the call graph for this function:

◆ co_interaction_followup_edit_original()

async< confirmation_callback_t > dpp::cluster::co_interaction_followup_edit_original ( const std::string &  token,
const message m 
)

Edit original followup message to a slash command This is an alias for cluster::interaction_response_edit.

See also
dpp::cluster::interaction_followup_edit_original
cluster::interaction_response_edit
Parameters
tokenToken for the interaction webhook
mmessage to edit, the ID should be set
Returns
confirmation returned object on completion

References automod_rules_get().

Here is the call graph for this function:

◆ co_interaction_followup_get()

async< confirmation_callback_t > dpp::cluster::co_interaction_followup_get ( const std::string &  token,
snowflake  message_id 
)

Get the followup message to a slash command.

See also
dpp::cluster::interaction_followup_get
https://discord.com/developers/docs/interactions/receiving-and-responding#get-followup-message
Parameters
tokenToken for the interaction webhook
message_idmessage to retrieve
Returns
message returned object on completion

References automod_rule_edit().

Here is the call graph for this function:

◆ co_interaction_followup_get_original()

async< confirmation_callback_t > dpp::cluster::co_interaction_followup_get_original ( const std::string &  token)

Get the original followup message to a slash command This is an alias for cluster::interaction_response_get_original.

See also
dpp::cluster::interaction_followup_get_original
cluster::interaction_response_get_original
Parameters
tokenToken for the interaction webhook
Returns
message returned object on completion

References automod_rule_delete().

Here is the call graph for this function:

◆ co_interaction_response_create()

async< confirmation_callback_t > dpp::cluster::co_interaction_response_create ( snowflake  interaction_id,
const std::string &  token,
const interaction_response r 
)

Respond to a slash command.

See also
dpp::cluster::interaction_response_create
https://discord.com/developers/docs/interactions/receiving-and-responding#create-interaction-response
Parameters
interaction_idInteraction id to respond to
tokenToken for the interaction webhook
rResponse to send
Returns
confirmation returned object on completion

References interaction_followup_delete(), and token.

Here is the call graph for this function:

◆ co_interaction_response_edit()

async< confirmation_callback_t > dpp::cluster::co_interaction_response_edit ( const std::string &  token,
const message m 
)

Edit response to a slash command.

See also
dpp::cluster::interaction_response_edit
https://discord.com/developers/docs/interactions/receiving-and-responding#edit-original-interaction-response
Parameters
tokenToken for the interaction webhook
mMessage to send
Returns
confirmation returned object on completion

References interaction_followup_edit(), dpp::unicode_emoji::m, and token.

Here is the call graph for this function:

◆ co_interaction_response_get_original()

async< confirmation_callback_t > dpp::cluster::co_interaction_response_get_original ( const std::string &  token)

Get the original response to a slash command.

See also
dpp::cluster::interaction_response_get_original
https://discord.com/developers/docs/interactions/receiving-and-responding#get-original-interaction-response
Parameters
tokenToken for the interaction webhook
Returns
message returned object on completion

References interaction_followup_get(), and token.

Here is the call graph for this function:

◆ co_invite_get()

async< confirmation_callback_t > dpp::cluster::co_invite_get ( const std::string &  invite_code)

Get details about an invite.

See also
dpp::cluster::invite_get
https://discord.com/developers/docs/resources/invite#get-invite
Parameters
invite_codeInvite code to get information on
Returns
invite returned object on completion

References dpp::unicode_emoji::m, and message_delete_all_reactions().

Here is the call graph for this function:

◆ co_message_add_reaction() [1/2]

async< confirmation_callback_t > dpp::cluster::co_message_add_reaction ( const struct message m,
const std::string &  reaction 
)

Add a reaction to a message.

The reaction string must be either an emojiname:id or a unicode character.

See also
dpp::cluster::message_add_reaction
https://discord.com/developers/docs/resources/channel#create-reaction
Parameters
mMessage to add a reaction to
reactionReaction to add. Emojis should be in the form emojiname:id
Returns
confirmation returned object on completion

References message_delete_all_reactions().

Referenced by event_handler_test().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ co_message_add_reaction() [2/2]

async< confirmation_callback_t > dpp::cluster::co_message_add_reaction ( snowflake  message_id,
snowflake  channel_id,
const std::string &  reaction 
)

Add a reaction to a message by id.

The reaction string must be either an emojiname:id or a unicode character.

See also
dpp::cluster::message_add_reaction
https://discord.com/developers/docs/topics/gateway#message-reaction-add
Parameters
message_idMessage to add reactions to
channel_idChannel to add reactions to
reactionReaction to add. Emojis should be in the form emojiname:id
Returns
confirmation returned object on completion

References message_delete_bulk().

Here is the call graph for this function:

◆ co_message_create()

async< confirmation_callback_t > dpp::cluster::co_message_create ( const struct message m)

Send a message to a channel.

The callback function is called when the message has been sent

See also
dpp::cluster::message_create
https://discord.com/developers/docs/resources/channel#create-message
Parameters
mMessage to send
Returns
message returned object on completion

References message_delete().

Referenced by event_handler_test().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ co_message_crosspost()

async< confirmation_callback_t > dpp::cluster::co_message_crosspost ( snowflake  message_id,
snowflake  channel_id 
)

Crosspost a message.

The callback function is called when the message has been sent

See also
dpp::cluster::message_crosspost
https://discord.com/developers/docs/resources/channel#crosspost-message
Parameters
message_idMessage to crosspost
channel_idChannel ID to crosspost from
Returns
message returned object on completion

References dpp::unicode_emoji::m, and message_delete_own_reaction().

Here is the call graph for this function:

◆ co_message_delete()

async< confirmation_callback_t > dpp::cluster::co_message_delete ( snowflake  message_id,
snowflake  channel_id 
)

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 also
dpp::cluster::message_delete
https://discord.com/developers/docs/resources/channel#delete-message
Parameters
message_idMessage ID to delete
channel_idChannel to delete from
Returns
confirmation returned object on completion

References dpp::unicode_emoji::m, and message_delete_reaction_emoji().

Here is the call graph for this function:

◆ co_message_delete_all_reactions() [1/2]

async< confirmation_callback_t > dpp::cluster::co_message_delete_all_reactions ( const struct message m)

Delete all reactions on a message.

See also
dpp::cluster::message_delete_all_reactions
https://discord.com/developers/docs/resources/channel#delete-all-reactions
Parameters
mMessage to delete reactions from
Returns
confirmation returned object on completion

References message_delete_own_reaction().

Here is the call graph for this function:

◆ co_message_delete_all_reactions() [2/2]

async< confirmation_callback_t > dpp::cluster::co_message_delete_all_reactions ( snowflake  message_id,
snowflake  channel_id 
)

Delete all reactions on a message by id.

See also
dpp::cluster::message_delete_all_reactions
https://discord.com/developers/docs/resources/channel#delete-all-reactions
Parameters
message_idMessage to delete reactions from
channel_idChannel to delete reactions from
Returns
confirmation returned object on completion

References dpp::unicode_emoji::m, and message_delete_reaction().

Here is the call graph for this function:

◆ co_message_delete_bulk()

async< confirmation_callback_t > dpp::cluster::co_message_delete_bulk ( const std::vector< snowflake > &  message_ids,
snowflake  channel_id 
)

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.
If any message provided older than 2 weeks or any duplicate message ID, it will fail.
See also
dpp::cluster::message_delete_bulk
https://discord.com/developers/docs/resources/channel#bulk-delete-messages
Parameters
message_idsList of message IDs to delete (at least 2 and at most 100 message IDs)
channel_idChannel to delete from
Returns
confirmation returned object on completion

References message_delete_reaction().

Here is the call graph for this function:

◆ co_message_delete_own_reaction() [1/2]

async< confirmation_callback_t > dpp::cluster::co_message_delete_own_reaction ( const struct message m,
const std::string &  reaction 
)

Delete own reaction from a message.

The reaction string must be either an emojiname:id or a unicode character.

See also
dpp::cluster::message_delete_own_reaction
https://discord.com/developers/docs/resources/channel#delete-own-reaction
Parameters
mMessage to delete own reaction from
reactionReaction to delete. The reaction should be in the form emojiname:id
Returns
confirmation returned object on completion

References message_delete_reaction_emoji().

Here is the call graph for this function:

◆ co_message_delete_own_reaction() [2/2]

async< confirmation_callback_t > dpp::cluster::co_message_delete_own_reaction ( snowflake  message_id,
snowflake  channel_id,
const std::string &  reaction 
)

Delete own reaction from a message by id.

The reaction string must be either an emojiname:id or a unicode character.

See also
dpp::cluster::message_delete_own_reaction
https://discord.com/developers/docs/resources/channel#delete-own-reaction
Parameters
message_idMessage to delete reactions from
channel_idChannel to delete reactions from
reactionReaction to delete. The reaction should be in the form emojiname:id
Returns
confirmation returned object on completion

References dpp::unicode_emoji::m, and message_edit().

Here is the call graph for this function:

◆ co_message_delete_reaction() [1/2]

async< confirmation_callback_t > dpp::cluster::co_message_delete_reaction ( const struct message m,
snowflake  user_id,
const std::string &  reaction 
)

Delete a user's reaction from a message.

The reaction string must be either an emojiname:id or a unicode character

See also
dpp::cluster::message_delete_reaction
https://discord.com/developers/docs/resources/channel#delete-user-reaction
Parameters
mMessage to delete a user's reaction from
user_idUser ID who's reaction you want to remove
reactionReaction to remove. Reactions should be in the form emojiname:id
Returns
confirmation returned object on completion

References dpp::unicode_emoji::m, and message_edit_flags().

Here is the call graph for this function:

◆ co_message_delete_reaction() [2/2]

async< confirmation_callback_t > dpp::cluster::co_message_delete_reaction ( snowflake  message_id,
snowflake  channel_id,
snowflake  user_id,
const std::string &  reaction 
)

Delete a user's reaction from a message by id.

The reaction string must be either an emojiname:id or a unicode character

See also
dpp::cluster::message_delete_reaction
https://discord.com/developers/docs/resources/channel#delete-user-reaction
Parameters
message_idMessage to delete reactions from
channel_idChannel to delete reactions from
user_idUser ID who's reaction you want to remove
reactionReaction to remove. Reactions should be in the form emojiname:id
Returns
confirmation returned object on completion

References message_get().

Here is the call graph for this function:

◆ co_message_delete_reaction_emoji() [1/2]

async< confirmation_callback_t > dpp::cluster::co_message_delete_reaction_emoji ( const struct message m,
const std::string &  reaction 
)

Delete all reactions on a message using a particular emoji.

The reaction string must be either an emojiname:id or a unicode character

See also
dpp::cluster::message_delete_reaction_emoji
https://discord.com/developers/docs/resources/channel#delete-all-reactions-for-emoji
Parameters
mMessage to delete reactions from
reactionReaction to delete, in the form emojiname:id or a unicode character
Returns
confirmation returned object on completion

References dpp::unicode_emoji::m, and message_get_reactions().

Here is the call graph for this function:

◆ co_message_delete_reaction_emoji() [2/2]

async< confirmation_callback_t > dpp::cluster::co_message_delete_reaction_emoji ( snowflake  message_id,
snowflake  channel_id,
const std::string &  reaction 
)

Delete all reactions on a message using a particular emoji by id.

The reaction string must be either an emojiname:id or a unicode character

See also
dpp::cluster::message_delete_reaction_emoji
https://discord.com/developers/docs/resources/channel#delete-all-reactions-for-emoji
Parameters
message_idMessage to delete reactions from
channel_idChannel to delete reactions from
reactionReaction to delete, in the form emojiname:id or a unicode character
Returns
confirmation returned object on completion

References message_get_reactions().

Here is the call graph for this function:

◆ co_message_edit()

async< confirmation_callback_t > dpp::cluster::co_message_edit ( const struct message m)

Edit a message on a channel.

The callback function is called when the message has been edited

See also
dpp::cluster::message_edit
https://discord.com/developers/docs/resources/channel#edit-message
Parameters
mMessage to edit
Returns
message returned object on completion

References message_pin().

Referenced by event_handler_test().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ co_message_edit_flags()

async< confirmation_callback_t > dpp::cluster::co_message_edit_flags ( const struct message m)

Edit the flags of a message on a channel.

The callback function is called when the message has been edited

Parameters
mMessage to edit the flags of
Returns
message returned object on completion

References messages_get().

Here is the call graph for this function:

◆ co_message_get()

async< confirmation_callback_t > dpp::cluster::co_message_get ( snowflake  message_id,
snowflake  channel_id 
)

Get a message.

See also
dpp::cluster::message_get
https://discord.com/developers/docs/resources/channel#get-channel-message
Parameters
message_idMessage ID
channel_idChannel ID
Returns
message returned object on completion

References message_unpin().

Here is the call graph for this function:

◆ co_message_get_reactions() [1/2]

async< confirmation_callback_t > dpp::cluster::co_message_get_reactions ( const struct message m,
const std::string &  reaction,
snowflake  before,
snowflake  after,
snowflake  limit 
)

Get reactions on a message for a particular emoji.

The reaction string must be either an emojiname:id or a unicode character

See also
dpp::cluster::message_get_reactions
https://discord.com/developers/docs/resources/channel#get-reactions
Parameters
mMessage to get reactions for
reactionReaction should be in the form emojiname:id or a unicode character
beforeReactions before this ID should be retrieved if this is set to non-zero
afterReactions before this ID should be retrieved if this is set to non-zero
limitThis number of reactions maximum should be returned
Returns
user_map returned object on completion

References dpp::unicode_emoji::m, and poll_get_answer_voters().

Here is the call graph for this function:

◆ co_message_get_reactions() [2/2]

async< confirmation_callback_t > dpp::cluster::co_message_get_reactions ( snowflake  message_id,
snowflake  channel_id,
const std::string &  reaction,
snowflake  before,
snowflake  after,
snowflake  limit 
)

Get reactions on a message for a particular emoji by id.

The reaction string must be either an emojiname:id or a unicode character

See also
dpp::cluster::message_get_reactions
https://discord.com/developers/docs/resources/channel#get-reactions
Parameters
message_idMessage to get reactions for
channel_idChannel to get reactions for
reactionReaction should be in the form emojiname:id or a unicode character
beforeReactions before this ID should be retrieved if this is set to non-zero
afterReactions before this ID should be retrieved if this is set to non-zero
limitThis number of reactions maximum should be returned
Returns
emoji_map returned object on completion

References poll_get_answer_voters().

Here is the call graph for this function:

◆ co_message_pin()

async< confirmation_callback_t > dpp::cluster::co_message_pin ( snowflake  channel_id,
snowflake  message_id 
)

Pin a message.

Note
This method supports audit log reasons set by the cluster::set_audit_reason() method.
See also
dpp::cluster::message_pin
https://discord.com/developers/docs/resources/channel#pin-message
Parameters
channel_idChannel id to pin message on
message_idMessage id to pin message on
Returns
confirmation returned object on completion

References dpp::unicode_emoji::m, and poll_end().

Here is the call graph for this function:

◆ co_message_unpin()

async< confirmation_callback_t > dpp::cluster::co_message_unpin ( snowflake  channel_id,
snowflake  message_id 
)

Unpin a message.

See also
dpp::cluster::message_unpin
https://discord.com/developers/docs/resources/channel#unpin-message
Note
This method supports audit log reasons set by the cluster::set_audit_reason() method.
Parameters
channel_idChannel id to unpin message on
message_idMessage id to unpin message on
Returns
confirmation returned object on completion

References channel_pins_get().

Here is the call graph for this function:

◆ co_messages_get()

async< confirmation_callback_t > dpp::cluster::co_messages_get ( snowflake  channel_id,
snowflake  around,
snowflake  before,
snowflake  after,
uint64_t  limit 
)

Get multiple messages.

This function will attempt to fetch as many messages as possible using multiple API calls if needed.

See also
dpp::cluster::messages_get
https://discord.com/developers/docs/resources/channel#get-channel-messages
Parameters
channel_idChannel ID to retrieve messages for
aroundMessages should be retrieved around this ID if this is set to non-zero
beforeMessages before this ID should be retrieved if this is set to non-zero
afterMessages after this ID should be retrieved if this is set to non-zero
limitThis number of messages maximum should be returned, up to a maximum of 100.
Returns
message_map returned object on completion

References poll_end().

Here is the call graph for this function:

◆ co_nitro_sticker_get()

async< confirmation_callback_t > dpp::cluster::co_nitro_sticker_get ( snowflake  id)

Get a nitro sticker.

See also
dpp::cluster::nitro_sticker_get
https://discord.com/developers/docs/resources/sticker#get-sticker
Parameters
idId of sticker to get.
Returns
sticker returned object on completion

References guild_template_modify().

Here is the call graph for this function:

◆ co_poll_end() [1/2]

async< confirmation_callback_t > dpp::cluster::co_poll_end ( const message m)

Immediately end a poll.

Parameters
mMessage that contains the poll
Returns
message returned object on completion
See also
dpp::cluster::poll_end
https://discord.com/developers/docs/resources/poll#end-poll

References role_edit().

Here is the call graph for this function:

◆ co_poll_end() [2/2]

async< confirmation_callback_t > dpp::cluster::co_poll_end ( snowflake  message_id,
snowflake  channel_id 
)

Immediately end a poll.

Parameters
message_idID of the message with the poll to end
channel_idID of the channel with the poll to end
Returns
message returned object on completion
See also
dpp::cluster::poll_end
https://discord.com/developers/docs/resources/poll#end-poll

References roles_edit_position().

Here is the call graph for this function:

◆ co_poll_get_answer_voters() [1/2]

async< confirmation_callback_t > dpp::cluster::co_poll_get_answer_voters ( const message m,
uint32_t  answer_id,
snowflake  after,
uint64_t  limit 
)

Get a list of users that voted for this specific answer.

Parameters
mMessage that contains the poll to retrieve the answers from
answer_idID of the answer to retrieve votes from (see poll_answer::answer_id)
afterUsers after this ID should be retrieved if this is set to non-zero
limitThis number of users maximum should be returned, up to 100
Returns
user_map returned object on completion
See also
dpp::cluster::poll_get_answer_voters
https://discord.com/developers/docs/resources/poll#get-answer-voters

References role_create().

Here is the call graph for this function:

◆ co_poll_get_answer_voters() [2/2]

async< confirmation_callback_t > dpp::cluster::co_poll_get_answer_voters ( snowflake  message_id,
snowflake  channel_id,
uint32_t  answer_id,
snowflake  after,
uint64_t  limit 
)

Get a list of users that voted for this specific answer.

Parameters
message_idID of the message with the poll to retrieve the answers from
channel_idID of the channel with the poll to retrieve the answers from
answer_idID of the answer to retrieve votes from (see poll_answer::answer_id)
afterUsers after this ID should be retrieved if this is set to non-zero
limitThis number of users maximum should be returned, up to 100
Returns
user_map returned object on completion
See also
dpp::cluster::poll_get_answer_voters
https://discord.com/developers/docs/resources/poll#get-answer-voters

References role_delete().

Here is the call graph for this function:

◆ co_role_create()

async< confirmation_callback_t > dpp::cluster::co_role_create ( const class role r)

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 also
dpp::cluster::role_create
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.
Parameters
rRole to create (guild ID is encapsulated in the role object)
Returns
role returned object on completion

References application_role_connection_get().

Here is the call graph for this function:

◆ co_role_delete()

async< confirmation_callback_t > dpp::cluster::co_role_delete ( snowflake  guild_id,
snowflake  role_id 
)

Delete a role.

Requires the MANAGE_ROLES permission. Fires a Guild Role Delete Gateway event.

See also
dpp::cluster::role_delete
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.
Parameters
guild_idGuild ID to delete the role on
role_idRole ID to delete
Returns
confirmation returned object on completion

References application_role_connection_update().

Here is the call graph for this function:

◆ co_role_edit()

async< confirmation_callback_t > dpp::cluster::co_role_edit ( const class role r)

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 also
dpp::cluster::role_edit
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.
Parameters
rRole to edit
Returns
role returned object on completion

References user_application_role_connection_get().

Here is the call graph for this function:

◆ co_roles_edit_position()

async< confirmation_callback_t > dpp::cluster::co_roles_edit_position ( snowflake  guild_id,
const std::vector< role > &  roles 
)

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 also
dpp::cluster::roles_edit_position
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.
Parameters
guild_idGuild ID to change the roles position on
rolesVector of roles to change the positions of
Returns
role_map returned object on completion

References user_application_role_connection_update().

Here is the call graph for this function:

◆ co_roles_get()

async< confirmation_callback_t > dpp::cluster::co_roles_get ( snowflake  guild_id)

Get a role for a guild.

See also
dpp::cluster::roles_get
https://discord.com/developers/docs/resources/guild#get-guild-roles
Parameters
guild_idGuild ID to get role for
Returns
role_map returned object on completion

References guild_events_get().

Here is the call graph for this function:

◆ co_skus_get()

async< confirmation_callback_t > dpp::cluster::co_skus_get ( )

Returns all SKUs for a given application.

Note
Because of how Discord's SKU and subscription systems work, you will see two SKUs for your premium offering. For integration and testing entitlements, you should use the SKU with type: 5.
See also
dpp::cluster::skus_get
https://discord.com/developers/docs/monetization/skus#list-skus
Returns
sku_map returned object on completion

References guild_sticker_create().

Here is the call graph for this function:

◆ co_sleep()

async< timer > dpp::cluster::co_sleep ( uint64_t  seconds)

Get an awaitable to wait a certain amount of seconds.

Use the co_await keyword on its return value to suspend the coroutine until the timer ends

Parameters
secondsHow long to wait for
Returns
async<timer> Object that can be co_await-ed to suspend the function for a certain time

◆ co_stage_instance_delete()

async< confirmation_callback_t > dpp::cluster::co_stage_instance_delete ( const snowflake  channel_id)

Delete a stage instance.

See also
dpp::cluster::stage_instance_delete
https://discord.com/developers/docs/resources/stage-instance#delete-stage-instance
Parameters
channel_idID of the associated channel
Returns
confirmation returned object on completion
Note
This method supports audit log reasons set by the cluster::set_audit_reason() method.

References guild_stickers_get().

Here is the call graph for this function:

◆ co_stage_instance_get()

async< confirmation_callback_t > dpp::cluster::co_stage_instance_get ( const snowflake  channel_id)

Get the stage instance associated with the channel id, if it exists.

See also
dpp::cluster::stage_instance_get
https://discord.com/developers/docs/resources/stage-instance#get-stage-instance
Parameters
channel_idID of the associated channel
Returns
stage_instance returned object on completion

References guild_sticker_get().

Here is the call graph for this function:

◆ co_sticker_packs_get()

async< confirmation_callback_t > dpp::cluster::co_sticker_packs_get ( )

Get a list of available sticker packs.

See also
dpp::cluster::sticker_packs_get
https://discord.com/developers/docs/resources/sticker#list-nitro-sticker-packs
Returns
sticker_pack_map returned object on completion

References guild_templates_get().

Here is the call graph for this function:

◆ co_template_get()

async< confirmation_callback_t > dpp::cluster::co_template_get ( const std::string &  code)

Get a template.

See also
dpp::cluster::template_get
https://discord.com/developers/docs/resources/guild-template#get-guild-template
Parameters
codeTemplate code
Returns
dtemplate returned object on completion

References threads_get_private_archived().

Here is the call graph for this function:

◆ co_thread_create()

async< confirmation_callback_t > dpp::cluster::co_thread_create ( 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 
)

Create a thread.

Note
This method supports audit log reasons set by the cluster::set_audit_reason() method.
See also
dpp::cluster::thread_create
https://discord.com/developers/docs/resources/channel#start-thread-without-message
Parameters
thread_nameName of the thread
channel_idChannel in which thread to create
auto_archive_durationDuration after which thread auto-archives. Can be set to - 60, 1440 (for boosted guilds can also be: 4320, 10080)
thread_typeType of thread - CHANNEL_PUBLIC_THREAD, CHANNEL_ANNOUNCEMENT_THREAD, CHANNEL_PRIVATE_THREAD
invitablewhether non-moderators can add other non-moderators to a thread; only available when creating a private thread
rate_limit_per_useramount 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
Returns
thread returned object on completion

References thread_get().

Here is the call graph for this function:

◆ co_thread_create_in_forum()

async< confirmation_callback_t > dpp::cluster::co_thread_create_in_forum ( 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 = {} 
)

Create a thread in a forum or media channel.

Note
This method supports audit log reasons set by the cluster::set_audit_reason() method.
See also
dpp::cluster::thread_create_in_forum
https://discord.com/developers/docs/resources/channel#start-thread-in-forum-channel
Parameters
thread_nameName of the forum thread
channel_idForum channel in which thread to create
msgThe message to start the thread with
auto_archive_durationDuration to automatically archive the thread after recent activity
rate_limit_per_useramount 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
applied_tagsList of IDs of forum tags (dpp::forum_tag) to apply to this thread
Returns
thread returned object on completion

References thread_member_remove().

Here is the call graph for this function:

◆ co_thread_create_with_message()

async< confirmation_callback_t > dpp::cluster::co_thread_create_with_message ( const std::string &  thread_name,
snowflake  channel_id,
snowflake  message_id,
uint16_t  auto_archive_duration,
uint16_t  rate_limit_per_user 
)

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 also
dpp::cluster::thread_create_with_message
https://discord.com/developers/docs/resources/channel#start-thread-from-message
Parameters
thread_nameName of the thread
channel_idChannel in which thread to create
message_idmessage to start thread with
auto_archive_durationDuration after which thread auto-archives. Can be set to - 60, 1440 (for boosted guilds can also be: 4320, 10080)
rate_limit_per_useramount 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
Returns
thread returned object on completion

References current_application_get().

Here is the call graph for this function:

◆ co_thread_edit()

async< confirmation_callback_t > dpp::cluster::co_thread_edit ( const thread t)

Edit a thread.

Note
This method supports audit log reasons set by the cluster::set_audit_reason() method.
See also
dpp::cluster::thread_edit
https://discord.com/developers/docs/topics/threads#editing-deleting-threads
Parameters
tThread to edit
Returns
thread returned object on completion

References current_user_edit().

Here is the call graph for this function:

◆ co_thread_get()

async< confirmation_callback_t > dpp::cluster::co_thread_get ( snowflake  thread_id)

Get the thread specified by thread_id.

This uses the same call as dpp::cluster::channel_get but returns a thread object.

See also
dpp::cluster::thread_get
https://discord.com/developers/docs/resources/channel#get-channel
Parameters
thread_idThe id of the thread to obtain.
Returns
thread returned object on completion

References user_set_voice_state().

Here is the call graph for this function:

◆ co_thread_member_add()

async< confirmation_callback_t > dpp::cluster::co_thread_member_add ( snowflake  thread_id,
snowflake  user_id 
)

Add a member to a thread.

See also
dpp::cluster::thread_member_add
https://discord.com/developers/docs/resources/channel#add-thread-member
Parameters
thread_idThread ID to add to
user_idMember ID to add
Returns
confirmation returned object on completion

References current_user_get().

Here is the call graph for this function:

◆ co_thread_member_get()

async< confirmation_callback_t > dpp::cluster::co_thread_member_get ( const snowflake  thread_id,
const snowflake  user_id 
)

Get a thread member.

See also
dpp::cluster::thread_member_get
https://discord.com/developers/docs/resources/channel#get-thread-member
Parameters
thread_idThread to get member for
user_idID of the user to get
Returns
thread_member returned object on completion

References thread_create_with_message().

Here is the call graph for this function:

◆ co_thread_member_remove()

async< confirmation_callback_t > dpp::cluster::co_thread_member_remove ( snowflake  thread_id,
snowflake  user_id 
)

Remove a member from a thread.

See also
dpp::cluster::thread_member_remove
https://discord.com/developers/docs/resources/channel#remove-thread-member
Parameters
thread_idThread ID to remove from
user_idMember ID to remove
Returns
confirmation returned object on completion

References current_user_set_voice_state().

Here is the call graph for this function:

◆ co_thread_members_get()

async< confirmation_callback_t > dpp::cluster::co_thread_members_get ( snowflake  thread_id)

Get members of a thread.

See also
dpp::cluster::thread_members_get
https://discord.com/developers/docs/resources/channel#list-thread-members
Parameters
thread_idThread to get members for
Returns
thread_member_map returned object on completion

References thread_member_add().

Here is the call graph for this function:

◆ co_threads_get_active()

async< confirmation_callback_t > dpp::cluster::co_threads_get_active ( snowflake  guild_id)

Get all active threads in the guild, including public and private threads.

Threads are ordered by their id, in descending order.

See also
dpp::cluster::threads_get_active
https://discord.com/developers/docs/resources/guild#list-active-guild-threads
Parameters
guild_idGuild to get active threads for
Returns
active_threads returned object on completion

References thread_members_get().

Here is the call graph for this function:

◆ co_threads_get_joined_private_archived()

async< confirmation_callback_t > dpp::cluster::co_threads_get_joined_private_archived ( snowflake  channel_id,
snowflake  before_id,
uint16_t  limit 
)

Get private archived threads in a channel which current user has joined (Sorted by ID in descending order)

See also
dpp::cluster::threads_get_joined_private_archived
https://discord.com/developers/docs/resources/channel#list-joined-private-archived-threads
Parameters
channel_idChannel to get public archived threads for
before_idGet threads before this id
limitNumber of threads to get
Returns
thread_map returned object on completion

References thread_create_in_forum().

Here is the call graph for this function:

◆ co_threads_get_private_archived()

async< confirmation_callback_t > dpp::cluster::co_threads_get_private_archived ( snowflake  channel_id,
time_t  before_timestamp,
uint16_t  limit 
)

Get private archived threads in a channel (Sorted by archive_timestamp in descending order)

See also
dpp::cluster::threads_get_private_archived
https://discord.com/developers/docs/resources/channel#list-private-archived-threads
Parameters
channel_idChannel to get public archived threads for
before_timestampGet threads archived before this timestamp
limitNumber of threads to get
Returns
thread_map returned object on completion

References thread_create().

Here is the call graph for this function:

◆ co_threads_get_public_archived()

async< confirmation_callback_t > dpp::cluster::co_threads_get_public_archived ( snowflake  channel_id,
time_t  before_timestamp,
uint16_t  limit 
)

Get public archived threads in a channel (Sorted by archive_timestamp in descending order)

See also
dpp::cluster::threads_get_public_archived
https://discord.com/developers/docs/resources/channel#list-public-archived-threads
Parameters
channel_idChannel to get public archived threads for
before_timestampGet threads archived before this timestamp
limitNumber of threads to get
Returns
thread_map returned object on completion

References thread_edit().

Here is the call graph for this function:

◆ co_user_application_role_connection_get()

async< confirmation_callback_t > dpp::cluster::co_user_application_role_connection_get ( snowflake  application_id)

Get user application role connection.

See also
dpp::cluster::user_application_role_connection_get
https://discord.com/developers/docs/resources/user#get-user-application-role-connection
Parameters
application_idThe application ID
Returns
application_role_connection returned object on completion

References guild_event_edit().

Here is the call graph for this function:

◆ co_user_application_role_connection_update()

async< confirmation_callback_t > dpp::cluster::co_user_application_role_connection_update ( snowflake  application_id,
const application_role_connection connection 
)

Update user application role connection.

See also
dpp::cluster::user_application_role_connection_update
https://discord.com/developers/docs/resources/user#update-user-application-role-connection
Parameters
application_idThe application ID
connectionThe application role connection to update
Returns
application_role_connection returned object on completion

References guild_event_get().

Here is the call graph for this function:

◆ co_user_get()

async< confirmation_callback_t > dpp::cluster::co_user_get ( snowflake  user_id)

Get a user by id, without using the cache.

See also
dpp::cluster::user_get
https://discord.com/developers/docs/resources/user#get-user
Parameters
user_idUser ID to retrieve
Returns
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.
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.

References delete_webhook().

Here is the call graph for this function:

◆ co_user_get_cached()

async< confirmation_callback_t > dpp::cluster::co_user_get_cached ( snowflake  user_id)

Get a user by id, checking in the cache first.

See also
dpp::cluster::user_get_cached
https://discord.com/developers/docs/resources/user#get-user
Parameters
user_idUser ID to retrieve
Returns
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.
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.

References delete_webhook_message().

Referenced by event_handler_test().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ co_user_set_voice_state()

async< confirmation_callback_t > dpp::cluster::co_user_set_voice_state ( snowflake  user_id,
snowflake  guild_id,
snowflake  channel_id,
bool  suppress = false 
)

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 also
dpp::cluster::user_set_voice_state
https://discord.com/developers/docs/resources/guild#modify-user-voice-state
Parameters
user_idThe user to set the voice state of
guild_idGuild to set voice state on
channel_idStage channel to set voice state on
Returns
confirmation returned object on completion
Parameters
suppressTrue if the user's audio should be suppressed, false if it should not

References user_get_cached().

Here is the call graph for this function:

◆ create_dm_channel()

void dpp::cluster::create_dm_channel ( snowflake  user_id,
command_completion_event_t  callback = utility::log_error() 
)

Create a dm channel.

See also
https://discord.com/developers/docs/resources/user#create-dm
Parameters
user_idUser ID to create DM channel with
callbackFunction to call when the API call completes. On success the callback will contain a dpp::channel object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by channel_invites_get_sync(), and co_channel_invites_get().

Here is the caller graph for this function:

◆ create_dm_channel_sync()

channel dpp::cluster::create_dm_channel_sync ( snowflake  user_id)

Create a dm channel.

See also
dpp::cluster::create_dm_channel
https://discord.com/developers/docs/resources/user#create-dm
Parameters
user_idUser ID to create DM channel with
Returns
channel returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References guild_emoji_create().

Here is the call graph for this function:

◆ create_webhook()

void dpp::cluster::create_webhook ( const class webhook w,
command_completion_event_t  callback = utility::log_error() 
)

Create a webhook.

Note
This method supports audit log reasons set by the cluster::set_audit_reason() method.
See also
https://discord.com/developers/docs/resources/webhook#create-webhook
Parameters
wWebhook to create
callbackFunction to call when the API call completes. On success the callback will contain a dpp::webhook object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

References API_PATH, dpp::json_interface< T >::build_json(), dpp::managed::id, and dpp::m_patch.

Referenced by co_current_user_leave_guild(), and current_user_leave_guild_sync().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ current_application_get()

void dpp::cluster::current_application_get ( command_completion_event_t  callback)

Get current (bot) application.

See also
https://discord.com/developers/docs/topics/oauth2#get-current-bot-application-information
Parameters
callbackFunction to call when the API call completes. On success the callback will contain a dpp::application object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_thread_create_with_message(), and thread_create_with_message_sync().

Here is the caller graph for this function:

◆ current_application_get_sync()

application dpp::cluster::current_application_get_sync ( )

Get current (bot) application.

See also
dpp::cluster::current_application_get
https://discord.com/developers/docs/topics/oauth2#get-current-bot-application-information
Returns
application returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References current_user_get_guilds().

Here is the call graph for this function:

◆ current_user_connections_get()

void dpp::cluster::current_user_connections_get ( command_completion_event_t  callback)

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 also
https://discord.com/developers/docs/resources/user#get-user-connections
Parameters
callbackFunction to call when the API call completes. On success the callback will contain a dpp::connection_map object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_current_user_edit(), and current_user_edit_sync().

Here is the caller graph for this function:

◆ current_user_connections_get_sync()

connection_map dpp::cluster::current_user_connections_get_sync ( )

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 also
dpp::cluster::current_user_connections_get
https://discord.com/developers/docs/resources/user#get-user-connections
Returns
connection_map returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References get_voice_regions().

Here is the call graph for this function:

◆ current_user_edit()

void dpp::cluster::current_user_edit ( const std::string &  nickname,
const std::string &  image_blob = "",
const image_type  type = i_png,
command_completion_event_t  callback = utility::log_error() 
)

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 also
https://discord.com/developers/docs/resources/user#modify-current-user
Parameters
nicknameNickname to set
image_blobAvatar data to upload (NOTE: Very heavily rate limited!)
typeType of image for avatar. It can be one of i_gif, i_jpg or i_png.
callbackFunction to call when the API call completes. On success the callback will contain a dpp::user object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().
Exceptions
dpp::length_exceptionImage data is larger than the maximum size of 256 kilobytes

References API_PATH, and dpp::m_get.

Referenced by co_thread_edit(), and thread_edit_sync().

Here is the caller graph for this function:

◆ current_user_edit_sync()

user dpp::cluster::current_user_edit_sync ( const std::string &  nickname,
const std::string &  image_blob = "",
const image_type  type = i_png 
)

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 also
dpp::cluster::current_user_edit
https://discord.com/developers/docs/resources/user#modify-current-user
Parameters
nicknameNickname to set
image_blobAvatar data to upload (NOTE: Very heavily rate limited!)
typeType of image for avatar. It can be one of i_gif, i_jpg or i_png.
Returns
user returned object on completion
Exceptions
dpp::length_exceptionImage data is larger than the maximum size of 256 kilobytes
dpp::rest_exceptionupon 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.

References current_user_connections_get().

Here is the call graph for this function:

◆ current_user_get()

void dpp::cluster::current_user_get ( command_completion_event_t  callback)

Get current (bot) user.

See also
https://discord.com/developers/docs/resources/user#get-current-user
Parameters
callbackFunction to call when the API call completes. On success the callback will contain a dpp::user_identified object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().
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.

Referenced by co_thread_member_add(), and thread_member_add_sync().

Here is the caller graph for this function:

◆ current_user_get_dms()

void dpp::cluster::current_user_get_dms ( command_completion_event_t  callback)

Get current user DM channels.

Parameters
callbackFunction to call when the API call completes. On success the callback will contain a dpp::channel_map object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by channel_typing_sync(), and co_channel_typing().

Here is the caller graph for this function:

◆ current_user_get_dms_sync()

channel_map dpp::cluster::current_user_get_dms_sync ( )

Get current user DM channels.

Returns
channel_map returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References guild_emoji_delete().

Here is the call graph for this function:

◆ current_user_get_guilds()

void dpp::cluster::current_user_get_guilds ( command_completion_event_t  callback)

Get current (bot) user guilds.

See also
https://discord.com/developers/docs/resources/user#get-current-user-guilds
Parameters
callbackFunction to call when the API call completes. On success the callback will contain a dpp::guild_map object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_current_application_get(), and current_application_get_sync().

Here is the caller graph for this function:

◆ current_user_get_guilds_sync()

guild_map dpp::cluster::current_user_get_guilds_sync ( )

Get current (bot) user guilds.

See also
dpp::cluster::current_user_get_guilds
https://discord.com/developers/docs/resources/user#get-current-user-guilds
Returns
guild_map returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References guild_get_voice_regions().

Here is the call graph for this function:

◆ current_user_get_sync()

user_identified dpp::cluster::current_user_get_sync ( )

Get current (bot) user.

See also
dpp::cluster::current_user_get
https://discord.com/developers/docs/resources/user#get-current-user
Returns
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.
Exceptions
dpp::rest_exceptionupon 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.

References current_user_leave_guild().

Here is the call graph for this function:

◆ current_user_join_thread()

void dpp::cluster::current_user_join_thread ( snowflake  thread_id,
command_completion_event_t  callback = utility::log_error() 
)

Join a thread.

See also
https://discord.com/developers/docs/resources/channel#join-thread
Parameters
thread_idThread ID to join
callbackFunction to call when the API call completes. On success the callback will contain a dpp::confirmation object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

References dpp::managed::id, me, and dpp::snowflake_not_null().

Referenced by co_guild_template_delete(), and guild_template_delete_sync().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ current_user_join_thread_sync()

confirmation dpp::cluster::current_user_join_thread_sync ( snowflake  thread_id)

Join a thread.

See also
dpp::cluster::current_user_join_thread
https://discord.com/developers/docs/resources/channel#join-thread
Parameters
thread_idThread ID to join
Returns
confirmation returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References threads_get_public_archived().

Here is the call graph for this function:

◆ current_user_leave_guild()

void dpp::cluster::current_user_leave_guild ( snowflake  guild_id,
command_completion_event_t  callback = utility::log_error() 
)

Leave a guild.

See also
https://discord.com/developers/docs/resources/user#leave-guild
Parameters
guild_idGuild ID to leave
callbackFunction to call when the API call completes. On success the callback will contain a dpp::confirmation object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_current_user_get(), and current_user_get_sync().

Here is the caller graph for this function:

◆ current_user_leave_guild_sync()

confirmation dpp::cluster::current_user_leave_guild_sync ( snowflake  guild_id)

Leave a guild.

See also
dpp::cluster::current_user_leave_guild
https://discord.com/developers/docs/resources/user#leave-guild
Parameters
guild_idGuild ID to leave
Returns
confirmation returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References create_webhook().

Here is the call graph for this function:

◆ current_user_leave_thread()

void dpp::cluster::current_user_leave_thread ( snowflake  thread_id,
command_completion_event_t  callback = utility::log_error() 
)

Leave a thread.

See also
https://discord.com/developers/docs/resources/channel#leave-thread
Parameters
thread_idThread ID to leave
callbackFunction to call when the API call completes. On success the callback will contain a dpp::confirmation object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_guild_template_modify(), and guild_template_modify_sync().

Here is the caller graph for this function:

◆ current_user_leave_thread_sync()

confirmation dpp::cluster::current_user_leave_thread_sync ( snowflake  thread_id)

Leave a thread.

See also
dpp::cluster::current_user_leave_thread
https://discord.com/developers/docs/resources/channel#leave-thread
Parameters
thread_idThread ID to leave
Returns
confirmation returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References thread_member_get().

Here is the call graph for this function:

◆ current_user_set_voice_state()

void dpp::cluster::current_user_set_voice_state ( snowflake  guild_id,
snowflake  channel_id,
bool  suppress = false,
time_t  request_to_speak_timestamp = 0,
command_completion_event_t  callback = utility::log_error() 
)

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 also
https://discord.com/developers/docs/resources/guild#modify-current-user-voice-state
Parameters
guild_idGuild to set voice state on
channel_idStage channel to set voice state on
callbackFunction to call when the API call completes.
suppressTrue if the user's audio should be suppressed, false if it should not
request_to_speak_timestampThe 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. On success the callback will contain a dpp::scheduled_event object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().
Exceptions
std::logic_exceptionYou attempted to set a request_to_speak_timestamp in the past which is not the value of 0.

Referenced by co_thread_member_remove(), and thread_member_remove_sync().

Here is the caller graph for this function:

◆ current_user_set_voice_state_sync()

confirmation dpp::cluster::current_user_set_voice_state_sync ( snowflake  guild_id,
snowflake  channel_id,
bool  suppress = false,
time_t  request_to_speak_timestamp = 0 
)

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 also
dpp::cluster::current_user_set_voice_state
https://discord.com/developers/docs/resources/guild#modify-current-user-voice-state
Parameters
guild_idGuild to set voice state on
channel_idStage channel to set voice state on
Returns
confirmation returned object on completion
Parameters
suppressTrue if the user's audio should be suppressed, false if it should not
request_to_speak_timestampThe 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.
Exceptions
std::logic_exceptionYou attempted to set a request_to_speak_timestamp in the past which is not the value of 0.
dpp::rest_exceptionupon 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.

References user_get().

Here is the call graph for this function:

◆ delete_webhook()

void dpp::cluster::delete_webhook ( snowflake  webhook_id,
command_completion_event_t  callback = utility::log_error() 
)

Delete a webhook.

Note
This method supports audit log reasons set by the cluster::set_audit_reason() method.
See also
https://discord.com/developers/docs/resources/webhook#delete-webhook
Parameters
webhook_idWebhook ID to delete
callbackFunction to call when the API call completes. On success the callback will contain a dpp::confirmation object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

References dpp::utility::make_url_parameters().

Referenced by co_user_get(), and user_get_sync().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ delete_webhook_message()

void dpp::cluster::delete_webhook_message ( const class webhook wh,
snowflake  message_id,
snowflake  thread_id = 0,
command_completion_event_t  callback = utility::log_error() 
)

Delete webhook message.

See also
https://discord.com/developers/docs/resources/webhook#delete-webhook-message
Parameters
whWebhook to delete message for
message_idMessage ID to delete
thread_idID of the thread the message is in
callbackFunction to call when the API call completes. On success the callback will contain a dpp::confirmation object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_user_get_cached(), and user_get_cached_sync().

Here is the caller graph for this function:

◆ delete_webhook_message_sync()

confirmation dpp::cluster::delete_webhook_message_sync ( const class webhook wh,
snowflake  message_id,
snowflake  thread_id = 0 
)

Delete webhook message.

See also
dpp::cluster::delete_webhook_message
https://discord.com/developers/docs/resources/webhook#delete-webhook-message
Parameters
whWebhook to delete message for
message_idMessage ID to delete
thread_idID of the thread the message is in
Returns
confirmation returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References execute_webhook(), and dpp::unicode_emoji::m.

Here is the call graph for this function:

◆ delete_webhook_sync()

confirmation dpp::cluster::delete_webhook_sync ( snowflake  webhook_id)

Delete a webhook.

Note
This method supports audit log reasons set by the cluster::set_audit_reason() method.
See also
dpp::cluster::delete_webhook
https://discord.com/developers/docs/resources/webhook#delete-webhook
Parameters
webhook_idWebhook ID to delete
Returns
confirmation returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References edit_webhook_with_token().

Here is the call graph for this function:

◆ delete_webhook_with_token()

void dpp::cluster::delete_webhook_with_token ( snowflake  webhook_id,
const std::string &  token,
command_completion_event_t  callback = utility::log_error() 
)

Delete webhook with token.

See also
https://discord.com/developers/docs/resources/webhook#delete-webhook-with-token
Parameters
webhook_idWebhook ID to delete
tokenToken of webhook to delete
callbackFunction to call when the API call completes. On success the callback will contain a dpp::confirmation object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

References dpp::json_interface< T >::to_json().

Referenced by co_get_voice_regions(), and get_voice_regions_sync().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ delete_webhook_with_token_sync()

confirmation dpp::cluster::delete_webhook_with_token_sync ( snowflake  webhook_id,
const std::string &  token 
)

Delete webhook with token.

See also
dpp::cluster::delete_webhook_with_token
https://discord.com/developers/docs/resources/webhook#delete-webhook-with-token
Parameters
webhook_idWebhook ID to delete
tokenToken of webhook to delete
Returns
confirmation returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References get_channel_webhooks().

Here is the call graph for this function:

◆ direct_message_create()

void dpp::cluster::direct_message_create ( snowflake  user_id,
const message m,
command_completion_event_t  callback = utility::log_error() 
)

Create a direct message, also create the channel for the direct message if needed.

See also
https://discord.com/developers/docs/resources/user#create-dm
https://discord.com/developers/docs/resources/channel#create-message
Parameters
user_idUser ID of user to send message to
mMessage object
callbackFunction to call when the API call completes. On success the callback will contain a dpp::message object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by channel_typing_sync(), and co_channel_typing().

Here is the caller graph for this function:

◆ direct_message_create_sync()

message dpp::cluster::direct_message_create_sync ( snowflake  user_id,
const message m 
)

Create a direct message, also create the channel for the direct message if needed.

See also
dpp::cluster::direct_message_create
https://discord.com/developers/docs/resources/user#create-dm
dpp::cluster::direct_message_create
https://discord.com/developers/docs/resources/channel#create-message
Parameters
user_idUser ID of user to send message to
mMessage object
Returns
message returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References guild_emoji_edit().

Here is the call graph for this function:

◆ edit_webhook()

void dpp::cluster::edit_webhook ( const class webhook wh,
command_completion_event_t  callback = utility::log_error() 
)

Edit webhook.

Note
This method supports audit log reasons set by the cluster::set_audit_reason() method.
See also
https://discord.com/developers/docs/resources/webhook#modify-webhook
Parameters
whWebhook to edit
callbackFunction to call when the API call completes. On success the callback will contain a dpp::webhook object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_guild_get_voice_regions(), and guild_get_voice_regions_sync().

Here is the caller graph for this function:

◆ edit_webhook_message()

void dpp::cluster::edit_webhook_message ( const class webhook wh,
const struct message m,
snowflake  thread_id = 0,
command_completion_event_t  callback = utility::log_error() 
)

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 also
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.
Parameters
whWebhook to edit message for
mNew message
thread_idID of the thread the message is in
callbackFunction to call when the API call completes. On success the callback will contain a dpp::message object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

References dpp::webhook::avatar, dpp::unicode_emoji::m, dpp::utility::make_url_parameters(), dpp::webhook::name, and dpp::utility::iconhash::to_string().

Here is the call graph for this function:

◆ edit_webhook_message_sync()

message dpp::cluster::edit_webhook_message_sync ( const class webhook wh,
const struct message m,
snowflake  thread_id = 0 
)

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 also
dpp::cluster::edit_webhook_message
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.
Parameters
whWebhook to edit message for
mNew message
thread_idID of the thread the message is in
Returns
message returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References get_webhook().

Here is the call graph for this function:

◆ edit_webhook_sync()

webhook dpp::cluster::edit_webhook_sync ( const class webhook wh)

Edit webhook.

Note
This method supports audit log reasons set by the cluster::set_audit_reason() method.
See also
dpp::cluster::edit_webhook
https://discord.com/developers/docs/resources/webhook#modify-webhook
Parameters
whWebhook to edit
Returns
webhook returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References get_guild_webhooks().

Here is the call graph for this function:

◆ edit_webhook_with_token()

void dpp::cluster::edit_webhook_with_token ( const class webhook wh,
command_completion_event_t  callback = utility::log_error() 
)

Edit webhook with token (token is encapsulated in the webhook object)

See also
https://discord.com/developers/docs/resources/webhook#modify-webhook-with-token
Parameters
whWebhook to edit (should include token)
callbackFunction to call when the API call completes. On success the callback will contain a dpp::webhook object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

References dpp::webhook::avatar, and dpp::utility::iconhash::to_string().

Referenced by co_delete_webhook(), and delete_webhook_sync().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ edit_webhook_with_token_sync()

webhook dpp::cluster::edit_webhook_with_token_sync ( const class webhook wh)

Edit webhook with token (token is encapsulated in the webhook object)

See also
dpp::cluster::edit_webhook_with_token
https://discord.com/developers/docs/resources/webhook#modify-webhook-with-token
Parameters
whWebhook to edit (should include token)
Returns
webhook returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References get_webhook_message().

Here is the call graph for this function:

◆ entitlement_test_create()

void dpp::cluster::entitlement_test_create ( const class entitlement new_entitlement,
command_completion_event_t  callback = utility::log_error() 
)

Creates a test entitlement to a given SKU for a given guild or user.

Discord will act as though that user or guild has entitlement to your premium offering.

See also
https://discord.com/developers/docs/monetization/entitlements#create-test-entitlement
Parameters
new_entitlementThe entitlement to create. Make sure your dpp::entitlement_type (inside your dpp::entitlement object) matches the type of the owner_id (if type is guild, owner_id is a guild id), otherwise it won't work!
callbackFunction to call when the API call completes. On success the callback will contain a dpp::entitlement object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_guild_emoji_delete(), and guild_emoji_delete_sync().

Here is the caller graph for this function:

◆ entitlement_test_create_sync()

entitlement dpp::cluster::entitlement_test_create_sync ( const class entitlement new_entitlement)

Creates a test entitlement to a given SKU for a given guild or user.

Discord will act as though that user or guild has entitlement to your premium offering.

See also
dpp::cluster::entitlement_test_create
https://discord.com/developers/docs/monetization/entitlements#create-test-entitlement
Parameters
new_entitlementThe entitlement to create. Make sure your dpp::entitlement_type (inside your dpp::entitlement object) matches the type of the owner_id (if type is guild, owner_id is a guild id), otherwise it won't work!
Returns
entitlement returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References guild_ban_add().

Here is the call graph for this function:

◆ entitlement_test_delete()

void dpp::cluster::entitlement_test_delete ( snowflake  entitlement_id,
command_completion_event_t  callback = utility::log_error() 
)

Deletes a currently-active test entitlement.

Discord will act as though that user or guild no longer has entitlement to your premium offering.

See also
https://discord.com/developers/docs/monetization/entitlements#delete-test-entitlement
Parameters
entitlement_idThe test entitlement to delete.
callbackFunction to call when the API call completes. On success the callback will contain a dpp::confirmation object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_guild_emoji_edit(), and guild_emoji_edit_sync().

Here is the caller graph for this function:

◆ entitlement_test_delete_sync()

confirmation dpp::cluster::entitlement_test_delete_sync ( snowflake  entitlement_id)

Deletes a currently-active test entitlement.

Discord will act as though that user or guild no longer has entitlement to your premium offering.

See also
dpp::cluster::entitlement_test_delete
https://discord.com/developers/docs/monetization/entitlements#delete-test-entitlement
Parameters
entitlement_idThe test entitlement to delete.
Returns
confirmation returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References guild_ban_delete().

Here is the call graph for this function:

◆ entitlements_get()

void dpp::cluster::entitlements_get ( snowflake  user_id = 0,
const std::vector< snowflake > &  sku_ids = {},
snowflake  before_id = 0,
snowflake  after_id = 0,
uint8_t  limit = 100,
snowflake  guild_id = 0,
bool  exclude_ended = false,
command_completion_event_t  callback = utility::log_error() 
)

Returns all entitlements for a given app, active and expired.

See also
https://discord.com/developers/docs/monetization/entitlements#list-entitlements
Parameters
user_idUser ID to look up entitlements for.
sku_idsList of SKU IDs to check entitlements for.
before_idRetrieve entitlements before this entitlement ID.
after_idRetrieve entitlements after this entitlement ID.
limitNumber of entitlements to return, 1-100 (default 100).
guild_idGuild ID to look up entitlements for.
exclude_endedWhether ended entitlements should be excluded from the search.
callbackFunction to call when the API call completes. On success the callback will contain a dpp::emoji_map object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_guild_emoji_create(), and guild_emoji_create_sync().

Here is the caller graph for this function:

◆ entitlements_get_sync()

entitlement_map dpp::cluster::entitlements_get_sync ( snowflake  user_id = 0,
const std::vector< snowflake > &  sku_ids = {},
snowflake  before_id = 0,
snowflake  after_id = 0,
uint8_t  limit = 100,
snowflake  guild_id = 0,
bool  exclude_ended = false 
)

Returns all entitlements for a given app, active and expired.

See also
dpp::cluster::entitlements_get
https://discord.com/developers/docs/monetization/entitlements#list-entitlements
Parameters
user_idUser ID to look up entitlements for.
sku_idsList of SKU IDs to check entitlements for.
before_idRetrieve entitlements before this entitlement ID.
after_idRetrieve entitlements after this entitlement ID.
limitNumber of entitlements to return, 1-100 (default 100).
guild_idGuild ID to look up entitlements for.
exclude_endedWhether ended entitlements should be excluded from the search.
Returns
entitlement_map returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References guild_auditlog_get().

Here is the call graph for this function:

◆ execute_webhook()

void dpp::cluster::execute_webhook ( const class webhook wh,
const struct message m,
bool  wait = false,
snowflake  thread_id = 0,
const std::string &  thread_name = "",
command_completion_event_t  callback = utility::log_error() 
)

Execute webhook.

See also
https://discord.com/developers/docs/resources/webhook#execute-webhook
Parameters
whWebhook to execute
mMessage to send
waitwaits for server confirmation of message send before response, and returns the created message body
thread_idSend a message to the specified thread within a webhook's channel. The thread will automatically be unarchived
thread_nameName of thread to create (requires the webhook channel to be a forum channel)
callbackFunction to call when the API call completes.
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. On success the callback will contain a dpp::message object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_delete_webhook_message(), and delete_webhook_message_sync().

Here is the caller graph for this function:

◆ execute_webhook_sync()

message dpp::cluster::execute_webhook_sync ( const class webhook wh,
const struct message m,
bool  wait = false,
snowflake  thread_id = 0,
const std::string &  thread_name = "" 
)

Execute webhook.

See also
dpp::cluster::execute_webhook
https://discord.com/developers/docs/resources/webhook#execute-webhook
Parameters
whWebhook to execute
mMessage to send
waitwaits for server confirmation of message send before response, and returns the created message body
thread_idSend a message to the specified thread within a webhook's channel. The thread will automatically be unarchived
thread_nameName of thread to create (requires the webhook channel to be a forum channel)
Returns
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.
Exceptions
dpp::rest_exceptionupon 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.

References get_webhook_with_token(), and token.

Here is the call graph for this function:

◆ gdm_add()

void dpp::cluster::gdm_add ( snowflake  channel_id,
snowflake  user_id,
const std::string &  access_token,
const std::string &  nick,
command_completion_event_t  callback = utility::log_error() 
)

Adds a recipient to a Group DM using their access token.

See also
https://discord.com/developers/docs/resources/channel#group-dm-add-recipient
Parameters
channel_idChannel id to add group DM recipients to
user_idUser ID to add
access_tokenAccess token from OAuth2
nickNickname of user to apply to the chat
callbackFunction to call when the API call completes. On success the callback will contain a dpp::confirmation object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by channels_get_sync(), and co_channels_get().

Here is the caller graph for this function:

◆ gdm_add_sync()

confirmation dpp::cluster::gdm_add_sync ( snowflake  channel_id,
snowflake  user_id,
const std::string &  access_token,
const std::string &  nick 
)

Adds a recipient to a Group DM using their access token.

See also
dpp::cluster::gdm_add
https://discord.com/developers/docs/resources/channel#group-dm-add-recipient
Parameters
channel_idChannel id to add group DM recipients to
user_idUser ID to add
access_tokenAccess token from OAuth2
nickNickname of user to apply to the chat
Returns
confirmation returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References guild_emoji_get().

Here is the call graph for this function:

◆ gdm_remove()

void dpp::cluster::gdm_remove ( snowflake  channel_id,
snowflake  user_id,
command_completion_event_t  callback = utility::log_error() 
)

Removes a recipient from a Group DM.

See also
https://discord.com/developers/docs/resources/channel#group-dm-remove-recipient
Parameters
channel_idChannel ID of group DM
user_idUser ID to remove from group DM
callbackFunction to call when the API call completes. On success the callback will contain a dpp::confirmation object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by channel_set_voice_status_sync(), and co_channel_set_voice_status().

Here is the caller graph for this function:

◆ gdm_remove_sync()

confirmation dpp::cluster::gdm_remove_sync ( snowflake  channel_id,
snowflake  user_id 
)

Removes a recipient from a Group DM.

See also
dpp::cluster::gdm_remove
https://discord.com/developers/docs/resources/channel#group-dm-remove-recipient
Parameters
channel_idChannel ID of group DM
user_idUser ID to remove from group DM
Returns
confirmation returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References guild_emojis_get().

Here is the call graph for this function:

◆ get_audit_reason()

std::string dpp::cluster::get_audit_reason ( )

Get the audit reason set for the next REST call to be made on this thread.

This is set per-thread, so you must ensure that if you call this method, your request that is associated with the reason happens on the same thread where you set the reason. Once the next call is made, the audit log reason is cleared for this thread automatically.

Note
This method call clears the audit reason when it returns it.
Returns
std::string The audit reason to be used.

◆ get_channel_webhooks()

void dpp::cluster::get_channel_webhooks ( snowflake  channel_id,
command_completion_event_t  callback 
)

Get channel webhooks.

See also
https://discord.com/developers/docs/resources/webhook#get-guild-webhooks
Parameters
channel_idChannel ID to get webhooks for
callbackFunction to call when the API call completes. On success the callback will contain a dpp::webhook_map object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

References API_PATH, dpp::m_get, and dpp::utility::url_encode().

Referenced by co_delete_webhook_with_token(), and delete_webhook_with_token_sync().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ get_channel_webhooks_sync()

webhook_map dpp::cluster::get_channel_webhooks_sync ( snowflake  channel_id)

Get channel webhooks.

See also
dpp::cluster::get_channel_webhooks
https://discord.com/developers/docs/resources/webhook#get-guild-webhooks
Parameters
channel_idChannel ID to get webhooks for
Returns
webhook_map returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

◆ get_dm_channel()

snowflake dpp::cluster::get_dm_channel ( snowflake  user_id)

Get the dm channel for a user id.

Parameters
user_idthe user id to get the dm channel for
Returns
Returns 0 on failure

◆ get_gateway_bot()

void dpp::cluster::get_gateway_bot ( command_completion_event_t  callback)

Get the gateway information for the bot using the token.

See also
https://discord.com/developers/docs/topics/gateway#get-gateway-bot
Parameters
callbackFunction to call when the API call completes. On success the callback will contain a dpp::gateway object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_guild_emoji_get(), and guild_emoji_get_sync().

Here is the caller graph for this function:

◆ get_gateway_bot_sync()

gateway dpp::cluster::get_gateway_bot_sync ( )

Get the gateway information for the bot using the token.

See also
dpp::cluster::get_gateway_bot
https://discord.com/developers/docs/topics/gateway#get-gateway-bot
Returns
gateway returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References guild_create().

Here is the call graph for this function:

◆ get_guild_webhooks()

void dpp::cluster::get_guild_webhooks ( snowflake  guild_id,
command_completion_event_t  callback 
)

Get guild webhooks.

See also
https://discord.com/developers/docs/resources/webhook#get-guild-webhooks
Parameters
guild_idGuild ID to get webhooks for
callbackFunction to call when the API call completes. On success the callback will contain a dpp::webhook_map object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_edit_webhook(), and edit_webhook_sync().

Here is the caller graph for this function:

◆ get_guild_webhooks_sync()

webhook_map dpp::cluster::get_guild_webhooks_sync ( snowflake  guild_id)

Get guild webhooks.

See also
dpp::cluster::get_guild_webhooks
https://discord.com/developers/docs/resources/webhook#get-guild-webhooks
Parameters
guild_idGuild ID to get webhooks for
Returns
webhook_map returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

◆ get_raw_rest()

request_queue * dpp::cluster::get_raw_rest ( )

Get the raw rest_queue object which handles all HTTP(S) requests that are not directed at Discord.

Returns
request_queue* pointer to request_queue object

◆ get_rest()

request_queue * dpp::cluster::get_rest ( )

Get the rest_queue object which handles HTTPS requests to Discord.

Returns
request_queue* pointer to request_queue object

◆ get_shard()

discord_client * dpp::cluster::get_shard ( uint32_t  id)

Get a shard by id, returning the discord_client.

Parameters
idShard ID
Returns
discord_client* shard, or null

Referenced by main().

Here is the caller graph for this function:

◆ get_shards()

const shard_list & dpp::cluster::get_shards ( )

Get the list of shards.

Returns
shard_list& Reference to map of shards for this cluster

Referenced by dpp::discord_client::one_second_timer().

Here is the caller graph for this function:

◆ get_voice_regions()

void dpp::cluster::get_voice_regions ( command_completion_event_t  callback)

Get all voice regions.

See also
https://discord.com/developers/docs/resources/voice#list-voice-regions
Parameters
callbackFunction to call when the API call completes. On success the callback will contain a dpp::voiceregion_map object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_current_user_connections_get(), and current_user_connections_get_sync().

Here is the caller graph for this function:

◆ get_voice_regions_sync()

voiceregion_map dpp::cluster::get_voice_regions_sync ( )

Get all voice regions.

See also
dpp::cluster::get_voice_regions
https://discord.com/developers/docs/resources/voice#list-voice-regions
Returns
voiceregion_map returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References delete_webhook_with_token(), and token.

Here is the call graph for this function:

◆ get_webhook()

void dpp::cluster::get_webhook ( snowflake  webhook_id,
command_completion_event_t  callback 
)

Get webhook.

See also
https://discord.com/developers/docs/resources/webhook#get-webhook
Parameters
webhook_idWebhook ID to get
callbackFunction to call when the API call completes. On success the callback will contain a dpp::webhook object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_edit_webhook_message(), and edit_webhook_message_sync().

Here is the caller graph for this function:

◆ get_webhook_message()

void dpp::cluster::get_webhook_message ( const class webhook wh,
snowflake  message_id,
snowflake  thread_id = 0,
command_completion_event_t  callback = utility::log_error() 
)

Get webhook message.

See also
https://discord.com/developers/docs/resources/webhook#get-webhook-message
Parameters
whWebhook to get the original message for
message_idThe message ID
thread_idID of the thread the message is in
callbackFunction to call when the API call completes. On success the callback will contain a dpp::message object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_edit_webhook_with_token(), and edit_webhook_with_token_sync().

Here is the caller graph for this function:

◆ get_webhook_message_sync()

message dpp::cluster::get_webhook_message_sync ( const class webhook wh,
snowflake  message_id,
snowflake  thread_id = 0 
)

Get webhook message.

See also
dpp::cluster::get_webhook_message
https://discord.com/developers/docs/resources/webhook#get-webhook-message
Parameters
whWebhook to get the original message for
message_idThe message ID
thread_idID of the thread the message is in
Returns
message returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

◆ get_webhook_sync()

webhook dpp::cluster::get_webhook_sync ( snowflake  webhook_id)

Get webhook.

See also
dpp::cluster::get_webhook
https://discord.com/developers/docs/resources/webhook#get-webhook
Parameters
webhook_idWebhook ID to get
Returns
webhook returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

◆ get_webhook_with_token()

void dpp::cluster::get_webhook_with_token ( snowflake  webhook_id,
const std::string &  token,
command_completion_event_t  callback 
)

Get webhook using token.

See also
https://discord.com/developers/docs/resources/webhook#get-webhook-with-token
Parameters
webhook_idWebhook ID to retrieve
tokenToken of webhook
callbackFunction to call when the API call completes. On success the callback will contain a dpp::webhook object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_execute_webhook(), and execute_webhook_sync().

Here is the caller graph for this function:

◆ get_webhook_with_token_sync()

webhook dpp::cluster::get_webhook_with_token_sync ( snowflake  webhook_id,
const std::string &  token 
)

Get webhook using token.

See also
dpp::cluster::get_webhook_with_token
https://discord.com/developers/docs/resources/webhook#get-webhook-with-token
Parameters
webhook_idWebhook ID to retrieve
tokenToken of webhook
Returns
webhook returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

◆ global_bulk_command_create()

void dpp::cluster::global_bulk_command_create ( const std::vector< slashcommand > &  commands,
command_completion_event_t  callback = utility::log_error() 
)

Create/overwrite global slash commands.

Any existing global slash commands will be deleted and replaced with these.

See also
https://discord.com/developers/docs/interactions/application-commands#bulk-overwrite-global-application-commands
Parameters
commandsVector of slash commands to create/update. overwriting existing commands that are registered globally for this application. Commands that do not already exist will count toward daily application command create limits.
callbackFunction to call when the API call completes. On success the callback will contain a dpp::slashcommand_map object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

References API_PATH, dpp::managed::id, dpp::m_delete, me, and dpp::rest_request< confirmation >().

Here is the call graph for this function:

◆ global_bulk_command_create_sync()

slashcommand_map dpp::cluster::global_bulk_command_create_sync ( const std::vector< slashcommand > &  commands)

Create/overwrite global slash commands.

Any existing global slash commands will be deleted and replaced with these.

See also
dpp::cluster::global_bulk_command_create
https://discord.com/developers/docs/interactions/application-commands#bulk-overwrite-global-application-commands
Parameters
commandsVector of slash commands to create/update. overwriting existing commands that are registered globally for this application. Commands that do not already exist will count toward daily application command create limits.
Returns
slashcommand_map returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References global_command_edit().

Here is the call graph for this function:

◆ global_bulk_command_delete()

void dpp::cluster::global_bulk_command_delete ( command_completion_event_t  callback = utility::log_error())

Delete all existing global slash commands.

See also
https://discord.com/developers/docs/interactions/application-commands#bulk-overwrite-global-application-commands
Parameters
callbackFunction to call when the API call completes. On success the callback will contain a dpp::slashcommand_map object in confirmation_callback_t::value which will be empty, meaning there are no commands. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

References API_PATH, dpp::managed::id, dpp::m_get, and me.

◆ global_bulk_command_delete_sync()

slashcommand_map dpp::cluster::global_bulk_command_delete_sync ( )

Delete all existing global slash commands.

See also
dpp::cluster::global_bulk_command_delete
https://discord.com/developers/docs/interactions/application-commands#bulk-overwrite-global-application-commands
Returns
slashcommand_map returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References global_commands_get().

Here is the call graph for this function:

◆ global_command_create()

void dpp::cluster::global_command_create ( const slashcommand s,
command_completion_event_t  callback = utility::log_error() 
)

Create a global slash command (a bot can have a maximum of 100 of these).

See also
https://discord.com/developers/docs/interactions/application-commands#create-global-application-command
Parameters
sSlash command to create
callbackFunction to call when the API call completes. On success the callback will contain a dpp::slashcommand object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

◆ global_command_create_sync()

slashcommand dpp::cluster::global_command_create_sync ( const slashcommand s)

Create a global slash command (a bot can have a maximum of 100 of these).

See also
dpp::cluster::global_command_create
https://discord.com/developers/docs/interactions/application-commands#create-global-application-command
Parameters
sSlash command to create
Returns
slashcommand returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References guild_bulk_command_create().

Here is the call graph for this function:

◆ global_command_delete()

void dpp::cluster::global_command_delete ( snowflake  id,
command_completion_event_t  callback = utility::log_error() 
)

Delete a global slash command (a bot can have a maximum of 100 of these)

See also
https://discord.com/developers/docs/interactions/application-commands#delete-global-application-command
Parameters
idSlash command to delete
callbackFunction to call when the API call completes. On success the callback will contain a dpp::confirmation object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

References API_PATH, dpp::managed::id, dpp::m_put, and me.

◆ global_command_delete_sync()

confirmation dpp::cluster::global_command_delete_sync ( snowflake  id)

Delete a global slash command (a bot can have a maximum of 100 of these)

See also
dpp::cluster::global_command_delete
https://discord.com/developers/docs/interactions/application-commands#delete-global-application-command
Parameters
idSlash command to delete
Returns
confirmation returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References guild_commands_get_permissions().

Here is the call graph for this function:

◆ global_command_edit()

void dpp::cluster::global_command_edit ( const slashcommand s,
command_completion_event_t  callback = utility::log_error() 
)

Edit a global slash command (a bot can have a maximum of 100 of these)

See also
https://discord.com/developers/docs/interactions/application-commands#edit-global-application-command
Parameters
sSlash command to change
callbackFunction to call when the API call completes. On success the callback will contain a dpp::confirmation object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

References API_PATH, dpp::managed::id, dpp::m_get, and me.

Referenced by co_global_bulk_command_create(), and global_bulk_command_create_sync().

Here is the caller graph for this function:

◆ global_command_edit_sync()

confirmation dpp::cluster::global_command_edit_sync ( const slashcommand s)

Edit a global slash command (a bot can have a maximum of 100 of these)

See also
dpp::cluster::global_command_edit
https://discord.com/developers/docs/interactions/application-commands#edit-global-application-command
Parameters
sSlash command to change
Returns
confirmation returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References guild_bulk_command_edit_permissions().

Here is the call graph for this function:

◆ global_command_get()

void dpp::cluster::global_command_get ( snowflake  id,
command_completion_event_t  callback = utility::log_error() 
)

Get a global slash command.

See also
https://discord.com/developers/docs/interactions/application-commands#get-global-application-command
Parameters
idThe ID of the slash command
callbackFunction to call when the API call completes. On success the callback will contain a dpp::slashcommand object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

◆ global_command_get_sync()

slashcommand dpp::cluster::global_command_get_sync ( snowflake  id)

Get a global slash command.

See also
dpp::cluster::global_command_get
https://discord.com/developers/docs/interactions/application-commands#get-global-application-command
Parameters
idThe ID of the slash command
Returns
slashcommand returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References guild_bulk_command_delete().

Here is the call graph for this function:

◆ global_commands_get()

void dpp::cluster::global_commands_get ( command_completion_event_t  callback)

Get the application's global slash commands.

See also
https://discord.com/developers/docs/interactions/application-commands#get-global-application-commands
Parameters
callbackFunction to call when the API call completes. On success the callback will contain a dpp::slashcommand_map object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_global_bulk_command_delete(), and global_bulk_command_delete_sync().

Here is the caller graph for this function:

◆ global_commands_get_sync()

slashcommand_map dpp::cluster::global_commands_get_sync ( )

Get the application's global slash commands.

See also
dpp::cluster::global_commands_get
https://discord.com/developers/docs/interactions/application-commands#get-global-application-commands
Returns
slashcommand_map returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References guild_command_create().

Here is the call graph for this function:

◆ guild_add_member()

void dpp::cluster::guild_add_member ( const guild_member gm,
const std::string &  access_token,
command_completion_event_t  callback = utility::log_error() 
)

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 also
https://discord.com/developers/docs/resources/guild#add-guild-member
Parameters
gmGuild member to add
access_tokenAccess token from Oauth2 scope
callbackFunction to call when the API call completes. On success the callback will contain a dpp::guild_member object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_guild_sync_integration(), and guild_sync_integration_sync().

Here is the caller graph for this function:

◆ guild_add_member_sync()

confirmation dpp::cluster::guild_add_member_sync ( const guild_member gm,
const std::string &  access_token 
)

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 also
dpp::cluster::guild_add_member
https://discord.com/developers/docs/resources/guild#add-guild-member
Parameters
gmGuild member to add
access_tokenAccess token from Oauth2 scope
Returns
confirmation returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References guild_member_delete().

Here is the call graph for this function:

◆ guild_auditlog_get()

void dpp::cluster::guild_auditlog_get ( snowflake  guild_id,
snowflake  user_id,
uint32_t  action_type,
snowflake  before,
snowflake  after,
uint32_t  limit,
command_completion_event_t  callback 
)

Get the audit log for a guild.

See also
https://discord.com/developers/docs/resources/audit-log#get-guild-audit-log
Parameters
guild_idGuild to get the audit log of
user_idEntries from a specific user ID. Set this to 0 will fetch any user
action_typeEntries for a specific dpp::audit_type. Set this to 0 will fetch any type
beforeEntries with ID less than a specific audit log entry ID. Used for paginating
afterEntries with ID greater than a specific audit log entry ID. Used for paginating
limitMaximum number of entries (between 1-100) to return
callbackFunction to call when the API call completes. On success the callback will contain a dpp::auditlog object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_entitlements_get(), and entitlements_get_sync().

Here is the caller graph for this function:

◆ guild_auditlog_get_sync()

auditlog dpp::cluster::guild_auditlog_get_sync ( snowflake  guild_id,
snowflake  user_id,
uint32_t  action_type,
snowflake  before,
snowflake  after,
uint32_t  limit 
)

Get the audit log for a guild.

See also
dpp::cluster::guild_auditlog_get
https://discord.com/developers/docs/resources/audit-log#get-guild-audit-log
Parameters
guild_idGuild to get the audit log of
user_idEntries from a specific user ID. Set this to 0 will fetch any user
action_typeEntries for a specific dpp::audit_type. Set this to 0 will fetch any type
beforeEntries with ID less than a specific audit log entry ID. Used for paginating
afterEntries with ID greater than a specific audit log entry ID. Used for paginating
limitMaximum number of entries (between 1-100) to return
Returns
auditlog returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References guild_delete_integration().

Here is the call graph for this function:

◆ guild_ban_add()

void dpp::cluster::guild_ban_add ( snowflake  guild_id,
snowflake  user_id,
uint32_t  delete_message_seconds = 0,
command_completion_event_t  callback = utility::log_error() 
)

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 also
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.
Parameters
guild_idGuild ID to add ban to
user_idUser ID to ban
delete_message_secondsHow many seconds to delete messages for, between 0 and 604800 (7 days). Defaults to 0
callbackFunction to call when the API call completes. On success the callback will contain a dpp::confirmation object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

References API_PATH, dpp::json_interface< T >::build_json(), and dpp::m_post.

Referenced by co_entitlement_test_create(), and entitlement_test_create_sync().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ guild_ban_add_sync()

confirmation dpp::cluster::guild_ban_add_sync ( snowflake  guild_id,
snowflake  user_id,
uint32_t  delete_message_seconds = 0 
)

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 also
dpp::cluster::guild_ban_add
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.
Parameters
guild_idGuild ID to add ban to
user_idUser ID to ban
delete_message_secondsHow many seconds to delete messages for, between 0 and 604800 (7 days). Defaults to 0
Returns
confirmation returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References guild_edit().

Here is the call graph for this function:

◆ guild_ban_delete()

void dpp::cluster::guild_ban_delete ( snowflake  guild_id,
snowflake  user_id,
command_completion_event_t  callback = utility::log_error() 
)

Delete guild ban.

Remove the ban for a user. Requires the BAN_MEMBERS permissions. Fires a Guild Ban Remove Gateway event.

See also
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.
Parameters
guild_idGuild to delete ban from
user_idUser ID to delete ban for
callbackFunction to call when the API call completes. On success the callback will contain a dpp::confirmation object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

References API_PATH, dpp::json_interface< T >::build_json(), dpp::managed::id, and dpp::m_patch.

Referenced by co_entitlement_test_delete(), and entitlement_test_delete_sync().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ guild_ban_delete_sync()

confirmation dpp::cluster::guild_ban_delete_sync ( snowflake  guild_id,
snowflake  user_id 
)

Delete guild ban.

Remove the ban for a user. Requires the BAN_MEMBERS permissions. Fires a Guild Ban Remove Gateway event.

See also
dpp::cluster::guild_ban_delete
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.
Parameters
guild_idGuild to delete ban from
user_idUser ID to delete ban for
Returns
confirmation returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References guild_edit_widget().

Here is the call graph for this function:

◆ guild_begin_prune()

void dpp::cluster::guild_begin_prune ( snowflake  guild_id,
const struct prune pruneinfo,
command_completion_event_t  callback = utility::log_error() 
)

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 also
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.
Parameters
guild_idGuild ID to prune
pruneinfoPruning info
callbackFunction to call when the API call completes. On success the callback will contain a dpp::prune object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

References API_PATH, dpp::m_put, and dpp::unicode_emoji::o.

◆ guild_begin_prune_sync()

prune dpp::cluster::guild_begin_prune_sync ( snowflake  guild_id,
const struct prune pruneinfo 
)

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 also
dpp::cluster::guild_begin_prune
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.
Parameters
guild_idGuild ID to prune
pruneinfoPruning info
Returns
prune returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References guild_get_welcome_screen().

Here is the call graph for this function:

◆ guild_bulk_command_create()

void dpp::cluster::guild_bulk_command_create ( const std::vector< slashcommand > &  commands,
snowflake  guild_id,
command_completion_event_t  callback = utility::log_error() 
)

Create/overwrite guild slash commands.

Any existing guild slash commands on this guild will be deleted and replaced with these.

See also
https://discord.com/developers/docs/interactions/application-commands#bulk-overwrite-guild-application-commands
Parameters
commandsVector 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.
guild_idGuild ID to create/update the slash commands in
callbackFunction to call when the API call completes. On success the callback will contain a dpp::slashcommand_map object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_global_command_create(), and global_command_create_sync().

Here is the caller graph for this function:

◆ guild_bulk_command_create_sync()

slashcommand_map dpp::cluster::guild_bulk_command_create_sync ( const std::vector< slashcommand > &  commands,
snowflake  guild_id 
)

Create/overwrite guild slash commands.

Any existing guild slash commands on this guild will be deleted and replaced with these.

See also
dpp::cluster::guild_bulk_command_create
https://discord.com/developers/docs/interactions/application-commands#bulk-overwrite-guild-application-commands
Parameters
commandsVector 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.
guild_idGuild ID to create/update the slash commands in
Returns
slashcommand_map returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References guild_command_delete().

Here is the call graph for this function:

◆ guild_bulk_command_delete()

void dpp::cluster::guild_bulk_command_delete ( snowflake  guild_id,
command_completion_event_t  callback = utility::log_error() 
)

Delete all existing guild slash commands.

See also
https://discord.com/developers/docs/interactions/application-commands#bulk-overwrite-global-application-commands
Parameters
guild_idGuild ID to delete the slash commands in.
callbackFunction to call when the API call completes. On success the callback will contain a dpp::slashcommand_map object in confirmation_callback_t::value which will be empty, meaning there are no commands. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_global_command_get(), and global_command_get_sync().

Here is the caller graph for this function:

◆ guild_bulk_command_delete_sync()

slashcommand_map dpp::cluster::guild_bulk_command_delete_sync ( snowflake  guild_id)

Delete all existing guild slash commands.

See also
dpp::cluster::guild_bulk_command_delete
https://discord.com/developers/docs/interactions/application-commands#bulk-overwrite-global-application-commands
Parameters
guild_idGuild ID to delete the slash commands in.
Returns
slashcommand_map returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References guild_command_edit_permissions().

Here is the call graph for this function:

◆ guild_bulk_command_edit_permissions()

void dpp::cluster::guild_bulk_command_edit_permissions ( const std::vector< slashcommand > &  commands,
snowflake  guild_id,
command_completion_event_t  callback = utility::log_error() 
)

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 also
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.
Parameters
commandsA vector of slash commands to edit/overwrite the permissions for
guild_idGuild ID to edit permissions of the slash commands in
callbackFunction to call when the API call completes. On success the callback will contain a dpp::guild_command_permissions_map object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().
Deprecated:
This has been disabled with updates to Permissions v2. You can use guild_command_edit_permissions instead

Referenced by co_global_command_edit(), and global_command_edit_sync().

Here is the caller graph for this function:

◆ guild_bulk_command_edit_permissions_sync()

guild_command_permissions_map dpp::cluster::guild_bulk_command_edit_permissions_sync ( const std::vector< slashcommand > &  commands,
snowflake  guild_id 
)

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 also
dpp::cluster::guild_bulk_command_edit_permissions
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.
Parameters
commandsA vector of slash commands to edit/overwrite the permissions for
guild_idGuild ID to edit permissions of the slash commands in
Returns
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
Exceptions
dpp::rest_exceptionupon 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.

References guild_command_get_permissions().

Here is the call graph for this function:

◆ guild_command_create()

void dpp::cluster::guild_command_create ( const slashcommand s,
snowflake  guild_id,
command_completion_event_t  callback = utility::log_error() 
)

Create a slash command local to a guild.

See also
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.
Parameters
sSlash command to create
guild_idGuild ID to create the slash command in
callbackFunction to call when the API call completes. On success the callback will contain a dpp::slashcommand object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

References API_PATH, dpp::slashcommand::application_id, dpp::managed::id, dpp::m_put, dpp::slashcommand::permissions, and dpp::rest_request< confirmation >().

Referenced by co_global_commands_get(), and global_commands_get_sync().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ guild_command_create_sync()

slashcommand dpp::cluster::guild_command_create_sync ( const slashcommand s,
snowflake  guild_id 
)

Create a slash command local to a guild.

See also
dpp::cluster::guild_command_create
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.
Parameters
sSlash command to create
guild_idGuild ID to create the slash command in
Returns
slashcommand returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References guild_command_edit().

Here is the call graph for this function:

◆ guild_command_delete()

void dpp::cluster::guild_command_delete ( snowflake  id,
snowflake  guild_id,
command_completion_event_t  callback = utility::log_error() 
)

Delete a slash command local to a guild.

See also
https://discord.com/developers/docs/interactions/application-commands#delete-guild-application-command
Parameters
idSlash command to delete
guild_idGuild ID to delete the slash command in
callbackFunction to call when the API call completes. On success the callback will contain a dpp::confirmation object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

References API_PATH, and dpp::m_get.

Referenced by co_guild_bulk_command_create(), and guild_bulk_command_create_sync().

Here is the caller graph for this function:

◆ guild_command_delete_sync()

confirmation dpp::cluster::guild_command_delete_sync ( snowflake  id,
snowflake  guild_id 
)

Delete a slash command local to a guild.

See also
dpp::cluster::guild_command_delete
https://discord.com/developers/docs/interactions/application-commands#delete-guild-application-command
Parameters
idSlash command to delete
guild_idGuild ID to delete the slash command in
Returns
confirmation returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References guild_commands_get().

Here is the call graph for this function:

◆ guild_command_edit()

void dpp::cluster::guild_command_edit ( const slashcommand s,
snowflake  guild_id,
command_completion_event_t  callback = utility::log_error() 
)

Edit a slash command local to a guild.

See also
https://discord.com/developers/docs/interactions/application-commands#edit-guild-application-command
Parameters
sSlash command to edit
guild_idGuild ID to edit the slash command in
callbackFunction to call when the API call completes. On success the callback will contain a dpp::confirmation object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_guild_command_create(), and guild_command_create_sync().

Here is the caller graph for this function:

◆ guild_command_edit_permissions()

void dpp::cluster::guild_command_edit_permissions ( const slashcommand s,
snowflake  guild_id,
command_completion_event_t  callback = utility::log_error() 
)

Edit slash command permissions of a guild.

See also
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
Parameters
sSlash command to edit the permissions for
guild_idGuild ID to edit the slash command in
callbackFunction to call when the API call completes. On success the callback will contain a dpp::confirmation object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

References API_PATH, dpp::slashcommand::application_id, dpp::json_interface< T >::build_json(), dpp::managed::id, dpp::m_patch, and dpp::rest_request< confirmation >().

Referenced by co_guild_bulk_command_delete(), and guild_bulk_command_delete_sync().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ guild_command_edit_permissions_sync()

confirmation dpp::cluster::guild_command_edit_permissions_sync ( const slashcommand s,
snowflake  guild_id 
)

Edit slash command permissions of a guild.

See also
dpp::cluster::guild_command_edit_permissions
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
Parameters
sSlash command to edit the permissions for
guild_idGuild ID to edit the slash command in
Returns
confirmation returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References interaction_response_create(), and token.

Here is the call graph for this function:

◆ guild_command_edit_sync()

confirmation dpp::cluster::guild_command_edit_sync ( const slashcommand s,
snowflake  guild_id 
)

Edit a slash command local to a guild.

See also
dpp::cluster::guild_command_edit
https://discord.com/developers/docs/interactions/application-commands#edit-guild-application-command
Parameters
sSlash command to edit
guild_idGuild ID to edit the slash command in
Returns
confirmation returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References interaction_followup_create(), dpp::unicode_emoji::m, and token.

Here is the call graph for this function:

◆ guild_command_get()

void dpp::cluster::guild_command_get ( snowflake  id,
snowflake  guild_id,
command_completion_event_t  callback = utility::log_error() 
)

Get a slash command of a guild.

See also
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
Parameters
idThe ID of the slash command
guild_idGuild ID to get the slash command from
callbackFunction to call when the API call completes. On success the callback will contain a dpp::slashcommand object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_guild_commands_get_permissions(), and guild_commands_get_permissions_sync().

Here is the caller graph for this function:

◆ guild_command_get_permissions()

void dpp::cluster::guild_command_get_permissions ( snowflake  id,
snowflake  guild_id,
command_completion_event_t  callback = utility::log_error() 
)

Get the permissions for a slash command of a guild.

See also
https://discord.com/developers/docs/interactions/application-commands#get-application-command-permissions
Parameters
idThe ID of the slash command to get the permissions for
guild_idGuild ID to get the permissions of
callbackFunction to call when the API call completes. On success the callback will contain a dpp::guild_command_permissions object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

References API_PATH, dpp::unicode_emoji::m, dpp::m_patch, and dpp::utility::url_encode().

Referenced by co_guild_bulk_command_edit_permissions(), and guild_bulk_command_edit_permissions_sync().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ guild_command_get_permissions_sync()

guild_command_permissions dpp::cluster::guild_command_get_permissions_sync ( snowflake  id,
snowflake  guild_id 
)

Get the permissions for a slash command of a guild.

See also
dpp::cluster::guild_command_get_permissions
https://discord.com/developers/docs/interactions/application-commands#get-application-command-permissions
Parameters
idThe ID of the slash command to get the permissions for
guild_idGuild ID to get the permissions of
Returns
guild_command_permissions returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References interaction_response_get_original(), and token.

Here is the call graph for this function:

◆ guild_command_get_sync()

slashcommand dpp::cluster::guild_command_get_sync ( snowflake  id,
snowflake  guild_id 
)

Get a slash command of a guild.

See also
dpp::cluster::guild_command_get
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
Parameters
idThe ID of the slash command
guild_idGuild ID to get the slash command from
Returns
slashcommand returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References interaction_response_edit(), dpp::unicode_emoji::m, and token.

Here is the call graph for this function:

◆ guild_commands_get()

void dpp::cluster::guild_commands_get ( snowflake  guild_id,
command_completion_event_t  callback 
)

Get the application's slash commands for a guild.

See also
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
Parameters
guild_idGuild ID to get the slash commands for
callbackFunction to call when the API call completes. On success the callback will contain a dpp::slashcommand_map object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

References API_PATH, dpp::m_get, dpp::rest_request< message >(), and dpp::utility::url_encode().

Referenced by co_guild_command_delete(), and guild_command_delete_sync().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ guild_commands_get_permissions()

void dpp::cluster::guild_commands_get_permissions ( snowflake  guild_id,
command_completion_event_t  callback 
)

Get all slash command permissions of a guild.

See also
https://discord.com/developers/docs/interactions/application-commands#get-application-command-permissions
Parameters
guild_idGuild ID to get the slash commands permissions for
callbackFunction to call when the API call completes. On success the callback will contain a dpp::guild_command_permissions_map object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_global_command_delete(), and global_command_delete_sync().

Here is the caller graph for this function:

◆ guild_commands_get_permissions_sync()

guild_command_permissions_map dpp::cluster::guild_commands_get_permissions_sync ( snowflake  guild_id)

Get all slash command permissions of a guild.

See also
dpp::cluster::guild_commands_get_permissions
https://discord.com/developers/docs/interactions/application-commands#get-application-command-permissions
Parameters
guild_idGuild ID to get the slash commands permissions for
Returns
guild_command_permissions_map returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References guild_command_get().

Here is the call graph for this function:

◆ guild_commands_get_sync()

slashcommand_map dpp::cluster::guild_commands_get_sync ( snowflake  guild_id)

Get the application's slash commands for a guild.

See also
dpp::cluster::guild_commands_get
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
Parameters
guild_idGuild ID to get the slash commands for
Returns
slashcommand_map returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References interaction_followup_edit_original(), dpp::unicode_emoji::m, and token.

Here is the call graph for this function:

◆ guild_create()

void dpp::cluster::guild_create ( const class guild g,
command_completion_event_t  callback = utility::log_error() 
)

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 also
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.
Parameters
gGuild to create
callbackFunction to call when the API call completes. On success the callback will contain a dpp::guild object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

References API_PATH, dpp::json_interface< T >::build_json(), and dpp::m_patch.

Referenced by co_get_gateway_bot(), and get_gateway_bot_sync().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ guild_create_from_template()

void dpp::cluster::guild_create_from_template ( const std::string &  code,
const std::string &  name,
command_completion_event_t  callback = utility::log_error() 
)

Create a new guild based on a template.

Note
This endpoint can be used only by bots in less than 10 guilds.
See also
https://discord.com/developers/docs/resources/guild-template#create-guild-from-guild-template
Parameters
codeTemplate code to create guild from
nameGuild name to create
callbackFunction to call when the API call completes. On success the callback will contain a dpp::guild object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_guild_sticker_get(), and guild_sticker_get_sync().

Here is the caller graph for this function:

◆ guild_create_from_template_sync()

guild dpp::cluster::guild_create_from_template_sync ( const std::string &  code,
const std::string &  name 
)

Create a new guild based on a template.

Note
This endpoint can be used only by bots in less than 10 guilds.
See also
dpp::cluster::guild_create_from_template
https://discord.com/developers/docs/resources/guild-template#create-guild-from-guild-template
Parameters
codeTemplate code to create guild from
nameGuild name to create
Returns
guild returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References guild_template_sync().

Here is the call graph for this function:

◆ guild_create_sync()

guild dpp::cluster::guild_create_sync ( const class guild g)

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 also
dpp::cluster::guild_create
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.
Parameters
gGuild to create
Returns
guild returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References guild_get_ban().

Here is the call graph for this function:

◆ guild_current_member_edit()

void dpp::cluster::guild_current_member_edit ( snowflake  guild_id,
const std::string &  nickname,
command_completion_event_t  callback = utility::log_error() 
)

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 also
https://discord.com/developers/docs/resources/guild#modify-current-member
Parameters
guild_idGuild ID to change on
nicknameNew nickname, or empty string to clear nickname
callbackFunction to call when the API call completes. On success the callback will contain a dpp::confirmation object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_guild_emojis_get(), and guild_emojis_get_sync().

Here is the caller graph for this function:

◆ guild_current_member_edit_sync()

confirmation dpp::cluster::guild_current_member_edit_sync ( snowflake  guild_id,
const std::string &  nickname 
)

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 also
dpp::cluster::guild_current_member_edit
https://discord.com/developers/docs/resources/guild#modify-current-member
Parameters
guild_idGuild ID to change on
nicknameNew nickname, or empty string to clear nickname
Returns
confirmation returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References guild_delete().

Here is the call graph for this function:

◆ guild_delete()

void dpp::cluster::guild_delete ( snowflake  guild_id,
command_completion_event_t  callback = utility::log_error() 
)

Delete a guild.

Delete a guild permanently. User must be owner. Fires a Guild Delete Gateway event.

See also
https://discord.com/developers/docs/resources/guild#delete-guild
Parameters
guild_idGuild ID to delete
callbackFunction to call when the API call completes. On success the callback will contain a dpp::confirmation object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

References API_PATH, and dpp::m_get.

Referenced by co_guild_current_member_edit(), and guild_current_member_edit_sync().

Here is the caller graph for this function:

◆ guild_delete_integration()

void dpp::cluster::guild_delete_integration ( snowflake  guild_id,
snowflake  integration_id,
command_completion_event_t  callback = utility::log_error() 
)

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 also
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.
Parameters
guild_idGuild ID to delete integration for
integration_idIntegration ID to delete
callbackFunction to call when the API call completes. On success the callback will contain a dpp::confirmation object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

References dpp::utility::make_url_parameters().

Referenced by co_guild_auditlog_get(), and guild_auditlog_get_sync().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ guild_delete_integration_sync()

confirmation dpp::cluster::guild_delete_integration_sync ( snowflake  guild_id,
snowflake  integration_id 
)

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 also
dpp::cluster::guild_delete_integration
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.
Parameters
guild_idGuild ID to delete integration for
integration_idIntegration ID to delete
Returns
confirmation returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References guild_get().

Here is the call graph for this function:

◆ guild_delete_sync()

confirmation dpp::cluster::guild_delete_sync ( snowflake  guild_id)

Delete a guild.

Delete a guild permanently. User must be owner. Fires a Guild Delete Gateway event.

See also
dpp::cluster::guild_delete
https://discord.com/developers/docs/resources/guild#delete-guild
Parameters
guild_idGuild ID to delete
Returns
confirmation returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References guild_get_bans().

Here is the call graph for this function:

◆ guild_edit()

void dpp::cluster::guild_edit ( const class guild g,
command_completion_event_t  callback = utility::log_error() 
)

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 also
https://discord.com/developers/docs/resources/guild#modify-guild
Note
This method supports audit log reasons set by the cluster::set_audit_reason() method.
Parameters
gGuild to edit
callbackFunction to call when the API call completes. On success the callback will contain a dpp::guild object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_guild_ban_add(), and guild_ban_add_sync().

Here is the caller graph for this function:

◆ guild_edit_member()

void dpp::cluster::guild_edit_member ( const guild_member gm,
command_completion_event_t  callback = utility::log_error() 
)

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 also
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.
Parameters
gmGuild member to edit
callbackFunction to call when the API call completes. On success the callback will contain a dpp::guild_member object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_guild_get_onboarding(), and guild_get_onboarding_sync().

Here is the caller graph for this function:

◆ guild_edit_member_sync()

guild_member dpp::cluster::guild_edit_member_sync ( const guild_member gm)

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 also
dpp::cluster::guild_edit_member
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.
Parameters
gmGuild member to edit
Returns
guild_member returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References guild_member_kick().

Here is the call graph for this function:

◆ guild_edit_onboarding()

void dpp::cluster::guild_edit_onboarding ( const struct onboarding o,
command_completion_event_t  callback = utility::log_error() 
)

Edit the guild's onboarding configuration.

Requires the MANAGE_GUILD and MANAGE_ROLES permissions.

Note
Onboarding enforces constraints when enabled. These constraints are that there must be at least 7 Default Channels and at least 5 of them must allow sending messages to the @everyone role. The onboarding::mode field modifies what is considered when enforcing these constraints.
See also
https://discord.com/developers/docs/resources/guild#modify-guild-onboarding
Note
This method supports audit log reasons set by the cluster::set_audit_reason() method.
Parameters
oThe onboarding object
callbackFunction to call when the API call completes. On success the callback will contain a dpp::onboarding object in confirmation_callback_t::value filled to match the vanity url. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_guild_get_prune_counts(), and guild_get_prune_counts_sync().

Here is the caller graph for this function:

◆ guild_edit_onboarding_sync()

onboarding dpp::cluster::guild_edit_onboarding_sync ( const struct onboarding o)

Edit the guild's onboarding configuration.

Requires the MANAGE_GUILD and MANAGE_ROLES permissions.

Note
Onboarding enforces constraints when enabled. These constraints are that there must be at least 7 Default Channels and at least 5 of them must allow sending messages to the @everyone role. The onboarding::mode field modifies what is considered when enforcing these constraints.
See also
dpp::cluster::guild_edit_onboarding
https://discord.com/developers/docs/resources/guild#modify-guild-onboarding
Note
This method supports audit log reasons set by the cluster::set_audit_reason() method.
Parameters
oThe onboarding object
Returns
onboarding returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References guild_get_member().

Here is the call graph for this function:

◆ guild_edit_sync()

guild dpp::cluster::guild_edit_sync ( const class guild g)

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 also
dpp::cluster::guild_edit
https://discord.com/developers/docs/resources/guild#modify-guild
Note
This method supports audit log reasons set by the cluster::set_audit_reason() method.
Parameters
gGuild to edit
Returns
guild returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References guild_get_integrations().

Here is the call graph for this function:

◆ guild_edit_welcome_screen()

void dpp::cluster::guild_edit_welcome_screen ( snowflake  guild_id,
const struct welcome_screen welcome_screen,
bool  enabled,
command_completion_event_t  callback = utility::log_error() 
)

Edit the guild's welcome screen.

Requires the MANAGE_GUILD permission. May fire a Guild Update Gateway event.

See also
https://discord.com/developers/docs/resources/guild#modify-guild-welcome-screen
Parameters
guild_idThe guild ID to edit the welcome screen for
welcome_screenThe welcome screen
enabledWhether the welcome screen should be enabled or disabled
callbackFunction to call when the API call completes. On success the callback will contain a dpp::welcome_screen object in confirmation_callback_t::value filled to match the vanity url. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_guild_set_nickname(), and guild_set_nickname_sync().

Here is the caller graph for this function:

◆ guild_edit_welcome_screen_sync()

dpp::welcome_screen dpp::cluster::guild_edit_welcome_screen_sync ( snowflake  guild_id,
const struct welcome_screen welcome_screen,
bool  enabled 
)

Edit the guild's welcome screen.

Requires the MANAGE_GUILD permission. May fire a Guild Update Gateway event.

See also
dpp::cluster::guild_edit_welcome_screen
https://discord.com/developers/docs/resources/guild#modify-guild-welcome-screen
Parameters
guild_idThe guild ID to edit the welcome screen for
welcome_screenThe welcome screen
enabledWhether the welcome screen should be enabled or disabled
Returns
dpp::welcome_screen returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References guild_member_add_role().

Here is the call graph for this function:

◆ guild_edit_widget()

void dpp::cluster::guild_edit_widget ( snowflake  guild_id,
const class guild_widget gw,
command_completion_event_t  callback = utility::log_error() 
)

Edit guild widget.

Requires the MANAGE_GUILD permission.

See also
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.
Parameters
guild_idGuild ID to edit widget for
gwNew guild widget information
callbackFunction to call when the API call completes. On success the callback will contain a dpp::guild_widget object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

References API_PATH, and dpp::m_get.

Referenced by co_guild_ban_delete(), and guild_ban_delete_sync().

Here is the caller graph for this function:

◆ guild_edit_widget_sync()

guild_widget dpp::cluster::guild_edit_widget_sync ( snowflake  guild_id,
const class guild_widget gw 
)

Edit guild widget.

Requires the MANAGE_GUILD permission.

See also
dpp::cluster::guild_edit_widget
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.
Parameters
guild_idGuild ID to edit widget for
gwNew guild widget information
Returns
guild_widget returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References guild_get_preview().

Here is the call graph for this function:

◆ guild_emoji_create()

void dpp::cluster::guild_emoji_create ( snowflake  guild_id,
const class emoji newemoji,
command_completion_event_t  callback = utility::log_error() 
)

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 also
https://discord.com/developers/docs/resources/emoji#create-guild-emoji
Parameters
guild_idGuild ID to create emoji om
newemojiEmoji to create
callbackFunction to call when the API call completes. On success the callback will contain a dpp::emoji object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_create_dm_channel(), and create_dm_channel_sync().

Here is the caller graph for this function:

◆ guild_emoji_create_sync()

emoji dpp::cluster::guild_emoji_create_sync ( snowflake  guild_id,
const class emoji newemoji 
)

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 also
dpp::cluster::guild_emoji_create
https://discord.com/developers/docs/resources/emoji#create-guild-emoji
Parameters
guild_idGuild ID to create emoji om
newemojiEmoji to create
Returns
emoji returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References entitlements_get().

Here is the call graph for this function:

◆ guild_emoji_delete()

void dpp::cluster::guild_emoji_delete ( snowflake  guild_id,
snowflake  emoji_id,
command_completion_event_t  callback = utility::log_error() 
)

Delete a guild emoji.

Note
This method supports audit log reasons set by the cluster::set_audit_reason() method.
See also
https://discord.com/developers/docs/resources/emoji#delete-guild-emoji
Parameters
guild_idGuild ID to delete emoji on
emoji_idEmoji ID to delete
callbackFunction to call when the API call completes. On success the callback will contain a dpp::confirmation object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_current_user_get_dms(), and current_user_get_dms_sync().

Here is the caller graph for this function:

◆ guild_emoji_delete_sync()

confirmation dpp::cluster::guild_emoji_delete_sync ( snowflake  guild_id,
snowflake  emoji_id 
)

Delete a guild emoji.

Note
This method supports audit log reasons set by the cluster::set_audit_reason() method.
See also
dpp::cluster::guild_emoji_delete
https://discord.com/developers/docs/resources/emoji#delete-guild-emoji
Parameters
guild_idGuild ID to delete emoji on
emoji_idEmoji ID to delete
Returns
confirmation returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References entitlement_test_create().

Here is the call graph for this function:

◆ guild_emoji_edit()

void dpp::cluster::guild_emoji_edit ( snowflake  guild_id,
const class emoji newemoji,
command_completion_event_t  callback = utility::log_error() 
)

Edit a single emoji.

You must ensure that the emoji passed contained image data using the emoji::load_image() method.

See also
https://discord.com/developers/docs/resources/emoji#modify-guild-emoji
Note
This method supports audit log reasons set by the cluster::set_audit_reason() method.
Parameters
guild_idGuild ID to edit emoji on
newemojiEmoji to edit
callbackFunction to call when the API call completes. On success the callback will contain a dpp::emoji object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_direct_message_create(), and direct_message_create_sync().

Here is the caller graph for this function:

◆ guild_emoji_edit_sync()

emoji dpp::cluster::guild_emoji_edit_sync ( snowflake  guild_id,
const class emoji newemoji 
)

Edit a single emoji.

You must ensure that the emoji passed contained image data using the emoji::load_image() method.

See also
dpp::cluster::guild_emoji_edit
https://discord.com/developers/docs/resources/emoji#modify-guild-emoji
Note
This method supports audit log reasons set by the cluster::set_audit_reason() method.
Parameters
guild_idGuild ID to edit emoji on
newemojiEmoji to edit
Returns
emoji returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References entitlement_test_delete().

Here is the call graph for this function:

◆ guild_emoji_get()

void dpp::cluster::guild_emoji_get ( snowflake  guild_id,
snowflake  emoji_id,
command_completion_event_t  callback 
)

Get a single emoji.

See also
https://discord.com/developers/docs/resources/emoji#get-guild-emoji
Parameters
guild_idGuild ID to get emoji for
emoji_idEmoji ID to get
callbackFunction to call when the API call completes. On success the callback will contain a dpp::emoji object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_gdm_add(), and gdm_add_sync().

Here is the caller graph for this function:

◆ guild_emoji_get_sync()

emoji dpp::cluster::guild_emoji_get_sync ( snowflake  guild_id,
snowflake  emoji_id 
)

Get a single emoji.

See also
dpp::cluster::guild_emoji_get
https://discord.com/developers/docs/resources/emoji#get-guild-emoji
Parameters
guild_idGuild ID to get emoji for
emoji_idEmoji ID to get
Returns
emoji returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References get_gateway_bot().

Here is the call graph for this function:

◆ guild_emojis_get()

void dpp::cluster::guild_emojis_get ( snowflake  guild_id,
command_completion_event_t  callback 
)

Get all emojis for a guild.

See also
https://discord.com/developers/docs/resources/emoji#list-guild-emojis
Parameters
guild_idGuild ID to get emojis for
callbackFunction to call when the API call completes. On success the callback will contain a dpp::emoji_map object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_gdm_remove(), and gdm_remove_sync().

Here is the caller graph for this function:

◆ guild_emojis_get_sync()

emoji_map dpp::cluster::guild_emojis_get_sync ( snowflake  guild_id)

Get all emojis for a guild.

See also
dpp::cluster::guild_emojis_get
https://discord.com/developers/docs/resources/emoji#list-guild-emojis
Parameters
guild_idGuild ID to get emojis for
Returns
emoji_map returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References guild_current_member_edit().

Here is the call graph for this function:

◆ guild_event_create()

void dpp::cluster::guild_event_create ( const scheduled_event event,
command_completion_event_t  callback = utility::log_error() 
)

Create a scheduled event on a guild.

See also
https://discord.com/developers/docs/resources/guild-scheduled-event#create-guild-scheduled-event
Parameters
eventEvent to create (guild ID must be populated)
callbackFunction to call when the API call completes. On success the callback will contain a dpp::scheduled_event_map object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by application_role_connection_get_sync(), and co_application_role_connection_get().

Here is the caller graph for this function:

◆ guild_event_create_sync()

scheduled_event dpp::cluster::guild_event_create_sync ( const scheduled_event event)

Create a scheduled event on a guild.

See also
dpp::cluster::guild_event_create
https://discord.com/developers/docs/resources/guild-scheduled-event#create-guild-scheduled-event
Parameters
eventEvent to create (guild ID must be populated)
Returns
scheduled_event returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References stage_instance_create().

Here is the call graph for this function:

◆ guild_event_delete()

void dpp::cluster::guild_event_delete ( snowflake  event_id,
snowflake  guild_id,
command_completion_event_t  callback = utility::log_error() 
)

Delete a scheduled event from a guild.

See also
https://discord.com/developers/docs/resources/guild-scheduled-event#delete-guild-scheduled-event
Parameters
event_idEvent ID to delete
guild_idGuild ID of event to delete
callbackFunction to call when the API call completes. On success the callback will contain a dpp::confirmation object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by application_role_connection_update_sync(), and co_application_role_connection_update().

Here is the caller graph for this function:

◆ guild_event_delete_sync()

confirmation dpp::cluster::guild_event_delete_sync ( snowflake  event_id,
snowflake  guild_id 
)

Delete a scheduled event from a guild.

See also
dpp::cluster::guild_event_delete
https://discord.com/developers/docs/resources/guild-scheduled-event#delete-guild-scheduled-event
Parameters
event_idEvent ID to delete
guild_idGuild ID of event to delete
Returns
confirmation returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References stage_instance_get().

Here is the call graph for this function:

◆ guild_event_edit()

void dpp::cluster::guild_event_edit ( const scheduled_event event,
command_completion_event_t  callback = utility::log_error() 
)

Edit/modify a scheduled event on a guild.

See also
https://discord.com/developers/docs/resources/guild-scheduled-event#modify-guild-scheduled-event
Parameters
eventEvent to create (event ID and guild ID must be populated)
callbackFunction to call when the API call completes. On success the callback will contain a dpp::scheduled_event_map object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_user_application_role_connection_get(), and user_application_role_connection_get_sync().

Here is the caller graph for this function:

◆ guild_event_edit_sync()

scheduled_event dpp::cluster::guild_event_edit_sync ( const scheduled_event event)

Edit/modify a scheduled event on a guild.

See also
dpp::cluster::guild_event_edit
https://discord.com/developers/docs/resources/guild-scheduled-event#modify-guild-scheduled-event
Parameters
eventEvent to create (event ID and guild ID must be populated)
Returns
scheduled_event returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References stage_instance_edit().

Here is the call graph for this function:

◆ guild_event_get()

void dpp::cluster::guild_event_get ( snowflake  guild_id,
snowflake  event_id,
command_completion_event_t  callback 
)

Get a scheduled event for a guild.

See also
https://discord.com/developers/docs/resources/guild-scheduled-event#get-guild-scheduled-event
Parameters
guild_idGuild to get event for
event_idEvent ID to get
callbackFunction to call when the API call completes. On success the callback will contain a dpp::scheduled_event object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_user_application_role_connection_update(), and user_application_role_connection_update_sync().

Here is the caller graph for this function:

◆ guild_event_get_sync()

scheduled_event dpp::cluster::guild_event_get_sync ( snowflake  guild_id,
snowflake  event_id 
)

Get a scheduled event for a guild.

See also
dpp::cluster::guild_event_get
https://discord.com/developers/docs/resources/guild-scheduled-event#get-guild-scheduled-event
Parameters
guild_idGuild to get event for
event_idEvent ID to get
Returns
scheduled_event returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References stage_instance_delete().

Here is the call graph for this function:

◆ guild_event_users_get()

void dpp::cluster::guild_event_users_get ( snowflake  guild_id,
snowflake  event_id,
command_completion_event_t  callback,
uint8_t  limit = 100,
snowflake  before = 0,
snowflake  after = 0 
)

Get users RSVP'd to an event.

See also
https://discord.com/developers/docs/resources/guild-scheduled-event#get-guild-scheduled-event-users
Parameters
guild_idGuild to get user list for
event_idGuild to get user list for
limitMaximum number of results to return
beforeReturn user IDs that fall before this ID, if provided
afterReturn user IDs that fall after this ID, if provided
callbackFunction to call when the API call completes. On success the callback will contain a dpp::event_member_map object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

◆ guild_events_get()

void dpp::cluster::guild_events_get ( snowflake  guild_id,
command_completion_event_t  callback 
)

Get all scheduled events for a guild.

See also
https://discord.com/developers/docs/resources/guild-scheduled-event#list-scheduled-events-for-guild
Parameters
guild_idGuild to get events for
callbackFunction to call when the API call completes. On success the callback will contain a dpp::scheduled_event_map object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_roles_get(), and roles_get_sync().

Here is the caller graph for this function:

◆ guild_events_get_sync()

scheduled_event_map dpp::cluster::guild_events_get_sync ( snowflake  guild_id)

Get all scheduled events for a guild.

See also
dpp::cluster::guild_events_get
https://discord.com/developers/docs/resources/guild-scheduled-event#list-scheduled-events-for-guild
Parameters
guild_idGuild to get events for
Returns
scheduled_event_map returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References skus_get().

Here is the call graph for this function:

◆ guild_get()

void dpp::cluster::guild_get ( snowflake  g,
command_completion_event_t  callback 
)

Get a guild.

Returns the guild object for the given id. This endpoint will also return approximate_member_count and approximate_presence_count for the guild.

See also
https://discord.com/developers/docs/resources/guild#get-guild
Parameters
gGuild ID to retrieve
callbackFunction to call when the API call completes. On success the callback will contain a dpp::guild object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

References API_PATH, and dpp::m_get.

Referenced by co_guild_delete_integration(), and guild_delete_integration_sync().

Here is the caller graph for this function:

◆ guild_get_ban()

void dpp::cluster::guild_get_ban ( snowflake  guild_id,
snowflake  user_id,
command_completion_event_t  callback 
)

Get single guild ban.

Requires the BAN_MEMBERS permission.

See also
https://discord.com/developers/docs/resources/guild#get-guild-ban
Parameters
guild_idGuild ID to get ban for
user_idUser ID of ban to retrieve
callbackFunction to call when the API call completes. On success the callback will contain a dpp::ban object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

References API_PATH, and dpp::m_get.

Referenced by co_guild_create(), and guild_create_sync().

Here is the caller graph for this function:

◆ guild_get_ban_sync()

ban dpp::cluster::guild_get_ban_sync ( snowflake  guild_id,
snowflake  user_id 
)

Get single guild ban.

Requires the BAN_MEMBERS permission.

See also
dpp::cluster::guild_get_ban
https://discord.com/developers/docs/resources/guild#get-guild-ban
Parameters
guild_idGuild ID to get ban for
user_idUser ID of ban to retrieve
Returns
ban returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References guild_get_vanity().

Here is the call graph for this function:

◆ guild_get_bans()

void dpp::cluster::guild_get_bans ( snowflake  guild_id,
snowflake  before,
snowflake  after,
snowflake  limit,
command_completion_event_t  callback 
)

Get guild ban list.

Requires the BAN_MEMBERS permission.

See also
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.
Parameters
guild_idGuild ID to get bans for
beforeIf non-zero, all bans for user ids before this user id will be returned up to the limit
afterif non-zero, all bans for user ids after this user id will be returned up to the limit
limitthe maximum number of bans to retrieve in this call up to a maximum of 1000
callbackFunction to call when the API call completes. On success the callback will contain a dpp::ban_map object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

References API_PATH, and dpp::m_get.

Referenced by co_guild_delete(), and guild_delete_sync().

Here is the caller graph for this function:

◆ guild_get_bans_sync()

ban_map dpp::cluster::guild_get_bans_sync ( snowflake  guild_id,
snowflake  before,
snowflake  after,
snowflake  limit 
)

Get guild ban list.

Requires the BAN_MEMBERS permission.

See also
dpp::cluster::guild_get_bans
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.
Parameters
guild_idGuild ID to get bans for
beforeIf non-zero, all bans for user ids before this user id will be returned up to the limit
afterif non-zero, all bans for user ids after this user id will be returned up to the limit
limitthe maximum number of bans to retrieve in this call up to a maximum of 1000
Returns
ban_map returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References guild_get_widget().

Here is the call graph for this function:

◆ guild_get_integrations()

void dpp::cluster::guild_get_integrations ( snowflake  guild_id,
command_completion_event_t  callback 
)

Get guild integrations.

Requires the MANAGE_GUILD permission.

See also
https://discord.com/developers/docs/resources/guild#get-guild-integrations
Parameters
guild_idGuild ID to get integrations for
callbackFunction to call when the API call completes. On success the callback will contain a dpp::integration_map object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().
Note
This endpoint returns a maximum of 50 integrations. If a guild has more integrations, they cannot be accessed.

References API_PATH, dpp::json_interface< T >::build_json(), dpp::managed::id, dpp::m_patch, and dpp::rest_request< confirmation >().

Referenced by co_guild_edit(), and guild_edit_sync().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ guild_get_integrations_sync()

integration_map dpp::cluster::guild_get_integrations_sync ( snowflake  guild_id)

Get guild integrations.

Requires the MANAGE_GUILD permission.

See also
dpp::cluster::guild_get_integrations
https://discord.com/developers/docs/resources/guild#get-guild-integrations
Parameters
guild_idGuild ID to get integrations for
Returns
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.
Exceptions
dpp::rest_exceptionupon 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.

References guild_get_prune_counts().

Here is the call graph for this function:

◆ guild_get_invites()

void dpp::cluster::guild_get_invites ( snowflake  guild_id,
command_completion_event_t  callback 
)

Get guild invites.

Returns a list of invite objects (with invite metadata) for the guild. Requires the MANAGE_GUILD permission.

See also
https://discord.com/developers/docs/resources/guild#get-guild-invites
Parameters
guild_idGuild ID to get invites for
callbackFunction to call when the API call completes. On success the callback will contain a dpp::invite_map object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_guild_member_timeout_remove(), and guild_member_timeout_remove_sync().

Here is the caller graph for this function:

◆ guild_get_invites_sync()

invite_map dpp::cluster::guild_get_invites_sync ( snowflake  guild_id)

Get guild invites.

Returns a list of invite objects (with invite metadata) for the guild. Requires the MANAGE_GUILD permission.

See also
dpp::cluster::guild_get_invites
https://discord.com/developers/docs/resources/guild#get-guild-invites
Parameters
guild_idGuild ID to get invites for
Returns
invite_map returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References dpp::unicode_emoji::m, and message_create().

Here is the call graph for this function:

◆ guild_get_member()

void dpp::cluster::guild_get_member ( snowflake  guild_id,
snowflake  user_id,
command_completion_event_t  callback 
)

Get a guild member.

See also
https://discord.com/developers/docs/resources/guild#get-guild-member
Parameters
guild_idGuild ID to get member for
user_idUser ID of member to get
callbackFunction to call when the API call completes. On success the callback will contain a dpp::guild_member object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

References dpp::guild_member::fill_from_json(), and dpp::snowflake_not_null().

Referenced by co_guild_edit_onboarding(), and guild_edit_onboarding_sync().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ guild_get_member_sync()

guild_member dpp::cluster::guild_get_member_sync ( snowflake  guild_id,
snowflake  user_id 
)

Get a guild member.

See also
dpp::cluster::guild_get_member
https://discord.com/developers/docs/resources/guild#get-guild-member
Parameters
guild_idGuild ID to get member for
user_idUser ID of member to get
Returns
guild_member returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References guild_member_timeout().

Here is the call graph for this function:

◆ guild_get_members()

void dpp::cluster::guild_get_members ( snowflake  guild_id,
uint16_t  limit,
snowflake  after,
command_completion_event_t  callback 
)

Get all guild members.

Note
This endpoint is restricted according to whether the GUILD_MEMBERS Privileged Intent is enabled for your application.
See also
https://discord.com/developers/docs/resources/guild#get-guild-members
Parameters
guild_idGuild ID to get all members for
limitmax number of members to return (1-1000)
afterthe highest user id in the previous page
callbackFunction to call when the API call completes. On success the callback will contain a dpp::guild_member_map object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_guild_get_welcome_screen(), and guild_get_welcome_screen_sync().

Here is the caller graph for this function:

◆ guild_get_members_sync()

guild_member_map dpp::cluster::guild_get_members_sync ( snowflake  guild_id,
uint16_t  limit,
snowflake  after 
)

Get all guild members.

Note
This endpoint is restricted according to whether the GUILD_MEMBERS Privileged Intent is enabled for your application.
See also
dpp::cluster::guild_get_members
https://discord.com/developers/docs/resources/guild#get-guild-members
Parameters
guild_idGuild ID to get all members for
limitmax number of members to return (1-1000)
afterthe highest user id in the previous page
Returns
guild_member_map returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References guild_member_timeout_remove().

Here is the call graph for this function:

◆ guild_get_onboarding()

void dpp::cluster::guild_get_onboarding ( snowflake  guild_id,
command_completion_event_t  callback 
)

Get the guild's onboarding configuration.

See also
https://discord.com/developers/docs/resources/guild#get-guild-onboarding
Parameters
guild_idThe guild to pull the onboarding configuration from.
callbackFunction to call when the API call completes. On success the callback will contain a dpp::onboarding object in confirmation_callback_t::value filled to match the vanity url. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_guild_modify_integration(), and guild_modify_integration_sync().

Here is the caller graph for this function:

◆ guild_get_onboarding_sync()

onboarding dpp::cluster::guild_get_onboarding_sync ( snowflake  guild_id)

Get the guild's onboarding configuration.

See also
dpp::cluster::guild_get_onboarding
https://discord.com/developers/docs/resources/guild#get-guild-onboarding
Parameters
guild_idThe guild to pull the onboarding configuration from.
Returns
onboarding returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References guild_edit_member().

Here is the call graph for this function:

◆ guild_get_preview()

void dpp::cluster::guild_get_preview ( snowflake  g,
command_completion_event_t  callback 
)

Get a guild preview.

Returns a guild object but only a subset of the fields will be populated.

Returns the guild preview object for the given id g. If the user is not in the guild, then the guild must be lurkable (it must be Discoverable or have a live public stage).

See also
https://discord.com/developers/docs/resources/guild#get-guild-preview
Parameters
gGuild ID to retrieve
callbackFunction to call when the API call completes. On success the callback will contain a dpp::guild object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

References API_PATH, dpp::json_interface< T >::build_json(), and dpp::m_get.

Referenced by co_guild_edit_widget(), and guild_edit_widget_sync().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ guild_get_prune_counts()

void dpp::cluster::guild_get_prune_counts ( snowflake  guild_id,
const struct prune pruneinfo,
command_completion_event_t  callback 
)

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 also
https://discord.com/developers/docs/resources/guild#get-guild-prune-count
Parameters
guild_idGuild ID to count for pruning
pruneinfoPruning info
callbackFunction to call when the API call completes. On success the callback will contain a dpp::prune object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

References API_PATH, and dpp::m_get.

Referenced by co_guild_get_integrations(), and guild_get_integrations_sync().

Here is the caller graph for this function:

◆ guild_get_prune_counts_sync()

prune dpp::cluster::guild_get_prune_counts_sync ( snowflake  guild_id,
const struct prune pruneinfo 
)

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 also
dpp::cluster::guild_get_prune_counts
https://discord.com/developers/docs/resources/guild#get-guild-prune-count
Parameters
guild_idGuild ID to count for pruning
pruneinfoPruning info
Returns
prune returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References guild_edit_onboarding(), and dpp::unicode_emoji::o.

Here is the call graph for this function:

◆ guild_get_vanity()

void dpp::cluster::guild_get_vanity ( snowflake  guild_id,
command_completion_event_t  callback 
)

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 also
https://discord.com/developers/docs/resources/guild#get-guild-vanity-url
Parameters
guild_idGuild to get vanity URL for
callbackFunction to call when the API call completes. On success the callback will contain a dpp::invite object in confirmation_callback_t::value filled to match the vanity url. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

References API_PATH, dpp::json_interface< T >::build_json(), and dpp::m_post.

Referenced by co_guild_get_ban(), and guild_get_ban_sync().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ guild_get_vanity_sync()

invite dpp::cluster::guild_get_vanity_sync ( snowflake  guild_id)

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 also
dpp::cluster::guild_get_vanity
https://discord.com/developers/docs/resources/guild#get-guild-vanity-url
Parameters
guild_idGuild to get vanity URL for
Returns
invite returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References guild_set_nickname().

Here is the call graph for this function:

◆ guild_get_voice_regions()

void dpp::cluster::guild_get_voice_regions ( snowflake  guild_id,
command_completion_event_t  callback 
)

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 also
https://discord.com/developers/docs/resources/guild#get-guild-voice-regions
Parameters
guild_idGuild ID to get voice regions for
callbackFunction to call when the API call completes. On success the callback will contain a dpp::voiceregion_map object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_current_user_get_guilds(), and current_user_get_guilds_sync().

Here is the caller graph for this function:

◆ guild_get_voice_regions_sync()

voiceregion_map dpp::cluster::guild_get_voice_regions_sync ( snowflake  guild_id)

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 also
dpp::cluster::guild_get_voice_regions
https://discord.com/developers/docs/resources/guild#get-guild-voice-regions
Parameters
guild_idGuild ID to get voice regions for
Returns
voiceregion_map returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References edit_webhook().

Here is the call graph for this function:

◆ guild_get_welcome_screen()

void dpp::cluster::guild_get_welcome_screen ( snowflake  guild_id,
command_completion_event_t  callback 
)

Get the guild's welcome screen.

If the welcome screen is not enabled, the MANAGE_GUILD permission is required.

See also
https://discord.com/developers/docs/resources/guild#get-guild-welcome-screen
Parameters
guild_idThe guild ID to get the welcome screen from
callbackFunction to call when the API call completes. On success the callback will contain a dpp::welcome_screen object in confirmation_callback_t::value filled to match the vanity url. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_guild_begin_prune(), and guild_begin_prune_sync().

Here is the caller graph for this function:

◆ guild_get_welcome_screen_sync()

dpp::welcome_screen dpp::cluster::guild_get_welcome_screen_sync ( snowflake  guild_id)

Get the guild's welcome screen.

If the welcome screen is not enabled, the MANAGE_GUILD permission is required.

See also
dpp::cluster::guild_get_welcome_screen
https://discord.com/developers/docs/resources/guild#get-guild-welcome-screen
Parameters
guild_idThe guild ID to get the welcome screen from
Returns
dpp::welcome_screen returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References guild_get_members().

Here is the call graph for this function:

◆ guild_get_widget()

void dpp::cluster::guild_get_widget ( snowflake  guild_id,
command_completion_event_t  callback 
)

Get guild widget.

Requires the MANAGE_GUILD permission.

See also
https://discord.com/developers/docs/resources/guild#get-guild-widget
Parameters
guild_idGuild ID to get widget for
callbackFunction to call when the API call completes. On success the callback will contain a dpp::guild_widget object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

References API_PATH, dpp::m_patch, dpp::unicode_emoji::o, and dpp::rest_request< confirmation >().

Referenced by co_guild_get_bans(), and guild_get_bans_sync().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ guild_get_widget_sync()

guild_widget dpp::cluster::guild_get_widget_sync ( snowflake  guild_id)

Get guild widget.

Requires the MANAGE_GUILD permission.

See also
dpp::cluster::guild_get_widget
https://discord.com/developers/docs/resources/guild#get-guild-widget
Parameters
guild_idGuild ID to get widget for
Returns
guild_widget returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References guild_sync_integration().

Here is the call graph for this function:

◆ guild_member_add_role()

void dpp::cluster::guild_member_add_role ( snowflake  guild_id,
snowflake  user_id,
snowflake  role_id,
command_completion_event_t  callback = utility::log_error() 
)

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 also
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.
Parameters
guild_idGuild ID to add a role to
user_idUser ID to add role to
role_idRole ID to add to the user
callbackFunction to call when the API call completes. On success the callback will contain a dpp::confirmation object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_guild_edit_welcome_screen(), and guild_edit_welcome_screen_sync().

Here is the caller graph for this function:

◆ guild_member_add_role_sync()

confirmation dpp::cluster::guild_member_add_role_sync ( snowflake  guild_id,
snowflake  user_id,
snowflake  role_id 
)

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 also
dpp::cluster::guild_member_add_role
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.
Parameters
guild_idGuild ID to add a role to
user_idUser ID to add role to
role_idRole ID to add to the user
Returns
confirmation returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References guild_member_delete_role().

Here is the call graph for this function:

◆ guild_member_delete()

void dpp::cluster::guild_member_delete ( snowflake  guild_id,
snowflake  user_id,
command_completion_event_t  callback = utility::log_error() 
)

Remove (kick) a guild member.

Remove a member from a guild. Requires KICK_MEMBERS permission. Fires a Guild Member Remove Gateway event.

See also
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
Parameters
guild_idGuild ID to kick member from
user_idUser ID to kick
callbackFunction to call when the API call completes. On success the callback will contain a dpp::confirmation object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_guild_add_member(), and guild_add_member_sync().

Here is the caller graph for this function:

◆ guild_member_delete_role()

void dpp::cluster::guild_member_delete_role ( snowflake  guild_id,
snowflake  user_id,
snowflake  role_id,
command_completion_event_t  callback = utility::log_error() 
)

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 also
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.
Parameters
guild_idGuild ID to remove role from user on
user_idUser ID to remove role from
role_idRole to remove
callbackFunction to call when the API call completes. On success the callback will contain a dpp::confirmation object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().
Deprecated:
Use dpp::cluster::guild_member_remove_role instead

Referenced by co_guild_member_add_role(), and guild_member_add_role_sync().

Here is the caller graph for this function:

◆ guild_member_delete_role_sync()

confirmation dpp::cluster::guild_member_delete_role_sync ( snowflake  guild_id,
snowflake  user_id,
snowflake  role_id 
)

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 also
dpp::cluster::guild_member_delete_role
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.
Parameters
guild_idGuild ID to remove role from user on
user_idUser ID to remove role from
role_idRole to remove
Returns
confirmation returned object on completion
Deprecated:
Use dpp::cluster::guild_member_remove_role instead
Exceptions
dpp::rest_exceptionupon 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.

References invite_delete().

Here is the call graph for this function:

◆ guild_member_delete_sync()

confirmation dpp::cluster::guild_member_delete_sync ( snowflake  guild_id,
snowflake  user_id 
)

Remove (kick) a guild member.

Remove a member from a guild. Requires KICK_MEMBERS permission. Fires a Guild Member Remove Gateway event.

See also
dpp::cluster::guild_member_delete
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
Parameters
guild_idGuild ID to kick member from
user_idUser ID to kick
Returns
confirmation returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References guild_member_remove_role().

Here is the call graph for this function:

◆ guild_member_kick()

void dpp::cluster::guild_member_kick ( snowflake  guild_id,
snowflake  user_id,
command_completion_event_t  callback = utility::log_error() 
)

Remove (kick) a guild member.

Remove a member from a guild. Requires KICK_MEMBERS permission. Fires a Guild Member Remove Gateway event.

See also
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.
Parameters
guild_idGuild ID to kick member from
user_idUser ID to kick
callbackFunction to call when the API call completes. On success the callback will contain a dpp::confirmation object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_guild_edit_member(), and guild_edit_member_sync().

Here is the caller graph for this function:

◆ guild_member_kick_sync()

confirmation dpp::cluster::guild_member_kick_sync ( snowflake  guild_id,
snowflake  user_id 
)

Remove (kick) a guild member.

Remove a member from a guild. Requires KICK_MEMBERS permission. Fires a Guild Member Remove Gateway event.

See also
dpp::cluster::guild_member_kick
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.
Parameters
guild_idGuild ID to kick member from
user_idUser ID to kick
Returns
confirmation returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References guild_member_move().

Here is the call graph for this function:

◆ guild_member_move()

void dpp::cluster::guild_member_move ( const snowflake  channel_id,
const snowflake  guild_id,
const snowflake  user_id,
command_completion_event_t  callback = utility::log_error() 
)

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.
This method supports audit log reasons set by the cluster::set_audit_reason() method.
See also
https://discord.com/developers/docs/resources/guild#modify-guild-member
Parameters
channel_idId of the channel to which the user is used. Set to 0 to disconnect the user
guild_idGuild id to which the user is connected
user_idUser id, who should be moved
callbackFunction to call when the API call completes. On success the callback will contain a dpp::guild_member object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_guild_member_kick(), and guild_member_kick_sync().

Here is the caller graph for this function:

◆ guild_member_move_sync()

guild_member dpp::cluster::guild_member_move_sync ( const snowflake  channel_id,
const snowflake  guild_id,
const snowflake  user_id 
)

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.
This method supports audit log reasons set by the cluster::set_audit_reason() method.
See also
dpp::cluster::guild_member_move
https://discord.com/developers/docs/resources/guild#modify-guild-member
Parameters
channel_idId of the channel to which the user is used. Set to 0 to disconnect the user
guild_idGuild id to which the user is connected
user_idUser id, who should be moved
Returns
guild_member returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References dpp::unicode_emoji::m, and message_add_reaction().

Here is the call graph for this function:

◆ guild_member_remove_role()

void dpp::cluster::guild_member_remove_role ( snowflake  guild_id,
snowflake  user_id,
snowflake  role_id,
command_completion_event_t  callback = utility::log_error() 
)

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 also
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.
Parameters
guild_idGuild ID to remove role from user on
user_idUser ID to remove role from
role_idRole to remove
callbackFunction to call when the API call completes. On success the callback will contain a dpp::confirmation object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_guild_member_delete(), and guild_member_delete_sync().

Here is the caller graph for this function:

◆ guild_member_remove_role_sync()

confirmation dpp::cluster::guild_member_remove_role_sync ( snowflake  guild_id,
snowflake  user_id,
snowflake  role_id 
)

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 also
dpp::cluster::guild_member_remove_role
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.
Parameters
guild_idGuild ID to remove role from user on
user_idUser ID to remove role from
role_idRole to remove
Returns
confirmation returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References invite_get().

Here is the call graph for this function:

◆ guild_member_timeout()

void dpp::cluster::guild_member_timeout ( snowflake  guild_id,
snowflake  user_id,
time_t  communication_disabled_until,
command_completion_event_t  callback = utility::log_error() 
)

Set the timeout of a guild member.

Fires a Guild Member Update Gateway event.

See also
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.
Parameters
guild_idGuild ID to timeout the member in
user_idUser ID to set the timeout for
communication_disabled_untilThe timestamp when the user's timeout will expire (up to 28 days in the future). Set to 0 to remove the timeout
callbackFunction to call when the API call completes. On success the callback will contain a dpp::confirmation object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_guild_get_member(), and guild_get_member_sync().

Here is the caller graph for this function:

◆ guild_member_timeout_remove()

void dpp::cluster::guild_member_timeout_remove ( snowflake  guild_id,
snowflake  user_id,
command_completion_event_t  callback = utility::log_error() 
)

Remove the timeout of a guild member.

A shortcut for guild_member_timeout(guild_id, user_id, 0, callback) Fires a Guild Member Update Gateway event.

See also
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.
Parameters
guild_idGuild ID to remove the member timeout from
user_idUser ID to remove the timeout for
callbackFunction to call when the API call completes. On success the callback will contain a dpp::confirmation object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_guild_get_members(), and guild_get_members_sync().

Here is the caller graph for this function:

◆ guild_member_timeout_remove_sync()

confirmation dpp::cluster::guild_member_timeout_remove_sync ( snowflake  guild_id,
snowflake  user_id 
)

Remove the timeout of a guild member.

A shortcut for guild_member_timeout(guild_id, user_id, 0, callback) Fires a Guild Member Update Gateway event.

See also
dpp::cluster::guild_member_timeout_remove
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.
Parameters
guild_idGuild ID to remove the member timeout from
user_idUser ID to remove the timeout for
Returns
confirmation returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References guild_get_invites().

Here is the call graph for this function:

◆ guild_member_timeout_sync()

confirmation dpp::cluster::guild_member_timeout_sync ( snowflake  guild_id,
snowflake  user_id,
time_t  communication_disabled_until 
)

Set the timeout of a guild member.

Fires a Guild Member Update Gateway event.

See also
dpp::cluster::guild_member_timeout
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.
Parameters
guild_idGuild ID to timeout the member in
user_idUser ID to set the timeout for
communication_disabled_untilThe timestamp when the user's timeout will expire (up to 28 days in the future). Set to 0 to remove the timeout
Returns
confirmation returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References guild_search_members().

Here is the call graph for this function:

◆ guild_modify_integration()

void dpp::cluster::guild_modify_integration ( snowflake  guild_id,
const class integration i,
command_completion_event_t  callback = utility::log_error() 
)

Modify guild integration.

Note
This method supports audit log reasons set by the cluster::set_audit_reason() method.
See also
https://discord.com/developers/docs/resources/guild#modify-guild-integration
Parameters
guild_idGuild ID to modify integration for
iIntegration to modify
callbackFunction to call when the API call completes. On success the callback will contain a dpp::integration object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

References API_PATH, dpp::m_post, and dpp::rest_request< confirmation >().

Here is the call graph for this function:

◆ guild_modify_integration_sync()

confirmation dpp::cluster::guild_modify_integration_sync ( snowflake  guild_id,
const class integration i 
)

Modify guild integration.

Note
This method supports audit log reasons set by the cluster::set_audit_reason() method.
See also
dpp::cluster::guild_modify_integration
https://discord.com/developers/docs/resources/guild#modify-guild-integration
Parameters
guild_idGuild ID to modify integration for
iIntegration to modify
Returns
confirmation returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References guild_get_onboarding().

Here is the call graph for this function:

◆ guild_search_members()

void dpp::cluster::guild_search_members ( snowflake  guild_id,
const std::string &  query,
uint16_t  limit,
command_completion_event_t  callback 
)

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 also
https://discord.com/developers/docs/resources/guild#search-guild-members
Parameters
guild_idGuild ID to search in
queryQuery string to match username(s) and nickname(s) against
limitmax number of members to return (1-1000)
callbackFunction to call when the API call completes. On success the callback will contain a dpp::guild_member_map object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_guild_member_timeout(), and guild_member_timeout_sync().

Here is the caller graph for this function:

◆ guild_search_members_sync()

guild_member_map dpp::cluster::guild_search_members_sync ( snowflake  guild_id,
const std::string &  query,
uint16_t  limit 
)

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 also
dpp::cluster::guild_search_members
https://discord.com/developers/docs/resources/guild#search-guild-members
Parameters
guild_idGuild ID to search in
queryQuery string to match username(s) and nickname(s) against
limitmax number of members to return (1-1000)
Returns
guild_member_map returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References message_add_reaction().

Here is the call graph for this function:

◆ guild_set_nickname()

void dpp::cluster::guild_set_nickname ( snowflake  guild_id,
const std::string &  nickname,
command_completion_event_t  callback = utility::log_error() 
)

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 also
https://discord.com/developers/docs/resources/guild#modify-current-user-nick
Parameters
guild_idGuild ID to change nickname on
nicknameNew nickname, or empty string to clear nickname
callbackFunction to call when the API call completes. On success the callback will contain a dpp::confirmation object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

References API_PATH, and dpp::m_get.

Referenced by co_guild_get_vanity(), and guild_get_vanity_sync().

Here is the caller graph for this function:

◆ guild_set_nickname_sync()

confirmation dpp::cluster::guild_set_nickname_sync ( snowflake  guild_id,
const std::string &  nickname 
)

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 also
dpp::cluster::guild_set_nickname
https://discord.com/developers/docs/resources/guild#modify-current-user-nick
Parameters
guild_idGuild ID to change nickname on
nicknameNew nickname, or empty string to clear nickname
Returns
confirmation returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References guild_edit_welcome_screen().

Here is the call graph for this function:

◆ guild_sticker_create()

void dpp::cluster::guild_sticker_create ( const sticker s,
command_completion_event_t  callback = utility::log_error() 
)

Create a sticker in a guild.

Note
This method supports audit log reasons set by the cluster::set_audit_reason() method.
See also
https://discord.com/developers/docs/resources/sticker#create-guild-sticker
Parameters
sSticker to create. Must have its guild ID set.
callbackFunction to call when the API call completes. On success the callback will contain a dpp::sticker object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

References API_PATH, and dpp::m_get.

Referenced by co_skus_get(), and skus_get_sync().

Here is the caller graph for this function:

◆ guild_sticker_create_sync()

sticker dpp::cluster::guild_sticker_create_sync ( const sticker s)

Create a sticker in a guild.

Note
This method supports audit log reasons set by the cluster::set_audit_reason() method.
See also
dpp::cluster::guild_sticker_create
https://discord.com/developers/docs/resources/sticker#create-guild-sticker
Parameters
sSticker to create. Must have its guild ID set.
Returns
sticker returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References nitro_sticker_get().

Here is the call graph for this function:

◆ guild_sticker_delete()

void dpp::cluster::guild_sticker_delete ( snowflake  sticker_id,
snowflake  guild_id,
command_completion_event_t  callback = utility::log_error() 
)

Delete a sticker from a guild.

Note
This method supports audit log reasons set by the cluster::set_audit_reason() method.
See also
https://discord.com/developers/docs/resources/sticker#delete-guild-sticker
Parameters
sticker_idsticker ID to delete
guild_idguild ID to delete from
callbackFunction to call when the API call completes. On success the callback will contain a dpp::sticker object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

References API_PATH, dpp::m_get, and dpp::rest_request_list< sticker_pack >().

Here is the call graph for this function:

◆ guild_sticker_delete_sync()

confirmation dpp::cluster::guild_sticker_delete_sync ( snowflake  sticker_id,
snowflake  guild_id 
)

Delete a sticker from a guild.

Note
This method supports audit log reasons set by the cluster::set_audit_reason() method.
See also
dpp::cluster::guild_sticker_delete
https://discord.com/developers/docs/resources/sticker#delete-guild-sticker
Parameters
sticker_idsticker ID to delete
guild_idguild ID to delete from
Returns
confirmation returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References sticker_packs_get().

Here is the call graph for this function:

◆ guild_sticker_get()

void dpp::cluster::guild_sticker_get ( snowflake  id,
snowflake  guild_id,
command_completion_event_t  callback 
)

Get a guild sticker.

See also
https://discord.com/developers/docs/resources/sticker#get-guild-sticker
Parameters
idId of sticker to get.
guild_idGuild ID of the guild where the sticker is
callbackFunction to call when the API call completes. On success the callback will contain a dpp::sticker object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_stage_instance_get(), and stage_instance_get_sync().

Here is the caller graph for this function:

◆ guild_sticker_get_sync()

sticker dpp::cluster::guild_sticker_get_sync ( snowflake  id,
snowflake  guild_id 
)

Get a guild sticker.

See also
dpp::cluster::guild_sticker_get
https://discord.com/developers/docs/resources/sticker#get-guild-sticker
Parameters
idId of sticker to get.
guild_idGuild ID of the guild where the sticker is
Returns
sticker returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References guild_create_from_template().

Here is the call graph for this function:

◆ guild_sticker_modify()

void dpp::cluster::guild_sticker_modify ( const sticker s,
command_completion_event_t  callback = utility::log_error() 
)

Modify a sticker in a guild.

Note
This method supports audit log reasons set by the cluster::set_audit_reason() method.
See also
https://discord.com/developers/docs/resources/sticker#modify-guild-sticker
Parameters
sSticker to modify. Must have its guild ID and sticker ID set.
callbackFunction to call when the API call completes. On success the callback will contain a dpp::sticker object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

◆ guild_sticker_modify_sync()

sticker dpp::cluster::guild_sticker_modify_sync ( const sticker s)

Modify a sticker in a guild.

Note
This method supports audit log reasons set by the cluster::set_audit_reason() method.
See also
dpp::cluster::guild_sticker_modify
https://discord.com/developers/docs/resources/sticker#modify-guild-sticker
Parameters
sSticker to modify. Must have its guild ID and sticker ID set.
Returns
sticker returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References guild_template_create().

Here is the call graph for this function:

◆ guild_stickers_get()

void dpp::cluster::guild_stickers_get ( snowflake  guild_id,
command_completion_event_t  callback 
)

Get all guild stickers.

See also
https://discord.com/developers/docs/resources/sticker#get-guild-stickers
Parameters
guild_idGuild ID of the guild where the sticker is
callbackFunction to call when the API call completes. On success the callback will contain a dpp::sticker_map object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_stage_instance_delete(), and stage_instance_delete_sync().

Here is the caller graph for this function:

◆ guild_stickers_get_sync()

sticker_map dpp::cluster::guild_stickers_get_sync ( snowflake  guild_id)

Get all guild stickers.

See also
dpp::cluster::guild_stickers_get
https://discord.com/developers/docs/resources/sticker#get-guild-stickers
Parameters
guild_idGuild ID of the guild where the sticker is
Returns
sticker_map returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References guild_template_delete().

Here is the call graph for this function:

◆ guild_sync_integration()

void dpp::cluster::guild_sync_integration ( snowflake  guild_id,
snowflake  integration_id,
command_completion_event_t  callback = utility::log_error() 
)

Sync guild integration.

See also
https://discord.com/developers/docs/resources/guild#sync-guild-integration
Parameters
guild_idGuild ID to sync integration on
integration_idIntegration ID to synchronise
callbackFunction to call when the API call completes. On success the callback will contain a dpp::confirmation object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_guild_get_widget(), and guild_get_widget_sync().

Here is the caller graph for this function:

◆ guild_sync_integration_sync()

confirmation dpp::cluster::guild_sync_integration_sync ( snowflake  guild_id,
snowflake  integration_id 
)

Sync guild integration.

See also
dpp::cluster::guild_sync_integration
https://discord.com/developers/docs/resources/guild#sync-guild-integration
Parameters
guild_idGuild ID to sync integration on
integration_idIntegration ID to synchronise
Returns
confirmation returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References guild_add_member().

Here is the call graph for this function:

◆ guild_template_create()

void dpp::cluster::guild_template_create ( snowflake  guild_id,
const std::string &  name,
const std::string &  description,
command_completion_event_t  callback = utility::log_error() 
)

Creates a template for the guild.

See also
https://discord.com/developers/docs/resources/guild-template#create-guild-template
Parameters
guild_idGuild to create template from
nameTemplate name to create
descriptionDescription of template to create
callbackFunction to call when the API call completes. On success the callback will contain a dpp::dtemplate object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_guild_sticker_modify(), and guild_sticker_modify_sync().

Here is the caller graph for this function:

◆ guild_template_create_sync()

dtemplate dpp::cluster::guild_template_create_sync ( snowflake  guild_id,
const std::string &  name,
const std::string &  description 
)

Creates a template for the guild.

See also
dpp::cluster::guild_template_create
https://discord.com/developers/docs/resources/guild-template#create-guild-template
Parameters
guild_idGuild to create template from
nameTemplate name to create
descriptionDescription of template to create
Returns
dtemplate returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References template_get().

Here is the call graph for this function:

◆ guild_template_delete()

void dpp::cluster::guild_template_delete ( snowflake  guild_id,
const std::string &  code,
command_completion_event_t  callback = utility::log_error() 
)

Deletes the template.

See also
https://discord.com/developers/docs/resources/guild-template#delete-guild-template
Parameters
guild_idGuild ID of template to delete
codeTemplate code to delete
callbackFunction to call when the API call completes. On success the callback will contain a dpp::confirmation object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

References API_PATH, and dpp::m_get.

Referenced by co_guild_stickers_get(), and guild_stickers_get_sync().

Here is the caller graph for this function:

◆ guild_template_delete_sync()

confirmation dpp::cluster::guild_template_delete_sync ( snowflake  guild_id,
const std::string &  code 
)

Deletes the template.

See also
dpp::cluster::guild_template_delete
https://discord.com/developers/docs/resources/guild-template#delete-guild-template
Parameters
guild_idGuild ID of template to delete
codeTemplate code to delete
Returns
confirmation returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References current_user_join_thread().

Here is the call graph for this function:

◆ guild_template_modify()

void dpp::cluster::guild_template_modify ( snowflake  guild_id,
const std::string &  code,
const std::string &  name,
const std::string &  description,
command_completion_event_t  callback = utility::log_error() 
)

Modifies the template's metadata.

See also
https://discord.com/developers/docs/resources/guild-template#modify-guild-template
Parameters
guild_idGuild ID of template to modify
codeTemplate code to modify
nameNew name of template
descriptionNew description of template
callbackFunction to call when the API call completes. On success the callback will contain a dpp::dtemplate object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_nitro_sticker_get(), and nitro_sticker_get_sync().

Here is the caller graph for this function:

◆ guild_template_modify_sync()

dtemplate dpp::cluster::guild_template_modify_sync ( snowflake  guild_id,
const std::string &  code,
const std::string &  name,
const std::string &  description 
)

Modifies the template's metadata.

See also
dpp::cluster::guild_template_modify
https://discord.com/developers/docs/resources/guild-template#modify-guild-template
Parameters
guild_idGuild ID of template to modify
codeTemplate code to modify
nameNew name of template
descriptionNew description of template
Returns
dtemplate returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References current_user_leave_thread().

Here is the call graph for this function:

◆ guild_template_sync()

void dpp::cluster::guild_template_sync ( snowflake  guild_id,
const std::string &  code,
command_completion_event_t  callback = utility::log_error() 
)

Syncs the template to the guild's current state.

See also
https://discord.com/developers/docs/resources/guild-template#sync-guild-template
Parameters
guild_idGuild to synchronise template for
codeCode of template to synchronise
callbackFunction to call when the API call completes. On success the callback will contain a dpp::dtemplate object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_guild_create_from_template(), and guild_create_from_template_sync().

Here is the caller graph for this function:

◆ guild_template_sync_sync()

dtemplate dpp::cluster::guild_template_sync_sync ( snowflake  guild_id,
const std::string &  code 
)

Syncs the template to the guild's current state.

See also
dpp::cluster::guild_template_sync
https://discord.com/developers/docs/resources/guild-template#sync-guild-template
Parameters
guild_idGuild to synchronise template for
codeCode of template to synchronise
Returns
dtemplate returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References threads_get_joined_private_archived().

Here is the call graph for this function:

◆ guild_templates_get()

void dpp::cluster::guild_templates_get ( snowflake  guild_id,
command_completion_event_t  callback 
)

Get guild templates.

See also
https://discord.com/developers/docs/resources/guild-template#get-guild-templates
Parameters
guild_idGuild ID to get templates for
callbackFunction to call when the API call completes. On success the callback will contain a dpp::dtemplate_map object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_sticker_packs_get(), and sticker_packs_get_sync().

Here is the caller graph for this function:

◆ guild_templates_get_sync()

dtemplate_map dpp::cluster::guild_templates_get_sync ( snowflake  guild_id)

Get guild templates.

See also
dpp::cluster::guild_templates_get
https://discord.com/developers/docs/resources/guild-template#get-guild-templates
Parameters
guild_idGuild ID to get templates for
Returns
dtemplate_map returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References threads_get_active().

Here is the call graph for this function:

◆ interaction_followup_create()

void dpp::cluster::interaction_followup_create ( const std::string &  token,
const message m,
command_completion_event_t  callback = utility::log_error() 
)

Create a followup message to a slash command.

See also
https://discord.com/developers/docs/interactions/receiving-and-responding#create-interaction-response
Parameters
tokenToken for the interaction webhook
mfollowup message to create
callbackFunction to call when the API call completes. On success the callback will contain a dpp::confirmation object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

References API_PATH, dpp::unicode_emoji::m, dpp::m_patch, and dpp::utility::url_encode().

Referenced by co_guild_command_edit(), and guild_command_edit_sync().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ interaction_followup_create_sync()

confirmation dpp::cluster::interaction_followup_create_sync ( const std::string &  token,
const message m 
)

Create a followup message to a slash command.

See also
dpp::cluster::interaction_followup_create
https://discord.com/developers/docs/interactions/receiving-and-responding#create-interaction-response
Parameters
tokenToken for the interaction webhook
mfollowup message to create
Returns
confirmation returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References interaction_followup_get_original(), and token.

Here is the call graph for this function:

◆ interaction_followup_delete()

void dpp::cluster::interaction_followup_delete ( const std::string &  token,
command_completion_event_t  callback = utility::log_error() 
)

Delete the initial interaction response.

See also
https://discord.com/developers/docs/interactions/receiving-and-responding#delete-original-interaction-response
Parameters
tokenToken for the interaction webhook
callbackFunction to call when the API call completes. On success the callback will contain a dpp::confirmation object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_interaction_response_create(), and interaction_response_create_sync().

Here is the caller graph for this function:

◆ interaction_followup_delete_sync()

confirmation dpp::cluster::interaction_followup_delete_sync ( const std::string &  token)

Delete the initial interaction response.

See also
dpp::cluster::interaction_followup_delete
https://discord.com/developers/docs/interactions/receiving-and-responding#delete-original-interaction-response
Parameters
tokenToken for the interaction webhook
Returns
confirmation returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References automod_rule_get().

Here is the call graph for this function:

◆ interaction_followup_edit()

void dpp::cluster::interaction_followup_edit ( const std::string &  token,
const message m,
command_completion_event_t  callback = utility::log_error() 
)

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.

See also
https://discord.com/developers/docs/interactions/receiving-and-responding#edit-followup-message
Parameters
tokenToken for the interaction webhook
mmessage to edit, the ID should be set
callbackFunction to call when the API call completes. On success the callback will contain a dpp::confirmation object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_interaction_response_edit(), and interaction_response_edit_sync().

Here is the caller graph for this function:

◆ interaction_followup_edit_original()

void dpp::cluster::interaction_followup_edit_original ( const std::string &  token,
const message m,
command_completion_event_t  callback = utility::log_error() 
)

Edit original followup message to a slash command This is an alias for cluster::interaction_response_edit.

See also
cluster::interaction_response_edit
Parameters
tokenToken for the interaction webhook
mmessage to edit, the ID should be set
callbackFunction to call when the API call completes. On success the callback will contain a dpp::confirmation object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

References API_PATH, dpp::m_get, dpp::rest_request< message >(), and dpp::utility::url_encode().

Referenced by co_guild_commands_get(), and guild_commands_get_sync().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ interaction_followup_edit_original_sync()

confirmation dpp::cluster::interaction_followup_edit_original_sync ( const std::string &  token,
const message m 
)

Edit original followup message to a slash command This is an alias for cluster::interaction_response_edit.

See also
dpp::cluster::interaction_followup_edit_original
cluster::interaction_response_edit
Parameters
tokenToken for the interaction webhook
mmessage to edit, the ID should be set
Returns
confirmation returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References automod_rules_get().

Here is the call graph for this function:

◆ interaction_followup_edit_sync()

confirmation dpp::cluster::interaction_followup_edit_sync ( const std::string &  token,
const message m 
)

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.

See also
dpp::cluster::interaction_followup_edit
https://discord.com/developers/docs/interactions/receiving-and-responding#edit-followup-message
Parameters
tokenToken for the interaction webhook
mmessage to edit, the ID should be set
Returns
confirmation returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References automod_rule_create().

Here is the call graph for this function:

◆ interaction_followup_get()

void dpp::cluster::interaction_followup_get ( const std::string &  token,
snowflake  message_id,
command_completion_event_t  callback 
)

Get the followup message to a slash command.

See also
https://discord.com/developers/docs/interactions/receiving-and-responding#get-followup-message
Parameters
tokenToken for the interaction webhook
message_idmessage to retrieve
callbackFunction to call when the API call completes. On success the callback will contain a dpp::message object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_interaction_response_get_original(), and interaction_response_get_original_sync().

Here is the caller graph for this function:

◆ interaction_followup_get_original()

void dpp::cluster::interaction_followup_get_original ( const std::string &  token,
command_completion_event_t  callback = utility::log_error() 
)

Get the original followup message to a slash command This is an alias for cluster::interaction_response_get_original.

See also
cluster::interaction_response_get_original
Parameters
tokenToken for the interaction webhook
callbackFunction to call when the API call completes. On success the callback will contain a dpp::message object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_interaction_followup_create(), and interaction_followup_create_sync().

Here is the caller graph for this function:

◆ interaction_followup_get_original_sync()

message dpp::cluster::interaction_followup_get_original_sync ( const std::string &  token)

Get the original followup message to a slash command This is an alias for cluster::interaction_response_get_original.

See also
dpp::cluster::interaction_followup_get_original
cluster::interaction_response_get_original
Parameters
tokenToken for the interaction webhook
Returns
message returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References automod_rule_delete().

Here is the call graph for this function:

◆ interaction_followup_get_sync()

message dpp::cluster::interaction_followup_get_sync ( const std::string &  token,
snowflake  message_id 
)

Get the followup message to a slash command.

See also
dpp::cluster::interaction_followup_get
https://discord.com/developers/docs/interactions/receiving-and-responding#get-followup-message
Parameters
tokenToken for the interaction webhook
message_idmessage to retrieve
Returns
message returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References automod_rule_edit().

Here is the call graph for this function:

◆ interaction_response_create()

void dpp::cluster::interaction_response_create ( snowflake  interaction_id,
const std::string &  token,
const interaction_response r,
command_completion_event_t  callback = utility::log_error() 
)

Respond to a slash command.

See also
https://discord.com/developers/docs/interactions/receiving-and-responding#create-interaction-response
Parameters
interaction_idInteraction id to respond to
tokenToken for the interaction webhook
rResponse to send
callbackFunction to call when the API call completes. On success the callback will contain a dpp::confirmation object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

References API_PATH, dpp::unicode_emoji::m, dpp::m_post, and dpp::utility::url_encode().

Referenced by co_guild_command_edit_permissions(), and guild_command_edit_permissions_sync().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ interaction_response_create_sync()

confirmation dpp::cluster::interaction_response_create_sync ( snowflake  interaction_id,
const std::string &  token,
const interaction_response r 
)

Respond to a slash command.

See also
dpp::cluster::interaction_response_create
https://discord.com/developers/docs/interactions/receiving-and-responding#create-interaction-response
Parameters
interaction_idInteraction id to respond to
tokenToken for the interaction webhook
rResponse to send
Returns
confirmation returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References interaction_followup_delete(), and token.

Here is the call graph for this function:

◆ interaction_response_edit()

void dpp::cluster::interaction_response_edit ( const std::string &  token,
const message m,
command_completion_event_t  callback = utility::log_error() 
)

Edit response to a slash command.

See also
https://discord.com/developers/docs/interactions/receiving-and-responding#edit-original-interaction-response
Parameters
tokenToken for the interaction webhook
mMessage to send
callbackFunction to call when the API call completes. On success the callback will contain a dpp::confirmation object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

References API_PATH, dpp::unicode_emoji::m, dpp::m_patch, and dpp::utility::url_encode().

Referenced by co_guild_command_get(), and guild_command_get_sync().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ interaction_response_edit_sync()

confirmation dpp::cluster::interaction_response_edit_sync ( const std::string &  token,
const message m 
)

Edit response to a slash command.

See also
dpp::cluster::interaction_response_edit
https://discord.com/developers/docs/interactions/receiving-and-responding#edit-original-interaction-response
Parameters
tokenToken for the interaction webhook
mMessage to send
Returns
confirmation returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References interaction_followup_edit(), dpp::unicode_emoji::m, and token.

Here is the call graph for this function:

◆ interaction_response_get_original()

void dpp::cluster::interaction_response_get_original ( const std::string &  token,
command_completion_event_t  callback = utility::log_error() 
)

Get the original response to a slash command.

See also
https://discord.com/developers/docs/interactions/receiving-and-responding#get-original-interaction-response
Parameters
tokenToken for the interaction webhook
callbackFunction to call when the API call completes. On success the callback will contain a dpp::message object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

References API_PATH, dpp::m_delete, dpp::rest_request< confirmation >(), and dpp::utility::url_encode().

Referenced by co_guild_command_get_permissions(), and guild_command_get_permissions_sync().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ interaction_response_get_original_sync()

message dpp::cluster::interaction_response_get_original_sync ( const std::string &  token)

Get the original response to a slash command.

See also
dpp::cluster::interaction_response_get_original
https://discord.com/developers/docs/interactions/receiving-and-responding#get-original-interaction-response
Parameters
tokenToken for the interaction webhook
Returns
message returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References interaction_followup_get(), and token.

Here is the call graph for this function:

◆ invite_delete()

void dpp::cluster::invite_delete ( const std::string &  invite,
command_completion_event_t  callback = utility::log_error() 
)

Delete an invite.

See also
https://discord.com/developers/docs/resources/invite#delete-invite
Note
This method supports audit log reasons set by the cluster::set_audit_reason() method.
Parameters
inviteInvite code to delete
callbackFunction to call when the API call completes. On success the callback will contain a dpp::invite object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_guild_member_delete_role(), and guild_member_delete_role_sync().

Here is the caller graph for this function:

◆ invite_get()

void dpp::cluster::invite_get ( const std::string &  invite_code,
command_completion_event_t  callback 
)

Get details about an invite.

See also
https://discord.com/developers/docs/resources/invite#get-invite
Parameters
invite_codeInvite code to get information on
callbackFunction to call when the API call completes. On success the callback will contain a dpp::invite object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_guild_member_remove_role(), and guild_member_remove_role_sync().

Here is the caller graph for this function:

◆ invite_get_sync()

invite dpp::cluster::invite_get_sync ( const std::string &  invite_code)

Get details about an invite.

See also
dpp::cluster::invite_get
https://discord.com/developers/docs/resources/invite#get-invite
Parameters
invite_codeInvite code to get information on
Returns
invite returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References dpp::unicode_emoji::m, and message_delete_all_reactions().

Here is the call graph for this function:

◆ log()

void dpp::cluster::log ( dpp::loglevel  severity,
const std::string &  msg 
) const

Log a message to whatever log the user is using.

The logged message is passed up the chain to the on_log event in user code which can then do whatever it wants to do with it.

Parameters
severityThe log level from dpp::loglevel
msgThe log message to output

Referenced by dpp::discord_voice_client::log().

Here is the caller graph for this function:

◆ message_add_reaction() [1/2]

void dpp::cluster::message_add_reaction ( const struct message m,
const std::string &  reaction,
command_completion_event_t  callback = utility::log_error() 
)

Add a reaction to a message.

The reaction string must be either an emojiname:id or a unicode character.

See also
https://discord.com/developers/docs/resources/channel#create-reaction
Parameters
mMessage to add a reaction to
reactionReaction to add. Emojis should be in the form emojiname:id
callbackFunction to call when the API call completes. On success the callback will contain a dpp::confirmation object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

References API_PATH, dpp::m_post, and dpp::rest_request< message >().

Referenced by co_guild_member_move(), co_guild_search_members(), guild_member_move_sync(), and guild_search_members_sync().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ message_add_reaction() [2/2]

void dpp::cluster::message_add_reaction ( snowflake  message_id,
snowflake  channel_id,
const std::string &  reaction,
command_completion_event_t  callback = utility::log_error() 
)

Add a reaction to a message by id.

The reaction string must be either an emojiname:id or a unicode character.

See also
https://discord.com/developers/docs/topics/gateway#message-reaction-add
Parameters
message_idMessage to add reactions to
channel_idChannel to add reactions to
reactionReaction to add. Emojis should be in the form emojiname:id
callbackFunction to call when the API call completes. On success the callback will contain a dpp::confirmation object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

◆ message_add_reaction_sync() [1/2]

confirmation dpp::cluster::message_add_reaction_sync ( const struct message m,
const std::string &  reaction 
)

Add a reaction to a message.

The reaction string must be either an emojiname:id or a unicode character.

See also
dpp::cluster::message_add_reaction
https://discord.com/developers/docs/resources/channel#create-reaction
Parameters
mMessage to add a reaction to
reactionReaction to add. Emojis should be in the form emojiname:id
Returns
confirmation returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References message_delete_all_reactions().

Here is the call graph for this function:

◆ message_add_reaction_sync() [2/2]

confirmation dpp::cluster::message_add_reaction_sync ( snowflake  message_id,
snowflake  channel_id,
const std::string &  reaction 
)

Add a reaction to a message by id.

The reaction string must be either an emojiname:id or a unicode character.

See also
dpp::cluster::message_add_reaction
https://discord.com/developers/docs/topics/gateway#message-reaction-add
Parameters
message_idMessage to add reactions to
channel_idChannel to add reactions to
reactionReaction to add. Emojis should be in the form emojiname:id
Returns
confirmation returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References message_delete_bulk().

Here is the call graph for this function:

◆ message_create()

void dpp::cluster::message_create ( const struct message m,
command_completion_event_t  callback = utility::log_error() 
)

Send a message to a channel.

The callback function is called when the message has been sent

See also
https://discord.com/developers/docs/resources/channel#create-message
Parameters
mMessage to send
callbackFunction to call when the API call completes. On success the callback will contain a dpp::message object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_guild_get_invites(), and guild_get_invites_sync().

Here is the caller graph for this function:

◆ message_create_sync()

message dpp::cluster::message_create_sync ( const struct message m)

Send a message to a channel.

The callback function is called when the message has been sent

See also
dpp::cluster::message_create
https://discord.com/developers/docs/resources/channel#create-message
Parameters
mMessage to send
Returns
message returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References message_delete().

Here is the call graph for this function:

◆ message_crosspost()

void dpp::cluster::message_crosspost ( snowflake  message_id,
snowflake  channel_id,
command_completion_event_t  callback = utility::log_error() 
)

Crosspost a message.

The callback function is called when the message has been sent

See also
https://discord.com/developers/docs/resources/channel#crosspost-message
Parameters
message_idMessage to crosspost
channel_idChannel ID to crosspost from
callbackFunction to call when the API call completes. On success the callback will contain a dpp::message object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

References dpp::unicode_emoji::m.

◆ message_crosspost_sync()

message dpp::cluster::message_crosspost_sync ( snowflake  message_id,
snowflake  channel_id 
)

Crosspost a message.

The callback function is called when the message has been sent

See also
dpp::cluster::message_crosspost
https://discord.com/developers/docs/resources/channel#crosspost-message
Parameters
message_idMessage to crosspost
channel_idChannel ID to crosspost from
Returns
message returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References dpp::unicode_emoji::m, and message_delete_own_reaction().

Here is the call graph for this function:

◆ message_delete()

void dpp::cluster::message_delete ( snowflake  message_id,
snowflake  channel_id,
command_completion_event_t  callback = utility::log_error() 
)

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 also
https://discord.com/developers/docs/resources/channel#delete-message
Parameters
message_idMessage ID to delete
channel_idChannel to delete from
callbackFunction to call when the API call completes. On success the callback will contain a dpp::confirmation object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_message_create(), event_handler_test(), and message_create_sync().

Here is the caller graph for this function:

◆ message_delete_all_reactions() [1/2]

void dpp::cluster::message_delete_all_reactions ( const struct message m,
command_completion_event_t  callback = utility::log_error() 
)

Delete all reactions on a message.

See also
https://discord.com/developers/docs/resources/channel#delete-all-reactions
Parameters
mMessage to delete reactions from
callbackFunction to call when the API call completes. On success the callback will contain a dpp::confirmation object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

References API_PATH, dpp::m_delete, and dpp::rest_request< confirmation >().

Referenced by co_invite_get(), co_message_add_reaction(), invite_get_sync(), and message_add_reaction_sync().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ message_delete_all_reactions() [2/2]

void dpp::cluster::message_delete_all_reactions ( snowflake  message_id,
snowflake  channel_id,
command_completion_event_t  callback = utility::log_error() 
)

Delete all reactions on a message by id.

See also
https://discord.com/developers/docs/resources/channel#delete-all-reactions
Parameters
message_idMessage to delete reactions from
channel_idChannel to delete reactions from
callbackFunction to call when the API call completes. On success the callback will contain a dpp::confirmation object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

◆ message_delete_all_reactions_sync() [1/2]

confirmation dpp::cluster::message_delete_all_reactions_sync ( const struct message m)

Delete all reactions on a message.

See also
dpp::cluster::message_delete_all_reactions
https://discord.com/developers/docs/resources/channel#delete-all-reactions
Parameters
mMessage to delete reactions from
Returns
confirmation returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References message_delete_own_reaction().

Here is the call graph for this function:

◆ message_delete_all_reactions_sync() [2/2]

confirmation dpp::cluster::message_delete_all_reactions_sync ( snowflake  message_id,
snowflake  channel_id 
)

Delete all reactions on a message by id.

See also
dpp::cluster::message_delete_all_reactions
https://discord.com/developers/docs/resources/channel#delete-all-reactions
Parameters
message_idMessage to delete reactions from
channel_idChannel to delete reactions from
Returns
confirmation returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References dpp::unicode_emoji::m, and message_delete_reaction().

Here is the call graph for this function:

◆ message_delete_bulk()

void dpp::cluster::message_delete_bulk ( const std::vector< snowflake > &  message_ids,
snowflake  channel_id,
command_completion_event_t  callback = utility::log_error() 
)

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.
If any message provided older than 2 weeks or any duplicate message ID, it will fail.
See also
https://discord.com/developers/docs/resources/channel#bulk-delete-messages
Parameters
message_idsList of message IDs to delete (at least 2 and at most 100 message IDs)
channel_idChannel to delete from
callbackFunction to call when the API call completes. On success the callback will contain a dpp::confirmation object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_message_add_reaction(), and message_add_reaction_sync().

Here is the caller graph for this function:

◆ message_delete_bulk_sync()

confirmation dpp::cluster::message_delete_bulk_sync ( const std::vector< snowflake > &  message_ids,
snowflake  channel_id 
)

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.
If any message provided older than 2 weeks or any duplicate message ID, it will fail.
See also
dpp::cluster::message_delete_bulk
https://discord.com/developers/docs/resources/channel#bulk-delete-messages
Parameters
message_idsList of message IDs to delete (at least 2 and at most 100 message IDs)
channel_idChannel to delete from
Returns
confirmation returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References message_delete_reaction().

Here is the call graph for this function:

◆ message_delete_own_reaction() [1/2]

void dpp::cluster::message_delete_own_reaction ( const struct message m,
const std::string &  reaction,
command_completion_event_t  callback = utility::log_error() 
)

Delete own reaction from a message.

The reaction string must be either an emojiname:id or a unicode character.

See also
https://discord.com/developers/docs/resources/channel#delete-own-reaction
Parameters
mMessage to delete own reaction from
reactionReaction to delete. The reaction should be in the form emojiname:id
callbackFunction to call when the API call completes. On success the callback will contain a dpp::confirmation object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_message_crosspost(), co_message_delete_all_reactions(), message_crosspost_sync(), and message_delete_all_reactions_sync().

Here is the caller graph for this function:

◆ message_delete_own_reaction() [2/2]

void dpp::cluster::message_delete_own_reaction ( snowflake  message_id,
snowflake  channel_id,
const std::string &  reaction,
command_completion_event_t  callback = utility::log_error() 
)

Delete own reaction from a message by id.

The reaction string must be either an emojiname:id or a unicode character.

See also
https://discord.com/developers/docs/resources/channel#delete-own-reaction
Parameters
message_idMessage to delete reactions from
channel_idChannel to delete reactions from
reactionReaction to delete. The reaction should be in the form emojiname:id
callbackFunction to call when the API call completes. On success the callback will contain a dpp::confirmation object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

References API_PATH, dpp::unicode_emoji::m, dpp::m_delete, dpp::rest_request< confirmation >(), and dpp::utility::url_encode().

Here is the call graph for this function:

◆ message_delete_own_reaction_sync() [1/2]

confirmation dpp::cluster::message_delete_own_reaction_sync ( const struct message m,
const std::string &  reaction 
)

Delete own reaction from a message.

The reaction string must be either an emojiname:id or a unicode character.

See also
dpp::cluster::message_delete_own_reaction
https://discord.com/developers/docs/resources/channel#delete-own-reaction
Parameters
mMessage to delete own reaction from
reactionReaction to delete. The reaction should be in the form emojiname:id
Returns
confirmation returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References message_delete_reaction_emoji().

Here is the call graph for this function:

◆ message_delete_own_reaction_sync() [2/2]

confirmation dpp::cluster::message_delete_own_reaction_sync ( snowflake  message_id,
snowflake  channel_id,
const std::string &  reaction 
)

Delete own reaction from a message by id.

The reaction string must be either an emojiname:id or a unicode character.

See also
dpp::cluster::message_delete_own_reaction
https://discord.com/developers/docs/resources/channel#delete-own-reaction
Parameters
message_idMessage to delete reactions from
channel_idChannel to delete reactions from
reactionReaction to delete. The reaction should be in the form emojiname:id
Returns
confirmation returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References dpp::unicode_emoji::m, and message_edit().

Here is the call graph for this function:

◆ message_delete_reaction() [1/2]

void dpp::cluster::message_delete_reaction ( const struct message m,
snowflake  user_id,
const std::string &  reaction,
command_completion_event_t  callback = utility::log_error() 
)

Delete a user's reaction from a message.

The reaction string must be either an emojiname:id or a unicode character

See also
https://discord.com/developers/docs/resources/channel#delete-user-reaction
Parameters
mMessage to delete a user's reaction from
user_idUser ID who's reaction you want to remove
reactionReaction to remove. Reactions should be in the form emojiname:id
callbackFunction to call when the API call completes. On success the callback will contain a dpp::confirmation object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_message_delete_all_reactions(), co_message_delete_bulk(), message_delete_all_reactions_sync(), and message_delete_bulk_sync().

Here is the caller graph for this function:

◆ message_delete_reaction() [2/2]

void dpp::cluster::message_delete_reaction ( snowflake  message_id,
snowflake  channel_id,
snowflake  user_id,
const std::string &  reaction,
command_completion_event_t  callback = utility::log_error() 
)

Delete a user's reaction from a message by id.

The reaction string must be either an emojiname:id or a unicode character

See also
https://discord.com/developers/docs/resources/channel#delete-user-reaction
Parameters
message_idMessage to delete reactions from
channel_idChannel to delete reactions from
user_idUser ID who's reaction you want to remove
reactionReaction to remove. Reactions should be in the form emojiname:id
callbackFunction to call when the API call completes. On success the callback will contain a dpp::confirmation object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

References API_PATH, dpp::unicode_emoji::m, and dpp::m_patch.

◆ message_delete_reaction_emoji() [1/2]

void dpp::cluster::message_delete_reaction_emoji ( const struct message m,
const std::string &  reaction,
command_completion_event_t  callback = utility::log_error() 
)

Delete all reactions on a message using a particular emoji.

The reaction string must be either an emojiname:id or a unicode character

See also
https://discord.com/developers/docs/resources/channel#delete-all-reactions-for-emoji
Parameters
mMessage to delete reactions from
reactionReaction to delete, in the form emojiname:id or a unicode character
callbackFunction to call when the API call completes. On success the callback will contain a dpp::confirmation object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

References API_PATH, dpp::unicode_emoji::m, and dpp::m_patch.

Referenced by co_message_delete(), co_message_delete_own_reaction(), message_delete_own_reaction_sync(), and message_delete_sync().

Here is the caller graph for this function:

◆ message_delete_reaction_emoji() [2/2]

void dpp::cluster::message_delete_reaction_emoji ( snowflake  message_id,
snowflake  channel_id,
const std::string &  reaction,
command_completion_event_t  callback = utility::log_error() 
)

Delete all reactions on a message using a particular emoji by id.

The reaction string must be either an emojiname:id or a unicode character

See also
https://discord.com/developers/docs/resources/channel#delete-all-reactions-for-emoji
Parameters
message_idMessage to delete reactions from
channel_idChannel to delete reactions from
reactionReaction to delete, in the form emojiname:id or a unicode character
callbackFunction to call when the API call completes. On success the callback will contain a dpp::confirmation object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

◆ message_delete_reaction_emoji_sync() [1/2]

confirmation dpp::cluster::message_delete_reaction_emoji_sync ( const struct message m,
const std::string &  reaction 
)

Delete all reactions on a message using a particular emoji.

The reaction string must be either an emojiname:id or a unicode character

See also
dpp::cluster::message_delete_reaction_emoji
https://discord.com/developers/docs/resources/channel#delete-all-reactions-for-emoji
Parameters
mMessage to delete reactions from
reactionReaction to delete, in the form emojiname:id or a unicode character
Returns
confirmation returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References dpp::unicode_emoji::m, and message_get_reactions().

Here is the call graph for this function:

◆ message_delete_reaction_emoji_sync() [2/2]

confirmation dpp::cluster::message_delete_reaction_emoji_sync ( snowflake  message_id,
snowflake  channel_id,
const std::string &  reaction 
)

Delete all reactions on a message using a particular emoji by id.

The reaction string must be either an emojiname:id or a unicode character

See also
dpp::cluster::message_delete_reaction_emoji
https://discord.com/developers/docs/resources/channel#delete-all-reactions-for-emoji
Parameters
message_idMessage to delete reactions from
channel_idChannel to delete reactions from
reactionReaction to delete, in the form emojiname:id or a unicode character
Returns
confirmation returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References message_get_reactions().

Here is the call graph for this function:

◆ message_delete_reaction_sync() [1/2]

confirmation dpp::cluster::message_delete_reaction_sync ( const struct message m,
snowflake  user_id,
const std::string &  reaction 
)

Delete a user's reaction from a message.

The reaction string must be either an emojiname:id or a unicode character

See also
dpp::cluster::message_delete_reaction
https://discord.com/developers/docs/resources/channel#delete-user-reaction
Parameters
mMessage to delete a user's reaction from
user_idUser ID who's reaction you want to remove
reactionReaction to remove. Reactions should be in the form emojiname:id
Returns
confirmation returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References dpp::unicode_emoji::m, and message_edit_flags().

Here is the call graph for this function:

◆ message_delete_reaction_sync() [2/2]

confirmation dpp::cluster::message_delete_reaction_sync ( snowflake  message_id,
snowflake  channel_id,
snowflake  user_id,
const std::string &  reaction 
)

Delete a user's reaction from a message by id.

The reaction string must be either an emojiname:id or a unicode character

See also
dpp::cluster::message_delete_reaction
https://discord.com/developers/docs/resources/channel#delete-user-reaction
Parameters
message_idMessage to delete reactions from
channel_idChannel to delete reactions from
user_idUser ID who's reaction you want to remove
reactionReaction to remove. Reactions should be in the form emojiname:id
Returns
confirmation returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References message_get().

Here is the call graph for this function:

◆ message_delete_sync()

confirmation dpp::cluster::message_delete_sync ( snowflake  message_id,
snowflake  channel_id 
)

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 also
dpp::cluster::message_delete
https://discord.com/developers/docs/resources/channel#delete-message
Parameters
message_idMessage ID to delete
channel_idChannel to delete from
Returns
confirmation returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References dpp::unicode_emoji::m, and message_delete_reaction_emoji().

Here is the call graph for this function:

◆ message_edit()

void dpp::cluster::message_edit ( const struct message m,
command_completion_event_t  callback = utility::log_error() 
)

Edit a message on a channel.

The callback function is called when the message has been edited

See also
https://discord.com/developers/docs/resources/channel#edit-message
Parameters
mMessage to edit
callbackFunction to call when the API call completes. On success the callback will contain a dpp::message object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

References API_PATH, dpp::m_get, and dpp::rest_request< message >().

Referenced by co_message_delete_own_reaction(), and message_delete_own_reaction_sync().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ message_edit_flags()

void dpp::cluster::message_edit_flags ( const struct message m,
command_completion_event_t  callback = utility::log_error() 
)

Edit the flags of a message on a channel.

The callback function is called when the message has been edited

Parameters
mMessage to edit the flags of
callbackFunction to call when the API call completes. On success the callback will contain a dpp::message object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_message_delete_reaction(), and message_delete_reaction_sync().

Here is the caller graph for this function:

◆ message_edit_flags_sync()

message dpp::cluster::message_edit_flags_sync ( const struct message m)

Edit the flags of a message on a channel.

The callback function is called when the message has been edited

Parameters
mMessage to edit the flags of
Returns
message returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References messages_get().

Here is the call graph for this function:

◆ message_edit_sync()

message dpp::cluster::message_edit_sync ( const struct message m)

Edit a message on a channel.

The callback function is called when the message has been edited

See also
dpp::cluster::message_edit
https://discord.com/developers/docs/resources/channel#edit-message
Parameters
mMessage to edit
Returns
message returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References message_pin().

Here is the call graph for this function:

◆ message_get()

void dpp::cluster::message_get ( snowflake  message_id,
snowflake  channel_id,
command_completion_event_t  callback 
)

Get a message.

See also
https://discord.com/developers/docs/resources/channel#get-channel-message
Parameters
message_idMessage ID
channel_idChannel ID
callbackFunction to call when the API call completes. On success the callback will contain a dpp::message object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_message_delete_reaction(), and message_delete_reaction_sync().

Here is the caller graph for this function:

◆ message_get_reactions() [1/2]

void dpp::cluster::message_get_reactions ( const struct message m,
const std::string &  reaction,
snowflake  before,
snowflake  after,
snowflake  limit,
command_completion_event_t  callback 
)

Get reactions on a message for a particular emoji.

The reaction string must be either an emojiname:id or a unicode character

See also
https://discord.com/developers/docs/resources/channel#get-reactions
Parameters
mMessage to get reactions for
reactionReaction should be in the form emojiname:id or a unicode character
beforeReactions before this ID should be retrieved if this is set to non-zero
afterReactions before this ID should be retrieved if this is set to non-zero
limitThis number of reactions maximum should be returned
callbackFunction to call when the API call completes. On success the callback will contain a dpp::user_map object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_message_delete_reaction_emoji(), and message_delete_reaction_emoji_sync().

Here is the caller graph for this function:

◆ message_get_reactions() [2/2]

void dpp::cluster::message_get_reactions ( snowflake  message_id,
snowflake  channel_id,
const std::string &  reaction,
snowflake  before,
snowflake  after,
snowflake  limit,
command_completion_event_t  callback 
)

Get reactions on a message for a particular emoji by id.

The reaction string must be either an emojiname:id or a unicode character

See also
https://discord.com/developers/docs/resources/channel#get-reactions
Parameters
message_idMessage to get reactions for
channel_idChannel to get reactions for
reactionReaction should be in the form emojiname:id or a unicode character
beforeReactions before this ID should be retrieved if this is set to non-zero
afterReactions before this ID should be retrieved if this is set to non-zero
limitThis number of reactions maximum should be returned
callbackFunction to call when the API call completes. On success the callback will contain a dpp::user_map object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

◆ message_get_reactions_sync() [1/2]

user_map dpp::cluster::message_get_reactions_sync ( const struct message m,
const std::string &  reaction,
snowflake  before,
snowflake  after,
snowflake  limit 
)

Get reactions on a message for a particular emoji.

The reaction string must be either an emojiname:id or a unicode character

See also
dpp::cluster::message_get_reactions
https://discord.com/developers/docs/resources/channel#get-reactions
Parameters
mMessage to get reactions for
reactionReaction should be in the form emojiname:id or a unicode character
beforeReactions before this ID should be retrieved if this is set to non-zero
afterReactions before this ID should be retrieved if this is set to non-zero
limitThis number of reactions maximum should be returned
Returns
user_map returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References dpp::unicode_emoji::m, and poll_get_answer_voters().

Here is the call graph for this function:

◆ message_get_reactions_sync() [2/2]

emoji_map dpp::cluster::message_get_reactions_sync ( snowflake  message_id,
snowflake  channel_id,
const std::string &  reaction,
snowflake  before,
snowflake  after,
snowflake  limit 
)

Get reactions on a message for a particular emoji by id.

The reaction string must be either an emojiname:id or a unicode character

See also
dpp::cluster::message_get_reactions
https://discord.com/developers/docs/resources/channel#get-reactions
Parameters
message_idMessage to get reactions for
channel_idChannel to get reactions for
reactionReaction should be in the form emojiname:id or a unicode character
beforeReactions before this ID should be retrieved if this is set to non-zero
afterReactions before this ID should be retrieved if this is set to non-zero
limitThis number of reactions maximum should be returned
Returns
emoji_map returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References poll_get_answer_voters().

Here is the call graph for this function:

◆ message_get_sync()

message dpp::cluster::message_get_sync ( snowflake  message_id,
snowflake  channel_id 
)

Get a message.

See also
dpp::cluster::message_get
https://discord.com/developers/docs/resources/channel#get-channel-message
Parameters
message_idMessage ID
channel_idChannel ID
Returns
message returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References message_unpin().

Here is the call graph for this function:

◆ message_pin()

void dpp::cluster::message_pin ( snowflake  channel_id,
snowflake  message_id,
command_completion_event_t  callback = utility::log_error() 
)

Pin a message.

Note
This method supports audit log reasons set by the cluster::set_audit_reason() method.
See also
https://discord.com/developers/docs/resources/channel#pin-message
Parameters
channel_idChannel id to pin message on
message_idMessage id to pin message on
callbackFunction to call when the API call completes. On success the callback will contain a dpp::confirmation object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_message_edit(), and message_edit_sync().

Here is the caller graph for this function:

◆ message_pin_sync()

confirmation dpp::cluster::message_pin_sync ( snowflake  channel_id,
snowflake  message_id 
)

Pin a message.

Note
This method supports audit log reasons set by the cluster::set_audit_reason() method.
See also
dpp::cluster::message_pin
https://discord.com/developers/docs/resources/channel#pin-message
Parameters
channel_idChannel id to pin message on
message_idMessage id to pin message on
Returns
confirmation returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References dpp::unicode_emoji::m, and poll_end().

Here is the call graph for this function:

◆ message_unpin()

void dpp::cluster::message_unpin ( snowflake  channel_id,
snowflake  message_id,
command_completion_event_t  callback = utility::log_error() 
)

Unpin a message.

See also
https://discord.com/developers/docs/resources/channel#unpin-message
Note
This method supports audit log reasons set by the cluster::set_audit_reason() method.
Parameters
channel_idChannel id to unpin message on
message_idMessage id to unpin message on
callbackFunction to call when the API call completes. On success the callback will contain a dpp::confirmation object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_message_get(), and message_get_sync().

Here is the caller graph for this function:

◆ message_unpin_sync()

confirmation dpp::cluster::message_unpin_sync ( snowflake  channel_id,
snowflake  message_id 
)

Unpin a message.

See also
dpp::cluster::message_unpin
https://discord.com/developers/docs/resources/channel#unpin-message
Note
This method supports audit log reasons set by the cluster::set_audit_reason() method.
Parameters
channel_idChannel id to unpin message on
message_idMessage id to unpin message on
Returns
confirmation returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References channel_pins_get().

Here is the call graph for this function:

◆ messages_get()

void dpp::cluster::messages_get ( snowflake  channel_id,
snowflake  around,
snowflake  before,
snowflake  after,
uint64_t  limit,
command_completion_event_t  callback 
)

Get multiple messages.

This function will attempt to fetch as many messages as possible using multiple API calls if needed.

See also
https://discord.com/developers/docs/resources/channel#get-channel-messages
Parameters
channel_idChannel ID to retrieve messages for
aroundMessages should be retrieved around this ID if this is set to non-zero
beforeMessages before this ID should be retrieved if this is set to non-zero
afterMessages after this ID should be retrieved if this is set to non-zero
limitThis number of messages maximum should be returned, up to a maximum of 100.
callbackFunction to call when the API call completes. On success the callback will contain a dpp::message_map object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_message_edit_flags(), and message_edit_flags_sync().

Here is the caller graph for this function:

◆ messages_get_sync()

message_map dpp::cluster::messages_get_sync ( snowflake  channel_id,
snowflake  around,
snowflake  before,
snowflake  after,
uint64_t  limit 
)

Get multiple messages.

This function will attempt to fetch as many messages as possible using multiple API calls if needed.

See also
dpp::cluster::messages_get
https://discord.com/developers/docs/resources/channel#get-channel-messages
Parameters
channel_idChannel ID to retrieve messages for
aroundMessages should be retrieved around this ID if this is set to non-zero
beforeMessages before this ID should be retrieved if this is set to non-zero
afterMessages after this ID should be retrieved if this is set to non-zero
limitThis number of messages maximum should be returned, up to a maximum of 100.
Returns
message_map returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References poll_end().

Here is the call graph for this function:

◆ nitro_sticker_get()

void dpp::cluster::nitro_sticker_get ( snowflake  id,
command_completion_event_t  callback 
)

Get a nitro sticker.

See also
https://discord.com/developers/docs/resources/sticker#get-sticker
Parameters
idId of sticker to get.
callbackFunction to call when the API call completes. On success the callback will contain a dpp::sticker object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_guild_sticker_create(), and guild_sticker_create_sync().

Here is the caller graph for this function:

◆ nitro_sticker_get_sync()

sticker dpp::cluster::nitro_sticker_get_sync ( snowflake  id)

Get a nitro sticker.

See also
dpp::cluster::nitro_sticker_get
https://discord.com/developers/docs/resources/sticker#get-sticker
Parameters
idId of sticker to get.
Returns
sticker returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References guild_template_modify().

Here is the call graph for this function:

◆ operator=() [1/2]

cluster& dpp::cluster::operator= ( const cluster &&  )
delete

dpp::cluster is non-moveable

◆ operator=() [2/2]

cluster& dpp::cluster::operator= ( const cluster )
delete

dpp::cluster is non-copyable

◆ poll_end() [1/2]

void dpp::cluster::poll_end ( const message m,
command_completion_event_t  callback = utility::log_error() 
)

Immediately end a poll.

Parameters
mMessage that contains the poll
callbackFunction to call when the API call completes.
See also
https://discord.com/developers/docs/resources/poll#end-poll On success the callback will contain a dpp::message object representing the message containing the poll in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_message_pin(), co_messages_get(), message_pin_sync(), and messages_get_sync().

Here is the caller graph for this function:

◆ poll_end() [2/2]

void dpp::cluster::poll_end ( snowflake  message_id,
snowflake  channel_id,
command_completion_event_t  callback = utility::log_error() 
)

Immediately end a poll.

Parameters
message_idID of the message with the poll to end
channel_idID of the channel with the poll to end
callbackFunction to call when the API call completes.
See also
https://discord.com/developers/docs/resources/poll#end-poll On success the callback will contain a dpp::message object representing the message containing the poll in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

◆ poll_end_sync() [1/2]

message dpp::cluster::poll_end_sync ( const message m)

Immediately end a poll.

Parameters
mMessage that contains the poll
Returns
message returned object on completion
See also
dpp::cluster::poll_end
https://discord.com/developers/docs/resources/poll#end-poll
Exceptions
dpp::rest_exceptionupon 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.

References role_edit().

Here is the call graph for this function:

◆ poll_end_sync() [2/2]

message dpp::cluster::poll_end_sync ( snowflake  message_id,
snowflake  channel_id 
)

Immediately end a poll.

Parameters
message_idID of the message with the poll to end
channel_idID of the channel with the poll to end
Returns
message returned object on completion
See also
dpp::cluster::poll_end
https://discord.com/developers/docs/resources/poll#end-poll
Exceptions
dpp::rest_exceptionupon 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.

References roles_edit_position().

Here is the call graph for this function:

◆ poll_get_answer_voters() [1/2]

void dpp::cluster::poll_get_answer_voters ( const message m,
uint32_t  answer_id,
snowflake  after,
uint64_t  limit,
command_completion_event_t  callback = utility::log_error() 
)

Get a list of users that voted for this specific answer.

Parameters
mMessage that contains the poll to retrieve the answers from
answer_idID of the answer to retrieve votes from (see poll_answer::answer_id)
afterUsers after this ID should be retrieved if this is set to non-zero
limitThis number of users maximum should be returned, up to 100
callbackFunction to call when the API call completes.
See also
https://discord.com/developers/docs/resources/poll#get-answer-voters On success the callback will contain a dpp::user_map object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_message_get_reactions(), and message_get_reactions_sync().

Here is the caller graph for this function:

◆ poll_get_answer_voters() [2/2]

void dpp::cluster::poll_get_answer_voters ( snowflake  message_id,
snowflake  channel_id,
uint32_t  answer_id,
snowflake  after,
uint64_t  limit,
command_completion_event_t  callback = utility::log_error() 
)

Get a list of users that voted for this specific answer.

Parameters
message_idID of the message with the poll to retrieve the answers from
channel_idID of the channel with the poll to retrieve the answers from
answer_idID of the answer to retrieve votes from (see poll_answer::answer_id)
afterUsers after this ID should be retrieved if this is set to non-zero
limitThis number of users maximum should be returned, up to 100
callbackFunction to call when the API call completes.
See also
https://discord.com/developers/docs/resources/poll#get-answer-voters On success the callback will contain a dpp::user_map object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

References API_PATH, and dpp::m_get.

◆ poll_get_answer_voters_sync() [1/2]

user_map dpp::cluster::poll_get_answer_voters_sync ( const message m,
uint32_t  answer_id,
snowflake  after,
uint64_t  limit 
)

Get a list of users that voted for this specific answer.

Parameters
mMessage that contains the poll to retrieve the answers from
answer_idID of the answer to retrieve votes from (see poll_answer::answer_id)
afterUsers after this ID should be retrieved if this is set to non-zero
limitThis number of users maximum should be returned, up to 100
Returns
user_map returned object on completion
See also
dpp::cluster::poll_get_answer_voters
https://discord.com/developers/docs/resources/poll#get-answer-voters
Exceptions
dpp::rest_exceptionupon 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.

References role_create().

Here is the call graph for this function:

◆ poll_get_answer_voters_sync() [2/2]

user_map dpp::cluster::poll_get_answer_voters_sync ( snowflake  message_id,
snowflake  channel_id,
uint32_t  answer_id,
snowflake  after,
uint64_t  limit 
)

Get a list of users that voted for this specific answer.

Parameters
message_idID of the message with the poll to retrieve the answers from
channel_idID of the channel with the poll to retrieve the answers from
answer_idID of the answer to retrieve votes from (see poll_answer::answer_id)
afterUsers after this ID should be retrieved if this is set to non-zero
limitThis number of users maximum should be returned, up to 100
Returns
user_map returned object on completion
See also
dpp::cluster::poll_get_answer_voters
https://discord.com/developers/docs/resources/poll#get-answer-voters
Exceptions
dpp::rest_exceptionupon 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.

References role_delete().

Here is the call graph for this function:

◆ post_rest()

void dpp::cluster::post_rest ( const std::string &  endpoint,
const std::string &  major_parameters,
const std::string &  parameters,
http_method  method,
const std::string &  postdata,
json_encode_t  callback,
const std::string &  filename = "",
const std::string &  filecontent = "",
const std::string &  filemimetype = "",
const std::string &  protocol = "1.1" 
)

Post a REST request.

Where possible use a helper method instead like message_create

Parameters
endpointEndpoint to post to, e.g. /api/guilds
major_parametersMajor parameters for the endpoint e.g. a guild id
parametersMinor parameters for the API request
methodMethod, e.g. GET, POST
postdataPost data (usually JSON encoded)
callbackFunction to call when the HTTP call completes. The callback parameter will contain amongst other things, the decoded json.
filenameFilename to post for POST requests (for uploading files)
filecontentFile content to post for POST requests (for uploading files)
filemimetypeFile content to post for POST requests (for uploading files)
protocolHTTP protocol to use (1.0 and 1.1 are supported)

Referenced by dpp::interaction_create_t::dialog().

Here is the caller graph for this function:

◆ post_rest_multipart()

void dpp::cluster::post_rest_multipart ( const std::string &  endpoint,
const std::string &  major_parameters,
const std::string &  parameters,
http_method  method,
const std::string &  postdata,
json_encode_t  callback,
const std::vector< message_file_data > &  file_data = {} 
)

Post a multipart REST request.

Where possible use a helper method instead like message_create

Parameters
endpointEndpoint to post to, e.g. /api/guilds
major_parametersMajor parameters for the endpoint e.g. a guild id
parametersMinor parameters for the API request
methodMethod, e.g. GET, POST
postdataPost data (usually JSON encoded)
callbackFunction to call when the HTTP call completes. The callback parameter will contain amongst other things, the decoded json.
file_dataList of files to post for POST requests (for uploading files)

◆ request()

void dpp::cluster::request ( const std::string &  url,
http_method  method,
http_completion_event  callback,
const std::string &  postdata = "",
const std::string &  mimetype = "text/plain",
const std::multimap< std::string, std::string > &  headers = {},
const std::string &  protocol = "1.1" 
)

Make a HTTP(S) request.

For use when wanting asynchronous access to HTTP APIs outside of Discord.

Parameters
urlFull URL to post to, e.g. https://api.somewhere.com/v1/foo/
methodMethod, e.g. GET, POST
callbackFunction to call when the HTTP call completes. No processing is done on the returned data.
postdataPOST data
mimetypeMIME type of POST data
headersHeaders to send with the request
protocolHTTP protocol to use (1.1 and 1.0 are supported)

Referenced by co_get_guild_webhooks().

Here is the caller graph for this function:

◆ role_create()

void dpp::cluster::role_create ( const class role r,
command_completion_event_t  callback = utility::log_error() 
)

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 also
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.
Parameters
rRole to create (guild ID is encapsulated in the role object)
callbackFunction to call when the API call completes. On success the callback will contain a dpp::role object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_poll_get_answer_voters(), and poll_get_answer_voters_sync().

Here is the caller graph for this function:

◆ role_create_sync()

role dpp::cluster::role_create_sync ( const class role r)

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 also
dpp::cluster::role_create
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.
Parameters
rRole to create (guild ID is encapsulated in the role object)
Returns
role returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References application_role_connection_get().

Here is the call graph for this function:

◆ role_delete()

void dpp::cluster::role_delete ( snowflake  guild_id,
snowflake  role_id,
command_completion_event_t  callback = utility::log_error() 
)

Delete a role.

Requires the MANAGE_ROLES permission. Fires a Guild Role Delete Gateway event.

See also
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.
Parameters
guild_idGuild ID to delete the role on
role_idRole ID to delete
callbackFunction to call when the API call completes. On success the callback will contain a dpp::confirmation object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

References API_PATH, and dpp::m_get.

Referenced by co_poll_get_answer_voters(), and poll_get_answer_voters_sync().

Here is the caller graph for this function:

◆ role_delete_sync()

confirmation dpp::cluster::role_delete_sync ( snowflake  guild_id,
snowflake  role_id 
)

Delete a role.

Requires the MANAGE_ROLES permission. Fires a Guild Role Delete Gateway event.

See also
dpp::cluster::role_delete
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.
Parameters
guild_idGuild ID to delete the role on
role_idRole ID to delete
Returns
confirmation returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References application_role_connection_update().

Here is the call graph for this function:

◆ role_edit()

void dpp::cluster::role_edit ( const class role r,
command_completion_event_t  callback = utility::log_error() 
)

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 also
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.
Parameters
rRole to edit
callbackFunction to call when the API call completes. On success the callback will contain a dpp::role object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

References API_PATH, and dpp::m_get.

Referenced by co_poll_end(), and poll_end_sync().

Here is the caller graph for this function:

◆ role_edit_sync()

role dpp::cluster::role_edit_sync ( const class role r)

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 also
dpp::cluster::role_edit
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.
Parameters
rRole to edit
Returns
role returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References user_application_role_connection_get().

Here is the call graph for this function:

◆ roles_edit_position()

void dpp::cluster::roles_edit_position ( snowflake  guild_id,
const std::vector< role > &  roles,
command_completion_event_t  callback = utility::log_error() 
)

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 also
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.
Parameters
guild_idGuild ID to change the roles position on
rolesVector of roles to change the positions of
callbackFunction to call when the API call completes. On success the callback will contain a dpp::role_map object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

References API_PATH, and dpp::m_put.

Referenced by co_poll_end(), and poll_end_sync().

Here is the caller graph for this function:

◆ roles_edit_position_sync()

role_map dpp::cluster::roles_edit_position_sync ( snowflake  guild_id,
const std::vector< role > &  roles 
)

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 also
dpp::cluster::roles_edit_position
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.
Parameters
guild_idGuild ID to change the roles position on
rolesVector of roles to change the positions of
Returns
role_map returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References user_application_role_connection_update().

Here is the call graph for this function:

◆ roles_get()

void dpp::cluster::roles_get ( snowflake  guild_id,
command_completion_event_t  callback 
)

Get a role for a guild.

See also
https://discord.com/developers/docs/resources/guild#get-guild-roles
Parameters
guild_idGuild ID to get role for
callbackFunction to call when the API call completes. On success the callback will contain a dpp::role_map object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

References API_PATH, dpp::json_interface< T >::build_json(), and dpp::m_put.

Referenced by channel_pins_get_sync(), and co_channel_pins_get().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ roles_get_sync()

role_map dpp::cluster::roles_get_sync ( snowflake  guild_id)

Get a role for a guild.

See also
dpp::cluster::roles_get
https://discord.com/developers/docs/resources/guild#get-guild-roles
Parameters
guild_idGuild ID to get role for
Returns
role_map returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References guild_events_get().

Here is the call graph for this function:

◆ set_audit_reason()

cluster & dpp::cluster::set_audit_reason ( const std::string &  reason)

Set the audit log reason for the next REST call to be made.

This is set per-thread, so you must ensure that if you call this method, your request that is associated with the reason happens on the same thread where you set the reason. Once the next call is made, the audit log reason is cleared for this thread automatically.

Example:

bot.set_audit_reason("Too much abusive content")
.channel_delete(my_channel_id);
Parameters
reasonThe reason to set for the next REST call on this thread
Returns
cluster& Reference to self for chaining.

◆ set_default_gateway()

cluster & dpp::cluster::set_default_gateway ( std::string &  default_gateway)

Sets the address of the default gateway, for connecting the websockets.

Returns
cluster& Reference to self for chaining.

◆ set_dm_channel()

void dpp::cluster::set_dm_channel ( snowflake  user_id,
snowflake  channel_id 
)

Set the dm channel id for a user id.

Parameters
user_iduser id to set the dm channel for
channel_iddm channel to set

◆ set_presence()

void dpp::cluster::set_presence ( const class dpp::presence p)

Set the presence for all shards on the cluster.

Parameters
pThe presence to set. Only the online status and the first activity are sent.

References dpp::audit_reason.

◆ set_websocket_protocol()

cluster & dpp::cluster::set_websocket_protocol ( websocket_protocol_t  mode)

Set the websocket protocol for all shards on this cluster.

You should call this method before cluster::start. Generally ws_etf is faster, but provides less facilities for debugging should something go wrong. It is recommended to use ETF in production and JSON in development.

Parameters
modewebsocket protocol to use, either ws_json or ws_etf.
Returns
cluster& Reference to self for chaining.
Exceptions
dpp::logic_exceptionIf called after the cluster is started (this is not supported)

Referenced by main().

Here is the caller graph for this function:

◆ shutdown()

void dpp::cluster::shutdown ( )

End cluster execution without destructing it.

To restart the cluster, call cluster::start() again.

◆ skus_get()

void dpp::cluster::skus_get ( command_completion_event_t  callback = utility::log_error())

Returns all SKUs for a given application.

Note
Because of how Discord's SKU and subscription systems work, you will see two SKUs for your premium offering. For integration and testing entitlements, you should use the SKU with type: 5.
See also
https://discord.com/developers/docs/monetization/skus#list-skus
Parameters
callbackFunction to call when the API call completes. On success the callback will contain a dpp::confirmation object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_guild_events_get(), and guild_events_get_sync().

Here is the caller graph for this function:

◆ skus_get_sync()

sku_map dpp::cluster::skus_get_sync ( )

Returns all SKUs for a given application.

Note
Because of how Discord's SKU and subscription systems work, you will see two SKUs for your premium offering. For integration and testing entitlements, you should use the SKU with type: 5.
See also
dpp::cluster::skus_get
https://discord.com/developers/docs/monetization/skus#list-skus
Returns
sku_map returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References guild_sticker_create().

Here is the call graph for this function:

◆ stage_instance_create()

void dpp::cluster::stage_instance_create ( const stage_instance instance,
command_completion_event_t  callback = utility::log_error() 
)

Create a stage instance on a stage channel.

See also
https://discord.com/developers/docs/resources/stage-instance#create-stage-instance
Parameters
instanceStage instance to create
callbackUser function to execute when the api call completes On success the callback will contain a dpp::stage_instance object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().
Note
This method supports audit log reasons set by the cluster::set_audit_reason() method.

Referenced by co_guild_event_create(), and guild_event_create_sync().

Here is the caller graph for this function:

◆ stage_instance_delete()

void dpp::cluster::stage_instance_delete ( const snowflake  channel_id,
command_completion_event_t  callback = utility::log_error() 
)

Delete a stage instance.

See also
https://discord.com/developers/docs/resources/stage-instance#delete-stage-instance
Parameters
channel_idID of the associated channel
callbackUser function to execute when the api call completes On success the callback will contain a dpp::confirmation object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().
Note
This method supports audit log reasons set by the cluster::set_audit_reason() method.

Referenced by co_guild_event_get(), and guild_event_get_sync().

Here is the caller graph for this function:

◆ stage_instance_delete_sync()

confirmation dpp::cluster::stage_instance_delete_sync ( const snowflake  channel_id)

Delete a stage instance.

See also
dpp::cluster::stage_instance_delete
https://discord.com/developers/docs/resources/stage-instance#delete-stage-instance
Parameters
channel_idID of the associated channel
Returns
confirmation returned object on completion
Note
This method supports audit log reasons set by the cluster::set_audit_reason() method.
Exceptions
dpp::rest_exceptionupon 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.

References guild_stickers_get().

Here is the call graph for this function:

◆ stage_instance_edit()

void dpp::cluster::stage_instance_edit ( const stage_instance instance,
command_completion_event_t  callback = utility::log_error() 
)

Edit a stage instance.

See also
https://discord.com/developers/docs/resources/stage-instance#modify-stage-instance
Parameters
instanceStage instance to edit
callbackUser function to execute when the api call completes On success the callback will contain a dpp::stage_instance object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().
Note
This method supports audit log reasons set by the cluster::set_audit_reason() method.

Referenced by co_guild_event_edit(), and guild_event_edit_sync().

Here is the caller graph for this function:

◆ stage_instance_get()

void dpp::cluster::stage_instance_get ( const snowflake  channel_id,
command_completion_event_t  callback 
)

Get the stage instance associated with the channel id, if it exists.

See also
https://discord.com/developers/docs/resources/stage-instance#get-stage-instance
Parameters
channel_idID of the associated channel
callbackUser function to execute when the api call completes On success the callback will contain a dpp::stage_instance object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_guild_event_delete(), and guild_event_delete_sync().

Here is the caller graph for this function:

◆ stage_instance_get_sync()

stage_instance dpp::cluster::stage_instance_get_sync ( const snowflake  channel_id)

Get the stage instance associated with the channel id, if it exists.

See also
dpp::cluster::stage_instance_get
https://discord.com/developers/docs/resources/stage-instance#get-stage-instance
Parameters
channel_idID of the associated channel
Returns
stage_instance returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References guild_sticker_get().

Here is the call graph for this function:

◆ start()

void dpp::cluster::start ( bool  return_after = true)

Start the cluster, connecting all its shards.

Returns once all shards are connected if return_after is true, otherwise enters an infinite loop while the shards run.

Parameters
return_afterIf true the bot will return to your program after starting shards, if false this function will never return.

References dpp::err_auto_shard, dpp::ll_info, and dpp::gateway::shards.

Referenced by main().

Here is the caller graph for this function:

◆ start_timer()

timer dpp::cluster::start_timer ( timer_callback_t  on_tick,
uint64_t  frequency,
timer_callback_t  on_stop = {} 
)

Start a timer.

Every frequency seconds, the callback is called.

Parameters
on_tickThe callback lambda to call for this timer when ticked
on_stopThe callback lambda to call for this timer when it is stopped
frequencyHow often to tick the timer in seconds
Returns
timer A handle to the timer, used to remove that timer later

References dpp::timer_t::next_tick, and dpp::timer_t::on_stop.

◆ sticker_packs_get()

void dpp::cluster::sticker_packs_get ( command_completion_event_t  callback)

Get a list of available sticker packs.

See also
https://discord.com/developers/docs/resources/sticker#list-nitro-sticker-packs
Parameters
callbackFunction to call when the API call completes. On success the callback will contain a dpp::sticker_pack_map object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_guild_sticker_delete(), and guild_sticker_delete_sync().

Here is the caller graph for this function:

◆ sticker_packs_get_sync()

sticker_pack_map dpp::cluster::sticker_packs_get_sync ( )

Get a list of available sticker packs.

See also
dpp::cluster::sticker_packs_get
https://discord.com/developers/docs/resources/sticker#list-nitro-sticker-packs
Returns
sticker_pack_map returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References guild_templates_get().

Here is the call graph for this function:

◆ stop_timer()

bool dpp::cluster::stop_timer ( timer  t)

Stop a ticking timer.

Parameters
tTimer handle received from cluster::start_timer
Returns
bool True if the timer was stopped, false if it did not exist
Note
If the timer has an on_stop lambda, the on_stop lambda will be called.

◆ template_get()

void dpp::cluster::template_get ( const std::string &  code,
command_completion_event_t  callback 
)

Get a template.

See also
https://discord.com/developers/docs/resources/guild-template#get-guild-template
Parameters
codeTemplate code
callbackFunction to call when the API call completes. On success the callback will contain a dpp::dtemplate object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_guild_template_create(), and guild_template_create_sync().

Here is the caller graph for this function:

◆ template_get_sync()

dtemplate dpp::cluster::template_get_sync ( const std::string &  code)

Get a template.

See also
dpp::cluster::template_get
https://discord.com/developers/docs/resources/guild-template#get-guild-template
Parameters
codeTemplate code
Returns
dtemplate returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References threads_get_private_archived().

Here is the call graph for this function:

◆ thread_create()

void dpp::cluster::thread_create ( 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,
command_completion_event_t  callback = utility::log_error() 
)

Create a thread.

Note
This method supports audit log reasons set by the cluster::set_audit_reason() method.
See also
https://discord.com/developers/docs/resources/channel#start-thread-without-message
Parameters
thread_nameName of the thread
channel_idChannel in which thread to create
auto_archive_durationDuration after which thread auto-archives. Can be set to - 60, 1440 (for boosted guilds can also be: 4320, 10080)
thread_typeType of thread - CHANNEL_PUBLIC_THREAD, CHANNEL_ANNOUNCEMENT_THREAD, CHANNEL_PRIVATE_THREAD
invitablewhether non-moderators can add other non-moderators to a thread; only available when creating a private thread
rate_limit_per_useramount 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
callbackFunction to call when the API call completes. On success the callback will contain a dpp::thread object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_threads_get_private_archived(), and threads_get_private_archived_sync().

Here is the caller graph for this function:

◆ thread_create_in_forum()

void dpp::cluster::thread_create_in_forum ( 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 = {},
command_completion_event_t  callback = utility::log_error() 
)

Create a thread in a forum or media channel.

Note
This method supports audit log reasons set by the cluster::set_audit_reason() method.
See also
https://discord.com/developers/docs/resources/channel#start-thread-in-forum-channel
Parameters
thread_nameName of the forum thread
channel_idForum channel in which thread to create
msgThe message to start the thread with
auto_archive_durationDuration to automatically archive the thread after recent activity
rate_limit_per_useramount 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
applied_tagsList of IDs of forum tags (dpp::forum_tag) to apply to this thread
callbackFunction to call when the API call completes. On success the callback will contain a dpp::thread object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_threads_get_joined_private_archived(), and threads_get_joined_private_archived_sync().

Here is the caller graph for this function:

◆ thread_create_in_forum_sync()

thread dpp::cluster::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 = {} 
)

Create a thread in a forum or media channel.

Note
This method supports audit log reasons set by the cluster::set_audit_reason() method.
See also
dpp::cluster::thread_create_in_forum
https://discord.com/developers/docs/resources/channel#start-thread-in-forum-channel
Parameters
thread_nameName of the forum thread
channel_idForum channel in which thread to create
msgThe message to start the thread with
auto_archive_durationDuration to automatically archive the thread after recent activity
rate_limit_per_useramount 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
applied_tagsList of IDs of forum tags (dpp::forum_tag) to apply to this thread
Returns
thread returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References thread_member_remove().

Here is the call graph for this function:

◆ thread_create_sync()

thread dpp::cluster::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 
)

Create a thread.

Note
This method supports audit log reasons set by the cluster::set_audit_reason() method.
See also
dpp::cluster::thread_create
https://discord.com/developers/docs/resources/channel#start-thread-without-message
Parameters
thread_nameName of the thread
channel_idChannel in which thread to create
auto_archive_durationDuration after which thread auto-archives. Can be set to - 60, 1440 (for boosted guilds can also be: 4320, 10080)
thread_typeType of thread - CHANNEL_PUBLIC_THREAD, CHANNEL_ANNOUNCEMENT_THREAD, CHANNEL_PRIVATE_THREAD
invitablewhether non-moderators can add other non-moderators to a thread; only available when creating a private thread
rate_limit_per_useramount 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
Returns
thread returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References thread_get().

Here is the call graph for this function:

◆ thread_create_with_message()

void dpp::cluster::thread_create_with_message ( const std::string &  thread_name,
snowflake  channel_id,
snowflake  message_id,
uint16_t  auto_archive_duration,
uint16_t  rate_limit_per_user,
command_completion_event_t  callback = utility::log_error() 
)

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 also
https://discord.com/developers/docs/resources/channel#start-thread-from-message
Parameters
thread_nameName of the thread
channel_idChannel in which thread to create
message_idmessage to start thread with
auto_archive_durationDuration after which thread auto-archives. Can be set to - 60, 1440 (for boosted guilds can also be: 4320, 10080)
rate_limit_per_useramount 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
callbackFunction to call when the API call completes. On success the callback will contain a dpp::thread object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_thread_member_get(), and thread_member_get_sync().

Here is the caller graph for this function:

◆ thread_create_with_message_sync()

thread dpp::cluster::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 
)

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 also
dpp::cluster::thread_create_with_message
https://discord.com/developers/docs/resources/channel#start-thread-from-message
Parameters
thread_nameName of the thread
channel_idChannel in which thread to create
message_idmessage to start thread with
auto_archive_durationDuration after which thread auto-archives. Can be set to - 60, 1440 (for boosted guilds can also be: 4320, 10080)
rate_limit_per_useramount 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
Returns
thread returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References current_application_get().

Here is the call graph for this function:

◆ thread_edit()

void dpp::cluster::thread_edit ( const thread t,
command_completion_event_t  callback = utility::log_error() 
)

Edit a thread.

Note
This method supports audit log reasons set by the cluster::set_audit_reason() method.
See also
https://discord.com/developers/docs/topics/threads#editing-deleting-threads
Parameters
tThread to edit
callbackFunction to call when the API call completes. On success the callback will contain a dpp::thread object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

References API_PATH, dpp::m_delete, and dpp::rest_request< confirmation >().

Referenced by co_threads_get_public_archived(), and threads_get_public_archived_sync().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ thread_edit_sync()

thread dpp::cluster::thread_edit_sync ( const thread t)

Edit a thread.

Note
This method supports audit log reasons set by the cluster::set_audit_reason() method.
See also
dpp::cluster::thread_edit
https://discord.com/developers/docs/topics/threads#editing-deleting-threads
Parameters
tThread to edit
Returns
thread returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References current_user_edit().

Here is the call graph for this function:

◆ thread_get()

void dpp::cluster::thread_get ( snowflake  thread_id,
command_completion_event_t  callback 
)

Get the thread specified by thread_id.

This uses the same call as dpp::cluster::channel_get but returns a thread object.

See also
https://discord.com/developers/docs/resources/channel#get-channel
Parameters
thread_idThe id of the thread to obtain.
callbackFunction to call when the API call completes On success the callback will contain a dpp::thread object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_thread_create(), and thread_create_sync().

Here is the caller graph for this function:

◆ thread_get_sync()

thread dpp::cluster::thread_get_sync ( snowflake  thread_id)

Get the thread specified by thread_id.

This uses the same call as dpp::cluster::channel_get but returns a thread object.

See also
dpp::cluster::thread_get
https://discord.com/developers/docs/resources/channel#get-channel
Parameters
thread_idThe id of the thread to obtain.
Returns
thread returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References user_set_voice_state().

Here is the call graph for this function:

◆ thread_member_add()

void dpp::cluster::thread_member_add ( snowflake  thread_id,
snowflake  user_id,
command_completion_event_t  callback = utility::log_error() 
)

Add a member to a thread.

See also
https://discord.com/developers/docs/resources/channel#add-thread-member
Parameters
thread_idThread ID to add to
user_idMember ID to add
callbackFunction to call when the API call completes. On success the callback will contain a dpp::confirmation object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_thread_members_get(), and thread_members_get_sync().

Here is the caller graph for this function:

◆ thread_member_add_sync()

confirmation dpp::cluster::thread_member_add_sync ( snowflake  thread_id,
snowflake  user_id 
)

Add a member to a thread.

See also
dpp::cluster::thread_member_add
https://discord.com/developers/docs/resources/channel#add-thread-member
Parameters
thread_idThread ID to add to
user_idMember ID to add
Returns
confirmation returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References current_user_get().

Here is the call graph for this function:

◆ thread_member_get()

void dpp::cluster::thread_member_get ( const snowflake  thread_id,
const snowflake  user_id,
command_completion_event_t  callback 
)

Get a thread member.

See also
https://discord.com/developers/docs/resources/channel#get-thread-member
Parameters
thread_idThread to get member for
user_idID of the user to get
callbackFunction to call when the API call completes On success the callback will contain a dpp::thread_member object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_current_user_leave_thread(), and current_user_leave_thread_sync().

Here is the caller graph for this function:

◆ thread_member_get_sync()

thread_member dpp::cluster::thread_member_get_sync ( const snowflake  thread_id,
const snowflake  user_id 
)

Get a thread member.

See also
dpp::cluster::thread_member_get
https://discord.com/developers/docs/resources/channel#get-thread-member
Parameters
thread_idThread to get member for
user_idID of the user to get
Returns
thread_member returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References thread_create_with_message().

Here is the call graph for this function:

◆ thread_member_remove()

void dpp::cluster::thread_member_remove ( snowflake  thread_id,
snowflake  user_id,
command_completion_event_t  callback = utility::log_error() 
)

Remove a member from a thread.

See also
https://discord.com/developers/docs/resources/channel#remove-thread-member
Parameters
thread_idThread ID to remove from
user_idMember ID to remove
callbackFunction to call when the API call completes. On success the callback will contain a dpp::confirmation object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_thread_create_in_forum(), and thread_create_in_forum_sync().

Here is the caller graph for this function:

◆ thread_member_remove_sync()

confirmation dpp::cluster::thread_member_remove_sync ( snowflake  thread_id,
snowflake  user_id 
)

Remove a member from a thread.

See also
dpp::cluster::thread_member_remove
https://discord.com/developers/docs/resources/channel#remove-thread-member
Parameters
thread_idThread ID to remove from
user_idMember ID to remove
Returns
confirmation returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References current_user_set_voice_state().

Here is the call graph for this function:

◆ thread_members_get()

void dpp::cluster::thread_members_get ( snowflake  thread_id,
command_completion_event_t  callback 
)

Get members of a thread.

See also
https://discord.com/developers/docs/resources/channel#list-thread-members
Parameters
thread_idThread to get members for
callbackFunction to call when the API call completes On success the callback will contain a dpp::thread_member_map object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_threads_get_active(), and threads_get_active_sync().

Here is the caller graph for this function:

◆ thread_members_get_sync()

thread_member_map dpp::cluster::thread_members_get_sync ( snowflake  thread_id)

Get members of a thread.

See also
dpp::cluster::thread_members_get
https://discord.com/developers/docs/resources/channel#list-thread-members
Parameters
thread_idThread to get members for
Returns
thread_member_map returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References thread_member_add().

Here is the call graph for this function:

◆ threads_get_active()

void dpp::cluster::threads_get_active ( snowflake  guild_id,
command_completion_event_t  callback 
)

Get all active threads in the guild, including public and private threads.

Threads are ordered by their id, in descending order.

See also
https://discord.com/developers/docs/resources/guild#list-active-guild-threads
Parameters
guild_idGuild to get active threads for
callbackFunction to call when the API call completes On success the callback will contain a dpp::active_threads object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_guild_templates_get(), and guild_templates_get_sync().

Here is the caller graph for this function:

◆ threads_get_active_sync()

active_threads dpp::cluster::threads_get_active_sync ( snowflake  guild_id)

Get all active threads in the guild, including public and private threads.

Threads are ordered by their id, in descending order.

See also
dpp::cluster::threads_get_active
https://discord.com/developers/docs/resources/guild#list-active-guild-threads
Parameters
guild_idGuild to get active threads for
Returns
active_threads returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References thread_members_get().

Here is the call graph for this function:

◆ threads_get_joined_private_archived()

void dpp::cluster::threads_get_joined_private_archived ( snowflake  channel_id,
snowflake  before_id,
uint16_t  limit,
command_completion_event_t  callback 
)

Get private archived threads in a channel which current user has joined (Sorted by ID in descending order)

See also
https://discord.com/developers/docs/resources/channel#list-joined-private-archived-threads
Parameters
channel_idChannel to get public archived threads for
before_idGet threads before this id
limitNumber of threads to get
callbackFunction to call when the API call completes On success the callback will contain a dpp::thread_map object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_guild_template_sync(), and guild_template_sync_sync().

Here is the caller graph for this function:

◆ threads_get_joined_private_archived_sync()

thread_map dpp::cluster::threads_get_joined_private_archived_sync ( snowflake  channel_id,
snowflake  before_id,
uint16_t  limit 
)

Get private archived threads in a channel which current user has joined (Sorted by ID in descending order)

See also
dpp::cluster::threads_get_joined_private_archived
https://discord.com/developers/docs/resources/channel#list-joined-private-archived-threads
Parameters
channel_idChannel to get public archived threads for
before_idGet threads before this id
limitNumber of threads to get
Returns
thread_map returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References thread_create_in_forum().

Here is the call graph for this function:

◆ threads_get_private_archived()

void dpp::cluster::threads_get_private_archived ( snowflake  channel_id,
time_t  before_timestamp,
uint16_t  limit,
command_completion_event_t  callback 
)

Get private archived threads in a channel (Sorted by archive_timestamp in descending order)

See also
https://discord.com/developers/docs/resources/channel#list-private-archived-threads
Parameters
channel_idChannel to get public archived threads for
before_timestampGet threads archived before this timestamp
limitNumber of threads to get
callbackFunction to call when the API call completes On success the callback will contain a dpp::thread_map object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_template_get(), and template_get_sync().

Here is the caller graph for this function:

◆ threads_get_private_archived_sync()

thread_map dpp::cluster::threads_get_private_archived_sync ( snowflake  channel_id,
time_t  before_timestamp,
uint16_t  limit 
)

Get private archived threads in a channel (Sorted by archive_timestamp in descending order)

See also
dpp::cluster::threads_get_private_archived
https://discord.com/developers/docs/resources/channel#list-private-archived-threads
Parameters
channel_idChannel to get public archived threads for
before_timestampGet threads archived before this timestamp
limitNumber of threads to get
Returns
thread_map returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References thread_create().

Here is the call graph for this function:

◆ threads_get_public_archived()

void dpp::cluster::threads_get_public_archived ( snowflake  channel_id,
time_t  before_timestamp,
uint16_t  limit,
command_completion_event_t  callback 
)

Get public archived threads in a channel (Sorted by archive_timestamp in descending order)

See also
https://discord.com/developers/docs/resources/channel#list-public-archived-threads
Parameters
channel_idChannel to get public archived threads for
before_timestampGet threads archived before this timestamp
limitNumber of threads to get
callbackFunction to call when the API call completes On success the callback will contain a dpp::thread_map object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_current_user_join_thread(), and current_user_join_thread_sync().

Here is the caller graph for this function:

◆ threads_get_public_archived_sync()

thread_map dpp::cluster::threads_get_public_archived_sync ( snowflake  channel_id,
time_t  before_timestamp,
uint16_t  limit 
)

Get public archived threads in a channel (Sorted by archive_timestamp in descending order)

See also
dpp::cluster::threads_get_public_archived
https://discord.com/developers/docs/resources/channel#list-public-archived-threads
Parameters
channel_idChannel to get public archived threads for
before_timestampGet threads archived before this timestamp
limitNumber of threads to get
Returns
thread_map returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References thread_edit().

Here is the call graph for this function:

◆ uptime()

dpp::utility::uptime dpp::cluster::uptime ( )

Returns the uptime of the cluster.

Returns
dpp::utility::uptime The uptime of the cluster

◆ user_application_role_connection_get()

void dpp::cluster::user_application_role_connection_get ( snowflake  application_id,
command_completion_event_t  callback 
)

Get user application role connection.

See also
https://discord.com/developers/docs/resources/user#get-user-application-role-connection
Parameters
application_idThe application ID
callbackFunction to call when the API call completes. On success the callback will contain a dpp::application_role_connection object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_role_edit(), and role_edit_sync().

Here is the caller graph for this function:

◆ user_application_role_connection_get_sync()

application_role_connection dpp::cluster::user_application_role_connection_get_sync ( snowflake  application_id)

Get user application role connection.

See also
dpp::cluster::user_application_role_connection_get
https://discord.com/developers/docs/resources/user#get-user-application-role-connection
Parameters
application_idThe application ID
Returns
application_role_connection returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References guild_event_edit().

Here is the call graph for this function:

◆ user_application_role_connection_update()

void dpp::cluster::user_application_role_connection_update ( snowflake  application_id,
const application_role_connection connection,
command_completion_event_t  callback = utility::log_error() 
)

Update user application role connection.

See also
https://discord.com/developers/docs/resources/user#update-user-application-role-connection
Parameters
application_idThe application ID
connectionThe application role connection to update
callbackFunction to call when the API call completes. On success the callback will contain a dpp::application_role_connection object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

Referenced by co_roles_edit_position(), and roles_edit_position_sync().

Here is the caller graph for this function:

◆ user_application_role_connection_update_sync()

application_role_connection dpp::cluster::user_application_role_connection_update_sync ( snowflake  application_id,
const application_role_connection connection 
)

Update user application role connection.

See also
dpp::cluster::user_application_role_connection_update
https://discord.com/developers/docs/resources/user#update-user-application-role-connection
Parameters
application_idThe application ID
connectionThe application role connection to update
Returns
application_role_connection returned object on completion
Exceptions
dpp::rest_exceptionupon 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.

References guild_event_get().

Here is the call graph for this function:

◆ user_get()

void dpp::cluster::user_get ( snowflake  user_id,
command_completion_event_t  callback 
)

Get a user by id, without using the cache.

See also
https://discord.com/developers/docs/resources/user#get-user
Parameters
user_idUser ID to retrieve
callbackFunction to call when the API call completes. On success the callback will contain a dpp::user_identified object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().
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.
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.

Referenced by co_current_user_set_voice_state(), and current_user_set_voice_state_sync().

Here is the caller graph for this function:

◆ user_get_cached()

void dpp::cluster::user_get_cached ( snowflake  user_id,
command_completion_event_t  callback 
)

Get a user by id, checking in the cache first.

See also
https://discord.com/developers/docs/resources/user#get-user
Parameters
user_idUser ID to retrieve
callbackFunction to call when the API call completes. On success the callback will contain a dpp::user_identified object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().
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.
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.

Referenced by co_user_set_voice_state(), and user_set_voice_state_sync().

Here is the caller graph for this function:

◆ user_get_cached_sync()

user_identified dpp::cluster::user_get_cached_sync ( snowflake  user_id)

Get a user by id, checking in the cache first.

See also
dpp::cluster::user_get_cached
https://discord.com/developers/docs/resources/user#get-user
Parameters
user_idUser ID to retrieve
Returns
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.
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.
Exceptions
dpp::rest_exceptionupon 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.

References delete_webhook_message().

Here is the call graph for this function:

◆ user_get_sync()

user_identified dpp::cluster::user_get_sync ( snowflake  user_id)

Get a user by id, without using the cache.

See also
dpp::cluster::user_get
https://discord.com/developers/docs/resources/user#get-user
Parameters
user_idUser ID to retrieve
Returns
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.
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.
Exceptions
dpp::rest_exceptionupon 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.

References delete_webhook().

Here is the call graph for this function:

◆ user_set_voice_state()

void dpp::cluster::user_set_voice_state ( snowflake  user_id,
snowflake  guild_id,
snowflake  channel_id,
bool  suppress = false,
command_completion_event_t  callback = utility::log_error() 
)

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 also
https://discord.com/developers/docs/resources/guild#modify-user-voice-state
Parameters
user_idThe user to set the voice state of
guild_idGuild to set voice state on
channel_idStage channel to set voice state on
callbackFunction to call when the API call completes.
suppressTrue if the user's audio should be suppressed, false if it should not On success the callback will contain a dpp::scheduled_event object in confirmation_callback_t::value. On failure, the value is undefined and confirmation_callback_t::is_error() method will return true. You can obtain full error details with confirmation_callback_t::get_error().

References API_PATH, and dpp::m_get.

Referenced by co_thread_get(), and thread_get_sync().

Here is the caller graph for this function:

◆ user_set_voice_state_sync()

confirmation dpp::cluster::user_set_voice_state_sync ( snowflake  user_id,
snowflake  guild_id,
snowflake  channel_id,
bool  suppress = false 
)

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 also
dpp::cluster::user_set_voice_state
https://discord.com/developers/docs/resources/guild#modify-user-voice-state
Parameters
user_idThe user to set the voice state of
guild_idGuild to set voice state on
channel_idStage channel to set voice state on
Returns
confirmation returned object on completion
Parameters
suppressTrue if the user's audio should be suppressed, false if it should not
Exceptions
dpp::rest_exceptionupon 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.

References user_get_cached().

Here is the call graph for this function:

Friends And Related Function Documentation

◆ discord_client

friend class discord_client
friend

◆ discord_voice_client

friend class discord_voice_client
friend

Member Data Documentation

◆ cache_policy

cache_policy_t dpp::cluster::cache_policy

Current cache policy for the cluster.

Referenced by dpp::discord_client::get_member_count().

◆ cluster_id

uint32_t dpp::cluster::cluster_id

ID of this cluster, between 0 and MAXCLUSTERS-1 inclusive.

◆ intents

uint32_t dpp::cluster::intents

Current bitmask of gateway intents.

◆ last_identify

time_t dpp::cluster::last_identify

Last time the bot sent an IDENTIFY.

Referenced by dpp::discord_client::handle_frame().

◆ maxclusters

uint32_t dpp::cluster::maxclusters

Total number of clusters that are active.

◆ me

dpp::user dpp::cluster::me

The details of the bot user.

This is assumed to be identical across all shards in the cluster. Each connecting shard updates this information.

Referenced by current_user_join_thread(), global_bulk_command_create(), global_bulk_command_delete(), global_command_delete(), global_command_edit(), and dpp::discord_voice_client::handle_frame().

◆ numshards

uint32_t dpp::cluster::numshards

Total number of shards across all clusters.

◆ on_autocomplete

event_router_t<autocomplete_t> dpp::cluster::on_autocomplete

Called when an auto completed field needs suggestions to present to the user This is triggered by discord when option choices have auto completion enabled which you have associated with a dpp::slashcommand.

Note
Use operator() to attach a lambda to this event, and the detach method to detach the listener using the returned ID. The function signature for this event takes a single const reference of type autocomplete_t&, and returns void.

◆ on_automod_rule_create

event_router_t<automod_rule_create_t> dpp::cluster::on_automod_rule_create

Called when a new automod rule is created.

See also
https://discord.com/developers/docs/topics/gateway-events#auto-moderation-rule-create
Note
Use operator() to attach a lambda to this event, and the detach method to detach the listener using the returned ID. The function signature for this event takes a single const reference of type automod_rule_create_t&, and returns void.

◆ on_automod_rule_delete

event_router_t<automod_rule_delete_t> dpp::cluster::on_automod_rule_delete

Called when an automod rule is deleted.

See also
https://discord.com/developers/docs/topics/gateway-events#auto-moderation-rule-delete
Note
Use operator() to attach a lambda to this event, and the detach method to detach the listener using the returned ID. The function signature for this event takes a single const reference of type automod_rule_delete_t&, and returns void.

◆ on_automod_rule_execute

event_router_t<automod_rule_execute_t> dpp::cluster::on_automod_rule_execute

Called when an automod rule is triggered/executed.

See also
https://discord.com/developers/docs/topics/gateway-events#auto-moderation-action-execution
Note
Use operator() to attach a lambda to this event, and the detach method to detach the listener using the returned ID. The function signature for this event takes a single const reference of type automod_rule_execute_t&, and returns void.

◆ on_automod_rule_update

event_router_t<automod_rule_update_t> dpp::cluster::on_automod_rule_update

Called when an automod rule is updated.

See also
https://discord.com/developers/docs/topics/gateway-events#auto-moderation-rule-update
Note
Use operator() to attach a lambda to this event, and the detach method to detach the listener using the returned ID. The function signature for this event takes a single const reference of type automod_rule_update_t&, and returns void.

◆ on_button_click

event_router_t<button_click_t> dpp::cluster::on_button_click

Called when a button is clicked attached to a message.

Button clicks are triggered by discord when buttons are clicked which you have associated with a message using dpp::component.

Note
Use operator() to attach a lambda to this event, and the detach method to detach the listener using the returned ID. The function signature for this event takes a single const reference of type button_click_t&, and returns void.

◆ on_channel_create

event_router_t<channel_create_t> dpp::cluster::on_channel_create

Called when a new channel is created on a guild.

Warning
If the cache policy has disabled channel caching, the pointer in this event will become invalid after the event ends. You should make a copy of any data you wish to preserve beyond this.
See also
https://discord.com/developers/docs/topics/gateway-events#channel-create
Note
Use operator() to attach a lambda to this event, and the detach method to detach the listener using the returned ID. The function signature for this event takes a single const reference of type channel_create_t&, and returns void.

◆ on_channel_delete

event_router_t<channel_delete_t> dpp::cluster::on_channel_delete

Called when a channel is deleted from a guild.

The channel will still be temporarily available in the cache. Pointers to the channel should not be retained long-term as they will be deleted by the garbage collector.

See also
https://discord.com/developers/docs/topics/gateway-events#channel-delete
Note
Use operator() to attach a lambda to this event, and the detach method to detach the listener using the returned ID. The function signature for this event takes a single const reference of type channel_delete_t&, and returns void.

◆ on_channel_pins_update

event_router_t<channel_pins_update_t> dpp::cluster::on_channel_pins_update

Called when a message is pinned.

Note that the pinned message is not returned to this event, just the timestamp of the last pinned message.

See also
https://discord.com/developers/docs/topics/gateway-events#channel-pins-update
Note
Use operator() to attach a lambda to this event, and the detach method to detach the listener using the returned ID. The function signature for this event takes a single const reference of type channel_pins_update_t&, and returns void.

◆ on_channel_update

event_router_t<channel_update_t> dpp::cluster::on_channel_update

Called when a channel is edited on a guild.

The new channel details have already been applied to the guild when you receive this event.

See also
https://discord.com/developers/docs/topics/gateway-events#channel-update
Note
Use operator() to attach a lambda to this event, and the detach method to detach the listener using the returned ID. The function signature for this event takes a single const reference of type channel_update_t&, and returns void.

◆ on_entitlement_create

event_router_t<entitlement_create_t> dpp::cluster::on_entitlement_create

Called when a user subscribes to an SKU.

See also
https://discord.com/developers/docs/monetization/entitlements#new-entitlement
Note
Use operator() to attach a lambda to this event, and the detach method to detach the listener using the returned ID. The function signature for this event takes a single const reference of type channel_delete_t&, and returns void.

◆ on_entitlement_delete

event_router_t<entitlement_delete_t> dpp::cluster::on_entitlement_delete

Called when a user's entitlement is deleted.

These events are infrequent and only occur if Discord issues a refund, or Discord removes an entitlement via "internal tooling". Entitlements are not deleted when they expire.

See also
https://discord.com/developers/docs/monetization/entitlements#deleted-entitlement
Note
Use operator() to attach a lambda to this event, and the detach method to detach the listener using the returned ID. The function signature for this event takes a single const reference of type channel_update_t&, and returns void.

◆ on_entitlement_update

event_router_t<entitlement_update_t> dpp::cluster::on_entitlement_update

Called when a user's subscription renews for the next billing period.

The ends_at field will have an updated value with the new expiration date.

See also
https://discord.com/developers/docs/monetization/entitlements#updated-entitlement
Note
Use operator() to attach a lambda to this event, and the detach method to detach the listener using the returned ID. The function signature for this event takes a single const reference of type channel_update_t&, and returns void.

◆ on_form_submit

event_router_t<form_submit_t> dpp::cluster::on_form_submit

Called when a modal dialog is submitted.

Form submits are triggered by discord when modal dialogs are submitted which you have associated with a slash command using dpp::interaction_modal_response.

Note
Use operator() to attach a lambda to this event, and the detach method to detach the listener using the returned ID. The function signature for this event takes a single const reference of type form_submit_t&, and returns void.

◆ on_guild_audit_log_entry_create

event_router_t<guild_audit_log_entry_create_t> dpp::cluster::on_guild_audit_log_entry_create

Called when a guild audit log entry is created.

See also
https://discord.com/developers/docs/topics/gateway-events#guild-audit-log-entry-create
Note
Use operator() to attach a lambda to this event, and the detach method to detach the listener using the returned ID. The function signature for this event takes a single const reference of type guild_audit_log_entry_create_t&, and returns void.

◆ on_guild_ban_add

event_router_t<guild_ban_add_t> dpp::cluster::on_guild_ban_add

Called when a ban is added to a guild.

Warning
If the cache policy has disabled guild caching, the pointer to the guild in this event may be nullptr.
See also
https://discord.com/developers/docs/topics/gateway-events#guild-ban-add
Note
Use operator() to attach a lambda to this event, and the detach method to detach the listener using the returned ID. The function signature for this event takes a single const reference of type guild_ban_add_t&, and returns void.

◆ on_guild_ban_remove

event_router_t<guild_ban_remove_t> dpp::cluster::on_guild_ban_remove

Called when a ban is removed from a guild.

Warning
If the cache policy has disabled guild caching, the pointer to the guild in this event may be nullptr.
See also
https://discord.com/developers/docs/topics/gateway-events#guild-ban-remove
Note
Use operator() to attach a lambda to this event, and the detach method to detach the listener using the returned ID. The function signature for this event takes a single const reference of type guild_ban_remove_t&, and returns void.

◆ on_guild_create

event_router_t<guild_create_t> dpp::cluster::on_guild_create

Called when a new guild is created.

D++ will request members for the guild for its cache using guild_members_chunk.

Warning
If the cache policy has disabled guild caching, the pointer in this event will become invalid after the event ends. You should make a copy of any data you wish to preserve beyond this.
See also
https://discord.com/developers/docs/topics/gateway-events#guild-create
Note
Use operator() to attach a lambda to this event, and the detach method to detach the listener using the returned ID. The function signature for this event takes a single const reference of type guild_create_t&, and returns void.

◆ on_guild_delete

event_router_t<guild_delete_t> dpp::cluster::on_guild_delete

Called when a guild is deleted.

A guild can be deleted via the bot being kicked, the bot leaving the guild explicitly with dpp::cluster::guild_delete, or via the guild being unavailable due to an outage.

See also
https://discord.com/developers/docs/topics/gateway-events#guild-delete
Note
Use operator() to attach a lambda to this event, and the detach method to detach the listener using the returned ID. The function signature for this event takes a single const reference of type guild_delete_t&, and returns void.

◆ on_guild_emojis_update

event_router_t<guild_emojis_update_t> dpp::cluster::on_guild_emojis_update

Called when new emojis are added to a guild.

The complete set of emojis is sent every time.

Warning
If the cache policy has disabled guild caching, the pointer to the guild in this event may be nullptr.
See also
https://discord.com/developers/docs/topics/gateway-events#guild-emojis-update
Note
Use operator() to attach a lambda to this event, and the detach method to detach the listener using the returned ID. The function signature for this event takes a single const reference of type guild_emojis_update_t&, and returns void.

◆ on_guild_integrations_update

event_router_t<guild_integrations_update_t> dpp::cluster::on_guild_integrations_update

Called when an integration is updated for a guild.

This returns the complete list. An integration is a connection to a guild of a user's associated accounts, e.g. youtube or twitch, for automatic assignment of roles etc.

Warning
If the cache policy has disabled guild caching, the pointer to the guild in this event may be nullptr.
See also
https://discord.com/developers/docs/topics/gateway-events#guild-integrations-update
Note
Use operator() to attach a lambda to this event, and the detach method to detach the listener using the returned ID. The function signature for this event takes a single const reference of type guild_integrations_update_t&, and returns void.

◆ on_guild_join_request_delete

event_router_t<guild_join_request_delete_t> dpp::cluster::on_guild_join_request_delete

on guild join request delete.

Triggered when a user declines the membership screening questionnaire for a guild.

Note
Use operator() to attach a lambda to this event, and the detach method to detach the listener using the returned ID. The function signature for this event takes a single const reference of type guild_join_request_delete_t&, and returns void.

◆ on_guild_member_add

event_router_t<guild_member_add_t> dpp::cluster::on_guild_member_add

Called when a new member joins a guild.

Warning
If the cache policy has disabled guild caching, the pointer to the guild in this event may be nullptr.
See also
https://discord.com/developers/docs/topics/gateway-events#guild-member-add
Note
Use operator() to attach a lambda to this event, and the detach method to detach the listener using the returned ID. The function signature for this event takes a single const reference of type guild_member_add_t&, and returns void.

◆ on_guild_member_remove

event_router_t<guild_member_remove_t> dpp::cluster::on_guild_member_remove

Called when a user leaves a guild (either through being kicked, or choosing to leave)

See also
https://discord.com/developers/docs/topics/gateway-events#guild-member-remove
Note
Use operator() to attach a lambda to this event, and the detach method to detach the listener using the returned ID. The function signature for this event takes a single const reference of type guild_member_remove_t&, and returns void.

◆ on_guild_member_update

event_router_t<guild_member_update_t> dpp::cluster::on_guild_member_update

Called when details of a guild member (e.g.

their roles or nickname) are updated.

Warning
If the cache policy has disabled guild caching, the pointer to the guild in this event may be nullptr.
See also
https://discord.com/developers/docs/topics/gateway-events#guild-member-update
Note
Use operator() to attach a lambda to this event, and the detach method to detach the listener using the returned ID. The function signature for this event takes a single const reference of type guild_member_update_t&, and returns void.

◆ on_guild_members_chunk

event_router_t<guild_members_chunk_t> dpp::cluster::on_guild_members_chunk

Called when a set of members is received for a guild.

D++ will request these for all new guilds if needed, after the cluster::on_guild_create events.

See also
https://discord.com/developers/docs/topics/gateway-events#guild-members-chunk
Note
Use operator() to attach a lambda to this event, and the detach method to detach the listener using the returned ID. The function signature for this event takes a single const reference of type guild_members_chunk_t&, and returns void.

◆ on_guild_role_create

event_router_t<guild_role_create_t> dpp::cluster::on_guild_role_create

Called when a new role is created on a guild.

See also
https://discord.com/developers/docs/topics/gateway-events#guild-role-create
Note
Use operator() to attach a lambda to this event, and the detach method to detach the listener using the returned ID. The function signature for this event takes a single const reference of type guild_role_create_t&, and returns void.

◆ on_guild_role_delete

event_router_t<guild_role_delete_t> dpp::cluster::on_guild_role_delete

Called when a role is deleted in a guild.

Warning
If the cache policy has disabled guild caching, the pointer to the guild in this event may be nullptr.
See also
https://discord.com/developers/docs/topics/gateway-events#guild-role-delete
Note
Use operator() to attach a lambda to this event, and the detach method to detach the listener using the returned ID. The function signature for this event takes a single const reference of type guild_role_delete_t&, and returns void.

◆ on_guild_role_update

event_router_t<guild_role_update_t> dpp::cluster::on_guild_role_update

Called when an existing role is updated on a guild.

Warning
If the cache policy has disabled guild caching, the pointer to the guild in this event may be nullptr.
See also
https://discord.com/developers/docs/topics/gateway-events#guild-role-update
Note
Use operator() to attach a lambda to this event, and the detach method to detach the listener using the returned ID. The function signature for this event takes a single const reference of type guild_role_update_t&, and returns void.

◆ on_guild_scheduled_event_create

event_router_t<guild_scheduled_event_create_t> dpp::cluster::on_guild_scheduled_event_create

Called when a new scheduled event is created.

Warning
If the cache policy has disabled guild caching, the pointer to the guild in this event may be nullptr.
See also
https://discord.com/developers/docs/topics/gateway-events#guild-scheduled-event-create
Note
Use operator() to attach a lambda to this event, and the detach method to detach the listener using the returned ID. The function signature for this event takes a single const reference of type guild_scheduled_event_create_t&, and returns void.

◆ on_guild_scheduled_event_delete

event_router_t<guild_scheduled_event_delete_t> dpp::cluster::on_guild_scheduled_event_delete

Called when a new scheduled event is deleted.

Warning
If the cache policy has disabled guild caching, the pointer to the guild in this event may be nullptr.
See also
https://discord.com/developers/docs/topics/gateway-events#guild-scheduled-event-delete
Note
Use operator() to attach a lambda to this event, and the detach method to detach the listener using the returned ID. The function signature for this event takes a single const reference of type guild_scheduled_event_delete_t&, and returns void.

◆ on_guild_scheduled_event_update

event_router_t<guild_scheduled_event_update_t> dpp::cluster::on_guild_scheduled_event_update

Called when a new scheduled event is updated.

Warning
If the cache policy has disabled guild caching, the pointer to the guild in this event may be nullptr.
See also
https://discord.com/developers/docs/topics/gateway-events#guild-scheduled-event-update
Note
Use operator() to attach a lambda to this event, and the detach method to detach the listener using the returned ID. The function signature for this event takes a single const reference of type guild_scheduled_event_update_t&, and returns void.

◆ on_guild_scheduled_event_user_add

event_router_t<guild_scheduled_event_user_add_t> dpp::cluster::on_guild_scheduled_event_user_add

Called when a user is added to a scheduled event.

Warning
If the cache policy has disabled guild caching, the pointer to the guild in this event may be nullptr.
See also
https://discord.com/developers/docs/topics/gateway-events#guild-scheduled-event-user-add
Note
Use operator() to attach a lambda to this event, and the detach method to detach the listener using the returned ID. The function signature for this event takes a single const reference of type guild_scheduled_event_user_add_t&, and returns void.

◆ on_guild_scheduled_event_user_remove

event_router_t<guild_scheduled_event_user_remove_t> dpp::cluster::on_guild_scheduled_event_user_remove

Called when a user is removed from a scheduled event.

Warning
If the cache policy has disabled guild caching, the pointer to the guild in this event may be nullptr.
See also
https://discord.com/developers/docs/topics/gateway-events#guild-scheduled-event-user-remove
Note
Use operator() to attach a lambda to this event, and the detach method to detach the listener using the returned ID. The function signature for this event takes a single const reference of type guild_scheduled_event_user_remove_t&, and returns void.

◆ on_guild_stickers_update

event_router_t<guild_stickers_update_t> dpp::cluster::on_guild_stickers_update

Called when new stickers are added to a guild.

The complete set of stickers is sent every time.

Warning
If the cache policy has disabled guild caching, the pointer to the guild in this event may be nullptr.
See also
https://discord.com/developers/docs/topics/gateway-events#guild-stickers-update
Note
Use operator() to attach a lambda to this event, and the detach method to detach the listener using the returned ID. The function signature for this event takes a single const reference of type guild_stickers_update_t&, and returns void.

◆ on_guild_update

event_router_t<guild_update_t> dpp::cluster::on_guild_update

Called when details of a guild are updated.

Warning
If the cache policy has disabled guild caching, the pointer in this event will become invalid after the event ends. You should make a copy of any data you wish to preserve beyond this. If the guild cache is disabled, only changed elements in the updated guild object will be set. all other values will be empty or defaults.
See also
https://discord.com/developers/docs/topics/gateway-events#guild-update
Note
Use operator() to attach a lambda to this event, and the detach method to detach the listener using the returned ID. The function signature for this event takes a single const reference of type guild_update_t&, and returns void.

◆ on_integration_create

event_router_t<integration_create_t> dpp::cluster::on_integration_create

Called when a new integration is attached to a guild by a user.

An integration is a connection to a guild of a user's associated accounts, e.g. youtube or twitch, for automatic assignment of roles etc.

Warning
If the cache policy has disabled guild caching, the pointer to the guild in this event may be nullptr.
See also
https://discord.com/developers/docs/topics/gateway-events#integration-create
Note
Use operator() to attach a lambda to this event, and the detach method to detach the listener using the returned ID. The function signature for this event takes a single const reference of type integration_create_t&, and returns void.

◆ on_integration_delete

event_router_t<integration_delete_t> dpp::cluster::on_integration_delete

Called when an integration is removed by a user.

An integration is a connection to a guild of a user's associated accounts, e.g. youtube or twitch, for automatic assignment of roles etc.

Warning
If the cache policy has disabled guild caching, the pointer to the guild in this event may be nullptr.
See also
https://discord.com/developers/docs/topics/gateway-events#integration-delete
Note
Use operator() to attach a lambda to this event, and the detach method to detach the listener using the returned ID. The function signature for this event takes a single const reference of type integration_delete_t&, and returns void.

◆ on_integration_update

event_router_t<integration_update_t> dpp::cluster::on_integration_update

Called when an integration is updated by a user.

This returns details of just the single integration that has changed. An integration is a connection to a guild of a user's associated accounts, e.g. youtube or twitch, for automatic assignment of roles etc.

Warning
If the cache policy has disabled guild caching, the pointer to the guild in this event may be nullptr.
See also
https://discord.com/developers/docs/topics/gateway-events#integration-update
Note
Use operator() to attach a lambda to this event, and the detach method to detach the listener using the returned ID. The function signature for this event takes a single const reference of type integration_update_t&, and returns void.

◆ on_interaction_create

event_router_t<interaction_create_t> dpp::cluster::on_interaction_create

Called when a new interaction is created.

Interactions are created by discord when commands you have registered are issued by a user. For an example of this in action please see Using Slash Commands and Interactions

See also
https://discord.com/developers/docs/topics/gateway-events#interaction-create
Note
Use operator() to attach a lambda to this event, and the detach method to detach the listener using the returned ID. The function signature for this event takes a single const reference of type interaction_create_t&, and returns void.
There are dedicated events to handle slashcommands (See dpp::cluster::on_slashcommand), user context menus (See dpp::cluster::on_user_context_menu) and message context menus (See dpp::cluster::on_message_context_menu)

◆ on_invite_create

event_router_t<invite_create_t> dpp::cluster::on_invite_create

Called when a new invite is created for a guild.

Warning
If the cache policy has disabled guild caching, the pointer to the guild in this event may be nullptr.
See also
https://discord.com/developers/docs/topics/gateway-events#invite-create
Note
Use operator() to attach a lambda to this event, and the detach method to detach the listener using the returned ID. The function signature for this event takes a single const reference of type invite_create_t&, and returns void.

◆ on_invite_delete

event_router_t<invite_delete_t> dpp::cluster::on_invite_delete

Called when an invite is deleted from a guild.

See also
https://discord.com/developers/docs/topics/gateway-events#invite-delete
Note
Use operator() to attach a lambda to this event, and the detach method to detach the listener using the returned ID. The function signature for this event takes a single const reference of type invite_delete_t&, and returns void.

◆ on_log

event_router_t<log_t> dpp::cluster::on_log

Called when a log message is to be written to the log.

You can attach any logging system here you wish, e.g. spdlog, or even just a simple use of std::cout or printf. If nothing attaches this log event, then the library will be silent.

Note
Use operator() to attach a lambda to this event, and the detach method to detach the listener using the returned ID. The function signature for this event takes a single const reference of type log_t&, and returns void.

Referenced by dpp::discord_client::log(), and main().

◆ on_message_context_menu

event_router_t<message_context_menu_t> dpp::cluster::on_message_context_menu

Called when a user right-clicks or long-presses on a message, where a slash command is bound to the dpp::ctxm_message command type.

Note
Use operator() to attach a lambda to this event, and the detach method to detach the listener using the returned ID. The function signature for this event takes a single const reference of type message_context_menu_t&, and returns void.

◆ on_message_create

event_router_t<message_create_t> dpp::cluster::on_message_create

Called when a new message arrives from discord.

Note that D++ does not cache messages. If you want to cache these objects you should create something yourself within your bot. Caching of messages is not on the roadmap to be supported as it consumes excessive amounts of RAM. For an example for caching of messages, please see Caching Messages

See also
https://discord.com/developers/docs/topics/gateway-events#message-create
Note
Use operator() to attach a lambda to this event, and the detach method to detach the listener using the returned ID. The function signature for this event takes a single const reference of type message_create_t&, and returns void.

Referenced by event_handler_test().

◆ on_message_delete

event_router_t<message_delete_t> dpp::cluster::on_message_delete

Called when a message is deleted.

The message has already been deleted from Discord when you receive this event.

See also
https://discord.com/developers/docs/topics/gateway-events#message-delete
Note
Use operator() to attach a lambda to this event, and the detach method to detach the listener using the returned ID. The function signature for this event takes a single const reference of type message_delete_t&, and returns void.

◆ on_message_delete_bulk

event_router_t<message_delete_bulk_t> dpp::cluster::on_message_delete_bulk

Called when multiple messages are deleted from a channel or DM.

See also
https://discord.com/developers/docs/topics/gateway-events#message-delete-bulk
Note
Use operator() to attach a lambda to this event, and the detach method to detach the listener using the returned ID. The function signature for this event takes a single const reference of type message_delete_bulk_t&, and returns void.

◆ on_message_poll_vote_add

event_router_t<message_poll_vote_add_t> dpp::cluster::on_message_poll_vote_add

Called when a vote is added to a message poll.

See also
https://discord.com/developers/docs/topics/gateway-events#message-poll-vote-add
Note
Use operator() to attach a lambda to this event, and the detach method to detach the listener using the returned ID. The function signature for this event takes a single const reference of type message_poll_vote_add_t&, and returns void.

◆ on_message_poll_vote_remove

event_router_t<message_poll_vote_remove_t> dpp::cluster::on_message_poll_vote_remove

Called when a vote is removed from a message poll.

See also
https://discord.com/developers/docs/topics/gateway-events#message-poll-vote-remove
Note
Use operator() to attach a lambda to this event, and the detach method to detach the listener using the returned ID. The function signature for this event takes a single const reference of type message_poll_vote_remove_t&, and returns void.

◆ on_message_reaction_add

event_router_t<message_reaction_add_t> dpp::cluster::on_message_reaction_add

Called when a new reaction is added to a message.

See also
https://discord.com/developers/docs/topics/gateway-events#message-reaction-add
Note
Use operator() to attach a lambda to this event, and the detach method to detach the listener using the returned ID. The function signature for this event takes a single const reference of type message_reaction_add_t&, and returns void.

◆ on_message_reaction_remove

event_router_t<message_reaction_remove_t> dpp::cluster::on_message_reaction_remove

Called when a single reaction is removed from a message.

See also
https://discord.com/developers/docs/topics/gateway-events#message-reaction-remove
Note
Use operator() to attach a lambda to this event, and the detach method to detach the listener using the returned ID. The function signature for this event takes a single const reference of type message_reaction_remove_t&, and returns void.

◆ on_message_reaction_remove_all

event_router_t<message_reaction_remove_all_t> dpp::cluster::on_message_reaction_remove_all

Called when all reactions are removed from a message.

See also
https://discord.com/developers/docs/topics/gateway-events#message-reaction-remove-all
Note
Use operator() to attach a lambda to this event, and the detach method to detach the listener using the returned ID. The function signature for this event takes a single const reference of type message_reaction_remove_all_t&, and returns void.

◆ on_message_reaction_remove_emoji

event_router_t<message_reaction_remove_emoji_t> dpp::cluster::on_message_reaction_remove_emoji

Called when all reactions for a particular emoji are removed from a message.

See also
https://discord.com/developers/docs/topics/gateway-events#message-reaction-remove-emoji
Note
Use operator() to attach a lambda to this event, and the detach method to detach the listener using the returned ID. The function signature for this event takes a single const reference of type message_reaction_remove_emoji_t&, and returns void.

◆ on_message_update

event_router_t<message_update_t> dpp::cluster::on_message_update

Called when a message is updated (edited).

See also
https://discord.com/developers/docs/topics/gateway-events#message-update
Note
Use operator() to attach a lambda to this event, and the detach method to detach the listener using the returned ID. The function signature for this event takes a single const reference of type message_update_t&, and returns void.

◆ on_presence_update

event_router_t<presence_update_t> dpp::cluster::on_presence_update

Called when a user's presence is updated.

To receive these you will need the GUILD_PRESENCES privileged intent. You will receive many of these, very often, and receiving them will significantly increase your bot's CPU usage. If you don't need them it is recommended to not ask for them.

See also
https://discord.com/developers/docs/topics/gateway-events#presence-update
Note
Use operator() to attach a lambda to this event, and the detach method to detach the listener using the returned ID. The function signature for this event takes a single const reference of type presence_update_t&, and returns void.

◆ on_ready

event_router_t<ready_t> dpp::cluster::on_ready

Called when a shard is connected and ready.

A set of cluster::on_guild_create events will follow this event.

See also
https://discord.com/developers/docs/topics/gateway-events#ready
Note
Use operator() to attach a lambda to this event, and the detach method to detach the listener using the returned ID. The function signature for this event takes a single const reference of type ready_t&, and returns void.

◆ on_resumed

event_router_t<resumed_t> dpp::cluster::on_resumed

Called when a connection to a shard successfully resumes.

A resumed session does not need to re-synchronise guilds, members, etc. This is generally non-fatal and informational only.

See also
https://discord.com/developers/docs/topics/gateway-events#resumed
Note
Use operator() to attach a lambda to this event, and the detach method to detach the listener using the returned ID. The function signature for this event takes a single const reference of type resumed_t&, and returns void.

◆ on_select_click

event_router_t<select_click_t> dpp::cluster::on_select_click

Called when a select menu is clicked attached to a message.

Select menu clicks are triggered by discord when select menus are clicked which you have associated with a message using dpp::component.

Note
Use operator() to attach a lambda to this event, and the detach method to detach the listener using the returned ID. The function signature for this event takes a single const reference of type select_click_t&, and returns void.

◆ on_slashcommand

event_router_t<slashcommand_t> dpp::cluster::on_slashcommand

Called when a slash command is issued.

Only dpp::ctxm_chat_input types of interaction are routed to this event. For an example of this in action please see Using Slash Commands and Interactions

Note
Use operator() to attach a lambda to this event, and the detach method to detach the listener using the returned ID. The function signature for this event takes a single const reference of type slashcommand_t&, and returns void.

◆ on_stage_instance_create

event_router_t<stage_instance_create_t> dpp::cluster::on_stage_instance_create

Called when a new stage instance is created on a stage channel.

Warning
If the cache policy has disabled guild caching, the pointer to the guild in this event may be nullptr.
See also
https://discord.com/developers/docs/topics/gateway-events#stage-instance-create
Note
Use operator() to attach a lambda to this event, and the detach method to detach the listener using the returned ID. The function signature for this event takes a single const reference of type stage_instance_create_t&, and returns void.

◆ on_stage_instance_delete

event_router_t<stage_instance_delete_t> dpp::cluster::on_stage_instance_delete

Called when an existing stage instance is deleted from a stage channel.

Warning
If the cache policy has disabled guild caching, the pointer to the guild in this event may be nullptr.
See also
https://discord.com/developers/docs/topics/gateway-events#stage-instance-delete
Note
Use operator() to attach a lambda to this event, and the detach method to detach the listener using the returned ID. The function signature for this event takes a single const reference of type stage_instance_delete_t&, and returns void.

◆ on_stage_instance_update

event_router_t<stage_instance_update_t> dpp::cluster::on_stage_instance_update

Called when a stage instance is updated.

Warning
If the cache policy has disabled guild caching, the pointer to the guild in this event may be nullptr.
See also
https://discord.com/developers/docs/topics/gateway-events#stage-instance-update
Note
Use operator() to attach a lambda to this event, and the detach method to detach the listener using the returned ID. The function signature for this event takes a single const reference of type stage_instance_update_t&, and returns void.

◆ on_thread_create

event_router_t<thread_create_t> dpp::cluster::on_thread_create

Called when a thread is created.

Note that threads are not cached by D++, but a list of thread IDs is accessible in a guild object

Warning
If the cache policy has disabled guild caching, the pointer to the guild in this event may be nullptr.
See also
https://discord.com/developers/docs/topics/gateway-events#thread-create
Note
Use operator() to attach a lambda to this event, and the detach method to detach the listener using the returned ID. The function signature for this event takes a single const reference of type thread_create_t&, and returns void.

◆ on_thread_delete

event_router_t<thread_delete_t> dpp::cluster::on_thread_delete

Called when a thread is deleted.

Warning
If the cache policy has disabled guild caching, the pointer to the guild in this event may be nullptr.
See also
https://discord.com/developers/docs/topics/gateway-events#thread-delete
Note
Use operator() to attach a lambda to this event, and the detach method to detach the listener using the returned ID. The function signature for this event takes a single const reference of type thread_delete_t&, and returns void.

◆ on_thread_list_sync

event_router_t<thread_list_sync_t> dpp::cluster::on_thread_list_sync

Called when thread list is synced (upon gaining access to a channel).

Note that threads are not cached by D++, but a list of thread IDs is accessible in a guild object

Warning
If the cache policy has disabled guild caching, the pointer to the guild in this event may be nullptr.
See also
https://discord.com/developers/docs/topics/gateway-events#thread-list-sync
Note
Use operator() to attach a lambda to this event, and the detach method to detach the listener using the returned ID. The function signature for this event takes a single const reference of type thread_list_sync_t&, and returns void.

◆ on_thread_member_update

event_router_t<thread_member_update_t> dpp::cluster::on_thread_member_update

Called when current user's thread member object is updated.

Warning
If the cache policy has disabled guild caching, the pointer to the guild in this event may be nullptr.
See also
https://discord.com/developers/docs/topics/gateway-events#thread-member-update
Note
Use operator() to attach a lambda to this event, and the detach method to detach the listener using the returned ID. The function signature for this event takes a single const reference of type thread_member_update_t&, and returns void.

◆ on_thread_members_update

event_router_t<thread_members_update_t> dpp::cluster::on_thread_members_update

Called when a thread's member list is updated (without GUILD_MEMBERS intent, is only called for current user)

Warning
If the cache policy has disabled guild caching, the pointer to the guild in this event may be nullptr.
See also
https://discord.com/developers/docs/topics/gateway-events#thread-members-update
Note
Use operator() to attach a lambda to this event, and the detach method to detach the listener using the returned ID. The function signature for this event takes a single const reference of type thread_members_update_t&, and returns void.

◆ on_thread_update

event_router_t<thread_update_t> dpp::cluster::on_thread_update

Called when a thread is updated.

Warning
If the cache policy has disabled guild caching, the pointer to the guild in this event may be nullptr.
See also
https://discord.com/developers/docs/topics/gateway-events#thread-update
Note
Use operator() to attach a lambda to this event, and the detach method to detach the listener using the returned ID. The function signature for this event takes a single const reference of type thread_update_t&, and returns void.

◆ on_typing_start

event_router_t<typing_start_t> dpp::cluster::on_typing_start

Called when a user is typing on a channel.

See also
https://discord.com/developers/docs/topics/gateway-events#typing-start
Note
Use operator() to attach a lambda to this event, and the detach method to detach the listener using the returned ID. The function signature for this event takes a single const reference of type typing_start_t&, and returns void.

◆ on_user_context_menu

event_router_t<user_context_menu_t> dpp::cluster::on_user_context_menu

Called when a user right-clicks or long-presses on a user, where a slash command is bound to the dpp::ctxm_user command type.

Note
Use operator() to attach a lambda to this event, and the detach method to detach the listener using the returned ID. The function signature for this event takes a single const reference of type user_context_menu_t&, and returns void.

◆ on_user_update

event_router_t<user_update_t> dpp::cluster::on_user_update

Called when a user is updated.

This is separate to cluster::on_guild_member_update and includes things such as an avatar change, username change, discriminator change or change in subscription status for nitro.

See also
https://discord.com/developers/docs/topics/gateway-events#user-update
Note
Use operator() to attach a lambda to this event, and the detach method to detach the listener using the returned ID. The function signature for this event takes a single const reference of type user_update_t&, and returns void.

◆ on_voice_buffer_send

event_router_t<voice_buffer_send_t> dpp::cluster::on_voice_buffer_send

Called when packets are sent from the voice buffer.

The voice buffer contains packets that are already encoded with Opus and encrypted with Sodium, and merged into packets by the repacketizer, which is done in the dpp::discord_voice_client::send_audio method. You should use the buffer size properties of dpp::voice_buffer_send_t to determine if you should fill the buffer with more content.

Warning
If the cache policy has disabled guild caching, the pointer to the guild in this event may be nullptr.
Note
Use operator() to attach a lambda to this event, and the detach method to detach the listener using the returned ID. The function signature for this event takes a single const reference of type voice_buffer_send_t&, and returns void.

◆ on_voice_client_disconnect

event_router_t<voice_client_disconnect_t> dpp::cluster::on_voice_client_disconnect

on voice client disconnect event

Note
Use operator() to attach a lambda to this event, and the detach method to detach the listener using the returned ID. The function signature for this event takes a single const reference of type voice_client_disconnect_t&, and returns void.

Referenced by dpp::discord_voice_client::handle_frame().

◆ on_voice_client_speaking

event_router_t<voice_client_speaking_t> dpp::cluster::on_voice_client_speaking

on voice client speaking event

Note
Use operator() to attach a lambda to this event, and the detach method to detach the listener using the returned ID. The function signature for this event takes a single const reference of type voice_client_speaking_t&, and returns void.

Referenced by dpp::discord_voice_client::handle_frame().

◆ on_voice_ready

event_router_t<voice_ready_t> dpp::cluster::on_voice_ready

Called when a voice channel is connected and ready to send audio.

Note that this is not directly attached to the READY event of the websocket, as there is further connection that needs to be done before audio is ready to send.

Warning
If the cache policy has disabled guild caching, the pointer to the guild in this event may be nullptr.
Note
Use operator() to attach a lambda to this event, and the detach method to detach the listener using the returned ID. The function signature for this event takes a single const reference of type voice_ready_t&, and returns void.

Referenced by dpp::discord_voice_client::handle_frame().

◆ on_voice_receive

event_router_t<voice_receive_t> dpp::cluster::on_voice_receive

Called when new audio data is received.

Each separate user's audio from the voice channel will arrive tagged with their user id in the event, if a user can be attributed to the received audio.

Note
Receiving audio for bots is not officially supported by discord.
Use operator() to attach a lambda to this event, and the detach method to detach the listener using the returned ID. The function signature for this event takes a single const reference of type voice_receive_t&, and returns void.

◆ on_voice_receive_combined

event_router_t<voice_receive_t> dpp::cluster::on_voice_receive_combined

Called when new audio data is received, combined and mixed for all speaking users.

Note
Receiving audio for bots is not officially supported by discord.
Use operator() to attach a lambda to this event, and the detach method to detach the listener using the returned ID. The function signature for this event takes a single const reference of type voice_receive_t&, and returns void.

◆ on_voice_server_update

event_router_t<voice_server_update_t> dpp::cluster::on_voice_server_update

Called when we are told which voice server we can use.

This will be sent either when we establish a new voice channel connection, or as discord rearrange their infrastructure.

Warning
If the cache policy has disabled guild caching, the pointer to the guild in this event may be nullptr.
Note
Use operator() to attach a lambda to this event, and the detach method to detach the listener using the returned ID. The function signature for this event takes a single const reference of type voice_server_update_t&, and returns void.

◆ on_voice_state_update

event_router_t<voice_state_update_t> dpp::cluster::on_voice_state_update

on voice state update event

See also
https://discord.com/developers/docs/topics/gateway-events#voice-state-update
Note
Use operator() to attach a lambda to this event, and the detach method to detach the listener using the returned ID. The function signature for this event takes a single const reference of type voice_state_update_t&, and returns void.

◆ on_voice_track_marker

event_router_t<voice_track_marker_t> dpp::cluster::on_voice_track_marker

Called when sending of audio passes over a track marker.

Track markers are arbitrarily placed "bookmarks" in the audio buffer, placed by the bot developer. Each track marker can have a string value associated with it which is specified in dpp::discord_voice_client::insert_marker and returned to this event.

Note
Use operator() to attach a lambda to this event, and the detach method to detach the listener using the returned ID. The function signature for this event takes a single const reference of type voice_track_marker_t&, and returns void.

◆ on_voice_user_talking

event_router_t<voice_user_talking_t> dpp::cluster::on_voice_user_talking

Called when a user is talking on a voice channel.

Warning
If the cache policy has disabled guild caching, the pointer to the guild in this event may be nullptr.
Note
Use operator() to attach a lambda to this event, and the detach method to detach the listener using the returned ID. The function signature for this event takes a single const reference of type voice_user_talking_t&, and returns void.

◆ on_webhooks_update

event_router_t<webhooks_update_t> dpp::cluster::on_webhooks_update

Called when the webhooks for a guild are updated.

See also
https://discord.com/developers/docs/topics/gateway-events#webhooks-update
Note
Use operator() to attach a lambda to this event, and the detach method to detach the listener using the returned ID. The function signature for this event takes a single const reference of type webhooks_update_t&, and returns void.

◆ rest_ping

double dpp::cluster::rest_ping

REST latency (HTTPS ping) in seconds.

◆ terminating

std::condition_variable dpp::cluster::terminating

Condition variable notified when the cluster is terminating.

◆ token

◆ ws_mode

websocket_protocol_t dpp::cluster::ws_mode

Websocket mode for all shards in the cluster, either ws_json or ws_etf.

Production bots should use ETF, while development bots should use JSON.


The documentation for this class was generated from the following files: